Swift-friendly API for a set of powerful Objective C runtime functions.
Switch branches/tags
Nothing to show
Clone or download
Latest commit c52df80 Nov 17, 2016
Type Name Latest commit message Commit time
Failed to load latest commit information.
ObjectiveKit.xcodeproj Release 0.2.0 Nov 16, 2016
ObjectiveKit Release 0.2.0 Nov 16, 2016
ObjectiveKitTests Release 0.2.0 Nov 16, 2016
.gitignore [#3] Computed properties instead of methods Nov 16, 2016
.travis.yml Preparing ObjectiveKit for release Nov 14, 2016
LICENSE Initial commit Nov 13, 2016
ObjectiveKit.podspec Release 0.2.0 Nov 16, 2016
Package.swift Preparing ObjectiveKit for release Nov 14, 2016
README.md Update README.md Nov 17, 2016
build.sh Fix build script Nov 15, 2016


ObjectiveKit - Swift friendly ObjC-Runtime functions

Build Status Version Carthage compatible


ObjectiveKit provides a Swift friendly API for a set of powerful Objective C runtime functions.


To use ObjectiveKit:

Import ObjectiveKit at the top of your Swift file:

import ObjectiveKit

The next step is to create an ObjectiveClass object typed for the class you want to modify or introspect:

let viewClass = ObjectiveClass<UIView>()

If using ObjectiveKit on a custom Swift class, make sure that it inherits at some point from NSObject and that it is exposed to the Objective C runtime using the @objc flag.


You can learn more about classes at runtime with these handy introspection methods:

let mapViewClass = ObjectiveClass<MKMapView>()
let ivars = mapViewClass.ivars // An array of ivars.
let selectors = mapViewClass.selectors // An array of selectors.
let properties = mapViewClass.properties // An array of properties.
let protocols = mapViewClass.protocols // An array of protocols.

Modifying classes at runtime

Add a pre-existing selector from another class to your ObjectiveClass:

let viewClass = ObjectiveClass<UIView>()
viewClass.addSelector(#selector(testSelector), from: self.classForCoder)
let view = UIView()

Add a custom method by providing the implementation with a closure:

let viewClass = ObjectiveClass<UIView>()
viewClass.addMethod(closureName, implementation: {
    print("hello world")
let view = UIView()

ObjectiveKit also supports exchanging selectors in the same class:

let viewClass = ObjectiveClass<UIView>()
viewClass.exchangeSelector(#selector(UIView.layoutSubviews), with: #selector(UIView.xxx_layoutSubviews))

Creating classes at runtime

Lastly, you can also create a custom ObjC class at runtime:

let runtimeClass = RuntimeClass(superclass: UIView.self)
runtimeClass.addIvar(ivarName, type: .Float)
let runtimeObject = runtimeClass.allocate()
runtimeObject.setValue(4.0, forKey: ivarName)

Setting up

Setting up with CocoaPods

source 'https://github.com/CocoaPods/Specs.git'
pod 'ObjectiveKit', '~> 0.2'

Setting up with Carthage

Carthage is a decentralized dependency manager that automates the process of adding frameworks to your Cocoa application.

You can install Carthage with Homebrew using the following command:

$ brew update
$ brew install carthage

To integrate ObjectiveKit into your Xcode project using Carthage, specify it in your Cartfile:

github "marmelroy/ObjectiveKit"