Skip to content

Commit

Permalink
Merge pull request #867 from LEOYoon-Tsaw/new_features
Browse files Browse the repository at this point in the history
Moving caret by mouse click
Resolve #795
  • Loading branch information
LEOYoon-Tsaw authored Apr 29, 2024
2 parents db0b523 + 7975ef3 commit 5db35e4
Show file tree
Hide file tree
Showing 7 changed files with 65 additions and 24 deletions.
2 changes: 1 addition & 1 deletion Sparkle
Submodule Sparkle updated 77 files
+15 −14 .github/workflows/ci.yml
+2 −2 .github/workflows/create-draft-release.yml
+14 −3 Autoupdate/AppInstaller.m
+1 −1 Autoupdate/SPUInstallationInfo.h
+5 −1 Autoupdate/SPUInstallationInputData.h
+16 −2 Autoupdate/SPUInstallationInputData.m
+3 −3 Autoupdate/SPUXarDeltaArchive.m
+1 −1 Autoupdate/SUBinaryDeltaApply.m
+1 −1 Autoupdate/SUBinaryDeltaCreate.m
+7 −0 Autoupdate/SUCodeSigningVerifier.h
+25 −1 Autoupdate/SUCodeSigningVerifier.m
+63 −5 Autoupdate/SUPlainInstaller.m
+9 −2 Autoupdate/SUSignatureVerifier.h
+29 −5 Autoupdate/SUSignatureVerifier.m
+1 −1 Autoupdate/main.m
+14 −2 CHANGELOG
+1 −1 Carthage-dev.json
+12 −5 Configurations/ConfigCommon.xcconfig
+1 −1 Configurations/ConfigDownloader.xcconfig
+18 −44 Configurations/make-release-package.sh
+2 −2 Configurations/set-git-version-info.sh
+5 −5 Documentation/Design Practices.md
+3 −3 Documentation/Installation.md
+1 −1 Documentation/Security.md
+0 −0 Downloader/Downloader.entitlements
+1 −2 Downloader/SPUDownloader.m
+0 −12 InstallerConnection/org.sparkle-project.InstallerConnection.entitlements
+1 −1 InstallerLauncher/SUInstallerLauncher.m
+0 −12 InstallerStatus/org.sparkle-project.InstallerStatus.entitlements
+4 −4 Package.swift
+2 −2 README.markdown
+2 −2 Sparkle.podspec
+42 −11 Sparkle.xcodeproj/project.pbxproj
+1 −1 Sparkle/SPUBasicUpdateDriver.m
+3 −2 Sparkle/SPUCoreBasedUpdateDriver.m
+1 −1 Sparkle/SPUDownloadDriver.h
+1 −1 Sparkle/SPUInstallerDriver.m
+3 −3 Sparkle/SPUStandardUpdaterController.h
+3 −3 Sparkle/SPUUpdater.h
+2 −2 Sparkle/SPUUpdater.m
+1 −1 Sparkle/SPUUpdaterDelegate.h
+11 −7 Sparkle/SPUUserDriver.h
+24 −0 Sparkle/SPUVerifierInformation.h
+27 −0 Sparkle/SPUVerifierInformation.m
+1 −0 Sparkle/SUAppcastItem+Private.h
+1 −1 Sparkle/SUAppcastItem.m
+1 −1 Sparkle/SUApplicationInfo.m
+2 −1 Sparkle/SULocalizations.h
+1 −1 Sparkle/SULog.h
+1 −1 Sparkle/SULog.m
+0 −2 Sparkle/SUSignatures.m
+2 −2 Sparkle/SUStatus.xib
+4 −4 Sparkle/SUStatusController.m
+21 −63 Sparkle/SUUpdateAlert.m
+4 −4 Sparkle/SUUpdatePermissionPrompt.m
+4 −1 Sparkle/SUUpdateValidator.h
+10 −5 Sparkle/SUUpdateValidator.m
+2 −2 Sparkle/SUUpdater.h
+1 −1 Sparkle/SUUpdater.m
+1 −1 Sparkle/SUUpdaterDelegate.h
+3 −3 Sparkle/ko.lproj/SUUpdateAlert.strings
+11 −8 Sparkle/ko.lproj/SUUpdatePermissionPrompt.strings
+83 −11 Sparkle/ko.lproj/Sparkle.strings
+18 −0 Sparkle/nn.lproj/SUUpdateAlert.strings
+24 −0 Sparkle/nn.lproj/SUUpdatePermissionPrompt.strings
+90 −0 Sparkle/nn.lproj/Sparkle.strings
+162 −0 TestApplication/nn.lproj/MainMenu.strings
+3 −3 Tests/SUAppcastTest.swift
+5 −5 Tests/SUBinaryDeltaTest.m
+15 −14 Tests/SUSignatureVerifierTest.m
+2 −2 Tests/SUUpdateValidatorTest.swift
+1 −0 Tests/Sparkle Unit Tests-Bridging-Header.h
+47 −0 common_cli/secret.swift
+1 −1 generate_appcast/URL+Hashing.swift
+40 −14 generate_appcast/main.swift
+32 −28 generate_keys/main.swift
+34 −17 sign_update/main.swift
16 changes: 8 additions & 8 deletions SquirrelConfig.m
Original file line number Diff line number Diff line change
Expand Up @@ -189,15 +189,15 @@ - (NSColor*)colorFromString:(NSString*)string {
sscanf(string.UTF8String, "0x%02x%02x%02x", &b, &g, &r);
}
if ([self.colorSpace isEqualToString:@"display_p3"]) {
return [NSColor colorWithDisplayP3Red:r / 255.0
green:g / 255.0
blue:b / 255.0
alpha:a / 255.0];
return [NSColor colorWithDisplayP3Red:(CGFloat)r / 255.
green:(CGFloat)g / 255.
blue:(CGFloat)b / 255.
alpha:(CGFloat)a / 255.];
} else { // sRGB by default
return [NSColor colorWithSRGBRed:r / 255.0
green:g / 255.0
blue:b / 255.0
alpha:a / 255.0];
return [NSColor colorWithSRGBRed:(CGFloat)r / 255.
green:(CGFloat)g / 255.
blue:(CGFloat)b / 255.
alpha:(CGFloat)a / 255.];
}
}

