Zonble: Ctrl-key punctuation support.
- An important feature which Yahoo Kimo IME supports.
This commit is contained in:
parent
e77f253ed6
commit
a2792f6279
|
@ -220,7 +220,7 @@ static NSString *const kGraphVizOutputfile = @"/tmp/vChewing-visualization.dot";
|
||||||
}
|
}
|
||||||
|
|
||||||
// if the composing buffer is empty and there's no reading, and there is some function key combination, we ignore it
|
// if the composing buffer is empty and there's no reading, and there is some function key combination, we ignore it
|
||||||
BOOL isFunctionKey = ([input isCommandHold] || [input isControlHold] || [input isOptionHold] || [input isNumericPad]);
|
BOOL isFunctionKey = ([input isCommandHold] || [input isOptionHold] || [input isNumericPad]) || [input isControlHotKey];
|
||||||
if (![state isKindOfClass:[InputStateNotEmpty class]] && isFunctionKey) {
|
if (![state isKindOfClass:[InputStateNotEmpty class]] && isFunctionKey) {
|
||||||
return NO;
|
return NO;
|
||||||
}
|
}
|
||||||
|
@ -282,7 +282,7 @@ static NSString *const kGraphVizOutputfile = @"/tmp/vChewing-visualization.dot";
|
||||||
|
|
||||||
// MARK: Handle BPMF Keys
|
// MARK: Handle BPMF Keys
|
||||||
// see if it's valid BPMF reading
|
// see if it's valid BPMF reading
|
||||||
if (_bpmfReadingBuffer->isValidKey((char) charCode)) {
|
if (![input isControlHold] && _bpmfReadingBuffer->isValidKey((char) charCode)) {
|
||||||
_bpmfReadingBuffer->combineKey((char) charCode);
|
_bpmfReadingBuffer->combineKey((char) charCode);
|
||||||
|
|
||||||
// if we have a tone marker, we have to insert the reading to the
|
// if we have a tone marker, we have to insert the reading to the
|
||||||
|
@ -457,8 +457,15 @@ static NSString *const kGraphVizOutputfile = @"/tmp/vChewing-visualization.dot";
|
||||||
|
|
||||||
// MARK: Punctuation
|
// MARK: Punctuation
|
||||||
// if nothing is matched, see if it's a punctuation key for current layout.
|
// if nothing is matched, see if it's a punctuation key for current layout.
|
||||||
string layout = [self _currentLayout];
|
string punctuationNamePrefix;
|
||||||
string punctuationNamePrefix = Preferences.halfWidthPunctuationEnabled ? string("_half_punctuation_") : string("_punctuation_");
|
if ([input isControlHold]) {
|
||||||
|
punctuationNamePrefix = string("_ctrl_punctuation_");
|
||||||
|
} else if (Preferences.halfWidthPunctuationEnabled) {
|
||||||
|
punctuationNamePrefix = string("_half_punctuation_");
|
||||||
|
} else {
|
||||||
|
punctuationNamePrefix = string("_punctuation_");
|
||||||
|
}
|
||||||
|
string layout = [self _currentLayout];
|
||||||
string customPunctuation = punctuationNamePrefix + layout + string(1, (char) charCode);
|
string customPunctuation = punctuationNamePrefix + layout + string(1, (char) charCode);
|
||||||
if ([self _handlePunctuation:customPunctuation state:state usingVerticalMode:input.useVerticalMode stateCallback:stateCallback errorCallback:errorCallback]) {
|
if ([self _handlePunctuation:customPunctuation state:state usingVerticalMode:input.useVerticalMode stateCallback:stateCallback errorCallback:errorCallback]) {
|
||||||
return YES;
|
return YES;
|
||||||
|
@ -998,7 +1005,14 @@ static NSString *const kGraphVizOutputfile = @"/tmp/vChewing-visualization.dot";
|
||||||
|
|
||||||
if (Preferences.useWinNT351BPMF) {
|
if (Preferences.useWinNT351BPMF) {
|
||||||
string layout = [self _currentLayout];
|
string layout = [self _currentLayout];
|
||||||
string punctuationNamePrefix = Preferences.halfWidthPunctuationEnabled ? string("_half_punctuation_") : string("_punctuation_");
|
string punctuationNamePrefix;
|
||||||
|
if ([input isControlHold]) {
|
||||||
|
punctuationNamePrefix = string("_ctrl_punctuation_");
|
||||||
|
} else if (Preferences.halfWidthPunctuationEnabled) {
|
||||||
|
punctuationNamePrefix = string("_half_punctuation_");
|
||||||
|
} else {
|
||||||
|
punctuationNamePrefix = string("_punctuation_");
|
||||||
|
}
|
||||||
string customPunctuation = punctuationNamePrefix + layout + string(1, (char) charCode);
|
string customPunctuation = punctuationNamePrefix + layout + string(1, (char) charCode);
|
||||||
string punctuation = punctuationNamePrefix + string(1, (char) charCode);
|
string punctuation = punctuationNamePrefix + string(1, (char) charCode);
|
||||||
|
|
||||||
|
|
|
@ -84,6 +84,10 @@ class KeyHandlerInput: NSObject {
|
||||||
flags.contains([.control])
|
flags.contains([.control])
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@objc var isControlHotKey: Bool {
|
||||||
|
flags.contains([.control]) && inputText?.first?.isLetter ?? false
|
||||||
|
}
|
||||||
|
|
||||||
@objc var isOptionHold: Bool {
|
@objc var isOptionHold: Bool {
|
||||||
flags.contains([.option])
|
flags.contains([.option])
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in New Issue