aboutsummaryrefslogtreecommitdiffstats
path: root/MASShortcut.xcodeproj/project.pbxproj
AgeCommit message (Collapse)Author
2016-10-28Trying to fix conditional key mask definition on 10.12Tomáš Znamenáček
2016-10-28Use modern key mask constants instead of the ones deprecated in 10.12Tomáš Znamenáček
See #99 for details.
2016-10-28Update build warnings as suggested by Xcode 8Tomáš Znamenáček
2016-08-08Upgrade Projects to Xcode 7Vadim Shpakovski
2016-04-14Add ko, nl, pl, ru, es translationsradex
2016-02-10Added basic German localization to the demo project.Tomáš Znamenáček
This makes it possible to test the German MASShortcut localization on the demo project.
2016-01-22Simplified and traditional Chinese localizations.MichaelRow
2015-10-14Japanese localizationshinya takahashi
2015-09-10Added basic localization for German, Spanish, French, Italian, and Japanese.Tomáš Znamenáček
2015-08-18Added Czech localization.Tomáš Znamenáček
2015-03-09Namespaced the testing build scheme name (Tests → MASShortcutTests).Tomáš Znamenáček
2015-03-08module mapTom Brow
2015-03-08DEFINES_MODULE = YESTom Brow
2015-01-14Added test for hotkeys and shortcut monitor.Tomáš Znamenáček
2015-01-12Added support for older OS X releases back to 10.6 included.Tomáš Znamenáček
Apart from turning off Auto Layout for the Demo project, the only thing remaining was several __weak qualifiers to prevent retain cycles in blocks. I have replaced them with __unsafe_unretained since __weak is not supported on 10.6. There should be no safety concerns here, since we are certain the pointers will remain valid.
2015-01-09Remove Xcode warnings and fix the hard-coded shortcut.Vadim Shpakovski
2015-01-09Removed an obsolete reference to the XCTest framework.Tomáš Znamenáček
2015-01-07Treat build warnings as errors.Tomáš Znamenáček
2015-01-07Updated header settings.Tomáš Znamenáček
2015-01-07Added a simplified binding API for MASShortcutView.Tomáš Znamenáček
This returns the associatedUserDefaultsKey property used in previous code versions, only the implementation uses less magic.
2015-01-07Added a custom transformer to store shortcuts as dictionaries.Tomáš Znamenáček
The MASDictionaryTransformer class is used to save shortcuts to user defaults (and load them back) using a simple dictionary. The value stored in the user defaults looks like this: $ defaults read com.shpakovski.mac.Demo { MASDemoShortcut = { keyCode = 15; modifierFlags = 1048576; }; … } This storage format has got the distinct advantage of being compatible with the format used by Shortcut Recorder. In order to use it, you have to set proper binding options for MASShortcutBinder and the recorder control (MASShortcutView).
2015-01-07Refactored the shortcut dispatcher and bindings to user defaults.Tomáš Znamenáček
This is a big change that was hard to split into smaller commits. There’s now a new class to bind shortcuts to actions, a new class to bind user defaults’ keys to actions, and a new way to associate user defaults with the recorder control (MASShortcutView). I have also updated the demo app to go with the changes. The new class to associate shortcuts with actions is called MASShortcutMonitor. It wraps the Carbon hotkey magic and offers a simple interface to add a shortcut along with a block that should be run when the shortcut is pressed. It’s the lowest-level interface. Since the usual requirement is to store the shortcuts into user defaults, there’s also a higher-level interface offered by the MASShortcutBinder class. That takes a defaults key and associates it with a block. When the shortcut stored under the defaults key changes, the binder automatically switches to the new shortcut. The class is a wrapper built atop of the previous one, the MASShortcutMonitor – it simply adds, updates and removes shortcuts as the user defaults change. I have removed the special user defaults integration code from the recorder control (MASShortcutView) and replaced it with a small Cocoa Bindings shim. This means that in order to keep the recorder control in sync with the defaults you just have to call the usual bind:toObject:withKeyPath:options: method, like this: [_shortcutView bind:MASShortcutBinding toObject:[NSUserDefaultsController sharedUserDefaultsController] withKeyPath[@"values.ExampleDefaultsKey" options:@{NSValueTransformerNameBindingOption:NSKeyedUnarchiveFromDataTransformerName}]; That’s more verbose than the previous solution, but it’s much cleaner and can be swept under a convenience call if needed. I might also add a dictionaryValue property later that would make it possible to bind the value to user defaults directly, without a transformer, and would enable backward compatibility with Shortcut Recorder.
2015-01-07Organized classes into Xcode folders.Tomáš Znamenáček
2015-01-07Introduced a standalone MASShortcutValidator class to validate shortcuts.Tomáš Znamenáček
It’s a natural simplification of the MASShortcut class. All MASShortcutView objects use a shared validator by default, but can be reconfigured to use a different validator if needed through the shortcutValidator property.
2015-01-07Converted keycode macros to plain functions.Tomáš Znamenáček
Plain functions are less prone to bugs, the compiler understands them better and can offer better error messages, and plain functions can be refactored more easily.
2015-01-07Introduced a separate header file for keycode definitions.Tomáš Znamenáček
2015-01-07Added a unit testing target.Tomáš Znamenáček
2015-01-07Deleted an unneccessary prefix header for the framework target.Tomáš Znamenáček
2015-01-07Created an umbrella header.Tomáš Znamenáček
Now you can just `#import <MASShortcut/Shortcut.h>`.
2015-01-07Repackaged the code as a framework and included the demo.Tomáš Znamenáček
Packaging the code as a framework is mostly just a formality. It doesn’t really change much, it just turns the code into a regular component. What it does change is that the code now has its own Xcode settings, which could make compatibility easier in the long run. Including the demo in the main repository makes it easier to hack on the library, since you can try the changes immediately. It also shows how to bundle the framework into an app that uses it.