Linux上手动编译安装librime、librime-lua以及ibus-rime

本文最后更新于 2024年9月28日 下午

Linux上的输入法有很多,大体都使用了Fcitx或者iBus作为输入法的引擎。相当于有了一个很不错的“地基”,你可以在这个“地基”上盖上自己的“小别墅”。而rime输入法,就是一个“毛坯别墅”,你可以在rime的基础上,再装修,打造自己的住所。

现在的问题是,使用Linux软件包自带的iBus(很多Linux发行版本,默认使用iBus输入法引擎)和ibus-rime,其内部的librime(ibus-rime的核心,也是rime的核心算法)版本比较低,需要我们手动编译才可以使用rime的完整功能

本篇文章就给大家演示,如何在Linux(Debian、Ubuntu发行版本)上,如何手动编译librime、librime-lua以及ibus-rime。

ibus-rime

ibus-rime 是一个基于 Rime 输入法引擎的iBus后端模块,用于在使用iBus框架的Linux发行版中提供中文输入支持。

理论上,我们安装ibus-rime只需要:

1
2
3
4
# 更新软件包管理器
sudo apt update
# 安装ibus-rime
sudo apt install ibus-rime

之后,重启用户界面(你可以注销当前桌面环境并重新登录系统桌面),你就可以在系统的设置内添加ibus-rime:
在Kali上安装ibus-rime后,GNOME内添加输入

但是,有一个小问题,部分软件包管理器内ibus-rime使用的librime,也就是rime核心算法库,使用的版本过于老旧(1.8.5左右),性能问题不好说,一些rime的新特性就无法使用;

比如薄荷输入法配置,引入Lua脚本就是使用高版本librime新特性,如果librime版本过低,就无法发挥薄荷输入法配置的全部功能,甚至无法使用

1
2
# 查找系统自带的librime版本
find /usr/lib /usr/local/lib /opt -name "librime.so*"

librime的版本是1.8.5

那么,如果librime版本不够,导致ibus-rime无法使用rime的新特性,如何解决呢? 方法很多,比如:

  • fcitx5版本(Flatpak): 基于Flatpak下载并使用Fcitx5(软件包管理器的Fcitx5-rime可能也使用低版本librime和librime-lua)
  • ibus-rime.AppImage: AppImage 格式的中州韵输入法(ibus-rime)的打包方案;目前不支持arm架构。

总的来说,方法还是很多的,这里提供手动编译的方法,方便依旧想使用ibus-rime的用户,或者使用ARM设备的Linux用户安装。

环境准备

首先,我们看看环境准备,主要分为卸载旧依赖安装编译依赖两个部分。

卸载旧依赖

卸载旧版本的ibus-rime;同时,因为我们需要从源码编译,而它依赖于librime和plum两个部分,所以我们也需要卸载这两个的相关软件包:

1
2
3
4
# 卸载ibus-rime
sudo apt purge ibus-rime
# 卸载librime有关依赖
sudo apt purge librime*

如果你之前就没有安装过ibus-rime,那么这一步就不需要执行了。但是我相信,你都看到这个教程了,十有八九是有安装😏。

卸载相关旧的依赖

安装编译依赖

首先根据官方文档:

特别注意,我们需要:

  • cmake>=3.25: 虽然官方的CMakeLists.txt内描述cmake的最低版本只需要3.12,但是根据issue #856描述,最好需要cmake>=3.25
  • git: 后续我们需要使用git来同步源代码来进行编译。

综上,我们安装依赖:

1
2
3
4
# 安装cmake和gcc
sudo apt install build-essential cmake
# 安装其他编译依赖
sudo apt install libboost-all-dev libgoogle-glog-dev libgtest-dev libyaml-cpp-dev libleveldb-dev libmarisa-dev libz-dev libopencc-dev libibus-1.0-dev libnotify-dev

可以检查一下cmake的版本:

1
cmake --version

检查cmake的版本

如果cmake的版本过低,可以在cmake项目官网安装高版本的cmake,比如:

