Add some bug fixes & translation updates
This commit is contained in:
		
							parent
							
								
									00b12e4183
								
							
						
					
					
						commit
						108a616e7f
					
				
							
								
								
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										1
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @ -69,3 +69,4 @@ ibus-1.3.6.tar.gz | ||||
| /ibus-1.5.29-rc2.tar.gz | ||||
| /ibus-1.5.30-beta1.tar.gz | ||||
| /ibus-1.5.30-rc1.tar.gz | ||||
| /ibus-1.5.30-rc2.tar.gz | ||||
|  | ||||
							
								
								
									
										225
									
								
								ibus-HEAD.patch
									
									
									
									
									
								
							
							
						
						
									
										225
									
								
								ibus-HEAD.patch
									
									
									
									
									
								
							| @ -0,0 +1,225 @@ | ||||
| From b6376d3a680f7f43583de7731629666b8dd85f01 Mon Sep 17 00:00:00 2001 | ||||
| From: fujiwarat <takao.fujiwara1@gmail.com> | ||||
| Date: Fri, 22 Mar 2024 09:47:28 +0900 | ||||
| Subject: [PATCH] ui/gtk3: Configure initial keymaps with localectl in Wayland | ||||
| 
 | ||||
| `setxkbmap -query` returns US layout with Xwayland and it does not | ||||
| correspond to the session keymaps so ibus-panel now uses | ||||
| `localectl status` in Wayland but it does not provide the session | ||||
| XKB options against `setxkbmap` command in Xorg. | ||||
| Need to think how to load or set the XKB options in Wayland later. | ||||
| 
 | ||||
| BUG=rhbz#2267615 | ||||
| ---
 | ||||
|  ui/gtk3/panel.vala     |   2 +- | ||||
|  ui/gtk3/xkblayout.vala | 123 ++++++++++++++++++++++++++++++----------- | ||||
|  2 files changed, 91 insertions(+), 34 deletions(-) | ||||
| 
 | ||||
| diff --git a/ui/gtk3/panel.vala b/ui/gtk3/panel.vala
 | ||||
| index c7176619..3576972d 100644
 | ||||
| --- a/ui/gtk3/panel.vala
 | ||||
| +++ b/ui/gtk3/panel.vala
 | ||||
