squirrel输入法是一个比较极客范的输入法,定制化与可玩性非常高, 由此带来的配置就比较复杂,而且没有界面,所以把常用配置记录下来方便直接使用。

squirrel目前的优势:

  • 配置相当丰富, 可定制性高
  • 输入速度快,兼容性好,兼容的系统版本非常多
  • 五笔支持的非常好
  • 不收集用户数据,这是我最看重的。

安装

稳定版下载

官方最近终于更新版本,之前一直14年版本,有点太老了。官方已经更新到0.14.0 (2019-06-23), 可以直接官方下载安装。

最新版本下载

如果想尝试最新功能,可以下载squirrel测试版本 https://bintray.com/rime/squirrel/testing/0.14.0%2Bgit08ed4f4。最近新加了vim_mode功能,我就下载了最新版本。

编译安装

想自己修改一些功能的,或者使用最最新的功能,可以自己编译安装。具体的编译方法如下:

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
#安装Xcode的工具,运行下面的命令

xcode-select --install

# 使用 [Homebrew](http://brew.sh/)安装相差依赖库:
# dev tools:
brew install cmake
brew install git
# libraries:
brew install boost

#下载源代码
git clone --recursive https://github.com/rime/squirrel.git

cd squirrel

#编译依赖库
make deps

#编译squirrel
make

#安装squirrel
sudo make install

配置

目前要定制化自己的特殊配置,都要以.custom.yaml结尾,这样在输入法升级或者重新部署的时候都不会直接覆盖这些文件。 这些配置文件里面都要以patch开头,以打补丁的方式来实现个性化定制。

  • squirrel.custom.yaml: 自定义皮肤, 鼠须管外观,地 ascii 模式;
  • default.custom.yaml: 设定备选词数量,定义输入方案, 快捷键的设置;
  • luna_pinyin_simp.custom.yaml: 定义扩充词库,加载符号库、模糊拼音;
  • wubi_pinyin.custom.yaml: 定义扩充词库、加载符号库;
  • installation.yaml: 同步和备份

squirrel设置

界面的配置squirrel.custom.yaml, 目前主要设置了通知方式、皮肤和某些app的默认输入方式。

这里要说一下vim_mode, 在使用vim快捷方式app中有用,按esc键会自动把中文模式切换成英文模式,而不用先按shift切换英文再按esc.

 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
patch:
  show_notifications_when: appropriate # 状态通知,适当,也可设为全开(always)全关(never)
  style:
    color_scheme: psionics
    horizontal: true                                   # 水平排列
    inline_preedit: true                               # 单行显示,false双行显示
    candidate_format: "%c\u2005%@ \u2005 \u2005"       # 用 1/6 em 空格 U+2005 来控制编号 %c 和候选词 %@ 前后的空间。
    corner_radius: 5                                   # 候选条圆角
    border_height: 6                                   # 窗口边界高度,大于圆角半径才生效
    border_width: 6                                    # 窗口边界宽度,大于圆角半径才生效
    font_face: "PingFangSC-Regular,HanaMinB"           # 候选词字体
    font_point: 18                                     # 候选字词大小
    label_font_face: "STHeitiSC-Light"                 # 候选词编号字体
    label_font_point: 16                               # 候选编号大小

  # 默认使用ascii输入,不用中文输入
  # app的名字可以在/Applications/的app目录中的Info.plist里面查找
  app_options:
    com.apple.dt.Xcode:
      ascii_mode: true
    com.runningwithcrayons.Alfred:
      ascii_mode: true
    com.googlecode.iterm2:
      ascii_mode: true
      vim_mode: true                                   # vim mode, 按esc键会自动切换成英文
    com.microsoft.VSCode:
      ascii_mode: true
      vim_mode: true
    com.apple.finder:
      ascii_mode: true
    com.apple.appstore:
      ascii_mode: true
    com.apple.systempreferences:
      ascii_mode: true
    com.apple.keychainaccess:
      ascii_mode: true
    # com.apple.Safari:
    #   ascii_mode: true

  us_keyboard_layout: true

效果如下:

界面

全局配置

配置文件为default.custom.yaml。 全局配置里面,可以定义输入方案、候选词数量和快捷键的设置。

  • 输入方案: 朙月拼音简化字和五笔拼音混合输入;
  • 候选词的个数设置为6个;
  • 候选词换页的按键修改为方括号;
  • 使用;和’来选择第二和三个候选词;
  • 修改shift_L为切所中英文(个人习惯);

default.custom.yaml具体配置如下

 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
patch:
  menu:
    page_size: 6 # 候选词的个数
  schema_list:
    - schema: wubi_pinyin           # 五笔拼音混合輸入
    - schema: luna_pinyin_simp      # 朙月拼音 简化字

  key_binder/bindings:
    - when: paging # [ -> 上一页
      accept: bracketleft
      send: Page_Up
    - when: has_menu # ] -> 下一页
      accept: bracketright
      send: Page_Down
    - when: has_menu # 按;选择第二个候选词
      accept: semicolon
      send: 2
    - when: has_menu # 按'选择第三个候选词
      accept: apostrophe
      send: 3

  ascii_composer/switch_key:
    Caps_Lock: noop
    Control_L: noop
    Control_R: noop
    Eisu_toggle: clear
    # 按下左 shift 英文字符直接上屏,不需要再次回车,输入法保持英文状态
    Shift_L: commit_code
    shift_R: noop