Expand Down
1 change: 1 addition & 0 deletions SquirrelInputController.h
Original file line number Diff line number Diff line change
Expand Up @@ -3,5 +3,6 @@

@interface SquirrelInputController : IMKInputController
- (BOOL)selectCandidate:(NSInteger)index;
- (BOOL)moveCaret:(BOOL)forward;
- (BOOL)pageUp:(BOOL)up;
@end
18 changes: 18 additions & 0 deletions SquirrelInputController.m
Original file line number Diff line number Diff line change
Expand Up @@ -251,6 +251,24 @@ - (BOOL)pageUp:(BOOL)up {
return handled;
}

- (BOOL)moveCaret:(BOOL)forward {
size_t current_caret_pos = rime_get_api()->get_caret_pos(_session);
const char* input = rime_get_api()->get_input(_session);
if (forward) {
if (current_caret_pos <= 0) {
return NO;
}
rime_get_api()->set_caret_pos(_session, current_caret_pos - 1);
} else {
if (current_caret_pos >= strlen(input)) {
return NO;
}
rime_get_api()->set_caret_pos(_session, current_caret_pos + 1);
}
[self rimeUpdate];
return YES;
}

- (void)onChordTimer:(NSTimer*)timer {
// chord release triggered by timer
int processed_keys = 0;
Expand Down
48 changes: 35 additions & 13 deletions SquirrelPanel.m
Original file line number Diff line number Diff line change
Expand Up @@ -829,6 +829,10 @@ - (void)drawRect:(NSRect)dirtyRect {
CGPathRef preeditPath = CGPathCreateMutable();
SquirrelTheme* theme = self.currentTheme;

NSPoint textFieldOrigin = dirtyRect.origin;
textFieldOrigin.y += theme.edgeInset.height;
textFieldOrigin.x += theme.edgeInset.width;

// Draw preedit Rect
NSRect backgroundRect = dirtyRect;
NSRect containingRect = dirtyRect;
Expand Down Expand Up @@ -1026,9 +1030,13 @@ - (void)drawRect:(NSRect)dirtyRect {
}
[panelLayer addSublayer:layer];
}
[_textView
setTextContainerInset:NSMakeSize(textFieldOrigin.x, textFieldOrigin.y)];
}