1
2
3
4
5
6
7
8
# 切换工作路径
cd /opt
# 下载cmake二进制文件
wget https://github.com/Kitware/CMake/releases/download/v3.30.0/cmake-3.30.0-linux-aarch64.sh
# 在此目录安装
bash cmake-3.30.0-linux-aarch64.sh
# 软链接到/usr/local/bin
ln -s /opt/cmake/bin/cmake /usr/local/bin/cmake

到此,我们的前期准备就完成了。

支持创作

制作教程不易,如果热心的小伙伴,想支持创作,可以加入我们的电圈(还可以解锁远程协助、好友位😃):

WebChart Recognise

当然,也欢迎在B站或YouTube上关注我们:

更多:

ibus-rime源码

需要编译安装ibus-rime,那么首先第一步就是获取项目的源代码了,ibus-rime的源代码就在GitHub上,目前隶属于rime项目内,我们克隆源代码:

1
git clone https://github.com/rime/ibus-rime.git

ibus-rime的编译需要依赖与两个外部库:

  • librime: librime的算法核心,还可以加上librime-lua插件,使其支持lua语法插件,进一步扩展rime。
  • plum: 东风破,相当于rime的软件包管理器,ibus-rime的编译安装过程中,需要使用东风破进行数据初始化。

ibus-rime已经做了仓库的关联:

.gitmodules
1
2
3
4
5
6
[submodule "librime"]
path = librime
url = https://github.com/rime/librime.git
[submodule "plum"]
path = plum
url = https://github.com/rime/plum.git

所以,我们直接使用git submodule update --init进一步克隆子仓库即可:

克隆子仓库并切换目录

如果你没什么网络问题,通常情况还是很顺利的。接下来,我们需要分别先编译librimeplum

librime

注意切换Terminal的工作目录到刚刚ibus-rime初始化后,librime目录内。

编译librime其实很简单,但是ibus-rime默认情况使用的librime分支,或许不是最新。我们这里可以使用git checkout命令切换一下:

1
git checkout master

切换分支

同时需要注意:默认情况下,如果需要Lua的支持,那么需要融合librime-lua插件。

薄荷输入法配置、雾凇拼音配置等等rime配置,有大量使用Lua扩展的功能,所以我们这个librime-lua插件是肯定要安装的啦。

librime-lua

根据项目地址:

我们在librime源码内,使用自带的插件安装脚本,执行:

1
2
# 自动下载librime插件
bash install-plugins.sh hchunhui/librime-lua

自动下载librime-lua插件

合并插件

在下载librime-lua后,我们合并插件内容进入librime:

1
make merged-plugins

如果编译不加以限制,可能会导致内存占用过高导致编译卡死,甚至系统卡死。

内存占用过高而被killed

所以,建议大家根据自己系统的核心数,限制编译的进程(线程)编译:

1
2
# 使用两个进程进行编译
make merged-plugins -j2

限制线程编译

合并插件完成

编译安装

最后,我们完成最后的编译安装即可:

1
2
3
4
# 编译
make
# 安装
sudo make install

同样,建议可以使用-j限制编译的进程数量哦。

编译安装开始

编译安装完成

plum

注意切换Terminal的工作目录到刚刚ibus-rime初始化后,plum目录内。

切换工作目录到plum源码目录

plum的编译比较简单了。你只需要:

1
2
# 编译并安装
make && sudo make install

编译plum

安装plum

编译ibus-rime

前期的准备都完成了。接下来终于可以回到ibus-rime了。编译的过程很简单,和plum差不多:

1
2
3
4
# 编译
make
# 安装
sudo make install

同样,建议可以使用-j限制编译的进程数量哦。

编译安装ibus-rime完成

使用ibus-rime

ibus-rime编译安装好后,你可能无法在Gnome桌面的设置内,添加Rime引擎;这个时候你可以注销桌面环境,重新登录。通常情况就没什么问题了

在Gnome内添加rime

