- Update HEAD.patch to make parallel dict build - Update 1385349-segv-bus-proxy.patch
This commit is contained in:
		
							parent
							
								
									5be3a0c89f
								
							
						
					
					
						commit
						c9bb32a521
					
				| @ -1,27 +1,17 @@ | |||||||
| From fd19aaaa097e71e7589bdb3627971dc10bf3873e Mon Sep 17 00:00:00 2001 | From 180ee9ce8d8f839db3e30803be5846c794416cbe Mon Sep 17 00:00:00 2001 | ||||||
| From: fujiwarat <takao.fujiwara1@gmail.com> | From: fujiwarat <takao.fujiwara1@gmail.com> | ||||||
| Date: Thu, 13 Feb 2020 19:33:32 +0900 | Date: Fri, 15 May 2020 19:17:03 +0900 | ||||||
| Subject: [PATCH] Fix SEGV in bus_panel_proxy_focus_in() | Subject: [PATCH] Fix SEGV in bus_panel_proxy_focus_in() | ||||||
| 
 | 
 | ||||||
| rhbz#1349148, rhbz#1385349 |  | ||||||
| SEGV in BUS_IS_PANEL_PROXY() in bus_panel_proxy_focus_in() |  | ||||||
| Check if GDBusConnect is closed before bus_panel_proxy_new() is called. |  | ||||||
| 
 |  | ||||||
| rhbz#1350291 SEGV in BUS_IS_CONNECTION(skip_connection) in | rhbz#1350291 SEGV in BUS_IS_CONNECTION(skip_connection) in | ||||||
| bus_dbus_impl_dispatch_message_by_rule() | bus_dbus_impl_dispatch_message_by_rule() | ||||||
| check if dbus_connection is closed in bus_dbus_impl_connection_filter_cb(). | check if dbus_connection is closed in bus_dbus_impl_connection_filter_cb(). | ||||||
| 
 | 
 | ||||||
| rhbz#1406699 SEGV in new_owner!=NULL in bus_dbus_impl_name_owner_changed() | rhbz#1767976 SEGV in assert(connection != NULL) in | ||||||
| which is called by bus_name_service_remove_owner() | bus_dbus_impl_connection_filter_cb() | ||||||
| If bus_connection_get_unique_name()==NULL, set new_owner="" in | call bus_connection_set_filter() in bus_dbus_impl_destroy(). | ||||||
| bus_name_service_remove_owner() |  | ||||||
| 
 | 
 | ||||||
| rhbz#1432252 SEGV in old_owner!=NULL in bus_dbus_impl_name_owner_changed() | rhbz#1601577 rhbz#1797726 SEGV in ibus_engine_desc_get_layout() in | ||||||
| which is called by bus_name_service_set_primary_owner() |  | ||||||
| If bus_connection_get_unique_name()==NULL, set old_owner="" in |  | ||||||
| bus_name_service_set_primary_owner() |  | ||||||
| 
 |  | ||||||
| rhbz#1601577 SEGV in ibus_engine_desc_get_layout() in |  | ||||||
| bus_engine_proxy_new_internal() | bus_engine_proxy_new_internal() | ||||||
| WIP: Added a GError to get the error message to check why the SEGV happened. | WIP: Added a GError to get the error message to check why the SEGV happened. | ||||||
| 
 | 
 | ||||||
| @ -34,111 +24,35 @@ Do not call atexit functions in _sighandler(). | |||||||
| rhbz#1795499 SEGV in ibus_bus_get_bus_address() because of no _bus->priv. | rhbz#1795499 SEGV in ibus_bus_get_bus_address() because of no _bus->priv. | ||||||
| _changed_cb() should not be called after ibus_bus_destroy() is called. | _changed_cb() should not be called after ibus_bus_destroy() is called. | ||||||
| 
 | 
 | ||||||
| BUG=rhbz#1349148 | rhbz#1771238 SEGV in assert(m_loop == null) in switcher.vala. | ||||||
| BUG=rhbz#1385349 | Grabbing keyboard could be failed and switcher received the keyboard | ||||||
|  | events and m_loop was not released. | ||||||
|  | 
 | ||||||
|  | rhbz#1797120 SEGV in assert(bus.is_connected()) in panel_binding_construct() | ||||||
|  | Check m_ibus in extension.vala:bus_name_acquired_cb() | ||||||
|  | 
 | ||||||
| BUG=rhbz#1350291 | BUG=rhbz#1350291 | ||||||
| BUG=rhbz#1406699 |  | ||||||
| BUG=rhbz#1432252 |  | ||||||
| BUG=rhbz#1601577 | BUG=rhbz#1601577 | ||||||
| BUG=rhbz#1663528 | BUG=rhbz#1663528 | ||||||
| BUG=rhbz#1767691 | BUG=rhbz#1767691 | ||||||
| BUG=rhbz#1795499 | BUG=rhbz#1795499 | ||||||
|  | BUG=rhbz#1771238 | ||||||
|  | BUG=rhbz#1767976 | ||||||
|  | BUG=rhbz#1797120 | ||||||
| ---
 | ---
 | ||||||
|  bus/dbusimpl.c    | 70 +++++++++++++++++++++++++++++++++++++++++------ |  bus/dbusimpl.c         | 47 ++++++++++++++++++++++++--- | ||||||
|  bus/engineproxy.c |  9 +++++- |  bus/engineproxy.c      | 11 ++++++- | ||||||
|  bus/ibusimpl.c    | 21 ++++++++++++-- |  client/x11/main.c      |  8 ++++- | ||||||
|  client/x11/main.c |  8 +++++- |  src/ibusbus.c          |  5 +++ | ||||||
|  src/ibusbus.c     |  5 ++++ |  ui/gtk3/extension.vala |  4 +++ | ||||||
|  5 files changed, 100 insertions(+), 13 deletions(-) |  ui/gtk3/switcher.vala  | 73 +++++++++++++++++++++++++----------------- | ||||||
|  |  6 files changed, 112 insertions(+), 36 deletions(-) | ||||||
| 
 | 
 | ||||||
| diff --git a/bus/dbusimpl.c b/bus/dbusimpl.c
 | diff --git a/bus/dbusimpl.c b/bus/dbusimpl.c
 | ||||||
| index b54ef817..fb38faf0 100644
 | index 59787a80..af2fbde2 100644
 | ||||||
| --- a/bus/dbusimpl.c
 | --- a/bus/dbusimpl.c
 | ||||||
| +++ b/bus/dbusimpl.c
 | +++ b/bus/dbusimpl.c
 | ||||||
| @@ -2,7 +2,8 @@
 | @@ -610,6 +610,7 @@ static void
 | ||||||
