您尚未登录。

#1 2019-10-12 01:27:27

ety001
会员
注册时间: 2012-05-01
帖子: 8

[已解决] 滚动升级后,在wine下无法使用fcitx

今天滚动升级后,发现wine下的微信和QQ都无法使用fcitx了。

具体表现是可以输入英文,但是按ctrl+space无法切换输入法(没有任何反应),非wine程序可以正常使用fcitx。

尝试过删掉配置目录,但是没有效果。

wine版本:4.17

下面是fcitx自检信息:

# 系统信息:
1.  `uname -a`:

        Linux mainhost 4.19.78-1-MANJARO #1 SMP PREEMPT Mon Oct 7 20:24:34 UTC 2019 x86_64 GNU/Linux

2.  `lsb_release -a`:

        LSB Version:	n/a
        Distributor ID:	ManjaroLinux
        Description:	Manjaro Linux
        Release:	18.1.0
        Codename:	Juhraya

3.  `lsb_release -d`:

        Description:	Manjaro Linux

4.  `/etc/lsb-release`:

        DISTRIB_ID=ManjaroLinux
        DISTRIB_RELEASE=18.1.0
        DISTRIB_CODENAME=Juhraya
        DISTRIB_DESCRIPTION="Manjaro Linux"

5.  `/etc/os-release`:

        NAME="Manjaro Linux"
        ID=manjaro
        ID_LIKE=arch
        PRETTY_NAME="Manjaro Linux"
        ANSI_COLOR="1;32"
        HOME_URL="https://www.manjaro.org/"
        SUPPORT_URL="https://www.manjaro.org/"
        BUG_REPORT_URL="https://bugs.manjaro.org/"

6.  桌面环境:

    桌面环境为 `xfce`。

7.  Bash 版本:

        BASH_VERSION='5.0.11(1)-release'

# 环境:
1.  DISPLAY:

        DISPLAY=':0.0'

2.  键盘布局:

    1.  `setxkbmap`:

            xkb_keymap {
            	xkb_keycodes  { include "evdev+aliases(qwerty)"	};
            	xkb_types     { include "complete"	};
            	xkb_compat    { include "complete"	};
            	xkb_symbols   { include "pc+cn+inet(evdev)+terminate(ctrl_alt_bksp)"	};
            	xkb_geometry  { include "hhk(basic)"	};
            };

    2.  `xprop`:

            _XKB_RULES_NAMES(STRING) = "evdev", "hhk", "cn", "", "terminate:ctrl_alt_bksp"

3.  Locale:

    1.  全部可用 locale:

            C
            en_US.utf8
            POSIX
            zh_CN.utf8

    2.  当前 locale:

            LANG=zh_CN.utf8
            LC_CTYPE=zh_CN.utf8
            LC_NUMERIC=zh_CN.UTF-8
            LC_TIME=zh_CN.UTF-8
            LC_COLLATE="zh_CN.utf8"
            LC_MONETARY=zh_CN.UTF-8
            LC_MESSAGES="zh_CN.utf8"
            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/ety001

    2.  `${XDG_CONFIG_HOME}`:

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

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

    3.  Fcitx 设置目录:

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

5.  当前用户:

    脚本作为 ety001 (1000) 运行。

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

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

2.  版本:

    Fcitx 版本: `4.2.9.5`

3.  进程:

    找到了 2 个 fcitx 进程:

         1792 fcitx
         1819 fcitx-dbus-watc

4.  `fcitx-remote`:

    `fcitx-remote` 工作正常.

5.  DBus 界面:

    使用 `dbus-send` 来检查 dbus。

    DBus 名称 `org.fcitx.Fcitx` 的所有者是 `:1.61`。

    DBus 名称 `org.fcitx.Fcitx` 的 PID 所有者是 `1792`。

# 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 服务的名称与环境变量中设置的相同.

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

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

2.  qt5 - `${QT_IM_MODULE}`:

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

3.  Qt 输入法模块文件:

    找到了 fcitx 的 qt 模块: `/usr/lib/fcitx/qt/libfcitx-libpinyin-dictmanager.so`.
    找到了 fcitx 的 qt 模块: `/usr/lib/fcitx/qt/libfcitx-quickphrase-editor5.so`.
    找到了 Qt5 的输入法模块: `/usr/lib/qt/plugins/platforminputcontexts/libfcitxplatforminputcontextplugin.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.32` 的 `gtk-query-immodules`.
        版本行:

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

        已找到 gtk `2.24.32` 的 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:*" 

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

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

        **无法在 `/usr/bin/gtk-query-immodules-2.0-32` 的输出重找到 fcitx.**

    2.  gtk 3:

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

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

        已找到 gtk `3.24.12` 的 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.32` 的输入法模块缓存.
        版本行:

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

        已找到 gtk `2.24.32` 的 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:*" 

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

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

        **无法输入法模块缓存 `/usr/lib32/gtk-2.0/2.10.0/immodules.cache` 中找到 fcitx**

    2.  gtk 3:

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

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

        已找到 gtk `3.24.12` 的 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:*" 

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

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

        **无法输入法模块缓存 `/usr/lib32/gtk-3.0/3.0.0/immodules.cache` 中找到 fcitx**

4.  Gtk 输入法模块文件:

    1.  gtk 2:

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

    2.  gtk 3:

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

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

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

2.  插件列表:

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

            fcitx-autoeng
            fcitx-autoeng-ng
            fcitx-chttrans
            fcitx-classic-ui
            fcitx-clipboard
            fcitx-cloudpinyin
            fcitx-dbus
            fcitx-freedesktop-notify
            fcitx-fullwidth-char
            fcitx-fullwidth-char-enhance
            fcitx-googlepinyin
            fcitx-imselector
            fcitx-ipc
            fcitx-ipcportal
            fcitx-keyboard
            fcitx-kimpanel-ui
            fcitx-libpinyin
            fcitx-notificationitem
            fcitx-pinyin
            fcitx-pinyin-enhance
            fcitx-punc
            fcitx-punc-ng
            fcitx-quickphrase
            fcitx-remote
            fcitx-sogoucloudpinyin
            fcitx-sogoupinyin
            fcitx-spell
            fcitx-table
            fcitx-unicode
            fcitx-vk
            fcitx-x11
            fcitx-xim
            fcitx-xkb
            fcitx-xkbdbus

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

            fcitx-qw

3.  插件库: 

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

4.  用户界面:

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

        fcitx-classic-ui
        fcitx-kimpanel-ui

    Kimpanel 进程:

         1433 sogou-qimpanel %U

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

        fcitx-keyboard-cn
        sogoupinyin
        googlepinyin
        pinyin-libpinyin

2.  默认输入法:

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

# 日志:
1.  `date`:

        2019年 10月 12日 星期六 01:23:25 CST

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

        总用量 4
        -rw-r--r-- 1 ety001 ety001 44 10月 12 01:21 crash.log

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

        fcitx: BadWindow (invalid Window parameter)

最近编辑记录 ety001 (2019-10-12 02:08:29)

离线

#2 2019-10-12 01:56:10

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

Re: [已解决] 滚动升级后,在wine下无法使用fcitx

降级 wine 版本到 4.16 即可。
这是个 wine 的 bug,并且在解决中: https://bugs.winehq.org/show_bug.cgi?id=47821

离线

#3 2019-10-12 01:58:59

ety001
会员
注册时间: 2012-05-01
帖子: 8

Re: [已解决] 滚动升级后,在wine下无法使用fcitx

依云 说:

降级 wine 版本到 4.16 即可。
这是个 wine 的 bug,并且在解决中: https://bugs.winehq.org/show_bug.cgi?id=47821

原来如此。

话说以后遇到类似问题,该如何debug?这次遇到这种现象,完全找不到任何报错信息,感觉有些茫然。

离线

#4 2019-10-12 02:08:04

ety001
会员
注册时间: 2012-05-01
帖子: 8

Re: [已解决] 滚动升级后,在wine下无法使用fcitx

降级后,问题解决。我看bug描述里,以及有修复patch了,等待更新的版本能够包含patch。

离线

#5 2019-10-12 14:02:22

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

Re: [已解决] 滚动升级后,在wine下无法使用fcitx

ety001 说:
依云 说:

降级 wine 版本到 4.16 即可。
这是个 wine 的 bug,并且在解决中: https://bugs.winehq.org/show_bug.cgi?id=47821

原来如此。

话说以后遇到类似问题,该如何debug?这次遇到这种现象,完全找不到任何报错信息,感觉有些茫然。

我的经历是这样的:

咦,本来我的微信好好的,今天咋不能输入中文了?
查一下 pacman.log,哦,wine 升级了。那降级一下看看。
啊咧,降级之后就好了,看来是 bug。
正准备二分法找到出问题的提交呢,群里有人告诉我上游已经在修了。就跑过去围观(加 cc 列表)等待后续。

离线

#6 2019-10-12 14:39:06

ety001
会员
注册时间: 2012-05-01
帖子: 8

Re: [已解决] 滚动升级后,在wine下无法使用fcitx

依云 说:
ety001 说:
依云 说:

降级 wine 版本到 4.16 即可。
这是个 wine 的 bug,并且在解决中: https://bugs.winehq.org/show_bug.cgi?id=47821

原来如此。

话说以后遇到类似问题,该如何debug?这次遇到这种现象,完全找不到任何报错信息,感觉有些茫然。

我的经历是这样的:

咦,本来我的微信好好的,今天咋不能输入中文了?
查一下 pacman.log,哦,wine 升级了。那降级一下看看。
啊咧,降级之后就好了,看来是 bug。
正准备二分法找到出问题的提交呢,群里有人告诉我上游已经在修了。就跑过去围观(加 cc 列表)等待后续。


好吧,我以为会有更多的调试参数或者日志可以使用作为参考。。。

离线

#7 2019-10-28 14:07:09

iriwen
会员
注册时间: 2019-10-28
帖子: 37

Re: [已解决] 滚动升级后,在wine下无法使用fcitx

依云 说:

降级 wine 版本到 4.16 即可。
这是个 wine 的 bug,并且在解决中: https://bugs.winehq.org/show_bug.cgi?id=47821

wine具体要怎么操作降级呢?要完全卸载掉wine,再进行安装还是有什么快捷高效的操作啊

离线

#8 2019-10-28 14:13:39

ety001
会员
注册时间: 2012-05-01
帖子: 8

Re: [已解决] 滚动升级后,在wine下无法使用fcitx

iriwen 说:
依云 说:

降级 wine 版本到 4.16 即可。
这是个 wine 的 bug,并且在解决中: https://bugs.winehq.org/show_bug.cgi?id=47821

wine具体要怎么操作降级呢?要完全卸载掉wine,再进行安装还是有什么快捷高效的操作啊



看这里:https://wiki.archlinux.org/index.php/Downgrading_packages_(%E7%AE%80%E4%BD%93%E4%B8%AD%E6%96%87)

我是用的AUR中的downgrader

离线

#9 2019-10-28 14:50:20

iriwen
会员
注册时间: 2019-10-28
帖子: 37

Re: [已解决] 滚动升级后,在wine下无法使用fcitx

ety001 说:
iriwen 说:
依云 说:

降级 wine 版本到 4.16 即可。
这是个 wine 的 bug,并且在解决中: https://bugs.winehq.org/show_bug.cgi?id=47821

wine具体要怎么操作降级呢?要完全卸载掉wine,再进行安装还是有什么快捷高效的操作啊



看这里:https://wiki.archlinux.org/index.php/Downgrading_packages_(%E7%AE%80%E4%BD%93%E4%B8%AD%E6%96%87)

我是用的AUR中的downgrader

好的,多谢  不过尝试降级到4.16  从github上买能好像下载不下来包,只能降级到4.15了

离线

页脚