diff options
| -rw-r--r-- | src/ld-symbol-category.c | 132 | ||||
| -rw-r--r-- | src/ld-symbol-category.h | 6 | 
2 files changed, 135 insertions, 3 deletions
| diff --git a/src/ld-symbol-category.c b/src/ld-symbol-category.c index 15c1351..0eb0dac 100644 --- a/src/ld-symbol-category.c +++ b/src/ld-symbol-category.c @@ -40,6 +40,21 @@ struct _LdSymbolCategoryPrivate  G_DEFINE_TYPE (LdSymbolCategory, ld_symbol_category, G_TYPE_OBJECT); +enum +{ +	PROP_0, +	PROP_NAME, +	PROP_IMAGE_PATH +}; + +static void +ld_symbol_category_get_property (GObject *object, guint property_id, +	GValue *value, GParamSpec *pspec); + +static void +ld_symbol_category_set_property (GObject *object, guint property_id, +	const GValue *value, GParamSpec *pspec); +  static void  ld_symbol_category_finalize (GObject *gobject); @@ -48,10 +63,33 @@ static void  ld_symbol_category_class_init (LdSymbolCategoryClass *klass)  {  	GObjectClass *object_class; +	GParamSpec *pspec;  	object_class = G_OBJECT_CLASS (klass); +	object_class->get_property = ld_symbol_category_get_property; +	object_class->set_property = ld_symbol_category_set_property;  	object_class->finalize = ld_symbol_category_finalize; +/** + * LdSymbolCategory:name: + * + * The name of this symbol category. + */ +	pspec = g_param_spec_string ("name", "Name", +		"The name of this symbol category.", +		"", G_PARAM_READWRITE); +	g_object_class_install_property (object_class, PROP_NAME, pspec); + +/** + * LdSymbolCategory:image-path: + * + * Path to an image file representing this category. + */ +	pspec = g_param_spec_string ("image-path", "Image path", +		"Path to an image file representing this category.", +		"", G_PARAM_READWRITE); +	g_object_class_install_property (object_class, PROP_IMAGE_PATH, pspec); +  	g_type_class_add_private (klass, sizeof (LdSymbolCategoryPrivate));  } @@ -63,6 +101,46 @@ ld_symbol_category_init (LdSymbolCategory *self)  }  static void +ld_symbol_category_get_property (GObject *object, guint property_id, +	GValue *value, GParamSpec *pspec) +{ +	LdSymbolCategory *self; + +	self = LD_SYMBOL_CATEGORY (object); +	switch (property_id) +	{ +	case PROP_NAME: +		g_value_set_string (value, ld_symbol_category_get_name (self)); +		break; +	case PROP_IMAGE_PATH: +		g_value_set_string (value, ld_symbol_category_get_image_path (self)); +		break; +	default: +		G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec); +	} +} + +static void +ld_symbol_category_set_property (GObject *object, guint property_id, +	const GValue *value, GParamSpec *pspec) +{ +	LdSymbolCategory *self; + +	self = LD_SYMBOL_CATEGORY (object); +	switch (property_id) +	{ +	case PROP_NAME: +		ld_symbol_category_set_name (self, g_value_get_string (value)); +		break; +	case PROP_IMAGE_PATH: +		ld_symbol_category_set_image_path (self, g_value_get_string (value)); +		break; +	default: +		G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec); +	} +} + +static void  ld_symbol_category_finalize (GObject *gobject)  {  	LdSymbolCategory *self; @@ -74,6 +152,9 @@ ld_symbol_category_finalize (GObject *gobject)  	if (self->priv->image_path)  		g_free (self->priv->image_path); +	g_slist_foreach (self->priv->children, (GFunc) g_object_unref, NULL); +	g_slist_free (self->priv->children); +  	/* Chain up to the parent class. */  	G_OBJECT_CLASS (ld_symbol_category_parent_class)->finalize (gobject);  } @@ -153,3 +234,54 @@ ld_symbol_category_get_image_path (LdSymbolCategory *self)  	return self->priv->image_path;  } +/** + * ld_symbol_category_insert_child: + * @self: An #LdSymbolCategory object. + * @child: The child to be inserted. + * @pos: The position at which the child will be inserted. + *       Negative values will append to the end of list. + * + * Insert a child into the category. + */ +void +ld_symbol_category_insert_child (LdSymbolCategory *self, +	GObject *child, gint pos) +{ +	g_return_if_fail (LD_IS_SYMBOL_CATEGORY (self)); +	g_return_if_fail (G_IS_OBJECT (child)); + +	g_object_ref (child); +	self->priv->children = g_slist_insert (self->priv->children, child, pos); +} + +/** + * ld_symbol_category_remove_child: + * @self: An #LdSymbolCategory object. + * @child: The child to be removed. + * + * Removes a child from the category. + */ +void +ld_symbol_category_remove_child (LdSymbolCategory *self, +	GObject *child) +{ +	g_return_if_fail (LD_IS_SYMBOL_CATEGORY (self)); +	g_return_if_fail (G_IS_OBJECT (child)); + +	g_object_unref (child); +	self->priv->children = g_slist_remove (self->priv->children, child); +} + +/** + * ld_symbol_category_get_children: + * @self: An #LdSymbolCategory object. + * + * Return value: The internal list of children. Do not modify. + */ +const GSList * +ld_symbol_category_get_children (LdSymbolCategory *self) +{ +	g_return_val_if_fail (LD_IS_SYMBOL_CATEGORY (self), NULL); +	return self->priv->children; +} + diff --git a/src/ld-symbol-category.h b/src/ld-symbol-category.h index 21286c9..113bf83 100644 --- a/src/ld-symbol-category.h +++ b/src/ld-symbol-category.h @@ -47,6 +47,7 @@ struct _LdSymbolCategory   */  struct _LdSymbolCategoryClass  { +/*< private >*/  	GObjectClass parent_class;  }; @@ -55,18 +56,17 @@ GType ld_symbol_category_get_type (void) G_GNUC_CONST;  LdSymbolCategory *ld_symbol_category_new (const gchar *name); -/* TODO: Create properties for "name" and "image_path". */  void ld_symbol_category_set_name (LdSymbolCategory *self, const gchar *name);  const gchar *ld_symbol_category_get_name (LdSymbolCategory *self);  void ld_symbol_category_set_image_path (LdSymbolCategory *self,  	const gchar *image_path);  const gchar *ld_symbol_category_get_image_path (LdSymbolCategory *self); -/* TODO: Implement. */ +  void ld_symbol_category_insert_child (LdSymbolCategory *self,  	GObject *child, gint pos);  void ld_symbol_category_remove_child (LdSymbolCategory *self,  	GObject *child); -GSList *ld_symbol_category_get_children (LdSymbolCategory *self); +const GSList *ld_symbol_category_get_children (LdSymbolCategory *self);  G_END_DECLS | 