|  /* vim:set et sts=4: */ |  | ||||||
|  /* ibus - The Input Bus |  | ||||||
|   * Copyright (C) 2008-2013 Peng Huang <shawn.p.huang@gmail.com> |  | ||||||
| - * Copyright (C) 2008-2013 Red Hat, Inc.
 |  | ||||||
| + * Copyright (C) 2015-2019 Takao Fujiwara <takao.fujiwara1@gmail.com>
 |  | ||||||
| + * Copyright (C) 2008-2019 Red Hat, Inc.
 |  | ||||||
|   * |  | ||||||
|   * This library is free software; you can redistribute it and/or |  | ||||||
|   * modify it under the terms of the GNU Lesser General Public |  | ||||||
| @@ -344,6 +345,8 @@ bus_name_service_set_primary_owner (BusNameService     *service,
 |  | ||||||
|                                      BusConnectionOwner *owner, |  | ||||||
|                                      BusDBusImpl        *dbus) |  | ||||||
|  { |  | ||||||
| +    gboolean has_old_owner = FALSE;
 |  | ||||||
| +
 |  | ||||||
|      g_assert (service != NULL); |  | ||||||
|      g_assert (owner != NULL); |  | ||||||
|      g_assert (dbus != NULL); |  | ||||||
| @@ -351,6 +354,13 @@ bus_name_service_set_primary_owner (BusNameService     *service,
 |  | ||||||
|      BusConnectionOwner *old = service->owners != NULL ? |  | ||||||
|              (BusConnectionOwner *)service->owners->data : NULL; |  | ||||||
|   |  | ||||||
| +    /* rhbz#1432252 If bus_connection_get_unique_name() == NULL,
 |  | ||||||
| +     * "Hello" method is not received yet.
 |  | ||||||
| +     */
 |  | ||||||
| +    if (old != NULL && bus_connection_get_unique_name (old->conn) != NULL) {
 |  | ||||||
| +        has_old_owner = TRUE;
 |  | ||||||
| +    }
 |  | ||||||
| +
 |  | ||||||