| @@ -509,7 +509,7 @@ class Panel : IBus.PanelService {
 | ||||
|          string layouts; | ||||
|          string variants; | ||||
|          string option; | ||||
| -        XKBLayout.get_layout(out layouts, out variants, out option);
 | ||||
| +        m_xkblayout.get_layout(out layouts, out variants, out option);
 | ||||
|   | ||||
|          GLib.List<IBus.EngineDesc> xkb_engines = | ||||
|                  new GLib.List<IBus.EngineDesc>(); | ||||
| diff --git a/ui/gtk3/xkblayout.vala b/ui/gtk3/xkblayout.vala
 | ||||
| index 729b48ce..7812c4bb 100644
 | ||||
| --- a/ui/gtk3/xkblayout.vala
 | ||||
| +++ b/ui/gtk3/xkblayout.vala
 | ||||
| @@ -4,7 +4,7 @@
 | ||||
|   * | ||||
|   * Copyright(c) 2014 Red Hat, Inc. | ||||
|   * Copyright(c) 2014 Peng Huang <shawn.p.huang@gmail.com> | ||||
| - * Copyright(c) 2014 Takao Fujiwara <tfujiwar@redhat.com>
 | ||||
| + * Copyright(c) 2014-2024 Takao Fujiwara <tfujiwar@redhat.com>
 | ||||
|   * | ||||
|   * This library is free software; you can redistribute it and/or | ||||
|   * modify it under the terms of the GNU Lesser General Public | ||||
| @@ -25,11 +25,11 @@
 | ||||
|  class XKBLayout | ||||
|  { | ||||
|      private const string XKB_COMMAND = "setxkbmap"; | ||||
| -    private const string XKB_QUERY_ARG = "-query";
 | ||||
|      private const string XKB_LAYOUT_ARG = "-layout"; | ||||
|      private const string XMODMAP_COMMAND = "xmodmap"; | ||||
|      private const string[] XMODMAP_KNOWN_FILES = {".xmodmap", ".xmodmaprc", | ||||
|                                                    ".Xmodmap", ".Xmodmaprc"}; | ||||
| +    private string[] m_get_layout_args = {};
 | ||||
|      private string[] m_xkb_latin_layouts = {}; | ||||
|      private string m_default_layout = ""; | ||||
|      private string m_default_variant = ""; | ||||
| @@ -39,16 +39,23 @@ class XKBLayout
 | ||||
|      public XKBLayout() { | ||||
|      } | ||||
|   | ||||
| +
 | ||||
|      public void set_latin_layouts(string[] xkb_latin_layouts) { | ||||
|          m_xkb_latin_layouts = xkb_latin_layouts; | ||||
|      } | ||||
|   | ||||
| -    public static void get_layout(out string layout,
 | ||||
| -                                  out string variant,
 | ||||
| -                                  out string option) {
 | ||||
| +
 | ||||
| +    public void get_layout(out string layout,
 | ||||
| +                           out string variant,
 | ||||
| +                           out string option) {
 | ||||
| +        search_get_layout_program();
 | ||||
| +        if (m_get_layout_args[0] == null) {
 | ||||
| +            warning("Not found localectl or setxkbmap command in PATH");
 | ||||
| +            return;
 | ||||
| +        }
 | ||||
|          string[] exec_command = {}; | ||||
| -        exec_command += XKB_COMMAND;
 | ||||
| -        exec_command += XKB_QUERY_ARG;
 | ||||
| +        foreach (unowned string arg in m_get_layout_args)
 | ||||
| +            exec_command += arg;
 | ||||
|          string standard_output = null; | ||||
|          string standard_error = null; | ||||
|          int exit_status = 0; | ||||
| @@ -69,46 +76,94 @@ class XKBLayout
 | ||||
|          } catch (GLib.SpawnError err) { | ||||
|              stderr.printf("IBUS_ERROR: %s\n", err.message); | ||||
|          } | ||||
| -        if (exit_status != 0) {
 | ||||
| +        if (exit_status != 0)
 | ||||
|              stderr.printf("IBUS_ERROR: %s\n", standard_error ?? ""); | ||||
| -        }
 | ||||
| -        if (standard_output == null) {
 | ||||
| +        if (standard_output == null)
 | ||||
|              return; | ||||
| +
 | ||||
| +        if (exec_command[0] == "localectl") {
 | ||||
| +            parse_localectl_status_str(standard_output,
 | ||||
| +                                       out layout,
 | ||||
| +                                       out variant,
 | ||||
| +                                       out option);
 | ||||
| +        } else if (exec_command[0] == XKB_COMMAND) {
 | ||||
| +            parse_xkbmap_query_str(standard_output,
 | ||||
| +                                   out layout,
 | ||||
| +                                   out variant,
 | ||||
| +                                   out option);
 | ||||
|          } | ||||
| +    }
 | ||||
| +
 | ||||
|   | ||||
| +    private void search_get_layout_program() {
 | ||||
| +        if (m_get_layout_args[0] != null)
 | ||||
| +            return;
 | ||||
| +        string get_layout_command = null;
 | ||||
| +        // setxkbmap can get the session XKB options in Xorg.
 | ||||
| +        if (BindingCommon.default_is_xdisplay())
 | ||||
| +            get_layout_command = "setxkbmap -query";
 | ||||
| +        else if (GLib.Environment.find_program_in_path("localectl") != null)
 | ||||
| +            get_layout_command = "localectl status";
 | ||||
| +        else if (GLib.Environment.find_program_in_path("setxkbmap") != null)
 | ||||
| +            get_layout_command = "setxkbmap -query";
 | ||||
| +        if (get_layout_command != null)
 | ||||
| +            m_get_layout_args = get_layout_command.split(" ");
 | ||||
| +    }
 | ||||
| +
 | ||||
| +
 | ||||
| +    private void parse_localectl_status_str(string standard_output,
 | ||||
| +                                            out string layout,
 | ||||
| +                                            out string variant,
 | ||||
| +                                            out string option) {
 | ||||
| +        layout = "";
 | ||||
| +        variant = "";
 | ||||
| +        option = "";
 | ||||
|          foreach (string line in standard_output.split("\n")) { | ||||
| -            string element = "layout:";
 | ||||
| -            string retval = "";
 | ||||
| -            if (line.has_prefix(element)) {
 | ||||
| -                retval = line[element.length:line.length];
 | ||||
| -                if (retval != null) {
 | ||||
| -                    retval = retval.strip();
 | ||||
| +            const string[] elements = { "X11 Layout:", "X11 Variant:" };
 | ||||
| +            foreach (unowned string element in elements) {
 | ||||
| +                string retval = "";
 | ||||
| +                int index = line.index_of(element);
 | ||||
| +                if (index >= 0) {
 | ||||
| +                    retval = line[index + element.length:line.length];
 | ||||
| +                    if (retval != null)
 | ||||
| +                        retval = retval.strip();
 | ||||
| +                    if (element == elements[0])
 | ||||
| +                        layout = retval;
 | ||||
| +                    else if (element == elements[1])
 | ||||
| +                        variant = retval;
 | ||||
|                  } | ||||
| -                layout = retval;
 | ||||
|              } | ||||
| +        }
 | ||||
| +    }
 | ||||
|   | ||||
| -            element = "variant:";
 | ||||
| -            retval = "";
 | ||||
| -            if (line.has_prefix(element)) {
 | ||||
| -                retval = line[element.length:line.length];
 | ||||
| -                if (retval != null) {
 | ||||
| -                    retval = retval.strip();
 | ||||
| -                }
 | ||||
| -                variant = retval;
 | ||||
| -            }
 | ||||
|   | ||||
| -            element = "options:";
 | ||||
| -            retval = "";
 | ||||
| -            if (line.has_prefix(element)) {
 | ||||
| -                retval = line[element.length:line.length];
 | ||||
| -                if (retval != null) {
 | ||||
| -                    retval = retval.strip();
 | ||||
| +    private void parse_xkbmap_query_str(string standard_output,
 | ||||
| +                                        out string layout,
 | ||||
| +                                        out string variant,
 | ||||
| +                                        out string option) {
 | ||||
| +        layout = "";
 | ||||
| +        variant = "";
 | ||||
| +        option = "";
 | ||||
| +        foreach (string line in standard_output.split("\n")) {
 | ||||
| +            const string[] elements = { "layout:", "variant:", "options:" };
 | ||||
| +            foreach (unowned string element in elements) {
 | ||||
| +                string retval = "";
 | ||||
| +                if (line.has_prefix(element)) {
 | ||||
| +                    retval = line[element.length:line.length];
 | ||||
| +                    if (retval != null)
 | ||||
| +                        retval = retval.strip();
 | ||||
| +                    if (element == elements[0])
 | ||||
| +                        layout = retval;
 | ||||
| +                    else if (element == elements[1])
 | ||||
| +                        variant = retval;
 | ||||
| +                    else if (element == elements[2])
 | ||||
| +                        option = retval;
 | ||||
|                  } | ||||
| -                option = retval;
 | ||||
|              } | ||||
|          } | ||||
|      } | ||||
|   | ||||
| +
 | ||||
|      public void set_layout(IBus.EngineDesc engine) { | ||||
|          string layout = engine.get_layout(); | ||||
|          string variant = engine.get_layout_variant(); | ||||
| @@ -206,6 +261,7 @@ class XKBLayout
 | ||||
|          run_xmodmap(); | ||||
|      } | ||||
|   | ||||
| +
 | ||||
|      public void run_xmodmap() { | ||||
|          if (!m_use_xmodmap) { | ||||
|              return; | ||||
| @@ -246,6 +302,7 @@ class XKBLayout
 | ||||
|          } | ||||
|      } | ||||
|   | ||||
| +
 | ||||
|      public void set_use_xmodmap(bool use_xmodmap) { | ||||
|          m_use_xmodmap = use_xmodmap; | ||||
|      } | ||||
| -- 
 | ||||
| 2.43.0 | ||||
| 
 | ||||
| @ -57,7 +57,7 @@ | ||||
| %global dbus_python_version 0.83.0 | ||||
| 
 | ||||
| Name:           ibus | ||||
| Version:        1.5.30~rc1 | ||||
| Version:        1.5.30~rc2 | ||||
| Release:        1%{?dist} | ||||
| Summary:        Intelligent Input Bus for Linux OS | ||||
| License:        LGPL-2.1-or-later | ||||
| @ -66,6 +66,7 @@ Source0:        https://github.com/ibus/%name/releases/download/%{source_version | ||||
| Source1:        %{name}-xinput | ||||
| Source2:        %{name}.conf.5 | ||||
| # Patch0:         %%{name}-HEAD.patch | ||||
| Patch0:         %{name}-HEAD.patch | ||||
| # Under testing #1349148 #1385349 #1350291 #1406699 #1432252 #1601577 | ||||
| Patch1:         %{name}-1385349-segv-bus-proxy.patch | ||||
| %if 0%{?fedora:0}%{?rhel:1} | ||||
| @ -580,6 +581,9 @@ dconf update || : | ||||
| %{_datadir}/installed-tests/ibus | ||||
| 
 | ||||
| %changelog | ||||
| * Fri Mar 22 2024 Takao Fujiwara <tfujiwar@redhat.com> - 1.5.30~rc1-2 | ||||
| - Add some bug fixes & translation updates | ||||
| 
 | ||||
| * Wed Feb 28 2024 Takao Fujiwara <tfujiwar@redhat.com> - 1.5.30~rc1-1 | ||||
| - Add some bug fixes & translation updates | ||||
| 
 | ||||
|  | ||||
							
								
								
									
										2
									
								
								sources
									
									
									
									
									
								
							
							
						
						
									
										2
									
								
								sources
									
									
									
									
									
								
							| @ -1 +1 @@ | ||||
| SHA512 (ibus-1.5.30-rc1.tar.gz) = a47aafce7d3e8b5d346ab584990bb94dfe7e037e4152ad1c704574d1eac38eaf640e5d9327ca604f29d4b727823293b2fe60370941c370e1b508ef89ceb1e1de | ||||
| SHA512 (ibus-1.5.30-rc2.tar.gz) = e86b661766b5da449dc75d1cd6871ea0cc112dd87eb6c801e2c6e14708d261d733565a205fab131cb3a22e16a0fe8d3e2f1a328e78521f3e2a4135e9bacdeccb | ||||
|  | ||||
		Loading…
	
		Reference in New Issue
	
	Block a user