五笔配置

配置文件为wubi_pinyin.custom.yaml, 主要定义五笔输入法里面的操作,字符串。

 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
# Rime schema settings
# encoding: utf-8

patch:
  switches:
    - name: ascii_mode
      reset: 0
      states: ["中文", "西文"]
    - name: full_shape
      states: ["半角", "全角"]
    - name: simplification
      reset: 0
      states: ["汉字", "漢字"]
    - name: show_emoji
      reset: 1
      states: [ "🈚️️\uFE0E", "🈶️️\uFE0F" ]

  simplifier:
      opencc_config: s2t.json  # 简入繁出

  engine/filters:
    - simplifier
    - uniquifier
    - [email protected]_conversion

  emoji_conversion:
    opencc_config: emoji.json
    option_name: show_emoji
    tags: abc


  "speller/max_code_length": 4 #最长4码
  "speller/auto_select": true #顶字上屏
  "speller/auto_select_unique_candidate": true #无重码自动上屏

  "translator/dictionary": wubi86 #加载五笔词库
  "reverse_lookup/comment_format/@1": xform/^(\w+).*/$1/

#  符号快速输入和部分符号的快速上屏
  punctuator:
    import_preset: symbols
    symbols:
      "/fs": [½, , ¼, , , ¾,  ]
      "/bq": [😂️, 😅️, ☺️, 😱️, 😭️, 😇️, 🙃️, 🤔️, 💊️, 💯️, 👍️, 🙈️, 💩️, 😈️ ]
      "/dn": [, , , , , , , , , ↩︎, , , , , , , , , ]
      "/fh": [ ©, ®, , , , , , , , , , , , , , ☑︎, , , , , , , , , , , , ]
      "/xh": [ , ×, , , , , , , , , , , , ]
    half_shape:
      "#": "#"
      "*": "*"
      "`": "`"
      "~": "~"
      "@": "@"
      "=": "="
      "/": ["/", "÷"]
      '\': "、"
      "_" : "──"
      "'": {pair: ["", ""]}
      "[": ["", "["]
      "]": ["", "]"]
      "$": ["¥", "$", "", "£", "¢", "¤"]
      "<": ["", "", "«", "<"]
      ">": ["", "", "»", ">"]
  recognizer/patterns/punct: "^/([a-z]+|[0-9]0?)$"

  # 使用自定义词典 custom_phrase.txt
  custom_phrase:
    dictionary: ""
    user_dict: custom_phrase
    db_class: stabledb
    enable_completion: false
    enable_sentence: false
    initial_quality: 1
  "engine/translators/@4": [email protected]_phrase

拼音配置

配置文件为luna_pinyin.custom.yaml.

  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
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
# luna_pinyin.custom.yaml
#
# 補靪功能:將朙月拼音的詞庫修改爲朙月拼音擴充詞庫
#
# 作者:瑾昀 <[email protected]>
#
# 部署位置:
# ~/.config/ibus/rime  (Linux)
# ~/Library/Rime  (Mac OS)
# %APPDATA%\Rime  (Windows)
#
# 於重新部署後生效
#
#
# 注意:本補靪適用於所有朙月拼音系列方案(「朙月拼音」、「朙月拼音·简化字」、「朙月拼音·臺灣正體」、「朙月拼音·語句流」)。
# 只須將本 custom.yaml 的前面名字改爲對應的輸入方案名字然後放入用戶文件夾重新部署即可。如 luna_pinyin_simp.custom.yaml。
# 雙拼用戶請使用 double_pinyin.custom.yaml。
#
#
# 附朙月拼音系列方案與其對應的 id 一覽表:
# 輸入方案	id
# 朙月拼音	luna_pinyin
# 朙月拼音·简化字	luna_pinyin_simp
# 朙月拼音·臺灣正體	luna_pinyin_tw
# 朙月拼音·語句流	luna_pinyin_fluency
#

patch:
  switches:
    - name: ascii_mode
      reset: 0
      states: ["中文", "西文"]
    - name: full_shape
      states: ["半角", "全角"]
    - name: simplification
      reset: 0
      states: [ "漢字", "汉字" ]


    
 #  加載 easy_en 依賴
  "schema/dependencies/@1": easy_en
  # 載入翻譯英文的碼表翻譯器,取名爲 english〔方案选单〕
  "engine/translators/@4": [email protected]
  # english 翻譯器的設定項
  english:
    dictionary: easy_en
    spelling_hints: 9
    enable_completion: false
    enable_sentence: false
    initial_quality: -2

 #  載入朙月拼音擴充詞庫
  "translator/dictionary": luna_pinyin.extended
  # 改寫拼寫運算,使得含西文的詞彙(位於 luna_pinyin.cn_en.dict.yaml 中)不影響簡拼功能(注意,此功能只適用於朙月拼音系列方案,不適用於各類雙拼方案)
  # 本條補靪只在「小狼毫 0.9.30」、「鼠鬚管 0.9.25 」、「Rime-1.2」及更高的版本中起作用。
  "speller/algebra/@before 0": xform/^([b-df-hj-np-tv-z])$/$1_/


 #  符号快速输入和部分符号的快速上屏
  punctuator:
    import_preset: symbols
    symbols:
      "/fs": [½, , ¼, , , ¾,  ]
      "/bq": [😂️, 😅️, ☺️, 😱️, 😭️, 😇️, 🙃️, 🤔️, 💊️, 💯️, 👍️, 🙈️, 💩️, 😈️ ]
      "/dn": [, , , , , , , , , ↩︎, , , , , , , , , ]
      "/fh": [ ©, ®, , , , , , , , , , , , , , ☑︎, , , , , , , , , , , , ]
      "/xh": [ , ×, , , , , , , , , , , , ]
    half_shape:
      "#": "#"
      "*": "*"
      "`": "`"
      "~": "~"
      "@": "@"
      "=": "="
      "/": ["/", "÷"]
      '\': "、"
      "_" : "──"
      "'": {pair: ["", ""]}
      "[": ["", "["]
      "]": ["", "]"]
      "$": ["¥", "$", "", "£", "¢", "¤"]
      "<": ["", "", "«", "<"]
      ">": ["", "", "»", ">"]
  recognizer/patterns/punct: "^/([a-z]+|[0-9]0?)$"
  
 # 模糊拼音
  'speller/algebra':
    - erase/^xx$/                      # 第一行保留

    # 模糊音定義
    # 需要哪組就刪去行首的 # 號,單雙向任選
    #- derive/^([zcs])h/$1/             # zh, ch, sh => z, c, s
    #- derive/^([zcs])([^h])/$1h$2/     # z, c, s => zh, ch, sh

    #- derive/^n/l/                     # n => l
    #- derive/^l/n/                     # l => n

    # 這兩組一般是單向的
    #- derive/^r/l/                     # r => l

    #- derive/^ren/yin/                 # ren => yin, reng => ying
    #- derive/^r/y/                     # r => y

    # 下面 hu <=> f 這組寫法複雜一些,分情況討論
    #- derive/^hu$/fu/                  # hu => fu
    #- derive/^hong$/feng/              # hong => feng
    #- derive/^hu([in])$/fe$1/          # hui => fei, hun => fen
    #- derive/^hu([ao])/f$1/            # hua => fa, ...

    #- derive/^fu$/hu/                  # fu => hu
    #- derive/^feng$/hong/              # feng => hong
    #- derive/^fe([in])$/hu$1/          # fei => hui, fen => hun
    #- derive/^f([ao])/hu$1/            # fa => hua, ...

    # 韻母部份
    #- derive/^([bpmf])eng$/$1ong/      # meng = mong, ...
    #- derive/([ei])n$/$1ng/            # en => eng, in => ing
    #- derive/([ei])ng$/$1n/            # eng => en, ing => in

    # 樣例足夠了,其他請自己總結……

    # 模糊音定義先於簡拼定義,方可令簡拼支持以上模糊音
    #- abbrev/^([a-z]).+$/$1/           # 簡拼(首字母)
    #- abbrev/^([zcs]h).+$/$1/          # 簡拼(zh, ch, sh)

    # 以下是一組容錯拼寫,《漢語拼音》方案以前者爲正
    - derive/^([nl])ve$/$1ue/          # nve = nue, lve = lue
    - derive/^([jqxy])u/$1v/           # ju = jv,
    - derive/un$/uen/                  # gun = guen,
    - derive/ui$/uei/                  # gui = guei,
    - derive/iu$/iou/                  # jiu = jiou,

    # 自動糾正一些常見的按鍵錯誤
    - derive/([aeiou])ng$/$1gn/        # dagn => dang 
    - derive/([dtngkhrzcs])o(u|ng)$/$1o/  # zho => zhong|zhou
    - derive/ong$/on/                  # zhonguo => zhong guo
    - derive/ao$/oa/                   # hoa => hao
    - derive/([iu])a(o|ng?)$/a$1$2/    # tain => tian

  # 分尖團後 v => ü 的改寫條件也要相應地擴充:
  #'translator/preedit_format':
  #  - "xform/([nljqxyzcs])v/$1ü/"

快速配置

  1. 打开用户设定, 找到用户配置文件夹。

    config

  2. 将之前的用户配置删除,然后将github的配置下载到用户配置文件夹中。

  3. 重新加载就大功告成了。

    reset

参考

  1. How to Rime with Squirrel
  2. 「鼠须管」的调教笔记
  3. 我的鼠须管配置
  4. 安装及配置 Mac 上的 Rime 输入法——鼠鬚管 (Squirrel)
  5. RimeWithSchemata
  6. 鼠须管输入法的新配色
  7. 致第一次安装RIME的你