fcitx / fcitx5

maybe a new fcitx.
1.6k stars 118 forks source link

hyprland中fcitx5不能唤出和引起崩溃的问题 #978

Closed vincentaxhe closed 7 months ago

vincentaxhe commented 7 months ago

可以这样复现,打开多个终端窗口,循环窗口,有时能出现输入法提示,有时不能,不能出现时,运行fcitx5 -r,有时会引起hyprland退出,hyprland issue:Hyprland crashes with waybar and fcitx5,还有更多fcitx5有关的issue。

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

        Linux vincent-laptop 6.6.16-2-MANJARO #1 SMP PREEMPT_DYNAMIC Sat Feb 10 09:40:02 UTC 2024 x86_64 GNU/Linux

2.  `lsb_release -a`:

        LSB Version:    n/a
        Distributor ID: ManjaroLinux
        Description:    Manjaro Linux
        Release:    23.1.3
        Codename:   Vulcan

3.  `lsb_release -d`:

        Description:    Manjaro Linux

4.  `/etc/lsb-release`:

        DISTRIB_ID="ManjaroLinux"
        DISTRIB_RELEASE="23.1.3"
        DISTRIB_CODENAME="Vulcan"
        DISTRIB_DESCRIPTION="Manjaro Linux"

5.  `/etc/os-release`:

        NAME="Manjaro Linux"
        PRETTY_NAME="Manjaro Linux"
        ID=manjaro
        ID_LIKE=arch
        BUILD_ID=rolling
        ANSI_COLOR="32;1;24;144;200"
        HOME_URL="https://manjaro.org/"
        DOCUMENTATION_URL="https://wiki.manjaro.org/"
        SUPPORT_URL="https://forum.manjaro.org/"
        BUG_REPORT_URL="https://docs.manjaro.org/reporting-bugs/"
        PRIVACY_POLICY_URL="https://manjaro.org/privacy-policy/"
        LOGO=manjarolinux
        VERSION=rolling

6.  桌面环境:

    无法确定桌面环境。

7.  XDG 会话类型:

        XDG_SESSION_TYPE='wayland'

8.  Bash 版本:

        BASH_VERSION='5.2.26(1)-release'

# 环境:
1.  DISPLAY:

        DISPLAY=':1'

        WAYLAND_DISPLAY='wayland-1'

2.  键盘布局:

    1.  `setxkbmap`:

            WARNING: Running setxkbmap against an Xwayland server
            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
            C.ASCII
            C.ASCII:
            C_C.C
            C_C.C:
            C.en
            C.en:
            C.utf8
            C.utf8:
            C.UTF-8
            C.UTF-8:
            English_United-States.437
            English_United-States.437:
            en_US.utf8
            en_US.utf8:
            POSIX
            POSIX:
            POSIX-UTF2
            POSIX-UTF2:
            universal.utf8@ucs4
            universal.utf8@ucs4:
            univ.utf8
            univ.utf8:
            zh_CN.utf8
            zh_CN.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=zh_CN.UTF-8

4.  目录:

    1.  主目录:

            /home/vincent

    2.  `${XDG_CONFIG_HOME}`:

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

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

    3.  Fcitx5 设置目录:

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

5.  当前用户:

    脚本作为 vincent (1000) 运行。

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

    在 `/usr/bin/fcitx5` 找到了 fcitx5。

2.  版本:

    Fcitx 版本: `5.1.8`

3.  进程:

    找到了 2 个 fcitx5 进程:

          14137 fcitx5
          16541 fcitx5

4.  `fcitx5-remote`:

    `fcitx5-remote` 工作正常。

