您尚未登录。

#1 2016-10-23 06:37:14

lujun9972
会员
注册时间: 2016-10-21
帖子: 73

[已解决] Just can't startup fcitx

I don't know what I have done.

I just boot my computer , start my awesomeWM and found the fcitx icon disappeard.

Then I can't switch to chinese inputmethod any more.

I tried to execute fcitx in a terminal but some errors reported:
[lujun9972@x41 fcitx]$ fcitx -r
[lujun9972@x41 fcitx]$ (INFO-9676 /build/fcitx/src/fcitx-4.2.9.1/src/lib/fcitx/addon.c:151) 加载附加组件配置文件: fcitx-dbus.conf
(INFO-9676 /build/fcitx/src/fcitx-4.2.9.1/src/lib/fcitx/addon.c:151) 加载附加组件配置文件: fcitx-x11.conf
(INFO-9676 /build/fcitx/src/fcitx-4.2.9.1/src/lib/fcitx/addon.c:151) 加载附加组件配置文件: fcitx-vk.conf
(INFO-9676 /build/fcitx/src/fcitx-4.2.9.1/src/lib/fcitx/addon.c:151) 加载附加组件配置文件: fcitx-table.conf
(INFO-9676 /build/fcitx/src/fcitx-4.2.9.1/src/lib/fcitx/addon.c:151) 加载附加组件配置文件: fcitx-imselector.conf
(INFO-9676 /build/fcitx/src/fcitx-4.2.9.1/src/lib/fcitx/addon.c:151) 加载附加组件配置文件: fcitx-sunpinyin.conf
(INFO-9676 /build/fcitx/src/fcitx-4.2.9.1/src/lib/fcitx/addon.c:151) 加载附加组件配置文件: fcitx-kimpanel-ui.conf
(INFO-9676 /build/fcitx/src/fcitx-4.2.9.1/src/lib/fcitx/addon.c:151) 加载附加组件配置文件: fcitx-unicode.conf
(INFO-9676 /build/fcitx/src/fcitx-4.2.9.1/src/lib/fcitx/addon.c:151) 加载附加组件配置文件: fcitx-spell.conf
(INFO-9676 /build/fcitx/src/fcitx-4.2.9.1/src/lib/fcitx/addon.c:151) 加载附加组件配置文件: fcitx-clipboard.conf
(INFO-9676 /build/fcitx/src/fcitx-4.2.9.1/src/lib/fcitx/addon.c:151) 加载附加组件配置文件: fcitx-classic-ui.conf
(INFO-9676 /build/fcitx/src/fcitx-4.2.9.1/src/lib/fcitx/addon.c:151) 加载附加组件配置文件: fcitx-chttrans.conf
(INFO-9676 /build/fcitx/src/fcitx-4.2.9.1/src/lib/fcitx/addon.c:151) 加载附加组件配置文件: fcitx-notificationitem.conf
(INFO-9676 /build/fcitx/src/fcitx-4.2.9.1/src/lib/fcitx/addon.c:151) 加载附加组件配置文件: fcitx-freedesktop-notify.conf
(INFO-9676 /build/fcitx/src/fcitx-4.2.9.1/src/lib/fcitx/addon.c:151) 加载附加组件配置文件: fcitx-qw.conf
(INFO-9676 /build/fcitx/src/fcitx-4.2.9.1/src/lib/fcitx/addon.c:151) 加载附加组件配置文件: fcitx-pinyin-enhance.conf
(INFO-9676 /build/fcitx/src/fcitx-4.2.9.1/src/lib/fcitx/addon.c:151) 加载附加组件配置文件: fcitx-xkbdbus.conf
(INFO-9676 /build/fcitx/src/fcitx-4.2.9.1/src/lib/fcitx/addon.c:151) 加载附加组件配置文件: fcitx-quickphrase.conf
(INFO-9676 /build/fcitx/src/fcitx-4.2.9.1/src/lib/fcitx/addon.c:151) 加载附加组件配置文件: fcitx-punc.conf
(INFO-9676 /build/fcitx/src/fcitx-4.2.9.1/src/lib/fcitx/addon.c:151) 加载附加组件配置文件: fcitx-pinyin.conf
(INFO-9676 /build/fcitx/src/fcitx-4.2.9.1/src/lib/fcitx/addon.c:151) 加载附加组件配置文件: fcitx-keyboard.conf
(INFO-9676 /build/fcitx/src/fcitx-4.2.9.1/src/lib/fcitx/addon.c:151) 加载附加组件配置文件: fcitx-xim.conf
(INFO-9676 /build/fcitx/src/fcitx-4.2.9.1/src/lib/fcitx/addon.c:151) 加载附加组件配置文件: fcitx-remote-module.conf
(INFO-9676 /build/fcitx/src/fcitx-4.2.9.1/src/lib/fcitx/addon.c:151) 加载附加组件配置文件: fcitx-xkb.conf
(INFO-9676 /build/fcitx/src/fcitx-4.2.9.1/src/lib/fcitx/addon.c:151) 加载附加组件配置文件: fcitx-fullwidth-char.conf
(INFO-9676 /build/fcitx/src/fcitx-4.2.9.1/src/lib/fcitx/addon.c:151) 加载附加组件配置文件: fcitx-autoeng.conf
(INFO-9676 /build/fcitx/src/fcitx-4.2.9.1/src/lib/fcitx/addon.c:151) 加载附加组件配置文件: fcitx-ipc.conf
(WARN-9676 /build/fcitx/src/fcitx-4.2.9.1/src/lib/fcitx/addon.c:298) 禁用插件 fcitx-xim,依赖 fcitx-x11 无法满足。
(WARN-9676 /build/fcitx/src/fcitx-4.2.9.1/src/lib/fcitx/addon.c:298) 禁用插件 fcitx-xkb,依赖 fcitx-x11 无法满足。
(WARN-9676 /build/fcitx/src/fcitx-4.2.9.1/src/lib/fcitx/addon.c:298) 禁用插件 fcitx-classic-ui,依赖 fcitx-x11 无法满足。
(WARN-9676 /build/fcitx/src/fcitx-4.2.9.1/src/lib/fcitx/addon.c:298) 禁用插件 fcitx-xkbdbus,依赖 fcitx-xkb,fcitx-dbus 无法满足。
(WARN-9676 /build/fcitx/src/fcitx-4.2.9.1/src/lib/fcitx/addon.c:298) 禁用插件 fcitx-vk,依赖 fcitx-x11 无法满足。
(INFO-5642 /build/fcitx/src/fcitx-4.2.9.1/src/frontend/ipc/ipc.c:640) Receive message ask for quit
(ERROR-9676 /build/fcitx/src/fcitx-4.2.9.1/src/lib/fcitx/ime.c:432) fcitx-keyboard-cm-mmuock already exists

