Horatio is a library of patterns, protocols, and classes typical for the "skeleton" of a modern app. This includes:
- Operations queue with conditions, observers, and improved error handling (based on Apple’s "Advanced NSOperations" sample code).
- HTTP requests for standard REST services.
- An injection container.
- A feature availability system for global or per-subject behaviors.
By implementing concrete implementations of various protocols, you can quickly implement complex, testable network apps.
Horatio relies on the Advanced NSOperations sample code from Apple.
This document contains the following sections:
- Requirements
- Setup
- Documentation
- Troubleshooting
- Contributing
- Contributor License
- Contact
- Future Work
Horatio is delivered as Swift 3.1 source files. Due to Swift’s current lack of ABI-compatibility, there is no pre-compiled framework delivery for it at the moment.
Horatio requires compilation against iOS SDK 9.0 or higher.
- Download the latest MPA-Horatio framework, provided as source files.
Typically, 3rd-party libraries reside inside a folder in your Xcode project (for example purposes, we assume your folder is called "Vendor"). Create a folder and copy the SDK source files into it (the Demo source files are not part of the main SDK, but could be copied into your app as a starting point for various behaviors and patterns beyond that which is provided by the SDK itself).
We recommend to use Xcode's group-feature to create a group for 3rd-party-libraries similar to the structure of our files on disk. For example, similar to the file structure in 2.2 above, our projects have a group called
Vendor
.
- Make sure the
Project Navigator
is visible (⌘+1). - Drag & drop
Horatio.xcodeproj
from yourFinder
to theVendor
group inXcode
using theProject Navigator
on the left side.
- Open your
AppDelegate.swift
file. - Search for the method
application(application: UIApplication, didFinishLaunchingWithOptions launchOptions:[NSObject: AnyObject]?) -> Bool
- Add the following lines to create a shared
Container
for use throughout your application:
Container.register(OperationQueue.self) { _ in OperationQueue() }
In addition, register Services, Bridges, Feeds, etc. Typically, you'll provide a startup manager class to handle the startup sequence.
Documentation for Horatio can be found on (TBD).
Make sure none of the following files are added to any target:
CalendarCondition.swift
(except if your app asks for permission to access the user’s calendar)CloudCondition.swift
(except if your app includes the CloudKit entitlement and at least one CloudKit container)HealthCondition.swift
(except if your app includes the HealthKit entitlement)PassbookCondition.swift
(except if your app uses Passbook API)PhotosCondition.swift
(except if your app asks for permission to access the user’s Photos data)UserNotificationCondition.swift
(except if your app includes the Push entitlement and has a valid APNS certificate for its bundle)
In the framework version of the project, these files are under the Optional group, and are not compiled by default into the generated framework.
We're looking forward to your contributions via pull requests.
Development environment
- Mac running the latest version of OS X
- Get the latest Xcode from the Mac App Store
You must sign a Contributor License Agreement (TBD).
If you have further questions or are running into trouble that cannot be resolved by any of the steps here, feel free to open a Github issue here, contact us at support@mudpotapps.com.
Horatio's roadmap is somewhat flexible, based on contributor's needs at any given point. Currently, the following items are being tackled in experimental branches for inclusion at a later date:
- Finishing the demo app, including documenting the app startup code.
- Moving the Startup Sequence feature into the framework.
- Moving the Environment/Config work into the framework.
- Adding stacks and updates to Features.
- Better pipelining of fetched files for faster and lower battery profile parsing.
- Rewritten operations system based on Javascript's Promises system.