Repo // Require that minimum candidate key count is 6, etc.

- SP2 Fix: Shared // Add missing dependency.
This commit is contained in:
ShikiSuen 2022-09-29 19:27:06 +08:00
parent a58530b02e
commit 227d0fb1bc
13 changed files with 36 additions and 31 deletions

View File

@ -13,13 +13,15 @@ let package = Package(
) )
], ],
dependencies: [ dependencies: [
.package(path: "../vChewing_CocoaExtension") .package(path: "../vChewing_CocoaExtension"),
.package(path: "../vChewing_SwiftExtension")
], ],
targets: [ targets: [
.target( .target(
name: "Shared", name: "Shared",
dependencies: [ dependencies: [
.product(name: "CocoaExtension", package: "vChewing_CocoaExtension") .product(name: "CocoaExtension", package: "vChewing_CocoaExtension"),
.product(name: "SwiftExtension", package: "vChewing_SwiftExtension")
] ]
) )
] ]

View File

@ -7,6 +7,7 @@
// requirements defined in MIT License. // requirements defined in MIT License.
import Foundation import Foundation
import SwiftExtension
// MARK: - UserDef Snapshot Manager // MARK: - UserDef Snapshot Manager
@ -214,10 +215,10 @@ public enum CandidateKey {
return NSLocalizedString("There should not be duplicated keys.", comment: "") return NSLocalizedString("There should not be duplicated keys.", comment: "")
case .tooShort: case .tooShort:
return NSLocalizedString( return NSLocalizedString(
"Please specify at least 4 candidate keys.", comment: "" "Please specify at least 6 candidate keys.", comment: ""
) )
case .tooLong: case .tooLong:
return NSLocalizedString("Maximum 15 candidate keys allowed.", comment: "") return NSLocalizedString("Maximum 9 candidate keys allowed.", comment: "")
} }
} }
} }
@ -233,10 +234,10 @@ public enum CandidateKey {
if trimmed.contains(" ") { if trimmed.contains(" ") {
throw CandidateKey.ErrorType.containSpace throw CandidateKey.ErrorType.containSpace
} }
if trimmed.count < 4 { if trimmed.count < 6 {
throw CandidateKey.ErrorType.tooShort throw CandidateKey.ErrorType.tooShort
} }
if trimmed.count > 15 { if trimmed.count > 9 {
throw CandidateKey.ErrorType.tooLong throw CandidateKey.ErrorType.tooLong
} }
let set = Set(Array(trimmed)) let set = Set(Array(trimmed))

View File

@ -13,7 +13,7 @@ import Foundation
// Extend the RangeReplaceableCollection to allow it clean duplicated characters. // Extend the RangeReplaceableCollection to allow it clean duplicated characters.
// Ref: https://stackoverflow.com/questions/25738817/ // Ref: https://stackoverflow.com/questions/25738817/
extension RangeReplaceableCollection where Element: Hashable { extension RangeReplaceableCollection where Element: Hashable {
public var deduplicate: Self { public var deduplicated: Self {
var set = Set<Element>() var set = Set<Element>()
return filter { set.insert($0).inserted } return filter { set.insert($0).inserted }
} }

View File

@ -275,7 +275,7 @@ public class KeyHandler {
Megrez.Compositor.KeyValuePaired(key: $0.0, value: $0.1.value) Megrez.Compositor.KeyValuePaired(key: $0.0, value: $0.1.value)
} }
arrCandidates = arrSuggestedCandidates.filter { arrCandidates.contains($0) } + arrCandidates arrCandidates = arrSuggestedCandidates.filter { arrCandidates.contains($0) } + arrCandidates
arrCandidates = arrCandidates.deduplicate arrCandidates = arrCandidates.deduplicated
arrCandidates = arrCandidates.stableSort { $0.key.split(separator: "-").count > $1.key.split(separator: "-").count } arrCandidates = arrCandidates.stableSort { $0.key.split(separator: "-").count > $1.key.split(separator: "-").count }
return arrCandidates.map { ($0.key, $0.value) } return arrCandidates.map { ($0.key, $0.value) }
} }

View File