I baidued the error but found nothing.

Running fcitx-diagnosefcitx-diagnose get
# 系统信息:
1.  `uname -a`:

        Linux x41 4.8.3-1-ARCH #1 SMP PREEMPT Thu Oct 20 20:19:42 CEST 2016 i686 GNU/Linux

2.  `lsb_release`:

    `lsb_release` 未找到.

3.  `/etc/lsb-release`:

    `/etc/lsb-release` 未找到.

4.  `/etc/os-release`:

        NAME="Arch Linux"
        ID=arch
        PRETTY_NAME="Arch Linux"
        ANSI_COLOR="0;36"
        HOME_URL="https://www.archlinux.org/"
        SUPPORT_URL="https://bbs.archlinux.org/"
        BUG_REPORT_URL="https://bugs.archlinux.org/"

5.  桌面环境:

    无法确定桌面环境。

6.  Bash Version:

        BASH_VERSION='4.3.46(1)-release'

# 环境:
1.  DISPLAY:

        DISPLAY=':0'

2.  键盘布局:

    1.  `setxkbmap`:

            xkb_keymap {
            	xkb_keycodes  { include "evdev+aliases(qwerty)"	};
            	xkb_types     { include "complete"	};
            	xkb_compat    { include "complete"	};
            	xkb_symbols   { include "pc+us+inet(evdev)"	};
            	xkb_geometry  { include "pc(pc105)"	};
            };

    2.  `xprop`:

            _XKB_RULES_NAMES(STRING) = "evdev", "pc105", "us", "", ""

3.  Locale:

    1.  全部可用 locale:

            C
            en_US.utf8
            POSIX
            zh_CN.utf8
            zh_TW.utf8

    2.  当前 locale:

            LANG=zh_CN.UTF-8
            LC_CTYPE="zh_CN.UTF-8"
            LC_NUMERIC="zh_CN.UTF-8"
            LC_TIME="zh_CN.UTF-8"
            LC_COLLATE="zh_CN.UTF-8"
            LC_MONETARY="zh_CN.UTF-8"
            LC_MESSAGES="zh_CN.UTF-8"
            LC_PAPER="zh_CN.UTF-8"
            LC_NAME="zh_CN.UTF-8"
            LC_ADDRESS="zh_CN.UTF-8"
            LC_TELEPHONE="zh_CN.UTF-8"
            LC_MEASUREMENT="zh_CN.UTF-8"
            LC_IDENTIFICATION="zh_CN.UTF-8"
            LC_ALL=

