New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

objc2swift

Package Overview
Dependencies
Maintainers
1
Versions
7
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

objc2swift

Objective-C to Swift Converter

  • 0.2.1
  • latest
  • Source
  • npm
  • Socket score

Version published
Maintainers
1
Created
Source

Objc2Swift.js npm version

Objc2Swift.js is an Objective-C to Swift converter written in JavaScript. (Live Demo)

This project is still highly experimenal and does not aim to provide human-less conversion. However, the most of Objective-C code can be converted to proper Swift code with less compilation errors.

Note: the author currently has no plan to support full features of Swift 3 or greater.

Features

  • Generate good-looking Swift 2.1 code from Objective-C code.
  • Full Objective-C parser which accepts large source code, not for toy-problem.
  • Preserve indents and comments in the original Objective-C code.
  • Reduce compilation errors with semantics analysis. See the Document for detail.
  • Command-line version supports #import delective with pre-compiled header cache.

Install

$ npm install -g objc2swift

Then, run the objc2swift command with --init option to setup the default configuration.

$ objc2swift --init ios

Note that the parameter ios means to setup objc2swift for using Xcode's iOS SDK. If you want to target other SDK, use osx, tvos or watchos.

Convert

Pass the target source file to the command. The conversion result will be written to the current directory with extension .swift.

$ objc2swift foo.m

The first conversion is very slow since there is no pre-compiled header cache. It will be speed-up later.

By default, the command searches user headers from the current directory and its subdirectories. To import more headers, use -I option can be used to specifiy include paths. For example,

$ objc2swift -I ~/git/myproject/ foo.m

The path specified by -I is recursively traversed.

Configuration

The default config path is ~/.objc2swift/config.json. A typical content of config.json is like following. If you want to add user header search path permanently instead of -I, add the path to includePaths array.

{
    "systemIncludePaths": [
        "${Xcode.app}/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/System/Library/Frameworks",
        "${Xcode.app}/Contents/Developer/Platforms/iPhoneOS.platform/Developer/SDKs/iPhoneOS.sdk/usr/include",
        "${Xcode.app}/Contents/Developer/Platforms/iPhoneOS.platform/usr/lib/clang/3.5/include"
    ],
    "includePaths": []
}

How to Build

git clone https://github.com/okaxaki/objc2swift.git
cd objc2swift
npm install
npm run build

Keywords

FAQs

Package last updated on 16 Jul 2023

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc