Skip to content

Latest commit

 

History

History
76 lines (58 loc) · 4.07 KB

development.md

File metadata and controls

76 lines (58 loc) · 4.07 KB

Development note

deploy process

Not automated yet. Cargo.tomlおよび.github/workflows/continuous_testing.yaml内の確認するバージョンを必要に応じて書き換え。 ChangelogのUnreleasedを新バージョンに書き替え。 これらの変更をVersion bumpとしてメインラインにmergeする。 githubでReleaseからDraft a new releaseしてvx.y.zのようなタグを作ってリリースする。 github workflowでartifactがアップロードされる。

その後cargoにもリリースするため

git checkout vx.y.z
cargo login && cargo publish --dry-run 
# 結果を見てよさそうなら 
cargo publish

という手順を踏む。

ローカルで試用する

cskkで何かを変えてIMEで確認したい時、静的リンクでない場合ビルド時と実行時両方に指定する。

fcitx5を例にすると

# cskkを別ディレクトリにインストール
cargo cinstall --prefix=/tmp/cskkdir
# fctix5-cskkでビルド時
PKG_CONFIG_PATH=/tmp/cskkdir/lib/pkgconfig cmake -B ./build && cd build && make
# fcitx5 の実行時
LD_LIBRARY_PATH=/tmp/cskkdir/lib/cskk FCITX_ADDON_DIRS=/home/naoaki/src/fcitx5-cskk/build/src:/usr/lib/x86_64-linux-gnu/fcitx5 fcitx5 --verbose=*=5 

このようにしてローカルビルドのlibcskkとfcitx5-cskkを試用できる。 ただし、XDG_BASE_DIR等の環境変数を変えない限りassets以下のrules類は通常のものを読みとる。

cskk

cskk v0.4では徐々に機能追加をしてしまったせいでprocess_key_event_innerのコメントの通り

  1. rom2kana可能? -yes-> かな入力として処理 (大文字のみcompositionmode変更コマンドとしても処理)
  2. 現在のCompositionMode内で解釈されるコマンド? -yes-> compositionmode用コマンドとして処理
  3. (delegate するタイプのinstructionだった場合) ループ
  4. rom2kana継続可能 or ascii? -yes-> 継続入力として処理
  5. rom2kana継続不可能 -all-> Flush後に入力として処理

と素の入力部分がとても散らかっている。 libskk同様に先にコマンドとして解釈しようとしたい。 inputmode+compositionmode -> Instruction 配列というのが現在の状態だが設定ファイルに書きだす? rom2kanaを一本化するためにprocess_key_event_innerを書き直す。

まずはv0.4.0のInstructionで設定ファイルにそのままおこせないものをどうするか

コマンド類

InputMode/CompositionMode以外の条件分岐があるものを変更する

Direct

  • 大文字が来た時にモード変更もInstructionで行い、キー処理を終わらないようなInstructionにしている。libskkでもNoneStateHanderで特殊処理していた。これをコマンドから外す。

Precomposition

  • Q以外の大文字が来た時に送り仮名モードへ変更を行い、キー処理を終わらないようなInstructionにしている。libskkではStartStateHandler内でコマンドでなくis_upperで特殊処理していた。これもコマンドから外す。
  • delegateが存在する。これもnext_candidateとして一括処理する?

Composition

  • delegated時のみ候補が空ならRegisterモードへ再度送っている。
  • candidate_listが正しい状態かをチェックして、candidtate_listを更新するか、次の候補へ移動するか、Registerモードへ送るかを決めている。これをnext_candidate、previous_candidateとしてハンドラ内では判断しないようにして、コマンド処理側でcandidate_listの何番目を指しているかによって動作を変える。

まず上記next/previous candidateの変更だけでリファクタリング後、Instructionの不要部分を消してからマージしたい。

bug or feature?

Shift 押しっぱなしの送り仮名

cskk current: S i N I -> ▼死に libskk: S i N I -> ▼死んい

abbrevモード不安定?

/を押してもabbrevにならない? / l e space C-g space でステートが残る?

その他

?が全角?ではなく半角になる?