4.  目录:

    1.  主目录:

            /home/lujun9972

    2.  `${XDG_CONFIG_HOME}`:

        环境变量 `XDG_CONFIG_HOME` 没有设定。

        `XDG_CONFIG_HOME` 的当前值是 `~/.config` (`/home/lujun9972/.config`)。

    3.  Fcitx 设置目录:

        当前 fcitx 设置目录是 `~/.config/fcitx` (`/home/lujun9972/.config/fcitx`)。

5.  当前用户:

    脚本作为 lujun9972 (1000) 运行。

# Fcitx 状态:
1.  可执行文件:

    在 `/usr/bin/fcitx` 找到了 fcitx.

2.  版本:

    Fcitx 版本: `4.2.9.1`

3.  进程:

    找到了 2 个 fcitx 进程:

         9676 fcitx
         9690 fcitx-dbus-watc

4.  `fcitx-remote`:

    `fcitx-remote` 工作正常.

# Fcitx 配置界面:
1.  配置工具封装:

    在 `/usr/bin/fcitx-configtool` 找到了 fcitx-configtool。

2.  用于 GTK+-2.0 的配置界面:

    **未找到 gtk2 的配置界面.**

3.  用于 GTK+-3.0 的配置界面:

    在 `/usr/bin/fcitx-config-gtk3` 找到了 `fcitx-config-gtk3`。

4.  KDE 的配置界面:

    **`kcmshell4` 未找到.**

# 前端设置:
## Xim:
1.  `${XMODIFIERS}`:

    环境变量 XMODIFIERS 已经正确地设为了 "@im=fcitx".
    从环境变量中获取的 Xim 服务名称为 fcitx.

2.  根窗口上的 XIM_SERVERS:

    **无法在根窗口找到 xim_server.**

## Qt:
1.  qt4 - `${QT4_IM_MODULE}`:

    环境变量 QT_IM_MODULE 已经正确地设为了 "fcitx".

2.  qt5 - `${QT_IM_MODULE}`:

    环境变量 QT_IM_MODULE 已经正确地设为了 "fcitx".

3.  Qt 输入法模块文件:
    找到了 Qt5 的输入法模块: `/usr/lib/qt/plugins/platforminputcontexts/libfcitxplatforminputcontextplugin.so`.
    找到了 fcitx 的 qt 模块: `/usr/lib/fcitx/qt/libfcitx-quickphrase-editor.so`.
    找到了 Qt4 的输入法模块: `/usr/lib/qt4/plugins/inputmethods/qtim-fcitx.so`.

## Gtk:
1.  gtk - `${GTK_IM_MODULE}`:

    环境变量 GTK_IM_MODULE 已经正确地设为了 "fcitx".

2.  `gtk-query-immodules`:

    1.  gtk 2:

        在 `/usr/bin/gtk-query-immodules-2.0` 找到了 gtk `2.24.31` 的 `gtk-query-immodules`.
        版本行:

            # Created by /usr/bin/gtk-query-immodules-2.0 from gtk+-2.24.31

        已找到 gtk `2.24.31` 的 fcitx 输入法模块.

            "/usr/lib/gtk-2.0/2.10.0/immodules/im-fcitx.so" 
            "fcitx" "Fcitx (Flexible Input Method Framework)" "fcitx" "/usr/share/locale" "ja:ko:zh:*" 

    2.  gtk 3:

        在 `/usr/bin/gtk-query-immodules-3.0` 找到了 gtk `3.22.1` 的 `gtk-query-immodules`.
        版本行:

            # Created by /usr/bin/gtk-query-immodules-3.0 from gtk+-3.22.1

        已找到 gtk `3.22.1` 的 fcitx 输入法模块.

            "/usr/lib/gtk-3.0/3.0.0/immodules/im-fcitx.so" 
            "fcitx" "Fcitx (Flexible Input Method Framework)" "fcitx" "/usr/share/locale" "ja:ko:zh:*" 

3.  Gtk 输入法模块缓存:

    1.  gtk 2:

        在 `/usr/lib/gtk-2.0/2.10.0/immodules.cache` 找到了 gtk `2.24.31` 的输入法模块缓存.
        版本行:

            # Created by /usr/bin/gtk-query-immodules-2.0 from gtk+-2.24.31

        已找到 gtk `2.24.31` 的 fcitx 输入法模块.

            "/usr/lib/gtk-2.0/2.10.0/immodules/im-fcitx.so" 
            "fcitx" "Fcitx (Flexible Input Method Framework)" "fcitx" "/usr/share/locale" "ja:ko:zh:*" 

    2.  gtk 3:

        在 `/usr/lib/gtk-3.0/3.0.0/immodules.cache` 找到了 gtk `3.22.1` 的输入法模块缓存.
        版本行:

            # Created by /usr/bin/gtk-query-immodules-3.0 from gtk+-3.22.1

        已找到 gtk `3.22.1` 的 fcitx 输入法模块.

            "/usr/lib/gtk-3.0/3.0.0/immodules/im-fcitx.so" 
            "fcitx" "Fcitx (Flexible Input Method Framework)" "fcitx" "/usr/share/locale" "ja:ko:zh:*" 

