forked from Kentzo/ShortcutRecorder
-
Notifications
You must be signed in to change notification settings - Fork 1
/
Copy pathSRKeyCodeTransformer.h
122 lines (98 loc) · 3.69 KB
/
SRKeyCodeTransformer.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
//
// SRKeyCodeTransformer.h
// ShortcutRecorder
//
// Copyright 2006-2012 Contributors. All rights reserved.
//
// License: BSD
//
// Contributors:
// David Dauer
// Jesper
// Jamie Kirkpatrick
// Ilya Kulakov
// Silvio Rizzi
#import <Cocoa/Cocoa.h>
#import <Carbon/Carbon.h>
/*!
@brief Transforms key code into unicode character or plain string.
*/
@interface SRKeyCodeTransformer : NSValueTransformer
/*!
@brief Returns initialized key code transformer.
@param aUsesASCII Determines whether transformer uses only ASCII capable keyboard input source.
@param aUsesPlainStrings Determines whether key codes without readable glyphs (e.g. F1...F19) are transformed to
to unicode characters (NSF1FunctionKey...NSF19FunctionKey) suitable for setting key equivalents
of Cocoa controls or to plain strings (@"F1"...@"F19") suitable for drawing, logging and accessibility.
@discussion This method is the designated initializer for SRKeyCodeTransformer.
*/
- (instancetype)initWithASCIICapableKeyboardInputSource:(BOOL)aUsesASCII plainStrings:(BOOL)aUsesPlainStrings;
/*!
@brief Determines whether transformer uses ASCII capable keyboard input source.
*/
@property (readonly) BOOL usesASCIICapableKeyboardInputSource;
/*!
@brief Determines whether key codes without readable glyphs are transformed to unicode characters or to plain strings.
*/
@property (readonly) BOOL usesPlainStrings;
/*!
@brief Returns the shared transformer.
*/
+ (instancetype)sharedTransformer;
/*!
@brief Returns the shared transformer configured to use only ASCII capable keyboard input source.
*/
+ (instancetype)sharedASCIITransformer;
/*!
@brief Returns the shared transformer configured to transform key codes to plain strings.
*/
+ (SRKeyCodeTransformer *)sharedPlainTransformer;
/*!
@brief Returns the shared transformer configured to use only ASCII capable keyboard input source
and to transform key codes to plain strings.
*/
+ (SRKeyCodeTransformer *)sharedPlainASCIITransformer;
/*!
@brief Returns mapping from special key codes to unicode characters.
*/
+ (NSDictionary *)specialKeyCodesToUnicodeCharactersMapping;
/*!
@brief Returns mapping from special key codes to plain strings.
*/
+ (NSDictionary *)specialKeyCodesToPlainStringsMapping;
/*!
@brief Determines whether key code is special.
@param aKeyCode Key code to be checked.
*/
- (BOOL)isKeyCodeSpecial:(unsigned short)aKeyCode;
/*!
@brief Transfroms given key code into unicode character by taking into account modifier flags.
@param aValue An instance of NSNumber (unsigned short) that represents key code.
@param aModifierFalgs An instance of NSNumber (NSUInteger) that represents modifier flags.
*/
- (NSString *)transformedValue:(NSNumber *)aValue withModifierFlags:(NSNumber *)aModifierFlags;
@end
/*!
@brief These constants represents unicode characters for key codes that do not have appropriate constants
in Carbon or Cocoa.
*/
typedef NS_ENUM(unichar, SRKeyCodeGlyph)
{
SRKeyCodeGlyphRight = 0x21E5,
SRKeyCodeGlyphReturn = 0x2305,
SRKeyCodeGlyphReturnR2L = 0x21A9,
SRKeyCodeGlyphDeleteLeft = 0x232B,
SRKeyCodeGlyphDeleteRight = 0x2326,
SRKeyCodeGlyphPadClear = 0x2327,
SRKeyCodeGlyphLeftArrow = 0x2190,
SRKeyCodeGlyphRightArrow = 0x2192,
SRKeyCodeGlyphUpArrow = 0x2191,
SRKeyCodeGlyphDownArrow = 0x2193,
SRKeyCodeGlyphPageDown = 0x21DF,
SRKeyCodeGlyphPageUp = 0x21DE,
SRKeyCodeGlyphNorthwestArrow = 0x2196,
SRKeyCodeGlyphSoutheastArrow = 0x2198,
SRKeyCodeGlyphEscape = 0x238B,
SRKeyCodeGlyphHelp = 0x003F,
SRKeyCodeGlyphSpace = 0x0020,
};