@ -233,7 +233,10 @@ public class PrefMgr: PrefMgrProtocol {
@AppProperty(key: UserDef.kCandidateKeys.rawValue, defaultValue: kDefaultCandidateKeys) @AppProperty(key: UserDef.kCandidateKeys.rawValue, defaultValue: kDefaultCandidateKeys)
public var candidateKeys: String { public var candidateKeys: String {
didSet { didSet {
if useIMKCandidateWindow { if candidateKeys != candidateKeys.deduplicated {
candidateKeys = candidateKeys.deduplicated
}
if !(6...9).contains(candidateKeys.count) {
candidateKeys = Self.kDefaultCandidateKeys candidateKeys = Self.kDefaultCandidateKeys
} }
} }

View File

@ -22,6 +22,8 @@ extension PrefMgr {
disableShiftTogglingAlphanumericalMode = false disableShiftTogglingAlphanumericalMode = false
togglingAlphanumericalModeWithLShift = false togglingAlphanumericalModeWithLShift = false
} }
// ( didSet )
candidateKeys = candidateKeys
// //
clientsIMKTextInputIncapable = Array(Set(clientsIMKTextInputIncapable)).sorted() clientsIMKTextInputIncapable = Array(Set(clientsIMKTextInputIncapable)).sorted()
// //

View File

@ -56,7 +56,7 @@ struct suiPrefPaneKeyboard: View {
items: CandidateKey.suggestions, items: CandidateKey.suggestions,
text: $selSelectionKeys.onChange { text: $selSelectionKeys.onChange {
let value = selSelectionKeys let value = selSelectionKeys
let keys: String = value.trimmingCharacters(in: .whitespacesAndNewlines).deduplicate let keys: String = value.trimmingCharacters(in: .whitespacesAndNewlines).deduplicated
do { do {
try CandidateKey.validate(keys: keys) try CandidateKey.validate(keys: keys)
PrefMgr.shared.candidateKeys = keys PrefMgr.shared.candidateKeys = keys
@ -64,8 +64,8 @@ struct suiPrefPaneKeyboard: View {
} catch CandidateKey.ErrorType.empty { } catch CandidateKey.ErrorType.empty {
selSelectionKeys = PrefMgr.shared.candidateKeys selSelectionKeys = PrefMgr.shared.candidateKeys
} catch { } catch {
if let window = ctlPrefUI.shared.controller.window { if let window = ctlPrefUI.shared.controller.window, let error = error as? CandidateKey.ErrorType {
let alert = NSAlert(error: error) let alert = NSAlert(error: error.errorDescription)
alert.beginSheetModal(for: window) { _ in alert.beginSheetModal(for: window) { _ in
selSelectionKeys = PrefMgr.shared.candidateKeys selSelectionKeys = PrefMgr.shared.candidateKeys
} }

View File

@ -135,8 +135,10 @@ class ctlPrefWindow: NSWindowController {
} }
selectionKeyComboBox.stringValue = candidateSelectionKeys selectionKeyComboBox.stringValue = candidateSelectionKeys
if PrefMgr.shared.useIMKCandidateWindow {
selectionKeyComboBox.isEnabled = false // IMKCandidates selectionKeyComboBox.isEnabled = false // IMKCandidates
} }
}
// CNS // CNS
// //
@ -198,7 +200,7 @@ class ctlPrefWindow: NSWindowController {
let keys = (sender as AnyObject).stringValue?.trimmingCharacters( let keys = (sender as AnyObject).stringValue?.trimmingCharacters(
in: .whitespacesAndNewlines in: .whitespacesAndNewlines
) )
.deduplicate .deduplicated
else { else {
return return
} }
@ -209,8 +211,8 @@ class ctlPrefWindow: NSWindowController {
} catch CandidateKey.ErrorType.empty { } catch CandidateKey.ErrorType.empty {
selectionKeyComboBox.stringValue = PrefMgr.shared.candidateKeys selectionKeyComboBox.stringValue = PrefMgr.shared.candidateKeys
} catch { } catch {
if let window = window { if let window = window, let error = error as? CandidateKey.ErrorType {
let alert = NSAlert(error: error) let alert = NSAlert(error: error.errorDescription)
alert.beginSheetModal(for: window) { _ in alert.beginSheetModal(for: window) { _ in
self.selectionKeyComboBox.stringValue = PrefMgr.shared.candidateKeys self.selectionKeyComboBox.stringValue = PrefMgr.shared.candidateKeys
} }

View File

@ -51,12 +51,11 @@
"\"%@\" already exists:\n ENTER to boost, SHIFT+COMMAND+ENTER to nerf, \n BackSpace or Delete key to exclude." = "\"%@\" already exists:\n ENTER to boost, SHIFT+COMMAND+ENTER to nerf, \n BackSpace or Delete key to exclude."; "\"%@\" already exists:\n ENTER to boost, SHIFT+COMMAND+ENTER to nerf, \n BackSpace or Delete key to exclude." = "\"%@\" already exists:\n ENTER to boost, SHIFT+COMMAND+ENTER to nerf, \n BackSpace or Delete key to exclude.";
"Edit Phrase Replacement Table…" = "Edit Phrase Replacement Table…"; "Edit Phrase Replacement Table…" = "Edit Phrase Replacement Table…";
"Use Phrase Replacement" = "Use Phrase Replacement"; "Use Phrase Replacement" = "Use Phrase Replacement";
"Candidates keys cannot be empty." = "Candidates keys cannot be empty.";
"Candidate keys can only contain ASCII characters like alphanumericals." = "Candidate keys can only contain ASCII characters like alphanumericals."; "Candidate keys can only contain ASCII characters like alphanumericals." = "Candidate keys can only contain ASCII characters like alphanumericals.";
"Candidate keys cannot contain space." = "Candidate keys cannot contain space."; "Candidate keys cannot contain space." = "Candidate keys cannot contain space.";
"There should not be duplicated keys." = "There should not be duplicated keys."; "There should not be duplicated keys." = "There should not be duplicated keys.";
"Please specify at least 4 candidate keys." = "Please specify at least 4 candidate keys."; "Please specify at least 6 candidate keys." = "Please specify at least 6 candidate keys.";
"Maximum 15 candidate keys allowed." = "Maximum 15 candidate keys allowed."; "Maximum 9 candidate keys allowed." = "Maximum 9 candidate keys allowed.";
"⚠︎ Phrase replacement mode enabled, interfering user phrase entry." = "⚠︎ Phrase replacement mode enabled, interfering user phrase entry."; "⚠︎ Phrase replacement mode enabled, interfering user phrase entry." = "⚠︎ Phrase replacement mode enabled, interfering user phrase entry.";
"⚠︎ Unhandlable: Chars and Readings in buffer doesn't match." = "⚠︎ Unhandlable: Chars and Readings in buffer doesn't match."; "⚠︎ Unhandlable: Chars and Readings in buffer doesn't match." = "⚠︎ Unhandlable: Chars and Readings in buffer doesn't match.";
"Per-Char Select Mode" = "Per-Char Select Mode"; "Per-Char Select Mode" = "Per-Char Select Mode";

View File

@ -51,12 +51,11 @@
"\"%@\" already exists:\n ENTER to boost, SHIFT+COMMAND+ENTER to nerf, \n BackSpace or Delete key to exclude." = "\"%@\" already exists:\n ENTER to boost, SHIFT+COMMAND+ENTER to nerf, \n BackSpace or Delete key to exclude."; "\"%@\" already exists:\n ENTER to boost, SHIFT+COMMAND+ENTER to nerf, \n BackSpace or Delete key to exclude." = "\"%@\" already exists:\n ENTER to boost, SHIFT+COMMAND+ENTER to nerf, \n BackSpace or Delete key to exclude.";
"Edit Phrase Replacement Table…" = "Edit Phrase Replacement Table…"; "Edit Phrase Replacement Table…" = "Edit Phrase Replacement Table…";
"Use Phrase Replacement" = "Use Phrase Replacement"; "Use Phrase Replacement" = "Use Phrase Replacement";
"Candidates keys cannot be empty." = "Candidates keys cannot be empty.";
"Candidate keys can only contain ASCII characters like alphanumericals." = "Candidate keys can only contain ASCII characters like alphanumericals."; "Candidate keys can only contain ASCII characters like alphanumericals." = "Candidate keys can only contain ASCII characters like alphanumericals.";
"Candidate keys cannot contain space." = "Candidate keys cannot contain space."; "Candidate keys cannot contain space." = "Candidate keys cannot contain space.";
"There should not be duplicated keys." = "There should not be duplicated keys."; "There should not be duplicated keys." = "There should not be duplicated keys.";
"Please specify at least 4 candidate keys." = "Please specify at least 4 candidate keys."; "Please specify at least 6 candidate keys." = "Please specify at least 6 candidate keys.";
"Maximum 15 candidate keys allowed." = "Maximum 15 candidate keys allowed."; "Maximum 9 candidate keys allowed." = "Maximum 9 candidate keys allowed.";
"⚠︎ Phrase replacement mode enabled, interfering user phrase entry." = "⚠︎ Phrase replacement mode enabled, interfering user phrase entry."; "⚠︎ Phrase replacement mode enabled, interfering user phrase entry." = "⚠︎ Phrase replacement mode enabled, interfering user phrase entry.";
"⚠︎ Unhandlable: Chars and Readings in buffer doesn't match." = "⚠︎ Unhandlable: Chars and Readings in buffer doesn't match."; "⚠︎ Unhandlable: Chars and Readings in buffer doesn't match." = "⚠︎ Unhandlable: Chars and Readings in buffer doesn't match.";
"Per-Char Select Mode" = "Per-Char Select Mode"; "Per-Char Select Mode" = "Per-Char Select Mode";

View File

@ -51,12 +51,11 @@
"\"%@\" already exists:\n ENTER to boost, SHIFT+COMMAND+ENTER to nerf, \n BackSpace or Delete key to exclude." = "「%@」は既存語彙:\n ENTER で最優先にし、SHIFT+COMMAND+ENTER で優先順位を下げる;\n BackSpace 或いは Delete で排除。"; "\"%@\" already exists:\n ENTER to boost, SHIFT+COMMAND+ENTER to nerf, \n BackSpace or Delete key to exclude." = "「%@」は既存語彙:\n ENTER で最優先にし、SHIFT+COMMAND+ENTER で優先順位を下げる;\n BackSpace 或いは Delete で排除。";
"Edit Phrase Replacement Table…" = "言葉置換表を編集…"; "Edit Phrase Replacement Table…" = "言葉置換表を編集…";
"Use Phrase Replacement" = "言葉置換機能"; "Use Phrase Replacement" = "言葉置換機能";
"Candidates keys cannot be empty." = "言選り用キー陣列に何かキーをご登録ください。";
"Candidate keys can only contain ASCII characters like alphanumericals." = "言選り用キー陣列にはASCII文字だけをご登録ください英数など。"; "Candidate keys can only contain ASCII characters like alphanumericals." = "言選り用キー陣列にはASCII文字だけをご登録ください英数など。";
"Candidate keys cannot contain space." = "言選り用キー陣列にスペースキーは登録できません。"; "Candidate keys cannot contain space." = "言選り用キー陣列にスペースキーは登録できません。";
"There should not be duplicated keys." = "言選り用キー陣列に同じキーの重複登録はできません。"; "There should not be duplicated keys." = "言選り用キー陣列に同じキーの重複登録はできません。";
"Please specify at least 4 candidate keys." = "言選り用キー陣列に少なくとも4つのキーをご登録ください。"; "Please specify at least 6 candidate keys." = "言選り用キー陣列に少なくとも6つのキーをご登録ください。";
"Maximum 15 candidate keys allowed." = "言選り用キー陣列には最多15つキー登録できます。"; "Maximum 9 candidate keys allowed." = "言選り用キー陣列には最多9つキー登録できます。";
"⚠︎ Phrase replacement mode enabled, interfering user phrase entry." = "⚠︎ 言葉置換機能稼働中、新添付言葉にも影響。"; "⚠︎ Phrase replacement mode enabled, interfering user phrase entry." = "⚠︎ 言葉置換機能稼働中、新添付言葉にも影響。";
"⚠︎ Unhandlable: Chars and Readings in buffer doesn't match." = "⚠︎ 対処不可:緩衝列の字数は読みの数と不同等。"; "⚠︎ Unhandlable: Chars and Readings in buffer doesn't match." = "⚠︎ 対処不可:緩衝列の字数は読みの数と不同等。";
"Per-Char Select Mode" = "全候補入力モード"; "Per-Char Select Mode" = "全候補入力モード";

View File

@ -51,12 +51,11 @@
"\"%@\" already exists:\n ENTER to boost, SHIFT+COMMAND+ENTER to nerf, \n BackSpace or Delete key to exclude." = "「%@」已存在:\n 敲 Enter 以升权、敲 Shift+Command+Enter 以降权;\n 敲 BackSpace 或 Delete 以排除。"; "\"%@\" already exists:\n ENTER to boost, SHIFT+COMMAND+ENTER to nerf, \n BackSpace or Delete key to exclude." = "「%@」已存在:\n 敲 Enter 以升权、敲 Shift+Command+Enter 以降权;\n 敲 BackSpace 或 Delete 以排除。";
"Edit Phrase Replacement Table…" = "编辑语汇置换表…"; "Edit Phrase Replacement Table…" = "编辑语汇置换表…";
"Use Phrase Replacement" = "使用语汇置换"; "Use Phrase Replacement" = "使用语汇置换";
"Candidates keys cannot be empty." = "您必须指定选字键。";
"Candidate keys can only contain ASCII characters like alphanumericals." = "选字键只能是英数等 ASCII 字符。"; "Candidate keys can only contain ASCII characters like alphanumericals." = "选字键只能是英数等 ASCII 字符。";
"Candidate keys cannot contain space." = "选字键不得包含空格。"; "Candidate keys cannot contain space." = "选字键不得包含空格。";
"There should not be duplicated keys." = "选字键不得重复。"; "There should not be duplicated keys." = "选字键不得重复。";
"Please specify at least 4 candidate keys." = "请至少指定四个选字键。"; "Please specify at least 6 candidate keys." = "请至少指定 6 个选字键。";
"Maximum 15 candidate keys allowed." = "选字键最多只能指定十五个。"; "Maximum 9 candidate keys allowed." = "选字键最多只能指定 9 个。";
"⚠︎ Phrase replacement mode enabled, interfering user phrase entry." = "⚠︎ 语汇置换功能已启用,会波及语汇自订。"; "⚠︎ Phrase replacement mode enabled, interfering user phrase entry." = "⚠︎ 语汇置换功能已启用,会波及语汇自订。";
"⚠︎ Unhandlable: Chars and Readings in buffer doesn't match." = "⚠︎ 无法处理:组字区字数与读音数不对应。"; "⚠︎ Unhandlable: Chars and Readings in buffer doesn't match." = "⚠︎ 无法处理:组字区字数与读音数不对应。";
"Per-Char Select Mode" = "模拟逐字选字输入"; "Per-Char Select Mode" = "模拟逐字选字输入";

View File

@ -51,12 +51,11 @@
"\"%@\" already exists:\n ENTER to boost, SHIFT+COMMAND+ENTER to nerf, \n BackSpace or Delete key to exclude." = "「%@」已存在:\n 敲 Enter 以升權、敲 Shift+Command+Enter 以降權;\n 敲 BackSpace 或 Delete 以排除。"; "\"%@\" already exists:\n ENTER to boost, SHIFT+COMMAND+ENTER to nerf, \n BackSpace or Delete key to exclude." = "「%@」已存在:\n 敲 Enter 以升權、敲 Shift+Command+Enter 以降權;\n 敲 BackSpace 或 Delete 以排除。";
"Edit Phrase Replacement Table…" = "編輯語彙置換表…"; "Edit Phrase Replacement Table…" = "編輯語彙置換表…";
"Use Phrase Replacement" = "使用語彙置換"; "Use Phrase Replacement" = "使用語彙置換";
"Candidates keys cannot be empty." = "您必須指定選字鍵。";
"Candidate keys can only contain ASCII characters like alphanumericals." = "選字鍵只能是英數等 ASCII 字符。"; "Candidate keys can only contain ASCII characters like alphanumericals." = "選字鍵只能是英數等 ASCII 字符。";
"Candidate keys cannot contain space." = "選字鍵不得包含空格。"; "Candidate keys cannot contain space." = "選字鍵不得包含空格。";
"There should not be duplicated keys." = "選字鍵不得重複。"; "There should not be duplicated keys." = "選字鍵不得重複。";
"Please specify at least 4 candidate keys." = "請至少指定四個選字鍵。"; "Please specify at least 6 candidate keys." = "請至少指定 6 個選字鍵。";
"Maximum 15 candidate keys allowed." = "選字鍵最多只能指定十五個。"; "Maximum 9 candidate keys allowed." = "選字鍵最多只能指定 9 個。";
"⚠︎ Phrase replacement mode enabled, interfering user phrase entry." = "⚠︎ 語彙置換功能已啟用,會波及語彙自訂。"; "⚠︎ Phrase replacement mode enabled, interfering user phrase entry." = "⚠︎ 語彙置換功能已啟用,會波及語彙自訂。";
"⚠︎ Unhandlable: Chars and Readings in buffer doesn't match." = "⚠︎ 無法處理:組字區字數與讀音數不對應。"; "⚠︎ Unhandlable: Chars and Readings in buffer doesn't match." = "⚠︎ 無法處理:組字區字數與讀音數不對應。";
"Per-Char Select Mode" = "模擬逐字選字輸入"; "Per-Char Select Mode" = "模擬逐字選字輸入";