4.  Gtk 输入法模块文件:

    1.  gtk 2:

        找到的全部 Gtk 2 输入法模块文件均存在.

    2.  gtk 3:

        找到的全部 Gtk 3 输入法模块文件均存在.

# 配置:
## Fcitx 插件:
1.  插件配置文件目录:

    找到了 fcitx 插件配置目录: `/usr/share/fcitx/addon`.

2.  插件列表:

    1.  找到了 25 个已启用的插件:

            fcitx-autoeng
            fcitx-chttrans
            fcitx-classic-ui
            fcitx-clipboard
            fcitx-dbus
            fcitx-freedesktop-notify
            fcitx-fullwidth-char
            fcitx-imselector
            fcitx-ipc
            fcitx-keyboard
            fcitx-kimpanel-ui
            fcitx-notificationitem
            fcitx-pinyin
            fcitx-pinyin-enhance
            fcitx-punc
            fcitx-quickphrase
            fcitx-remote
            fcitx-spell
            fcitx-sunpinyin
            fcitx-table
            fcitx-unicode
            fcitx-vk
            fcitx-xim
            fcitx-xkb
            fcitx-xkbdbus

    2.  找到了 2 个被禁用的插件:

            fcitx-qw
            fcitx-x11

3.  插件库: 

    所有插件所需的库都被找到。

4.  用户界面:

    找到了 2 个已启用的用户界面插件:

        fcitx-classic-ui
        fcitx-kimpanel-ui

## 输入法:
1.  找到了 2 个启用的输入法:

        fcitx-keyboard-us
        sunpinyin

2.  默认输入法:

    您已经正确的将一个键盘输入法 "fcitx-keyboard-us" 设为默认.

# 日志:
1.  `date`:

        2016年 10月 23日 星期日 06:32:36 CST

2.  `~/.config/fcitx/log/`:

        总用量 4
        -rw-r--r-- 1 lujun9972 users 44 10月 22 08:34 crash.log

3.  `~/.config/fcitx/log/crash.log`:

        fcitx: BadWindow (invalid Window parameter)

There is a crash log but I don't know what's the meaning.

My .xinitrc is quite simple and yes, I exported  before exec
# [[file:../../tmp/dotfile410ODk::*xinitrc][xinitrc:1]]
export GTK_IM_MODULE=fcitx
export QT_IM_MODULE=fcitx
export XMODIFIERS="@im=fcitx"
export LANG=zh_CN.UTF-8
fcitx
# xmodmap -e "remove Lock = Caps_Lock"
# xmodmap -e "keysym Caps_Lock = Super_R"
# xmodmap -e "keysym XF86WakeUp = Super_R"
exec awesome
# xinitrc:1 ends here
UPDATE: I reinstalled fcitx-im but still not work

I use =pacman -R= to remove fcitx and then use =pacman -S= to install the fcitx again but nothing happened.

UPDATE:The fcitx process is actually exist

Running =ps -elf |grep fcitx=, I get

[lujun9972@x41 ~]$ ps -elf |grep fcitx
1 S lujun99+   414     1  0  80   0 - 15868 poll_s 08:06 ?        00:00:00 fcitx
1 S lujun99+   421     1  0  80   0 -  1419 SyS_ep 08:06 ?        00:00:00 /usr/bin/dbus-daemon --fork --print-pid 4 --print-address 6 --config-file /usr/share/fcitx/dbus/daemon.conf
1 S lujun99+   425     1  0  99  19 -  1295 poll_s 08:06 ?        00:00:00 /usr/bin/fcitx-dbus-watcher unix:abstract=/tmp/dbus-tDFYcBL35D,guid=eb82b29a43213403fa4154be580bff14 421

最近编辑记录 lujun9972 (2016-10-23 14:46:13)

离线

#2 2016-10-23 10:02:12

依云
会员
所在地: a.k.a. 百合仙子
注册时间: 2011-08-21
帖子: 8,919
个人网站

Re: [已解决] Just can't startup fcitx

你需要启用 fcitx-x11。配置工具应该还能用(fcitx-configtool)。

离线

#3 2016-10-23 14:45:36

lujun9972
会员
注册时间: 2016-10-21
帖子: 73

Re: [已解决] Just can't startup fcitx

十分感谢。

我后来是直接吧~/.config/fcitx目录给删掉了~

然后就OK了,我对比了一下两次fcitx-diagnose的结果

发现第二次确实启用了fcitx-x11,所以应该确实就是你所说的这个解决方案。

离线

页脚