From 3be2fe149ee28a264f7a01588da06df803796b72 Mon Sep 17 00:00:00 2001 From: Kan-Ru Chen Date: Sat, 10 Feb 2024 08:43:51 +0900 Subject: [PATCH 1/5] feat: use ibus systray to show both engine icon and input mode --- CMakeLists.txt | 4 ++++ data/chewing.xml.in | 29 +++++++++++++++-------------- src/main.c | 21 +++++++++++++++------ 3 files changed, 34 insertions(+), 20 deletions(-) diff --git a/CMakeLists.txt b/CMakeLists.txt index d2f8a474..2d50db46 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -79,11 +79,15 @@ add_compile_definitions( ) # chewing.xml +set(ICON_PROP_KEY "InputMode") set(SYMBOL_XML "") set(CHEWING_HOTKEYS "Super+space") set(HOTKEYS_XML "${CHEWING_HOTKEYS}") set(SETUP_PROGRAM_XML "${CMAKE_INSTALL_FULL_LIBEXECDIR}/ibus-setup-chewing") +if(IBUS_VERSION LESS 1.5.11) + set(ICON_PROP_KEY "") +endif() if(IBUS_VERSION LESS 1.3.99) set(SYMBOL_XML "") set(HOTKEYS_XML "") diff --git a/data/chewing.xml.in b/data/chewing.xml.in index d8d1bb8d..5087c226 100644 --- a/data/chewing.xml.in +++ b/data/chewing.xml.in @@ -11,20 +11,21 @@ ibus-chewing - chewing - Chewing - Chinese chewing input method - zh_TW - GPLv2+ - Peng Huang, Ding-Yi Chen - @PRJ_DATA_DIR@/icons/@PROJECT_NAME@.png - us - @PRJ_VER@ - @PROJECT_NAME@ - 80 - @HOTKEYS_XML@ - @SYMBOL_XML@ - @SETUP_PROGRAM_XML@ + chewing + Chewing + Chinese chewing input method + zh_TW + GPLv2+ + Peng Huang, Ding-Yi Chen + @PRJ_DATA_DIR@/icons/@PROJECT_NAME@.png + us + @PRJ_VER@ + @PROJECT_NAME@ + 80 + @ICON_PROP_KEY@ + @HOTKEYS_XML@ + @SYMBOL_XML@ + @SETUP_PROGRAM_XML@ diff --git a/src/main.c b/src/main.c index 595ebee7..ad9ec808 100644 --- a/src/main.c +++ b/src/main.c @@ -82,14 +82,23 @@ static void start_component(void) { QUOTE_ME(PROJECT_NAME)); } + // clang-format off IBusEngineDesc *engineDesc = ibus_engine_desc_new_varargs( - "name", "chewing", "longname", _("Chewing"), "description", - _("Chinese chewing input method"), "language", "zh_TW", "license", - "GPLv2+", "author", _("Peng Huang, Ding-Yi Chen"), "icon", - QUOTE_ME(PRJ_DATA_DIR) "/icons/" QUOTE_ME(PROJECT_NAME) ".png", - "layout", "us", "setup", QUOTE_ME(LIBEXEC_DIR) "/ibus-setup-chewing", - "version", QUOTE_ME(PRJ_VER), "textdomain", QUOTE_ME(PROJECT_NAME), + "name", "chewing", + "longname", _("Chewing"), + "description", _("Chinese chewing input method"), + "language", "zh_TW", + "license", "GPLv2+", + "author", _("Peng Huang, Ding-Yi Chen"), + "icon", QUOTE_ME(PRJ_DATA_DIR) "/icons/" QUOTE_ME(PROJECT_NAME) ".png", + "icon_prop_key", "InputMode", + "symbol", "酷", + "layout", "us", + "setup", QUOTE_ME(LIBEXEC_DIR) "/ibus-setup-chewing", + "version", QUOTE_ME(PRJ_VER), + "textdomain", QUOTE_ME(PROJECT_NAME), NULL); + // clang-format on ibus_component_add_engine(component, engineDesc); From 9b06a2d68458c940741f87ea5c557308cc7290fd Mon Sep 17 00:00:00 2001 From: Kan-Ru Chen Date: Sat, 10 Feb 2024 08:47:40 +0900 Subject: [PATCH 2/5] feat: make input mode switching toggle less ambiguous --- src/ibus-chewing-engine.c | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/src/ibus-chewing-engine.c b/src/ibus-chewing-engine.c index 20c69934..2295b74a 100644 --- a/src/ibus-chewing-engine.c +++ b/src/ibus-chewing-engine.c @@ -336,10 +336,10 @@ ibus_chewing_engine_class_init(IBusChewingEngineClass *klass G_GNUC_UNUSED) { GObjectClass *g_object_class G_GNUC_UNUSED = (GObjectClass *)klass; IBusEngineClass *ibus_engine_class = (IBusEngineClass *)klass; - klass->InputMode_label_chi = - g_object_ref_sink(ibus_text_new_from_static_string(_("Chinese Mode"))); + klass->InputMode_label_chi = g_object_ref_sink( + ibus_text_new_from_static_string(_("Switch to Alphanumeric Mode"))); klass->InputMode_label_eng = g_object_ref_sink( - ibus_text_new_from_static_string(_("Alphanumeric Mode"))); + ibus_text_new_from_static_string(_("Switch to Chinese Mode"))); klass->InputMode_tooltip = g_object_ref_sink(ibus_text_new_from_static_string( _("Click to toggle Chinese/Alphanumeric Mode"))); From 3f97187d2a7e1495808bb3c9fa6d0b07903ba261 Mon Sep 17 00:00:00 2001 From: Kan-Ru Chen Date: Sat, 10 Feb 2024 08:58:59 +0900 Subject: [PATCH 3/5] feat: translate strings in C files --- ...bus-setup-chewing.pot => ibus-chewing.pot} | 65 +++++++++++++++++-- 1 file changed, 59 insertions(+), 6 deletions(-) rename po/{ibus-setup-chewing.pot => ibus-chewing.pot} (80%) diff --git a/po/ibus-setup-chewing.pot b/po/ibus-chewing.pot similarity index 80% rename from po/ibus-setup-chewing.pot rename to po/ibus-chewing.pot index 7b14ea08..893dd5f7 100644 --- a/po/ibus-setup-chewing.pot +++ b/po/ibus-chewing.pot @@ -1,19 +1,20 @@ -# Copyright (C) 2024 Kan-Ru Chen -# This file is distributed under the same license as the ibus-setup-chewing package. -# Kan-Ru Chen , 2024. +# SOME DESCRIPTIVE TITLE. +# Copyright (C) YEAR THE PACKAGE'S COPYRIGHT HOLDER +# This file is distributed under the same license as the PACKAGE package. +# FIRST AUTHOR , YEAR. # #, fuzzy msgid "" msgstr "" -"Project-Id-Version: ibus-setup-chewing 2.0.0\n" +"Project-Id-Version: PACKAGE VERSION\n" "Report-Msgid-Bugs-To: \n" -"POT-Creation-Date: 2024-02-07 22:12+0900\n" +"POT-Creation-Date: 2024-02-10 08:57+0900\n" "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n" "Last-Translator: FULL NAME \n" "Language-Team: LANGUAGE \n" "Language: \n" "MIME-Version: 1.0\n" -"Content-Type: text/plain; charset=CHARSET\n" +"Content-Type: text/plain; charset=UTF-8\n" "Content-Transfer-Encoding: 8bit\n" #: src/setup/ibus-setup-chewing-window.ui:13 @@ -243,3 +244,55 @@ msgstr "" #: src/setup/ibus-setup-chewing-window.ui:211 msgid "Choose from vertical or horizontal panel" msgstr "" + +#: src/main.c:67 +msgid "Cannot connect to IBus!" +msgstr "" + +#: src/main.c:78 +msgid "Chewing component" +msgstr "" + +#: src/main.c:79 src/main.c:92 +msgid "Peng Huang, Ding-Yi Chen" +msgstr "" + +#: src/main.c:88 +msgid "Chewing" +msgstr "" + +#: src/main.c:89 +msgid "Chinese chewing input method" +msgstr "" + +#: src/ibus-chewing-engine.c:340 +msgid "Switch to Alphanumeric Mode" +msgstr "" + +#: src/ibus-chewing-engine.c:342 +msgid "Switch to Chinese Mode" +msgstr "" + +#: src/ibus-chewing-engine.c:345 +msgid "Click to toggle Chinese/Alphanumeric Mode" +msgstr "" + +#: src/ibus-chewing-engine.c:351 +msgid "Fullwidth Form" +msgstr "" + +#: src/ibus-chewing-engine.c:353 +msgid "Halfwidth Form" +msgstr "" + +#: src/ibus-chewing-engine.c:356 +msgid "Click to toggle Halfwidth/Fullwidth Form" +msgstr "" + +#: src/ibus-chewing-engine.c:362 +msgid "IBus-Chewing Preferences" +msgstr "" + +#: src/ibus-chewing-engine.c:364 +msgid "Click to configure IBus-Chewing" +msgstr "" From 4af93bc1840fe3cedd62f5da463e071b6a2cead5 Mon Sep 17 00:00:00 2001 From: Kan-Ru Chen Date: Sat, 10 Feb 2024 09:07:43 +0900 Subject: [PATCH 4/5] feat: remove systray options from setup --- src/setup/ibus-setup-chewing-window.c | 2 -- src/setup/ibus-setup-chewing-window.ui | 8 -------- 2 files changed, 10 deletions(-) diff --git a/src/setup/ibus-setup-chewing-window.c b/src/setup/ibus-setup-chewing-window.c index 195e2bea..867ec8c9 100644 --- a/src/setup/ibus-setup-chewing-window.c +++ b/src/setup/ibus-setup-chewing-window.c @@ -27,7 +27,6 @@ struct _IbusSetupChewingWindow { AdwComboRow *kb_type; AdwComboRow *sel_keys; AdwSwitchRow *plain_zhuyin; - AdwSwitchRow *show_systray; AdwSwitchRow *auto_shift_cur; AdwSwitchRow *add_phrase_direction; AdwSwitchRow *clean_buffer_focus_out; @@ -60,7 +59,6 @@ ibus_setup_chewing_window_class_init(IbusSetupChewingWindowClass *klass) { bind_child(kb_type); bind_child(sel_keys); bind_child(plain_zhuyin); - bind_child(show_systray); bind_child(auto_shift_cur); bind_child(add_phrase_direction); bind_child(clean_buffer_focus_out); diff --git a/src/setup/ibus-setup-chewing-window.ui b/src/setup/ibus-setup-chewing-window.ui index d92073d7..6a2a91e6 100644 --- a/src/setup/ibus-setup-chewing-window.ui +++ b/src/setup/ibus-setup-chewing-window.ui @@ -62,14 +62,6 @@ Enable or disable automatic candidate selection - - - Show Systray Icon - Whether to show the systray icon - This feature is currently not implemented. - False - - From 7936c02e0dd405b8488e358a419003ec717f7d8e Mon Sep 17 00:00:00 2001 From: Kan-Ru Chen Date: Sat, 10 Feb 2024 09:17:40 +0900 Subject: [PATCH 5/5] fix: remove strings that don't need translation --- po/ibus-chewing.pot | 14 +++----------- src/main.c | 16 +++++++++++----- 2 files changed, 14 insertions(+), 16 deletions(-) diff --git a/po/ibus-chewing.pot b/po/ibus-chewing.pot index 893dd5f7..1be15d31 100644 --- a/po/ibus-chewing.pot +++ b/po/ibus-chewing.pot @@ -8,7 +8,7 @@ msgid "" msgstr "" "Project-Id-Version: PACKAGE VERSION\n" "Report-Msgid-Bugs-To: \n" -"POT-Creation-Date: 2024-02-10 08:57+0900\n" +"POT-Creation-Date: 2024-02-10 09:15+0900\n" "PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE\n" "Last-Translator: FULL NAME \n" "Language-Team: LANGUAGE \n" @@ -249,19 +249,11 @@ msgstr "" msgid "Cannot connect to IBus!" msgstr "" -#: src/main.c:78 -msgid "Chewing component" -msgstr "" - -#: src/main.c:79 src/main.c:92 -msgid "Peng Huang, Ding-Yi Chen" -msgstr "" - -#: src/main.c:88 +#: src/main.c:94 msgid "Chewing" msgstr "" -#: src/main.c:89 +#: src/main.c:95 msgid "Chinese chewing input method" msgstr "" diff --git a/src/main.c b/src/main.c index ad9ec808..b26c2ec7 100644 --- a/src/main.c +++ b/src/main.c @@ -74,12 +74,18 @@ static void start_component(void) { component = ibus_component_new_from_file( QUOTE_ME(DATA_DIR) "/ibus/component/chewing.xml"); } else { + // clang-format off component = ibus_component_new( - QUOTE_ME(PROJECT_SCHEMA_ID), _("Chewing component"), - QUOTE_ME(PRJ_VER), "GPLv2+", _("Peng Huang, Ding-Yi Chen"), - "http://code.google.com/p/ibus", + QUOTE_ME(PROJECT_SCHEMA_ID), + "Chewing component", + QUOTE_ME(PRJ_VER), + "GPLv2+", + "Peng Huang, Ding-Yi Chen", + "https://github.com/chewing/ibus-chewing", QUOTE_ME(LIBEXEC_DIR) "/ibus-engine-chewing --ibus", - QUOTE_ME(PROJECT_NAME)); + QUOTE_ME(PROJECT_NAME) + ); + // clang-format on } // clang-format off @@ -89,7 +95,7 @@ static void start_component(void) { "description", _("Chinese chewing input method"), "language", "zh_TW", "license", "GPLv2+", - "author", _("Peng Huang, Ding-Yi Chen"), + "author", "Peng Huang, Ding-Yi Chen", "icon", QUOTE_ME(PRJ_DATA_DIR) "/icons/" QUOTE_ME(PROJECT_NAME) ".png", "icon_prop_key", "InputMode", "symbol", "酷",