mirror of
				https://gitlab.gnome.org/GNOME/glib.git
				synced 2025-10-26 14:02:17 +01:00 
			
		
		
		
	Merge branch 'th/gsignal-cleanup' into 'master'
[th/gsignal-cleanup] minor changes to GSignal related code See merge request GNOME/glib!1900
This commit is contained in:
		| @@ -1952,30 +1952,38 @@ g_signal_new_valist (const gchar       *signal_name, | |||||||
|                      GSignalFlags       signal_flags, |                      GSignalFlags       signal_flags, | ||||||
|                      GClosure          *class_closure, |                      GClosure          *class_closure, | ||||||
|                      GSignalAccumulator accumulator, |                      GSignalAccumulator accumulator, | ||||||
| 		     gpointer		accu_data, |                      gpointer           accu_data, | ||||||
|                      GSignalCMarshaller c_marshaller, |                      GSignalCMarshaller c_marshaller, | ||||||
|                      GType              return_type, |                      GType              return_type, | ||||||
|                      guint              n_params, |                      guint              n_params, | ||||||
|                      va_list            args) |                      va_list            args) | ||||||
| { | { | ||||||
|  |   /* Somewhat arbitrarily reserve 200 bytes. That should cover the majority | ||||||
|  |    * of cases where n_params is small and still be small enough for what we | ||||||
|  |    * want to put on the stack. */ | ||||||
|  |   GType param_types_stack[200 / sizeof (GType)]; | ||||||
|  |   GType *param_types_heap = NULL; | ||||||
|   GType *param_types; |   GType *param_types; | ||||||
|   guint i; |   guint i; | ||||||
|   guint signal_id; |   guint signal_id; | ||||||
|  |  | ||||||
|  |   param_types = param_types_stack; | ||||||
|   if (n_params > 0) |   if (n_params > 0) | ||||||
|     { |     { | ||||||
|       param_types = g_new (GType, n_params); |       if (G_UNLIKELY (n_params > G_N_ELEMENTS (param_types_stack))) | ||||||
|  |         { | ||||||
|  |           param_types_heap = g_new (GType, n_params); | ||||||
|  |           param_types = param_types_heap; | ||||||
|  |         } | ||||||
|  |  | ||||||
|       for (i = 0; i < n_params; i++) |       for (i = 0; i < n_params; i++) | ||||||
| 	param_types[i] = va_arg (args, GType); |         param_types[i] = va_arg (args, GType); | ||||||
|     } |     } | ||||||
|   else |  | ||||||
|     param_types = NULL; |  | ||||||
|  |  | ||||||
|   signal_id = g_signal_newv (signal_name, itype, signal_flags, |   signal_id = g_signal_newv (signal_name, itype, signal_flags, | ||||||
| 			     class_closure, accumulator, accu_data, c_marshaller, |                              class_closure, accumulator, accu_data, c_marshaller, | ||||||
| 			     return_type, n_params, param_types); |                              return_type, n_params, param_types); | ||||||
|   g_free (param_types); |   g_free (param_types_heap); | ||||||
|  |  | ||||||
|   return signal_id; |   return signal_id; | ||||||
| } | } | ||||||
| @@ -4004,6 +4012,7 @@ g_signal_accumulator_first_wins (GSignalInvocationHint *ihint, | |||||||
|  * g_clear_signal_handler: |  * g_clear_signal_handler: | ||||||
|  * @handler_id_ptr: A pointer to a handler ID (of type #gulong) of the handler to be disconnected. |  * @handler_id_ptr: A pointer to a handler ID (of type #gulong) of the handler to be disconnected. | ||||||
|  * @instance: (type GObject.Object): The instance to remove the signal handler from. |  * @instance: (type GObject.Object): The instance to remove the signal handler from. | ||||||
|  |  *   This pointer may be %NULL or invalid, if the handler ID is zero. | ||||||
|  * |  * | ||||||
|  * Disconnects a handler from @instance so it will not be called during |  * Disconnects a handler from @instance so it will not be called during | ||||||
|  * any future or currently ongoing emissions of the signal it has been |  * any future or currently ongoing emissions of the signal it has been | ||||||
| @@ -4011,21 +4020,20 @@ g_signal_accumulator_first_wins (GSignalInvocationHint *ihint, | |||||||
|  * |  * | ||||||
|  * If the handler ID is 0 then this function does nothing. |  * If the handler ID is 0 then this function does nothing. | ||||||
|  * |  * | ||||||
|  * A macro is also included that allows this function to be used without |  * There is also a macro version of this function so that the code | ||||||
|  * pointer casts. |  * will be inlined. | ||||||
|  * |  * | ||||||
|  * Since: 2.62 |  * Since: 2.62 | ||||||
|  */ |  */ | ||||||
| #undef g_clear_signal_handler |  | ||||||
| void | void | ||||||
| g_clear_signal_handler (gulong   *handler_id_ptr, | (g_clear_signal_handler) (gulong   *handler_id_ptr, | ||||||
|                         gpointer  instance) |                           gpointer  instance) | ||||||
| { | { | ||||||
|   g_return_if_fail (handler_id_ptr != NULL); |   g_return_if_fail (handler_id_ptr != NULL); | ||||||
|  |  | ||||||
|   if (*handler_id_ptr != 0) | #ifndef g_clear_signal_handler | ||||||
|     { | #error g_clear_signal_handler() macro is not defined | ||||||
|       g_signal_handler_disconnect (instance, *handler_id_ptr); | #endif | ||||||
|       *handler_id_ptr = 0; |  | ||||||
|     } |   g_clear_signal_handler (handler_id_ptr, instance); | ||||||
| } | } | ||||||
|   | |||||||
| @@ -451,13 +451,14 @@ void	 g_clear_signal_handler		      (gulong            *handler_id_ptr, | |||||||
|  |  | ||||||
| #define  g_clear_signal_handler(handler_id_ptr, instance)           \ | #define  g_clear_signal_handler(handler_id_ptr, instance)           \ | ||||||
|   G_STMT_START {                                                    \ |   G_STMT_START {                                                    \ | ||||||
|     G_STATIC_ASSERT (sizeof *(handler_id_ptr) == sizeof (gulong));  \ |     gpointer const _instance      = (instance);                     \ | ||||||
|     gulong _handler_id = *(handler_id_ptr);                         \ |     gulong *const _handler_id_ptr = (handler_id_ptr);               \ | ||||||
|  |     const gulong _handler_id      = *_handler_id_ptr;               \ | ||||||
|                                                                     \ |                                                                     \ | ||||||
|     if (_handler_id > 0)                                            \ |     if (_handler_id > 0)                                            \ | ||||||
|       {                                                             \ |       {                                                             \ | ||||||
|         g_signal_handler_disconnect ((instance), _handler_id);      \ |         *_handler_id_ptr = 0;                                       \ | ||||||
|         *(handler_id_ptr) = 0;                                      \ |         g_signal_handler_disconnect (_instance, _handler_id);       \ | ||||||
|       }                                                             \ |       }                                                             \ | ||||||
|   } G_STMT_END                                                      \ |   } G_STMT_END                                                      \ | ||||||
|   GLIB_AVAILABLE_MACRO_IN_2_62 |   GLIB_AVAILABLE_MACRO_IN_2_62 | ||||||
|   | |||||||
		Reference in New Issue
	
	Block a user