Skip to content

nevir/SMJobKit

Repository files navigation

SMJobKit

Using SMJobBless and friends is rather ...painful. SMJobKit does everything in its power to alleviate that and get you back to writing awesome OS X apps.

SMJobKit is more than just a framework/library to link against. It gives you:

  • A Xcode target template for SMJobBless-ready launchd services, completely configured for proper code signing!

  • A client abstraction that manages installing/upgrading your app's service(s).

  • A service library that pulls in as little additional code as possible. Less surface area for security vulnerabilities!

Project Configuration

To get started, pull the SMJobKit project into your own project or workspace. Have your application depend on the SMJobKit framework, and hit build. In addition to building the framework, this also causes the Xcode template to install its self into ~/Library/Developer/Xcode/Templates.

Next, you should set up your service helper/target: Add a new SMJobKit Service target to the project. This is relatively configuration-heavy, so you should probably build it right away to make sure everything is properly configured (and your code signing certificates are in order). You may want to review the [template's documentation](https://github.com/nevir/XMJobKit/tree/master/SMJobKit Service.xctemplate) for an in-depth explanation of what it is doing for you.

Finally, you need to add a Copy Files build phase to your application target. The destination should be "Wrapper" with a subpath of Contents/Library/LaunchServices. Add the service's built product to the list. Make sure you add a dependency on your service target!

And, hopefully, that's all you need to do in order to configure your project!

Client Abstraction

You'll want to create a subclass of SMJClient in your application, and override serviceIdentifier at the very least.

Service Implementation

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published