English 简体中文 🇨🇳
RFKit is a useful toolkit for daily Cocoa development.
RFKit Version | Minimum Xcode Version | Minimum iOS Target | Minimum macOS Target | Minimum watchOS Target | Minimum tvOS Target |
---|---|---|---|---|---|
2.5+ | Xcode 9 | iOS 9 | macOS 10.9 | watchOS 2.0 | tvOS 9.0 |
2.4 | Xcode 8 | iOS 8 | macOS 10.8 | watchOS 2.0 | tvOS 9.0 |
2.0-2.3 | Xcode 8 | iOS 6 | macOS 10.8 | watchOS 2.0 | tvOS 9.0 |
1.7 | Xcode 7 | iOS 6 | macOS 10.8 | watchOS 2.0 | tvOS 9.0 |
1.6 | Xcode 8 | iOS 6 | N/A | watchOS 2.0 | N/A |
To install using CocoaPods, add the following to your project Podfile:
pod 'RFKit'
Specify develop branch to install the lastest version:
pod 'RFKit', :git => 'https://github.com/BB9z/RFKit.git', :branch => 'develop'
A more complex sample:
pod 'RFKit',
:git => 'https://github.com/BB9z/RFKit.git',
:subspecs => ['Default', 'Category/NSDateFormatter']
Although I recommend using CocoaPods, Carthage is still supported.
Specify RFKit in your Cartfile:
github "BB9z/RFKit"
You can always import RFKit by adding source code into your project. Just copy any files you needs.
dout contains a set of convenient log toolcha, which was designed for debugging.
Features:
-
Out out format is better than NSLog(), and more faster.
-
Auto add expression before the results.
e.g.:
int a = 10; dout_int(101+a) // Output: 101+a = 111
-
Optimized for multiple threads debugging, you can easily find the output come from which thread.
-
Support add position information in log output to help tracking location of log statements. Set
DOUT_FALG_TRACE
as1
to active. -
Special log methods for warning and error. Can change theirs behave to throw exception or assert fail.
-
Behavior can be highly customizable through the switch.
-
As macro, usually no performance loss.
Details: dout Document(in Chinese)
Handle build or runtime differences. Provides an unified and simple interface for upper components. Contains:debugging switch define, default header file, RFARC and language extensions.
RFDEBUG
, RFKit debug mode switch. Set as 1
to active. If it´s not defined, will defined as 1
when DEBUG
is true and NDEBUG
not defined.
RFDebugLevel
, controlling debugging behavior. If it´s not defined, will be defined as 2
if RFDEBUG
is true, otherwise 1
.
UIKit and Foundation header is included in RFRuntime by default.
Defined some fake protocols for declaring a class support something or not.
Some helper function for GCD.
Include some components from libextobjc:
- metamacros.h, macros for metaprogramming.
- EXTKeyPathCoding, allows compile-time verification of key paths.
- EXTScope, several tools relative to scope.
@keypathClassInstance is similar with @keypath, but accept a class as parameter instead of a instance variable.
Important part of RFKit. They contains many useful methods.
RFKitDefaultCategories.h
defends which extension is imported by default.
See each header file to know the specific features.
Add new methods and constants for geometry structures: CGPoint
, CGSize
, CGRect
. Add an new CGAngle
angle structure.
RFResizeAnchor
and RFAlignmentAnchor
provides a reference for resizing and aligning.
Performance toolkit.
Some external components were placed under external
folder.