|      if (old != NULL) { |  | ||||||
|          g_signal_emit (dbus, |  | ||||||
|                         dbus_signals[NAME_LOST], |  | ||||||
| @@ -370,7 +380,8 @@ bus_name_service_set_primary_owner (BusNameService     *service,
 |  | ||||||
|                     0, |  | ||||||
|                     owner->conn, |  | ||||||
|                     service->name, |  | ||||||
| -                   old != NULL ? bus_connection_get_unique_name (old->conn) : "",
 |  | ||||||
| +                   has_old_owner ? bus_connection_get_unique_name (old->conn) :
 |  | ||||||
| +                           "",
 |  | ||||||
|                     bus_connection_get_unique_name (owner->conn)); |  | ||||||
|   |  | ||||||
|      if (old != NULL && old->do_not_queue != 0) { |  | ||||||
| @@ -427,6 +438,7 @@ bus_name_service_remove_owner (BusNameService     *service,
 |  | ||||||
|                                 BusDBusImpl        *dbus) |  | ||||||
|  { |  | ||||||
|      GSList *owners; |  | ||||||
| +    gboolean has_new_owner = FALSE;
 |  | ||||||
|   |  | ||||||
|      g_assert (service != NULL); |  | ||||||
|      g_assert (owner != NULL); |  | ||||||
| @@ -439,6 +451,13 @@ bus_name_service_remove_owner (BusNameService     *service,
 |  | ||||||
|          BusConnectionOwner *_new = NULL; |  | ||||||
|          if (owners->next != NULL) { |  | ||||||
|              _new = (BusConnectionOwner *)owners->next->data; |  | ||||||
| +            /* rhbz#1406699 If bus_connection_get_unique_name() == NULL,
 |  | ||||||
| +             * "Hello" method is not received yet.
 |  | ||||||
| +             */
 |  | ||||||
| +            if (_new != NULL &&
 |  | ||||||
| +                bus_connection_get_unique_name (_new->conn) != NULL) {
 |  | ||||||
| +                has_new_owner = TRUE;
 |  | ||||||
| +            }
 |  | ||||||
|          } |  | ||||||
|   |  | ||||||
|          if (dbus != NULL) { |  | ||||||
| @@ -447,7 +466,7 @@ bus_name_service_remove_owner (BusNameService     *service,
 |  | ||||||
|                             0, |  | ||||||
|                             owner->conn, |  | ||||||
|                             service->name); |  | ||||||
| -            if (_new != NULL) {
 |  | ||||||
| +            if (has_new_owner) {
 |  | ||||||
|                  g_signal_emit (dbus, |  | ||||||
|                                 dbus_signals[NAME_ACQUIRED], |  | ||||||
|                                 0, |  | ||||||
| @@ -460,7 +479,7 @@ bus_name_service_remove_owner (BusNameService     *service,
 |  | ||||||
|                      _new != NULL ? _new->conn : NULL, |  | ||||||
|                      service->name, |  | ||||||
|                      bus_connection_get_unique_name (owner->conn), |  | ||||||
| -                    _new != NULL ? bus_connection_get_unique_name (_new->conn) : "");
 |  | ||||||
| +                    has_new_owner ? bus_connection_get_unique_name (_new->conn) : "");
 |  | ||||||
|   |  | ||||||
|          } |  | ||||||
|      } |  | ||||||
| @@ -591,6 +610,7 @@ static void
 |  | ||||||
|  bus_dbus_impl_destroy (BusDBusImpl *dbus) |  bus_dbus_impl_destroy (BusDBusImpl *dbus) | ||||||
|  { |  { | ||||||
|      GList *p; |      GList *p; | ||||||
| @ -146,7 +60,18 @@ index b54ef817..fb38faf0 100644 | |||||||
|   |   | ||||||
|      for (p = dbus->objects; p != NULL; p = p->next) { |      for (p = dbus->objects; p != NULL; p = p->next) { | ||||||
|          IBusService *object = (IBusService *) p->data; |          IBusService *object = (IBusService *) p->data; | ||||||
| @@ -628,12 +648,39 @@ bus_dbus_impl_destroy (BusDBusImpl *dbus)
 | @@ -633,6 +634,10 @@ bus_dbus_impl_destroy (BusDBusImpl *dbus)
 | ||||||
|  |   | ||||||
|  |      for (p = dbus->connections; p != NULL; p = p->next) { | ||||||
|  |          BusConnection *connection = BUS_CONNECTION (p->data); | ||||||
|  | +        /* rhbz#1767976 Fix connection == NULL in
 | ||||||
|  | +         * bus_dbus_impl_connection_filter_cb()
 | ||||||
|  | +         */
 | ||||||
|  | +        bus_connection_set_filter (connection, NULL, NULL, NULL);
 | ||||||
|  |          g_signal_handlers_disconnect_by_func (connection, | ||||||
|  |                  bus_dbus_impl_connection_destroy_cb, dbus); | ||||||
|  |          ibus_object_destroy (IBUS_OBJECT (connection)); | ||||||
|  | @@ -647,12 +652,39 @@ bus_dbus_impl_destroy (BusDBusImpl *dbus)
 | ||||||
|      dbus->unique_names = NULL; |      dbus->unique_names = NULL; | ||||||
|      dbus->names = NULL; |      dbus->names = NULL; | ||||||
|   |   | ||||||
| @ -188,7 +113,7 @@ index b54ef817..fb38faf0 100644 | |||||||
|   |   | ||||||
|      /* FIXME destruct _lock and _queue members. */ |      /* FIXME destruct _lock and _queue members. */ | ||||||
|      IBUS_OBJECT_CLASS(bus_dbus_impl_parent_class)->destroy ((IBusObject *) dbus); |      IBUS_OBJECT_CLASS(bus_dbus_impl_parent_class)->destroy ((IBusObject *) dbus); | ||||||
| @@ -1464,13 +1511,20 @@ bus_dbus_impl_connection_filter_cb (GDBusConnection *dbus_connection,
 | @@ -1483,13 +1515,20 @@ bus_dbus_impl_connection_filter_cb (GDBusConnection *dbus_connection,
 | ||||||
|                                      gboolean         incoming, |                                      gboolean         incoming, | ||||||
|                                      gpointer         user_data) |                                      gpointer         user_data) | ||||||
|  { |  { | ||||||
| @ -212,10 +137,16 @@ index b54ef817..fb38faf0 100644 | |||||||
|      if (incoming) { |      if (incoming) { | ||||||
|          /* is incoming message */ |          /* is incoming message */ | ||||||
| diff --git a/bus/engineproxy.c b/bus/engineproxy.c
 | diff --git a/bus/engineproxy.c b/bus/engineproxy.c
 | ||||||
| index 2d98995c..2176e0c9 100644
 | index 2d98995c..ec17900f 100644
 | ||||||
| --- a/bus/engineproxy.c
 | --- a/bus/engineproxy.c
 | ||||||
| +++ b/bus/engineproxy.c
 | +++ b/bus/engineproxy.c
 | ||||||
| @@ -665,6 +665,7 @@ bus_engine_proxy_new_internal (const gchar     *path,
 | @@ -660,11 +660,13 @@ bus_engine_proxy_g_signal (GDBusProxy  *proxy,
 | ||||||
|  |      g_return_if_reached (); | ||||||
|  |  } | ||||||
|  |   | ||||||
|  | +#pragma GCC optimize ("O0")
 | ||||||
|  |  static BusEngineProxy * | ||||||
|  |  bus_engine_proxy_new_internal (const gchar     *path, | ||||||
|                                 IBusEngineDesc  *desc, |                                 IBusEngineDesc  *desc, | ||||||
|                                 GDBusConnection *connection) |                                 GDBusConnection *connection) | ||||||
|  { |  { | ||||||
| @ -223,7 +154,7 @@ index 2d98995c..2176e0c9 100644 | |||||||
|      g_assert (path); |      g_assert (path); | ||||||
|      g_assert (IBUS_IS_ENGINE_DESC (desc)); |      g_assert (IBUS_IS_ENGINE_DESC (desc)); | ||||||
|      g_assert (G_IS_DBUS_CONNECTION (connection)); |      g_assert (G_IS_DBUS_CONNECTION (connection)); | ||||||
| @@ -673,7 +674,7 @@ bus_engine_proxy_new_internal (const gchar     *path,
 | @@ -673,7 +675,7 @@ bus_engine_proxy_new_internal (const gchar     *path,
 | ||||||
|      BusEngineProxy *engine = |      BusEngineProxy *engine = | ||||||
|          (BusEngineProxy *) g_initable_new (BUS_TYPE_ENGINE_PROXY, |          (BusEngineProxy *) g_initable_new (BUS_TYPE_ENGINE_PROXY, | ||||||
|                                             NULL, |                                             NULL, | ||||||
| @ -232,7 +163,7 @@ index 2d98995c..2176e0c9 100644 | |||||||
|                                             "desc",              desc, |                                             "desc",              desc, | ||||||
|                                             "g-connection",      connection, |                                             "g-connection",      connection, | ||||||
|                                             "g-interface-name",  IBUS_INTERFACE_ENGINE, |                                             "g-interface-name",  IBUS_INTERFACE_ENGINE, | ||||||
| @@ -681,6 +682,12 @@ bus_engine_proxy_new_internal (const gchar     *path,
 | @@ -681,12 +683,19 @@ bus_engine_proxy_new_internal (const gchar     *path,
 | ||||||
|                                             "g-default-timeout", g_gdbus_timeout, |                                             "g-default-timeout", g_gdbus_timeout, | ||||||
|                                             "g-flags",           flags, |                                             "g-flags",           flags, | ||||||
|                                             NULL); |                                             NULL); | ||||||
| @ -245,60 +176,13 @@ index 2d98995c..2176e0c9 100644 | |||||||
|      const gchar *layout = ibus_engine_desc_get_layout (desc); |      const gchar *layout = ibus_engine_desc_get_layout (desc); | ||||||
|      if (layout != NULL && layout[0] != '\0') { |      if (layout != NULL && layout[0] != '\0') { | ||||||
|          engine->keymap = ibus_keymap_get (layout); |          engine->keymap = ibus_keymap_get (layout); | ||||||
| diff --git a/bus/ibusimpl.c b/bus/ibusimpl.c
 |  | ||||||
| index 85761d30..f0dbccd1 100644
 |  | ||||||
| --- a/bus/ibusimpl.c
 |  | ||||||
| +++ b/bus/ibusimpl.c
 |  | ||||||
| @@ -464,13 +464,16 @@ _dbus_name_owner_changed_cb (BusDBusImpl   *dbus,
 |  | ||||||
|      else if (!g_strcmp0 (name, IBUS_SERVICE_PANEL_EXTENSION_EMOJI)) |  | ||||||
|          panel_type = PANEL_TYPE_EXTENSION_EMOJI; |  | ||||||
|   |  | ||||||
| -    if (panel_type != PANEL_TYPE_NONE) {
 |  | ||||||
| +    do {
 |  | ||||||
| +        if (panel_type == PANEL_TYPE_NONE)
 |  | ||||||
| +            break;
 |  | ||||||
|          if (g_strcmp0 (new_name, "") != 0) { |  | ||||||
|              /* a Panel process is started. */ |  | ||||||
|              BusConnection *connection; |  | ||||||
|              BusInputContext *context = NULL; |  | ||||||
|              BusPanelProxy   **panel = (panel_type == PANEL_TYPE_PANEL) ? |  | ||||||
|                                        &ibus->panel : &ibus->emoji_extension; |  | ||||||
| +            GDBusConnection *dbus_connection = NULL;
 |  | ||||||
|   |  | ||||||
|              if (*panel != NULL) { |  | ||||||
|                  ibus_proxy_destroy ((IBusProxy *)(*panel)); |  | ||||||
| @@ -479,9 +482,21 @@ _dbus_name_owner_changed_cb (BusDBusImpl   *dbus,
 |  | ||||||
|                  g_assert (*panel == NULL); |  | ||||||
|      } |      } | ||||||
|  |      return engine; | ||||||
|  |  } | ||||||
|  | +#pragma GCC reset_options
 | ||||||
|   |   | ||||||
| -            connection = bus_dbus_impl_get_connection_by_name (BUS_DEFAULT_DBUS, new_name);
 |  typedef struct { | ||||||
| +            connection = bus_dbus_impl_get_connection_by_name (BUS_DEFAULT_DBUS,
 |      GTask           *task; | ||||||
| +                                                               new_name);
 |  | ||||||
|              g_return_if_fail (connection != NULL); |  | ||||||
|   |  | ||||||
| +            dbus_connection = bus_connection_get_dbus_connection (connection);
 |  | ||||||
| +            /* rhbz#1349148 rhbz#1385349
 |  | ||||||
| +             * Avoid SEGV of BUS_IS_PANEL_PROXY (ibus->panel)
 |  | ||||||
| +             * This function is called during destroying the connection
 |  | ||||||
| +             * in this case? */
 |  | ||||||
| +            if (dbus_connection == NULL ||
 |  | ||||||
| +                g_dbus_connection_is_closed (dbus_connection)) {
 |  | ||||||
| +                new_name = "";
 |  | ||||||
| +                break;
 |  | ||||||
| +            }
 |  | ||||||
| +
 |  | ||||||
|              *panel = bus_panel_proxy_new (connection, panel_type); |  | ||||||
|              if (panel_type == PANEL_TYPE_EXTENSION_EMOJI) |  | ||||||
|                  ibus->enable_emoji_extension = FALSE; |  | ||||||
| @@ -535,7 +550,7 @@ _dbus_name_owner_changed_cb (BusDBusImpl   *dbus,
 |  | ||||||
|                  } |  | ||||||
|              } |  | ||||||
|          } |  | ||||||
| -    }
 |  | ||||||
| +    } while (0);
 |  | ||||||
|   |  | ||||||
|      bus_ibus_impl_component_name_owner_changed (ibus, name, old_name, new_name); |  | ||||||
|  } |  | ||||||
| diff --git a/client/x11/main.c b/client/x11/main.c
 | diff --git a/client/x11/main.c b/client/x11/main.c
 | ||||||
| index c9ee174d..768b91f0 100644
 | index c9ee174d..768b91f0 100644
 | ||||||
| --- a/client/x11/main.c
 | --- a/client/x11/main.c
 | ||||||
| @ -341,6 +225,125 @@ index b7ffbb47..668c8a26 100644 | |||||||
|          g_object_unref (bus->priv->monitor); |          g_object_unref (bus->priv->monitor); | ||||||
|          bus->priv->monitor = NULL; |          bus->priv->monitor = NULL; | ||||||
|      } |      } | ||||||
|  | diff --git a/ui/gtk3/extension.vala b/ui/gtk3/extension.vala
 | ||||||
|  | index ea3cd464..57ed1357 100644
 | ||||||
|  | --- a/ui/gtk3/extension.vala
 | ||||||
|  | +++ b/ui/gtk3/extension.vala
 | ||||||
|  | @@ -73,6 +73,10 @@ class ExtensionGtk : Gtk.Application {
 | ||||||
|  |                                        string signal_name, | ||||||
|  |                                        Variant parameters) { | ||||||
|  |          debug("signal_name = %s", signal_name); | ||||||
|  | +        /* rhbz#1797120 Fix assert(bus.is_connected()) in
 | ||||||
|  | +         * panel_binding_construct()
 | ||||||
|  | +         */
 | ||||||
|  | +        return_if_fail(m_bus.is_connected());
 | ||||||
|  |          m_panel = new PanelBinding(m_bus, this); | ||||||
|  |          m_panel.load_settings(); | ||||||
|  |      } | ||||||
|  | diff --git a/ui/gtk3/switcher.vala b/ui/gtk3/switcher.vala
 | ||||||
|  | index a4529c88..29a70dd5 100644
 | ||||||
|  | --- a/ui/gtk3/switcher.vala
 | ||||||
|  | +++ b/ui/gtk3/switcher.vala
 | ||||||
|  | @@ -140,8 +140,8 @@ class Switcher : Gtk.Window {
 | ||||||
|  |                     IBus.EngineDesc[] engines, | ||||||
|  |                     int               index, | ||||||
|  |                     string            input_context_path) { | ||||||
|  | -        assert (m_loop == null);
 | ||||||
|  | -        assert (index < engines.length);
 | ||||||
|  | +        assert(m_loop == null);
 | ||||||
|  | +        assert(index < engines.length);
 | ||||||
|  |   | ||||||
|  |          m_is_running = true; | ||||||
|  |          m_keyval = keyval; | ||||||
|  | @@ -198,16 +198,18 @@ class Switcher : Gtk.Window {
 | ||||||
|  |                             null, | ||||||
|  |                             event, | ||||||
|  |                             null); | ||||||
|  | -        if (status != Gdk.GrabStatus.SUCCESS)
 | ||||||
|  | +        if (status != Gdk.GrabStatus.SUCCESS) {
 | ||||||
|  |              warning("Grab keyboard failed! status = %d", status); | ||||||
|  | -        status = seat.grab(get_window(),
 | ||||||
|  | -                           Gdk.SeatCapabilities.POINTER,
 | ||||||
|  | -                           true,
 | ||||||
|  | -                           null,
 | ||||||
|  | -                           event,
 | ||||||
|  | -                           null);
 | ||||||
|  | -        if (status != Gdk.GrabStatus.SUCCESS)
 | ||||||
|  | -            warning("Grab pointer failed! status = %d", status);
 | ||||||
|  | +        } else {
 | ||||||
|  | +            status = seat.grab(get_window(),
 | ||||||
|  | +                               Gdk.SeatCapabilities.POINTER,
 | ||||||
|  | +                               true,
 | ||||||
|  | +                               null,
 | ||||||
|  | +                               event,
 | ||||||
|  | +                               null);
 | ||||||
|  | +            if (status != Gdk.GrabStatus.SUCCESS)
 | ||||||
|  | +                warning("Grab pointer failed! status = %d", status);
 | ||||||
|  | +        }
 | ||||||
|  |  #else | ||||||
|  |          Gdk.Device device = event.get_device(); | ||||||
|  |          if (device == null) { | ||||||
|  | @@ -243,30 +245,41 @@ class Switcher : Gtk.Window {
 | ||||||
|  |                                 Gdk.EventMask.KEY_RELEASE_MASK, | ||||||
|  |                                 null, | ||||||
|  |                                 Gdk.CURRENT_TIME); | ||||||
|  | -        if (status != Gdk.GrabStatus.SUCCESS)
 | ||||||
|  | +        if (status != Gdk.GrabStatus.SUCCESS) {
 | ||||||
|  |              warning("Grab keyboard failed! status = %d", status); | ||||||
|  | -        // Grab all pointer events
 | ||||||
|  | -        status = pointer.grab(get_window(),
 | ||||||
|  | -                              Gdk.GrabOwnership.NONE,
 | ||||||
|  | -                              true,
 | ||||||
|  | -                              Gdk.EventMask.BUTTON_PRESS_MASK |
 | ||||||
|  | -                              Gdk.EventMask.BUTTON_RELEASE_MASK,
 | ||||||
|  | -                              null,
 | ||||||
|  | -                              Gdk.CURRENT_TIME);
 | ||||||
|  | -        if (status != Gdk.GrabStatus.SUCCESS)
 | ||||||
|  | -            warning("Grab pointer failed! status = %d", status);
 | ||||||
|  | +        } else {
 | ||||||
|  | +            // Grab all pointer events
 | ||||||
|  | +            status = pointer.grab(get_window(),
 | ||||||
|  | +                                  Gdk.GrabOwnership.NONE,
 | ||||||
|  | +                                  true,
 | ||||||
|  | +                                  Gdk.EventMask.BUTTON_PRESS_MASK |
 | ||||||
|  | +                                  Gdk.EventMask.BUTTON_RELEASE_MASK,
 | ||||||
|  | +                                  null,
 | ||||||
|  | +                                  Gdk.CURRENT_TIME);
 | ||||||
|  | +            if (status != Gdk.GrabStatus.SUCCESS)
 | ||||||
|  | +                warning("Grab pointer failed! status = %d", status);
 | ||||||
|  | +        }
 | ||||||
|  |  #endif | ||||||
|  |   | ||||||
|  | -        // Probably we can delete m_popup_delay_time in 1.6
 | ||||||
|  | -        pointer.get_position_double(null,
 | ||||||
|  | -                                    out m_mouse_init_x,
 | ||||||
|  | -                                    out m_mouse_init_y);
 | ||||||
|  | -        m_mouse_moved = false;
 | ||||||
|  | +        /* Fix RHBZ #1771238 assert(m_loop == null)
 | ||||||
|  | +         * Grabbing keyboard can be failed when the second Super-e is typed
 | ||||||
|  | +         * before Switcher dialog is focused. And m_loop could not be released
 | ||||||
|  | +         * if the failed Super-e would call m_loop.run() below and could not
 | ||||||
|  | +         * call key_release_event(). And m_loop == null would be false in the
 | ||||||
|  | +         * third Super-e.
 | ||||||
|  | +         */
 | ||||||
|  | +        if (status == Gdk.GrabStatus.SUCCESS) {
 | ||||||
|  | +            // Probably we can delete m_popup_delay_time in 1.6
 | ||||||
|  | +            pointer.get_position_double(null,
 | ||||||
|  | +                                        out m_mouse_init_x,
 | ||||||
|  | +                                        out m_mouse_init_y);
 | ||||||
|  | +            m_mouse_moved = false;
 | ||||||
|  |   | ||||||
|  |   | ||||||
|  | -        m_loop = new GLib.MainLoop();
 | ||||||
|  | -        m_loop.run();
 | ||||||
|  | -        m_loop = null;
 | ||||||
|  | +            m_loop = new GLib.MainLoop();
 | ||||||
|  | +            m_loop.run();
 | ||||||
|  | +            m_loop = null;
 | ||||||
|  | +        }
 | ||||||
|  |   | ||||||
|  |  #if VALA_0_34 | ||||||
|  |          seat.ungrab(); | ||||||
| -- 
 | -- 
 | ||||||
| 2.24.1 | 2.24.1 | ||||||
| 
 | 
 | ||||||
|  | |||||||
							
								
								
									
										288
									
								
								ibus-HEAD.patch
									
									
									
									
									
								
							
							
						
						
									
										288
									
								
								ibus-HEAD.patch
									
									
									
									
									
								
							| @ -309,3 +309,291 @@ index f760fd5b..4232c549 100755 | |||||||
| -- 
 | -- 
 | ||||||
| 2.24.1 | 2.24.1 | ||||||
| 
 | 
 | ||||||
|  | From 8c4125bc78ce3502b5aeb053e7029cc2594f83f2 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: Changwoo Ryu <cwryu@debian.org> | ||||||
|  | Date: Sun, 12 Apr 2020 05:28:15 +0900 | ||||||
|  | Subject: [PATCH] src: Build the Emoji dictionaries in parallel | ||||||
|  | 
 | ||||||
|  | Instead of building Emoji dictionaries src/dicts/emoji-*.dict in sequence, a | ||||||
|  | pattern rule is specified for them. The make -jN option builds the | ||||||
|  | dictionaries in parallel. | ||||||
|  | 
 | ||||||
|  | The GNU make extensions like pattern rule and patsubst function are used for | ||||||
|  | it. But src/Makefile.am has had other GNU make extensions for a while, so | ||||||
|  | using more extensions should not make portability worse. | ||||||
|  | 
 | ||||||
|  | BUG=https://github.com/ibus/ibus/pull/2209 | ||||||
|  | ---
 | ||||||
|  |  src/Makefile.am | 55 ++++++++++++++++++++++++------------------------- | ||||||
|  |  1 file changed, 27 insertions(+), 28 deletions(-) | ||||||
|  | 
 | ||||||
|  | diff --git a/src/Makefile.am b/src/Makefile.am
 | ||||||
|  | index a8e3d07d..99de1ab7 100644
 | ||||||
|  | --- a/src/Makefile.am
 | ||||||
|  | +++ b/src/Makefile.am
 | ||||||
|  | @@ -246,42 +246,41 @@ if ENABLE_EMOJI_DICT
 | ||||||
|  |  AM_CPPFLAGS += -DENABLE_EMOJI_DICT | ||||||
|  |   | ||||||
|  |  dictdir = $(pkgdatadir)/dicts | ||||||
|  | -dict_DATA = dicts/emoji-en.dict
 | ||||||
|  |  LANG_FILES = $(basename $(notdir $(wildcard $(EMOJI_ANNOTATION_DIR)/*.xml))) | ||||||
|  | +EMOJI_DICT_FILES = $(patsubst %,dicts/emoji-%.dict,$(LANG_FILES))
 | ||||||
|  | +dict_DATA = $(EMOJI_DICT_FILES)
 | ||||||
|  |   | ||||||
|  |  noinst_PROGRAMS += emoji-parser | ||||||
|  |   | ||||||
|  | -dicts/emoji-en.dict: emoji-parser
 | ||||||
|  | +dicts/emoji-%.dict: emoji-parser
 | ||||||
|  |  	$(AM_V_at)if test x"$(LANG_FILES)" = x ; then \ | ||||||
|  |  	    echo "WARNING: Not found $(EMOJI_ANNOTATION_DIR)/en.xml" 1>&2; \ | ||||||
|  |  	fi; \ | ||||||
|  | -	for f in $(LANG_FILES) ; do \
 | ||||||
|  | -	    if test -f dicts/emoji-$$f.dict; then \
 | ||||||
|  | -	        echo "Already exists dicts/emoji-$$f.dict"; \
 | ||||||
|  | -	        continue; \
 | ||||||
|  | -	    fi; \
 | ||||||
|  | -	    if test -f \
 | ||||||
|  | -	    "$(EMOJI_ANNOTATION_DIR)/../annotationsDerived/$$f.xml" ; then \
 | ||||||
|  | -	        xml_derived_option="--xml-derived $(EMOJI_ANNOTATION_DIR)/../annotationsDerived/$$f.xml"; \
 | ||||||
|  | +	if test -f $@; then \
 | ||||||
|  | +	    echo "Already exists $@"; \
 | ||||||
|  | +	    exit 0; \
 | ||||||
|  | +	fi; \
 | ||||||
|  | +	if test -f \
 | ||||||
|  | +	    "$(EMOJI_ANNOTATION_DIR)/../annotationsDerived/$*.xml" ; then \
 | ||||||
|  | +	        xml_derived_option="--xml-derived $(EMOJI_ANNOTATION_DIR)/../annotationsDerived/$*.xml"; \
 | ||||||
|  |  	        plus_comment="derived"; \ | ||||||
|  | -	    fi; \
 | ||||||
|  | -	    if test x"$$f" = xen ; then \
 | ||||||
|  | -	        $(builddir)/emoji-parser \
 | ||||||
|  | -	            --unicode-emoji-dir $(UNICODE_EMOJI_DIR) \
 | ||||||
|  | -	            --xml $(EMOJI_ANNOTATION_DIR)/$$f.xml \
 | ||||||
|  | -	            $$xml_derived_option \
 | ||||||
|  | -	            --xml-ascii $(top_srcdir)/data/annotations/en_ascii.xml \
 | ||||||
|  | -	            --out-category ibusemojigen.h \
 | ||||||
|  | -	            --out $@; \
 | ||||||
|  | -	    else \
 | ||||||
|  | -	        $(builddir)/emoji-parser \
 | ||||||
|  | -	            --unicode-emoji-dir $(UNICODE_EMOJI_DIR) \
 | ||||||
|  | -	            --xml $(EMOJI_ANNOTATION_DIR)/$$f.xml \
 | ||||||
|  | -	            $$xml_derived_option \
 | ||||||
|  | -	            --out dicts/emoji-$$f.dict; \
 | ||||||
|  | -	    fi; \
 | ||||||
|  | -	    echo "Generated $$plus_comment dicts/emoji-$$f.dict"; \
 | ||||||
|  | -	done
 | ||||||
|  | +	fi; \
 | ||||||
|  | +	if test x"$*" = xen ; then \
 | ||||||
|  | +	    $(builddir)/emoji-parser \
 | ||||||
|  | +	        --unicode-emoji-dir $(UNICODE_EMOJI_DIR) \
 | ||||||
|  | +	        --xml $(EMOJI_ANNOTATION_DIR)/$*.xml \
 | ||||||
|  | +	        $$xml_derived_option \
 | ||||||
|  | +	        --xml-ascii $(top_srcdir)/data/annotations/en_ascii.xml \
 | ||||||
|  | +	        --out-category ibusemojigen.h \
 | ||||||
|  | +	        --out $@; \
 | ||||||
|  | +	else \
 | ||||||
|  | +	    $(builddir)/emoji-parser \
 | ||||||
|  | +	        --unicode-emoji-dir $(UNICODE_EMOJI_DIR) \
 | ||||||
|  | +	        --xml $(EMOJI_ANNOTATION_DIR)/$*.xml \
 | ||||||
|  | +	        $$xml_derived_option \
 | ||||||
|  | +	        --out $@; \
 | ||||||
|  | +	fi; \
 | ||||||
|  | +	echo "Generated $$plus_comment $@"
 | ||||||
|  |   | ||||||
|  |  ibusemojigen.h: dicts/emoji-en.dict | ||||||
|  |  	$(NULL) | ||||||
|  | -- 
 | ||||||
|  | 2.23.0.rc1 | ||||||
|  | 
 | ||||||
|  | From 02105c4d486283e6b561181d9c934d4d23f2d65e Mon Sep 17 00:00:00 2001 | ||||||
|  | From: fujiwarat <takao.fujiwara1@gmail.com> | ||||||
|  | Date: Thu, 14 May 2020 15:48:34 +0900 | ||||||
|  | Subject: [PATCH] bus: Fix SEGV in bus_panel_proxy_focus_in() | ||||||
|  | 
 | ||||||
|  | SEGV in BUS_IS_PANEL_PROXY() in bus_panel_proxy_focus_in() | ||||||
|  | Check if GDBusConnect is closed before bus_panel_proxy_new() is called. | ||||||
|  | 
 | ||||||
|  | BUG=rhbz#1349148 | ||||||
|  | BUG=rhbz#1385349 | ||||||
|  | ---
 | ||||||
|  |  bus/ibusimpl.c | 25 ++++++++++++++++++++----- | ||||||
|  |  1 file changed, 20 insertions(+), 5 deletions(-) | ||||||
|  | 
 | ||||||
|  | diff --git a/bus/ibusimpl.c b/bus/ibusimpl.c
 | ||||||
|  | index 85761d30..e432e849 100644
 | ||||||
|  | --- a/bus/ibusimpl.c
 | ||||||
|  | +++ b/bus/ibusimpl.c
 | ||||||
|  | @@ -2,8 +2,8 @@
 | ||||||
|  |  /* vim:set et sts=4: */ | ||||||
|  |  /* ibus - The Input Bus | ||||||
|  |   * Copyright (C) 2008-2013 Peng Huang <shawn.p.huang@gmail.com> | ||||||
|  | - * Copyright (C) 2011-2019 Takao Fujiwara <takao.fujiwara1@gmail.com>
 | ||||||
|  | - * Copyright (C) 2008-2019 Red Hat, Inc.
 | ||||||
|  | + * Copyright (C) 2011-2020 Takao Fujiwara <takao.fujiwara1@gmail.com>
 | ||||||
|  | + * Copyright (C) 2008-2020 Red Hat, Inc.
 | ||||||
|  |   * | ||||||
|  |   * This library is free software; you can redistribute it and/or | ||||||
|  |   * modify it under the terms of the GNU Lesser General Public | ||||||
|  | @@ -464,13 +464,16 @@ _dbus_name_owner_changed_cb (BusDBusImpl   *dbus,
 | ||||||
|  |      else if (!g_strcmp0 (name, IBUS_SERVICE_PANEL_EXTENSION_EMOJI)) | ||||||
|  |          panel_type = PANEL_TYPE_EXTENSION_EMOJI; | ||||||
|  |   | ||||||
|  | -    if (panel_type != PANEL_TYPE_NONE) {
 | ||||||
|  | +    do {
 | ||||||
|  | +        if (panel_type == PANEL_TYPE_NONE)
 | ||||||
|  | +            break;
 | ||||||
|  |          if (g_strcmp0 (new_name, "") != 0) { | ||||||
|  |              /* a Panel process is started. */ | ||||||
|  |              BusConnection *connection; | ||||||
|  |              BusInputContext *context = NULL; | ||||||
|  |              BusPanelProxy   **panel = (panel_type == PANEL_TYPE_PANEL) ? | ||||||
|  |                                        &ibus->panel : &ibus->emoji_extension; | ||||||
|  | +            GDBusConnection *dbus_connection = NULL;
 | ||||||
|  |   | ||||||
|  |              if (*panel != NULL) { | ||||||
|  |                  ibus_proxy_destroy ((IBusProxy *)(*panel)); | ||||||
|  | @@ -479,9 +482,21 @@ _dbus_name_owner_changed_cb (BusDBusImpl   *dbus,
 | ||||||
|  |                  g_assert (*panel == NULL); | ||||||
|  |              } | ||||||
|  |   | ||||||
|  | -            connection = bus_dbus_impl_get_connection_by_name (BUS_DEFAULT_DBUS, new_name);
 | ||||||
|  | +            connection = bus_dbus_impl_get_connection_by_name (BUS_DEFAULT_DBUS,
 | ||||||
|  | +                                                               new_name);
 | ||||||
|  |              g_return_if_fail (connection != NULL); | ||||||
|  |   | ||||||
|  | +            dbus_connection = bus_connection_get_dbus_connection (connection);
 | ||||||
|  | +            /* rhbz#1349148 rhbz#1385349
 | ||||||
|  | +             * Avoid SEGV of BUS_IS_PANEL_PROXY (ibus->panel)
 | ||||||
|  | +             * This function is called during destroying the connection
 | ||||||
|  | +             * in this case? */
 | ||||||
|  | +            if (dbus_connection == NULL ||
 | ||||||
|  | +                g_dbus_connection_is_closed (dbus_connection)) {
 | ||||||
|  | +                new_name = "";
 | ||||||
|  | +                break;
 | ||||||
|  | +            }
 | ||||||
|  | +
 | ||||||
|  |              *panel = bus_panel_proxy_new (connection, panel_type); | ||||||
|  |              if (panel_type == PANEL_TYPE_EXTENSION_EMOJI) | ||||||
|  |                  ibus->enable_emoji_extension = FALSE; | ||||||
|  | @@ -535,7 +550,7 @@ _dbus_name_owner_changed_cb (BusDBusImpl   *dbus,
 | ||||||
|  |                  } | ||||||
|  |              } | ||||||
|  |          } | ||||||
|  | -    }
 | ||||||
|  | +    } while (0);
 | ||||||
|  |   | ||||||
|  |      bus_ibus_impl_component_name_owner_changed (ibus, name, old_name, new_name); | ||||||
|  |  } | ||||||
|  | -- 
 | ||||||
|  | 2.24.1 | ||||||
|  | 
 | ||||||
|  | From f591381e3c892947ecaffe9131b9039ab9014498 Mon Sep 17 00:00:00 2001 | ||||||
|  | From: fujiwarat <takao.fujiwara1@gmail.com> | ||||||
|  | Date: Thu, 14 May 2020 16:02:00 +0900 | ||||||
|  | Subject: [PATCH] bus: Fix SEGV in bus_dbus_impl_name_owner_changed() | ||||||
|  | 
 | ||||||
|  | rhbz#1406699 SEGV in new_owner!=NULL in bus_dbus_impl_name_owner_changed() | ||||||
|  | which is called by bus_name_service_remove_owner() | ||||||
|  | If bus_connection_get_unique_name()==NULL, set new_owner="" in | ||||||
|  | bus_name_service_remove_owner() | ||||||
|  | 
 | ||||||
|  | rhbz#1432252 SEGV in old_owner!=NULL in bus_dbus_impl_name_owner_changed() | ||||||
|  | which is called by bus_name_service_set_primary_owner() | ||||||
|  | If bus_connection_get_unique_name()==NULL, set old_owner="" in | ||||||
|  | bus_name_service_set_primary_owner() | ||||||
|  | 
 | ||||||
|  | BUG=rhbz#1406699 | ||||||
|  | BUG=rhbz#1432252 | ||||||
|  | ---
 | ||||||
|  |  bus/dbusimpl.c | 27 +++++++++++++++++++++++---- | ||||||
|  |  1 file changed, 23 insertions(+), 4 deletions(-) | ||||||
|  | 
 | ||||||
|  | diff --git a/bus/dbusimpl.c b/bus/dbusimpl.c
 | ||||||
|  | index b54ef817..59787a80 100644
 | ||||||
|  | --- a/bus/dbusimpl.c
 | ||||||
|  | +++ b/bus/dbusimpl.c
 | ||||||
|  | @@ -2,7 +2,8 @@
 | ||||||
|  |  /* vim:set et sts=4: */ | ||||||
|  |  /* ibus - The Input Bus | ||||||
|  |   * Copyright (C) 2008-2013 Peng Huang <shawn.p.huang@gmail.com> | ||||||
|  | - * Copyright (C) 2008-2013 Red Hat, Inc.
 | ||||||
|  | + * Copyright (C) 2015-2020 Takao Fujiwara <takao.fujiwara1@gmail.com>
 | ||||||
|  | + * Copyright (C) 2008-2020 Red Hat, Inc.
 | ||||||
|  |   * | ||||||
|  |   * This library is free software; you can redistribute it and/or | ||||||
|  |   * modify it under the terms of the GNU Lesser General Public | ||||||
|  | @@ -344,6 +345,8 @@ bus_name_service_set_primary_owner (BusNameService     *service,
 | ||||||
|  |                                      BusConnectionOwner *owner, | ||||||
|  |                                      BusDBusImpl        *dbus) | ||||||
|  |  { | ||||||
|  | +    gboolean has_old_owner = FALSE;
 | ||||||
|  | +
 | ||||||
|  |      g_assert (service != NULL); | ||||||
|  |      g_assert (owner != NULL); | ||||||
|  |      g_assert (dbus != NULL); | ||||||
|  | @@ -351,6 +354,13 @@ bus_name_service_set_primary_owner (BusNameService     *service,
 | ||||||
|  |      BusConnectionOwner *old = service->owners != NULL ? | ||||||
|  |              (BusConnectionOwner *)service->owners->data : NULL; | ||||||
|  |   | ||||||
|  | +    /* rhbz#1432252 If bus_connection_get_unique_name() == NULL,
 | ||||||
|  | +     * "Hello" method is not received yet.
 | ||||||
|  | +     */
 | ||||||
|  | +    if (old != NULL && bus_connection_get_unique_name (old->conn) != NULL) {
 | ||||||
|  | +        has_old_owner = TRUE;
 | ||||||
|  | +    }
 | ||||||
|  | +
 | ||||||
|  |      if (old != NULL) { | ||||||
|  |          g_signal_emit (dbus, | ||||||
|  |                         dbus_signals[NAME_LOST], | ||||||
|  | @@ -370,7 +380,8 @@ bus_name_service_set_primary_owner (BusNameService     *service,
 | ||||||
|  |                     0, | ||||||
|  |                     owner->conn, | ||||||
|  |                     service->name, | ||||||
|  | -                   old != NULL ? bus_connection_get_unique_name (old->conn) : "",
 | ||||||
|  | +                   has_old_owner ? bus_connection_get_unique_name (old->conn) :
 | ||||||
|  | +                           "",
 | ||||||
|  |                     bus_connection_get_unique_name (owner->conn)); | ||||||
|  |   | ||||||
|  |      if (old != NULL && old->do_not_queue != 0) { | ||||||
|  | @@ -427,6 +438,7 @@ bus_name_service_remove_owner (BusNameService     *service,
 | ||||||
|  |                                 BusDBusImpl        *dbus) | ||||||
|  |  { | ||||||
|  |      GSList *owners; | ||||||
|  | +    gboolean has_new_owner = FALSE;
 | ||||||
|  |   | ||||||
|  |      g_assert (service != NULL); | ||||||
|  |      g_assert (owner != NULL); | ||||||
|  | @@ -439,6 +451,13 @@ bus_name_service_remove_owner (BusNameService     *service,
 | ||||||
|  |          BusConnectionOwner *_new = NULL; | ||||||
|  |          if (owners->next != NULL) { | ||||||
|  |              _new = (BusConnectionOwner *)owners->next->data; | ||||||
|  | +            /* rhbz#1406699 If bus_connection_get_unique_name() == NULL,
 | ||||||
|  | +             * "Hello" method is not received yet.
 | ||||||
|  | +             */
 | ||||||
|  | +            if (_new != NULL &&
 | ||||||
|  | +                bus_connection_get_unique_name (_new->conn) != NULL) {
 | ||||||
|  | +                has_new_owner = TRUE;
 | ||||||
|  | +            }
 | ||||||
|  |          } | ||||||
|  |   | ||||||
|  |          if (dbus != NULL) { | ||||||
|  | @@ -447,7 +466,7 @@ bus_name_service_remove_owner (BusNameService     *service,
 | ||||||
|  |                             0, | ||||||
|  |                             owner->conn, | ||||||
|  |                             service->name); | ||||||
|  | -            if (_new != NULL) {
 | ||||||
|  | +            if (has_new_owner) {
 | ||||||
|  |                  g_signal_emit (dbus, | ||||||
|  |                                 dbus_signals[NAME_ACQUIRED], | ||||||
|  |                                 0, | ||||||
|  | @@ -460,7 +479,7 @@ bus_name_service_remove_owner (BusNameService     *service,
 | ||||||
|  |                      _new != NULL ? _new->conn : NULL, | ||||||
|  |                      service->name, | ||||||
|  |                      bus_connection_get_unique_name (owner->conn), | ||||||
|  | -                    _new != NULL ? bus_connection_get_unique_name (_new->conn) : "");
 | ||||||
|  | +                    has_new_owner ? bus_connection_get_unique_name (_new->conn) : "");
 | ||||||
|  |   | ||||||
|  |          } | ||||||
|  |      } | ||||||
|  | -- 
 | ||||||
|  | 2.24.1 | ||||||
|  | 
 | ||||||
|  | |||||||
| @ -35,7 +35,7 @@ | |||||||
| 
 | 
 | ||||||
| Name:           ibus | Name:           ibus | ||||||
| Version:        1.5.22 | Version:        1.5.22 | ||||||
| Release:        5%{?dist} | Release:        6%{?dist} | ||||||
| Summary:        Intelligent Input Bus for Linux OS | Summary:        Intelligent Input Bus for Linux OS | ||||||
| License:        LGPLv2+ | License:        LGPLv2+ | ||||||
| URL:            https://github.com/ibus/%name/wiki | URL:            https://github.com/ibus/%name/wiki | ||||||
| @ -269,6 +269,7 @@ fi | |||||||
| #autoreconf -f -i -v | #autoreconf -f -i -v | ||||||
| #make -C ui/gtk3 maintainer-clean-generic | #make -C ui/gtk3 maintainer-clean-generic | ||||||
| #make -C tools maintainer-clean-generic | #make -C tools maintainer-clean-generic | ||||||
|  | autoreconf -f -i -v | ||||||
| %configure \ | %configure \ | ||||||
|     --disable-static \ |     --disable-static \ | ||||||
|     --enable-gtk2 \ |     --enable-gtk2 \ | ||||||
| @ -290,6 +291,7 @@ fi | |||||||
|     --enable-install-tests \ |     --enable-install-tests \ | ||||||
|     %{nil} |     %{nil} | ||||||
| 
 | 
 | ||||||
|  | make -C ui/gtk3 maintainer-clean-generic | ||||||
| %make_build | %make_build | ||||||
| 
 | 
 | ||||||
| %install | %install | ||||||
| @ -461,6 +463,11 @@ dconf update || : | |||||||
| %{_datadir}/installed-tests/ibus | %{_datadir}/installed-tests/ibus | ||||||
| 
 | 
 | ||||||
| %changelog | %changelog | ||||||
|  | * Fri May 15 2020 Takao Fujiwara <tfujiwar@redhat.com> - 1.5.22-6 | ||||||
|  | - Update HEAD.patch to make parallel dict build | ||||||
|  | - Update 1385349-segv-bus-proxy.patch | ||||||
|  | - Resolves #1767976 #1601577 #1771238 #1797120 | ||||||
|  | 
 | ||||||
| * Wed Apr 22 2020 Takao Fujiwara <tfujiwar@redhat.com> - 1.5.22-5 | * Wed Apr 22 2020 Takao Fujiwara <tfujiwar@redhat.com> - 1.5.22-5 | ||||||
| - Update ibus-desktop-testing-runner for su command | - Update ibus-desktop-testing-runner for su command | ||||||
| 
 | 
 | ||||||
|  | |||||||
		Loading…
	
		Reference in New Issue
	
	Block a user