mirror of
https://gitlab.gnome.org/GNOME/glib.git
synced 2025-03-30 20:33:08 +02:00
Merge branch 'fix-freeze-count-underflow' into 'main'
gobject: Don't thaw excessively Closes #2666 See merge request GNOME/glib!2736
This commit is contained in:
commit
6e42e2efe1
@ -2128,7 +2128,7 @@ g_object_new_with_custom_constructor (GObjectClass *class,
|
|||||||
/* Remember: if it was newly_constructed then g_object_init()
|
/* Remember: if it was newly_constructed then g_object_init()
|
||||||
* already did a freeze, so we now have two. Release one.
|
* already did a freeze, so we now have two. Release one.
|
||||||
*/
|
*/
|
||||||
if (newly_constructed)
|
if (newly_constructed && CLASS_HAS_NOTIFY (class))
|
||||||
g_object_notify_queue_thaw (object, nqueue);
|
g_object_notify_queue_thaw (object, nqueue);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -18,27 +18,15 @@
|
|||||||
#include <glib-object.h>
|
#include <glib-object.h>
|
||||||
|
|
||||||
/* --- MySingleton class --- */
|
/* --- MySingleton class --- */
|
||||||
typedef struct {
|
|
||||||
|
struct _MySingleton {
|
||||||
GObject parent_instance;
|
GObject parent_instance;
|
||||||
} MySingleton;
|
int myint;
|
||||||
typedef struct {
|
};
|
||||||
GObjectClass parent_class;
|
|
||||||
} MySingletonClass;
|
|
||||||
|
|
||||||
static GType my_singleton_get_type (void);
|
#define MY_TYPE_SINGLETON my_singleton_get_type ()
|
||||||
#define MY_TYPE_SINGLETON (my_singleton_get_type ())
|
G_DECLARE_FINAL_TYPE (MySingleton, my_singleton, MY, SINGLETON, GObject)
|
||||||
#define MY_SINGLETON(o) \
|
G_DEFINE_FINAL_TYPE (MySingleton, my_singleton, G_TYPE_OBJECT)
|
||||||
(G_TYPE_CHECK_INSTANCE_CAST ((o), MY_TYPE_SINGLETON, MySingleton))
|
|
||||||
#define MY_IS_SINGLETON(o) \
|
|
||||||
(G_TYPE_CHECK_INSTANCE_TYPE ((o), MY_TYPE_SINGLETON))
|
|
||||||
#define MY_SINGLETON_CLASS(c) \
|
|
||||||
(G_TYPE_CHECK_CLASS_CAST ((c), MY_TYPE_SINGLETON, MySingletonClass))
|
|
||||||
#define MY_IS_SINGLETON_CLASS(c) \
|
|
||||||
(G_TYPE_CHECK_CLASS_TYPE ((c), MY_TYPE_SINGLETON))
|
|
||||||
#define MY_SINGLETON_GET_CLASS(o) \
|
|
||||||
(G_TYPE_INSTANCE_GET_CLASS ((o), MY_TYPE_SINGLETON, MySingletonClass))
|
|
||||||
|
|
||||||
G_DEFINE_TYPE (MySingleton, my_singleton, G_TYPE_OBJECT)
|
|
||||||
|
|
||||||
static MySingleton *the_one_and_only = NULL;
|
static MySingleton *the_one_and_only = NULL;
|
||||||
|
|
||||||
@ -54,6 +42,15 @@ my_singleton_constructor (GType type,
|
|||||||
return G_OBJECT_CLASS (my_singleton_parent_class)->constructor (type, n_construct_properties, construct_properties);
|
return G_OBJECT_CLASS (my_singleton_parent_class)->constructor (type, n_construct_properties, construct_properties);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
my_singleton_finalize (GObject *object)
|
||||||
|
{
|
||||||
|
g_assert ((GObject *) the_one_and_only == object);
|
||||||
|
the_one_and_only = NULL;
|
||||||
|
|
||||||
|
G_OBJECT_CLASS (my_singleton_parent_class)->finalize (object);
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
my_singleton_init (MySingleton *self)
|
my_singleton_init (MySingleton *self)
|
||||||
{
|
{
|
||||||
@ -62,15 +59,49 @@ my_singleton_init (MySingleton *self)
|
|||||||
}
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
my_singleton_class_init (MySingletonClass *klass)
|
my_singleton_set_property (GObject *gobject,
|
||||||
|
guint prop_id,
|
||||||
|
const GValue *value,
|
||||||
|
GParamSpec *pspec)
|
||||||
{
|
{
|
||||||
G_OBJECT_CLASS (klass)->constructor = my_singleton_constructor;
|
MySingleton *self = (MySingleton *) gobject;
|
||||||
|
|
||||||
|
g_assert (prop_id == 1);
|
||||||
|
|
||||||
|
self->myint = g_value_get_int (value);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* --- test program --- */
|
static void
|
||||||
int
|
my_singleton_get_property (GObject *gobject,
|
||||||
main (int argc,
|
guint prop_id,
|
||||||
char *argv[])
|
GValue *value,
|
||||||
|
GParamSpec *pspec)
|
||||||
|
{
|
||||||
|
MySingleton *self = (MySingleton *) gobject;
|
||||||
|
|
||||||
|
g_assert (prop_id == 1);
|
||||||
|
|
||||||
|
g_value_set_int (value, self->myint);
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
my_singleton_class_init (MySingletonClass *klass)
|
||||||
|
{
|
||||||
|
GObjectClass *object_class = G_OBJECT_CLASS (klass);
|
||||||
|
|
||||||
|
object_class->constructor = my_singleton_constructor;
|
||||||
|
object_class->finalize = my_singleton_finalize;
|
||||||
|
object_class->set_property = my_singleton_set_property;
|
||||||
|
object_class->get_property = my_singleton_get_property;
|
||||||
|
|
||||||
|
g_object_class_install_property (G_OBJECT_CLASS (klass), 1,
|
||||||
|
g_param_spec_int ("foo", NULL, NULL,
|
||||||
|
0, G_MAXINT, 0,
|
||||||
|
G_PARAM_READWRITE | G_PARAM_CONSTRUCT | G_PARAM_STATIC_STRINGS));
|
||||||
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
test_singleton_construction (void)
|
||||||
{
|
{
|
||||||
MySingleton *singleton, *obj;
|
MySingleton *singleton, *obj;
|
||||||
|
|
||||||
@ -85,5 +116,32 @@ main (int argc,
|
|||||||
|
|
||||||
/* shutdown */
|
/* shutdown */
|
||||||
g_object_unref (singleton);
|
g_object_unref (singleton);
|
||||||
return 0;
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
test_singleton_construct_property (void)
|
||||||
|
{
|
||||||
|
MySingleton *singleton;
|
||||||
|
|
||||||
|
g_test_summary ("Test that creating a singleton with a construct-time property works");
|
||||||
|
g_test_bug ("https://gitlab.gnome.org/GNOME/glib/-/issues/2666");
|
||||||
|
|
||||||
|
/* create the singleton and set a property at construction time */
|
||||||
|
singleton = g_object_new (MY_TYPE_SINGLETON, "foo", 1, NULL);
|
||||||
|
g_assert_nonnull (singleton);
|
||||||
|
|
||||||
|
/* shutdown */
|
||||||
|
g_object_unref (singleton);
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
main (int argc,
|
||||||
|
char *argv[])
|
||||||
|
{
|
||||||
|
g_test_init (&argc, &argv, NULL);
|
||||||
|
|
||||||
|
g_test_add_func ("/gobject/singleton/construction", test_singleton_construction);
|
||||||
|
g_test_add_func ("/gobject/singleton/construct-property", test_singleton_construct_property);
|
||||||
|
|
||||||
|
return g_test_run ();
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user