之后就可以使用了。

Opt:plum安装薄荷

上文我们已经编译安装了ibus-rime,接下来我们就使用薄荷输入法配置来快速初始化rime。

方法很多,比如常规的方法就是下载薄荷输入的配置,导入ibus-rime的配置文件目录内,重新部署即可。使用plum安装薄荷配置,只需要一条命令:

1
rime-install Mintimate/oh-my-rime:plum/full

每一次都是全量更新替换,这样的更新配置方便很多。而且都是同名文件替换,意味着如果你使用custom文件覆写薄荷输入法配置,那么自定义的配置会被保留下来。

我之前在薄荷输入法文档内已经做了详细介绍。本章节就来点不一样的,使用plum安装薄荷输入配置。

plum的原理,实际上就是根据方案的配置处方文件,对方案内部的文件进行“抓药”。比如薄荷的全量处方

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
# encoding: utf-8
---
recipe:
Rx: plum/full
args:
description: >-
全量安装、更新
install_files: >-
dicts/*.*
opencc/*.*
lua/*.*
lua/aux_code/*.*
default.yaml
squirrel.yaml
weasel.yaml
ibus_rime.yaml
rime_mint*.yaml
double_pinyin*.schema.yaml
t9.schema.yaml
terra*.yaml
stroke*.yaml
wubi86*.yaml
wubi98*.yaml
symbols.yaml
radical*.yaml
melt_eng*.yaml

plum操作解析:

  • plum使用git对薄荷的仓库进行克隆;
  • 检录出薄荷仓库,读取plum/full.recipe.yaml
  • 根据内部配置进行文件部署和覆盖,比如dicts/*.*,就是把dicts文件内部所有文件部署到本地rime配置目录;terra*.yaml就是把仓库根目录内terra开头和.yaml结尾的文件拷贝到本地rime配置目录。

那么,我们这次编译应该如何使用呢? 还记得我们刚刚是有编译plum的,只需要再次cd到plum目录内:
再次进入plum的目录内

可以看到,二进制文件rime-install,我们就使用二进制配置薄荷输入法方案:

1
./rime-install Mintimate/oh-my-rime:plum/full

默认情况,plum下载的配置文件:

  • 如果系统是Windows,那么默认配置到小狼毫的配置目录内;
  • 如果系统是macOS,那么默认配置到鼠须个人的配置目录内,即$HOME/Library/Rime内。
  • 如果系统是Linux,那么默认配置到ibus的配置目录内,即$HOME/.config/ibus/rime内。

plum自动配置薄荷

是不是发现一个问题? 如果我的设备是使用Fcitx5,plum自动配置到默认的地址,岂不是还需要手动移动配置文件?其实plum也可以完成,只需要运行脚本时候,环境变量内声明即可:

1
2
# 提前明确rime需要配置到那个目录
rime_dir="$HOME/.local/share/fcitx5/rime" bash rime-install

END

总而言之,本文不仅提供了详细的步骤来确保ibus-rime及其核心组件得到最新升级,还强调了这一升级对于提升中文输入质量和个性化配置的重要性。通过遵循本文的指导,用户将能够充分利用Rime输入法引擎的最新特性,享受到更加流畅、高效且具有高度定制性的中文输入体验。

不知道大家在Linux上,还是使用ibus-rime作为输入方案么? 还是使用Fcitx5-rime了呢? 其实现在Fcitx5非常完善,但是我还是习惯使用ibus…… 习惯这东西,真实一个可怕的东西。不过,也可能是我的输入习惯,ibus已经完全够用,加上我平时操作Linux,大部分情况都是SSH远程登录,自然对输入法的需求比较少。

你是用什么输入法框架呢? 使用的rime输入方案又是什么呢? 是否是薄荷输入法呢?



Linux上手动编译安装librime、librime-lua以及ibus-rime
https://www.mintimate.cn/2024/07/13/rimeLinuxMakeIbus/
作者
Mintimate
发布于
2024年7月13日
许可协议