5.  DBus 界面:

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

    DBus 名称 `org.fcitx.Fcitx5` 的所有者是 `:1.34`。

    DBus 名称 `org.fcitx.Fcitx5` 的 PID 所有者是 `16541`。

    来自 dbus 的调试信息:

           Group [wayland:] has 17 InputContext(s)
          IC [71e1fb11d5214dc29d92577d51152364] program:Alacritty frontend:wayland_v2 cap:100000072 focus:1
          IC [2ef9382a39824a4a84cd85c2c0285a7d] program: frontend:dbus cap:0 focus:0
          IC [1aa291f4eddf4a78a7c86ea72ad8a270] program: frontend:dbus cap:0 focus:0
          IC [f25126dabda544778a7e084547899cee] program: frontend:dbus cap:0 focus:0
          IC [7d4861221ae54254b25986bddc7713a1] program: frontend:dbus cap:0 focus:0
          IC [348e2d4330224abe8a0dc3d973ec2a35] program: frontend:wayland_v2 cap:100000072 focus:0
          IC [fc95ee67b72b45759bfe67fe0d9743dc] program:firefox frontend:dbus cap:e001000072 focus:0
          IC [cd6d7c48d131425e898395a1dfc7ef35] program:firefox frontend:dbus cap:6001000032 focus:0
          IC [166b9ba6d3884cf7800b5575da7d7b49] program:firefox frontend:wayland_v2 cap:100000072 focus:0
          IC [32b9b15a7d2c49ea95d40b144fa389e3] program: frontend:dbus cap:0 focus:0
          IC [087ab92e9ed3444285a86e09c1b85d06] program:firefox frontend:dbus cap:6001000032 focus:0
          IC [4f34979a04ee4889b5e46d1a9e8819c0] program: frontend:dbus cap:0 focus:0
          IC [7cb7667e4a63449783d437f481190dc0] program:firefox frontend:dbus cap:6001000032 focus:0
          IC [d2605f6e1dab4810b35b17a36ad21719] program:Steam++ frontend:wayland_v2 cap:100000072 focus:0
          IC [86fd41aa386846cf9e58352bc77fbb59] program: frontend:dbus cap:0 focus:0
          IC [8134447cf8684fe289c9aa8044fa44ab] program: frontend:dbus cap:0 focus:0
          IC [79d0f95ac0c44d8595160e980b25d38c] program: frontend:dbus cap:0 focus:0
        Group [x11::1] has 0 InputContext(s)
        Input Context without group

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

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

2.  Qt 的配置界面:

    在 `/usr/bin/fcitx5-config-qt` 找到了 `fcitx5-config-qt`。

3.  KDE 的配置界面:

    **`kcmshell5` 未找到.**

# 前端设置:
此脚本检查的环境变量仅能显示当前命令行的环境。仍有可能您的环境并没有应用于整个桌面。您可以通过使用命令对某个无法正常工作的进程使用命令 `xargs -0 -L1 /proc/$PID/environ` 检查此进程的实际的环境变量。

## Xim:
1.  `${XMODIFIERS}`:

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

2.  根窗口上的 XIM_SERVERS:

    Xim 服务的名称与环境变量中设置的相同。

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

    环境变量 QT_IM_MODULE 已经正确地设为了“fcitx”。

    **`fcitx5-qt4-immodule-probing` 未找到.**

2.  qt5 - `${QT_IM_MODULE}`:

    环境变量 QT_IM_MODULE 已经正确地设为了“fcitx”。

    使用 fcitx5-qt5-immodule-probing 来检查在当前环境下将被实际使用的输入法模块:

        QT_QPA_PLATFORM=wayland
        QT_IM_MODULE=fcitx
        IM_MODULE_CLASSNAME=fcitx::QFcitxPlatformInputContext

3.  qt6 - `${QT_IM_MODULE}`:

    环境变量 QT_IM_MODULE 已经正确地设为了“fcitx”。

    使用 fcitx5-qt6-immodule-probing 来检查在当前环境下将被实际使用的输入法模块:

        QT_QPA_PLATFORM=wayland
        QT_IM_MODULE=fcitx
        IM_MODULE_CLASSNAME=fcitx::QFcitxPlatformInputContext

4.  Qt 输入法模块文件:

    找到了 fcitx5 的 qt 输入法模块:`/usr/lib/qt/plugins/platforminputcontexts/libfcitx5platforminputcontextplugin.so`。
    找到了未知的 fcitx qt 模块:`/usr/lib/qt/plugins/plasma/kcms/systemsettings/kcm_fcitx5.so`。
    找到了 fcitx5 的 qt6 输入法模块:`/usr/lib/qt6/plugins/platforminputcontexts/libfcitx5platforminputcontextplugin.so`。
    找到了 fcitx5 qt6 模块:`/usr/lib/fcitx5/qt6/libfcitx-quickphrase-editor5.so`。

    下列错误也许并不准确,因为对路径所对应的 Qt 版本的猜测取决于发行版如何打包 Qt。如果您不使用任何对应版本的 Qt 程序,或者在 Wayland 下使用 Qt 的 text-input 支持,下列错误也不是严重问题。
    **无法找到 Qt4 的 fcitx5 输入法模块。**

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

    环境变量 GTK_IM_MODULE 已经正确地设为了“fcitx”。

    使用 fcitx5-gtk2-immodule-probing 来检查在当前环境下将被实际使用的输入法模块:

        GTK_IM_MODULE=fcitx

    使用 fcitx5-gtk3-immodule-probing 来检查在当前环境下将被实际使用的输入法模块:

        GTK_IM_MODULE=fcitx

    使用 fcitx5-gtk4-immodule-probing 来检查在当前环境下将被实际使用的输入法模块:

        GTK_IM_MODULE=fcitx

2.  `gtk-query-immodules`:

    1.  gtk 2:

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

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

        已找到 gtk `2.24.33` 的 fcitx5 输入法模块。

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

    2.  gtk 3:

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

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

        已找到 gtk `3.24.41` 的 fcitx5 输入法模块。

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

