全部博文(293)
分类: LINUX
2010-04-22 14:05:26
介绍一下 alternatives 命令: 这是一个只有 root 才能执行的命令。alternatives 的意思是 “可选择的内容”。假如你的系统中有几个命令功能十分类似,却又不能随意删除,那么可以用 alternatives 来指定一个全局的设置。在 FC3 中,全局默认输入法和 java 系统等等都是用它来进行设置的。它有几种功能,可以用命令行参数来指定。alternatives --install 代码: alternatives --install /etc/X11/xinit/xinput.d/zh_CN xinput-zh_CN /etc/X11/xinit/xinput.d/scim 100 alternatives --install /etc/X11/xinit/xinput.d/zh_CN xinput-zh_CN /etc/X11/xinit/xinput.d/fcitx 99 这两个命令的意思就是将刚才新建的 scim 和 fcitx 两个文件作为 zh_CN 的可选内容。它们的优先级分别是 100 和 99,它们共同的名字是 xinput-zh_CN。 另外一种功能是选择默认值。上面的命令仅仅向数据库中添加了可选内容,接下来当然是进行选择了。可以用两种办法,第一种是 alternatives --auto 代码: alternatives --auto xinput-zh_CN 会把默认输入法设置为 scim。(为什么?因为我们在上面指定的优先级是 100,是最高的,fcitx 只有 99) 第二种是 alternatives --config 代码: [root@jackycom ~]# alternatives --config xinput-zh_CN There are 3 programs which provide 'xinput-zh_CN'. Selection Command ----------------------------------------------- 1 /etc/X11/xinit/xinput.d/iiimf *+ 2 /etc/X11/xinit/xinput.d/scim 3 /etc/X11/xinit/xinput.d/fcitx Enter to keep the current selection[+], or type selection number: 可以看到系统中已经通过 alternatives --install 添加了三个可选内容。优先级最高的是 `*' 指示的那一个,目前的默认全局使用的是 `+' 指示的那一个。输入数字 3 就会将默认值改为 fcitx,输入回车的话就不做改动。 哪种好一点?它们不会冲突,哪个都可以。要修改优先级怎么办?比如要把 fcitx 的优先级提高成 101,应该怎么办?答案很简单,再运行一次 alternatives --install 就可以了 代码: alternatives --install /etc/X11/xinit/xinput.d/zh_CN xinput-zh_CN /etc/X11/xinit/xinput.d/fcitx 101 需要注意的是,这样做不会修改当前的默认值,只有再运行 alternatives --auto 才会做出选择。或者,用 alternatives --config 也可以。 alternatives 还有一些功能,包括删除一个可选项等等。同样,这个设置应该由输入法的安装程序 rpm 来做。在 scim 为 fc3 编译的 rpm 中包含了这个设置。但是如果我们手动卸载 scim/fcitx,或者要卸载原来安装的旧版本,那么需要运行下面的脚本,这个脚本是从 scim 的 rpm 中找到的 代码: #!/bin/bash # reset locale registeration. cd /etc/alternatives for name in xinput-* do if /usr/sbin/alternatives --display $name | grep "^/etc/X11/xinit/xinput.d/scim" | grep "[0-9]$" > /dev/null then /usr/sbin/alternatives --remove $name /etc/X11/xinit/xinput.d/scim /usr/sbin/alternatives --auto $name fi done 上面都是全局的设置。应该说,这些都是输入法自己的任务,虽然现在我们暂时只能手动操作。 要进行个人的设置怎么办? 最简单的应该是 gnome-im-switch applet 吧…… 在任务栏里有的 如果找不到这个 applet,那么在命令行下怎么配置呢?根据 xinput.sh 文件,它会检测 $HOME/.xinput.d/zh_CN 和 $HOME/.xinput.d/default。所以,我们这样做 代码: mkdir $HOME/.xinput.d ln -s /etc/X11/xinit/xinput.d/scim $HOME/.xinput.d/zh_CN 如果要使用 fcitx,那么就把第二句换一换就可以了。注销,重新登录,输入法设置就这么简单 如何进行简单的测试 在出现问题时,最好先对自己的系统环境、配置情况进行简单的测试和了解。这样,在论坛上提问时就会有效得多。 首先,检查系统的环境。根据上面输入法启动的过程分析,我们需要一个可执行文件,以及几个环境变量。以 fcitx 为例,我们需要的可执行文件是 fcitx, 环境变量是 LC_CTYPE=*.UTF-8/zh_CN.* , XMODIFIERS=@im=fcitx 和 GTK_IM_MODULE=xim 1. 使用 which 命令来查看 fcitx 是否已经正常安装。运行 which fcitx,如果可以运行,将会输出它的路径。如果无法运行,那么会报告找不到, no fcitx in (/usr/bin:....) 直接运行 fcitx 可能会有一些乱码。所以,不是用来检查的好方法。不过,可以临时修改终端默认编码,重新运行 fcitx 就可以看到正常的字符了,也许可以看到有用的信息。 2. 使用 locale 命令来查看当前的语言环境。如果折腾过很多关于挂载和美化方面的内容,对于这个命令一定相当熟悉了。locale 的组成包括地区/语言以及编码格式等等,例如 en_US.UTF-8 表示美国英语,UTF-8 编码,而 en_GB.ISO8859-1 是英国英语,扩展的欧洲编码。fcitx 可以应用在两类语言环境中,首先当然是中文环境,也就是说 zh_CN.* ,编码随意;其次是所有 UTF-8 编码的语言环境中,因为 UTF-8 可以对所有字符进行编码,当然可以支持中文输入了。之所以检查 LC_CTYPE 是因为它与输入法紧密相关,但是所有 LC_* 变量最好保持一致。 对于 locale 的设置最好在 $HOME/.i18n 中进行,那样是本地设置,不会影响其他用户。全局设置语言环境可以修改 /etc/sysconfig/i18n 文件。再次强调,只要是 zh_CN.*, 或者是 *.UTF-8 ,那么都可以使用中文输入法 3. 使用 export 命令来检查 XMODIFIERS 和 GTK_IM_MODULE 的值。当然,输出会比较多,看起来会有些费眼力。如果会使用 grep 命令,再用 awk -F '=' '{print }' 会得到比较明白的结果,不过学会用这些命令的代价比较高,要有十几分钟的练习 如果输出与上面 /etc/X11/xinit/xinput.d/fcitx 的文件内容相符,那么环境变量就没有问题了。 4. 如果出现了问题,那么检查一下 /etc/X11/xinit/xinput.d/fcitx 的文件内容,是否出现了 typo 拼写错误,然后运行一下 /etc/X11/xinit/xinitrc.d/xinput.sh,看看有什么输出。正常情况下,输出与直接运行输入法的可执行程序时是一样的 5. 环境变量没有问题,输入法也没有问题,手动运行 xinput.sh 也没有问题的话,仍然有可能无法自动启动输入法。这里存在一个时机的问题,也就是说,xinput.sh 应该在所有需要输入法的程序之前启动,这样所设置的变量才会产生效果。每设置一个变量,都只能对设置之后启动的程序产生影响,并且只能对在同一终端会话下启动的程序产生影响。登陆图形界面时,所有程序都属于同一个终端会话,但是先后的时机可能不同。如果在 $HOME/.bashrc 等等文件中设置输入法,或者在 KDE autostart 中设置输入法,很可能会遇到这种问题,这也是为什么反对在这些文件中进行输入法设置的原因 6. 输入法本身有问题,怎么检查呢……在终端中运行它就可以了。但是要注意,运行前一定要设置好所有变量,设置的方法仍然是 export 命令。例如,要检查 fcitx 是否运行正常,可以这样 引用: export LC_ALL=zh_CN.UTF-8 export XMODIFIERS=@im=fcitx export GTK_IM_MODULE=xim fcitx gedit 不必理会环境变量曾经是什么,把相关的环境变量全部重新设置,可以保证万无一失。运行 fcitx 之后,要记住新设置的环境变量只对当前的终端会话有效,所以要在终端下启动一个应用程序,例如这里启动了 gedit,然后我们可以验证 fcitx 是否可用 7. 如果是 acroread 或者 realplay 之类的第三方非自由软件/程序,那么可能与 scim 等等使用 gtk-immodules 的输入法发生冲突。运行这些软件时会莫名其妙地失去响应。发生这种情况时,先打开一个终端,然后在终端下启动程序,例如 realplay,看看有没有什么特别的输出,例如 segment fault 或者 double free 等等。 按照作者们的说法,是因为 c++ 的 ABI 不一致,造成了 gtk-immodules 向应用程序报告了错误的输入法位置。解决的办法只要重新编译输入法就可以了。不过更简单的办法,是修改可执行文件 /usr/bin/acroread 以及 /usr/bin/realplay ,在第二行插入一行 引用: export GTK_IM_MODULE=xim 原因同上,这时,所有在脚本中执行的命令属于同一个终端会话,因此重置环境变量之后,可以影响整个应用程序的设置,而 gtk-immodules 设置为 xim 也就是使用 XIM,这时输入法与应用程序就不直接联系了。 可能遇到的问题 1. 系统中如果已经删掉了 iiimf 那么需要手动建立 /etc/X11/xinit/xinput.d 这个目录 2. 如果想默认使用英文环境 en_US.UTF-8 但是仍然需要用中文输入法,可以像上面那样用 alternatives 对 en_US 做全局设置,也可以象个人设置中那样, 代码: ln -s /etc/X11/xinit/xinput.d/scim $HOME/.xinput.d/en_US scim 和 fcitx 都支持 en_US.UTF-8 环境, 如果要用 fcitx 就把上面的改一改就可以 不要在 .bashrc 中做有关输入法和 locale 的设置!需要的话 , 尽量在 $HOME/.i18n 中设置, 而不要修改 /etc/sysconfig/i18n 。安装输入法不需要修改 locale 设置 3. 升级的 gtk2 中可能用 gtk-query-immodules-2.0-32 取代了 gtk-query-immodules-2.0,不过这个命令应当由输入法的安装程序 rpm 来运行,不应该由用户来运行。但是如果是编译安装 scim 却没有运行它,那么就运行一次好了。 代码: gtk-query-immodules-2.0-32 > /etc/gtk-2.0/gtk.immodules 从这个命令可以知道,mandrake 版面提出的临时解决 scim 与 acroread, realplay 等程序冲突的办法,即注释掉 gtk.immodules 文件中与 scim 相关的条目,实际上是无效的,因为这个文件会在安装卸载输入法时更新。正确的做法前面说过了。 撤销本文的所有影响 对于全局设置,上面已经提到了如何在卸载 scim 之后撤销 alternatives 的影响。其实只要用 alternatives --remove 命令就可以了。 对于个人设置,只要删除 $HOME/.xinput.d/ 目录下的相应文件就可以。例如,假如我们设置了 en_US 为指向 scim 的链接,从而在英文环境下使用 scim 输入法,那么只要删掉这个链接。 命令的可重复性 每个命令都可以多次执行,对结果不会有影响 必须先建立 /etc/X11/xinit/xinput.d 目录下的那些文件,而 alternatives 命令的运行顺序是无关的,全局设置与个人设置也是无关的,可以只进行全局设置,也可以只进行个人设置 |