- (BOOL)clickAtPoint:(NSPoint)_point index:(NSInteger*)_index {
- (BOOL)clickAtPoint:(NSPoint)_point
index:(NSInteger*)_index
preeditIndex:(NSInteger*)_preeditIndex {
if (CGPathContainsPoint(_shape.path, nil, _point, NO)) {
NSPoint point =
NSMakePoint(_point.x - self.textView.textContainerInset.width,
Expand All @@ -1047,11 +1055,20 @@ - (BOOL)clickAtPoint:(NSPoint)_point index:(NSInteger*)_index {
point = NSMakePoint(point.x - NSMinX(lineFragment.typographicBounds),
point.y - NSMinY(lineFragment.typographicBounds));
index += [lineFragment characterIndexForPoint:point];
for (NSUInteger i = 0; i < _candidateRanges.count; i += 1) {
NSRange range = [_candidateRanges[i] rangeValue];
if (index >= range.location && index < NSMaxRange(range)) {
*_index = i;
break;
if (index >= _preeditRange.location &&
index < NSMaxRange(_preeditRange)) {
if (_preeditIndex) {
*_preeditIndex = index;
}
} else {
for (NSUInteger i = 0; i < _candidateRanges.count; i += 1) {
NSRange range = [_candidateRanges[i] rangeValue];
if (index >= range.location && index < NSMaxRange(range)) {
if (_index) {
*_index = i;
}
break;
}
}
}
break;
Expand Down Expand Up @@ -1227,7 +1244,7 @@ - (void)sendEvent:(NSEvent*)event {
case NSEventTypeLeftMouseDown: {
NSPoint point = [self mousePosition];
NSInteger index = -1;
if ([_view clickAtPoint:point index:&index]) {
if ([_view clickAtPoint:point index:&index preeditIndex:nil]) {
if (index >= 0 && index < _candidates.count) {
_index = index;
}
Expand All @@ -1236,7 +1253,15 @@ - (void)sendEvent:(NSEvent*)event {
case NSEventTypeLeftMouseUp: {
NSPoint point = [self mousePosition];
NSInteger index = -1;
if ([_view clickAtPoint:point index:&index]) {
NSInteger preeditIndex = -1;
if ([_view clickAtPoint:point index:&index preeditIndex:&preeditIndex]) {
if (preeditIndex >= 0 && preeditIndex < _preedit.length) {
if (preeditIndex < _caretPos) {
[_inputController moveCaret:YES];
} else if (preeditIndex > _caretPos) {
[_inputController moveCaret:NO];
}
}
if (index >= 0 && index < _candidates.count && index == _index) {
[_inputController selectCandidate:index];
}
Expand All @@ -1261,7 +1286,7 @@ - (void)sendEvent:(NSEvent*)event {
case NSEventTypeMouseMoved: {
NSPoint point = [self mousePosition];
NSInteger index = -1;
if ([_view clickAtPoint:point index:&index]) {
if ([_view clickAtPoint:point index:&index preeditIndex:nil]) {
if (index >= 0 && index < _candidates.count && _cursorIndex != index) {
[self showPreedit:_preedit
selRange:_selRange
Expand Down Expand Up @@ -1459,12 +1484,9 @@ - (void)show {
[self.contentView setBoundsOrigin:NSMakePoint(0, 0)];
[_view.textView setBoundsOrigin:NSMakePoint(0, 0)];
}
BOOL translucency = theme.translucency;
[_view setFrame:self.contentView.bounds];
[_view.textView setFrame:self.contentView.bounds];
[_view.textView setTextContainerInset:NSMakeSize(theme.edgeInset.width,
theme.edgeInset.height)];

BOOL translucency = theme.translucency;
if (translucency) {
[_back setFrame:self.contentView.bounds];
_back.appearance = NSApp.effectiveAppearance;
Expand Down
2 changes: 1 addition & 1 deletion plum

0 comments on commit 5db35e4

Please sign in to comment.