3.  Gtk 输入法模块缓存:

    1.  gtk 2:

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

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

        已找到 gtk `2.24.33` 的 fcitx5 输入法模块。

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

    2.  gtk 3:

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

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

        已找到 gtk `3.24.41` 的 fcitx5 输入法模块。

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

4.  Gtk 输入法模块文件:

    1.  gtk 2:

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

    2.  gtk 3:

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

    3.  gtk 4:

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

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

    找到了 fcitx5 的插件配置目录:`/usr/share/fcitx5/addon`。

2.  插件列表:

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

            Simplified and Traditional Chinese Translation 5.1.3
            Classic User Interface 5.1.8
            Clipboard 5.1.8
            Cloud Pinyin 5.1.3
            DBus 5.1.8
            DBus Frontend 5.1.8
            Emoji 5.1.8
            Fcitx4 Frontend 5.1.8
            Full width character 5.1.3
            IBus Frontend 5.1.8
            Input method selector 5.1.8
            Keyboard 5.1.8
            KDE Input Method Panel 5.1.8
            Status Notifier 5.1.8
            Notification 5.1.8
            Pinyin 5.1.3
            Extra Pinyin functionality 5.1.3
            Punctuation 5.1.3
            Quick Phrase 5.1.8
            Rime 5.1.4
            Spell 5.1.8
            Table 5.1.3
            Unicode 5.1.8
            DBus Virtual Keyboard 5.1.8
            Wayland 5.1.8
            Wayland Input method frontend 5.1.8
            XCB 5.1.8
            X Input Method Frontend 5.1.8

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

3.  插件库: 

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

4.  用户界面:

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

        Classic User Interface
        KDE Input Method Panel
        DBus Virtual Keyboard

## 输入法:
1.  `/home/vincent/.config/fcitx5/profile`:

        [Groups/0]
        # Group Name
        Name=默认
        # Layout
        Default Layout=us
        # Default Input Method
        DefaultIM=rime

        [Groups/0/Items/0]
        # Name
        Name=keyboard-us
        # Layout
        Layout=

        [Groups/0/Items/1]
        # Name
        Name=pinyin
        # Layout
        Layout=

        [Groups/0/Items/2]
        # Name
        Name=rime
        # Layout
        Layout=

        [GroupOrder]
        0=默认

# 日志:
1.  `date`:

        2024年 03月 03日 星期日 11:07:22 CST

2.  `/home/vincent/.config/fcitx5/crash.log`:

        =========================
        Fcitx 5.1.6 -- Get Signal No.: 11
        Date: try "date -d @1704027462" if you are using GNU date ***
        ProcessID: 108773
        /usr/bin/fcitx5(+0x10bfc)[0x557bc3b96bfc]
        /usr/lib/libc.so.6(+0x3e710)[0x7fcd8c037710]
        /usr/lib/librime.so.1(+0x865cb)[0x7fcd89e505cb]
        /usr/lib/librime.so.1(_ZN4rime10ConfigData8TraverseERKNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE+0x171)[0x7fcd89e956a1]
        /usr/lib/librime.so.1(_ZN4rime6Config7GetListERKNSt7__cxx1112basic_stringIcSt11char_traitsIcESaIcEEE+0x29)[0x7fcd89e89449]
        /usr/lib/librime.so.1(_ZN4rime15WorkspaceUpdate3RunEPNS_8DeployerE+0x250)[0x7fcd89f22c90]
        /usr/lib/librime.so.1(_ZN4rime8Deployer3RunEv+0x14f)[0x7fcd89e691bf]
        /usr/lib/librime.so.1(+0x9f4fd)[0x7fcd89e694fd]
        /usr/lib/librime.so.1(_ZNSt13__future_base13_State_baseV29_M_do_setEPSt8functionIFSt10unique_ptrINS_12_Result_baseENS3_8_DeleterEEvEEPb+0x2d)[0x7fcd89e644dd]
        /usr/lib/libc.so.6(+0x91bbf)[0x7fcd8c08abbf]
        /usr/lib/librime.so.1(+0x9ac1a)[0x7fcd89e64c1a]
        /usr/lib/libstdc++.so.6(+0xe1943)[0x7fcd8c2e1943]
        /usr/lib/libc.so.6(+0x8c9eb)[0x7fcd8c0859eb]
        /usr/lib/libc.so.6(+0x1107cc)[0x7fcd8c1097cc]

**警告:fcitx5-diagnose 的输出可能包含敏感信息,包括发行版名称,内核版本,正在运行的程序名称等。**

**尽管这些信息对于开发者诊断问题有帮助,请在公开发送到在线网站前检查并且根据需要移除的对应信息。**
wengxt commented 7 months ago

谁崩溃,就是谁的问题。