/* * Copyright (C) 2012 - Juan Ferrer Toribio * * This program is free software: you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation, either version 3 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see . */ #include "gvn-param-spec.h" #include "gvn-misc.h" #include "gvn-value.h" /** * SECTION: gvn-param-spec * @Short_description: * @Title: GvnParamSpec **/ /** * gvn_param_spec_new: * * Creates a new #GvnParamSpec. * * Return value: the new #GvnParamSpec **/ GvnParamSpec * gvn_param_spec_new () { return gvn_param_spec_new_with_attrs (G_TYPE_NONE, TRUE, TRUE, NULL); } /** * gvn_param_spec_new_with_attrs: * @gtype: the #GType * @editable: a %gboolean indicating whether it will be editable * @null: a %gboolean indicating whether it can be null * @def: the default #GValue * * Creates a new #GvnParamSpec. * * Return value: the new #GvnParamSpec **/ GvnParamSpec * gvn_param_spec_new_with_attrs (GType gtype, gboolean editable, gboolean null, const GValue * def) { g_return_val_if_fail (G_IS_VALUE (def) || !def, NULL); GvnParamSpec * obj = g_new (GvnParamSpec, 1); obj->gtype = gtype; obj->editable = editable; obj->null = null; obj->def = NULL; gvn_param_spec_set_default (obj, def); return obj; } //+++++++++++++++++++++++++++++++++++++++++++++++++++ Public /** * gvn_param_spec_get_gtype: * @obj: a #GvnParamSpec * * Gets the type of @obj. * * Return value: the type **/ GType gvn_param_spec_get_gtype (const GvnParamSpec * obj) { g_return_val_if_fail (obj, G_TYPE_INVALID); return obj->gtype; } /** * gvn_param_spec_set_gtype: * @obj: a #GvnParamSpec * @gtype: the #GType **/ void gvn_param_spec_set_gtype (GvnParamSpec * obj, GType gtype) { g_return_if_fail (obj); g_return_if_fail (G_TYPE_IS_VALUE_TYPE (gtype) || gtype == G_TYPE_NONE); obj->gtype = gtype; } /** * gvn_param_spec_get_editable: * @obj: a #GvnParamSpec **/ gboolean gvn_param_spec_get_editable (const GvnParamSpec * obj) { g_return_val_if_fail (obj, FALSE); return obj->editable; } /** * gvn_param_spec_set_editable: * @obj: a #GvnParamSpec * @editable: a %gboolean indicating whether it will be editable * * Sets if the value can be edited. **/ void gvn_param_spec_set_editable (GvnParamSpec * obj, gboolean editable) { g_return_if_fail (obj); obj->editable = editable; } /** * gvn_param_spec_get_null: * @obj: a #GvnParamSpec **/ gboolean gvn_param_spec_get_null (const GvnParamSpec * obj) { g_return_val_if_fail (obj, FALSE); return obj->null; } /** * gvn_param_spec_set_null: * @obj: a #GvnParamSpec * @null: a %gboolean indicating whether it can be null * * Set if the value can be null. **/ void gvn_param_spec_set_null (GvnParamSpec * obj, gboolean null) { g_return_if_fail (obj); obj->null = null; } /** * gvn_param_spec_get_default: * @obj: a #GvnParamSpec * * Gets the default value. * * Return value: the #GValue or %NULL if it havent **/ const GValue * gvn_param_spec_get_default (const GvnParamSpec * obj) { g_return_val_if_fail (obj, NULL); return obj->def; } /** * gvn_param_spec_set_default: * @obj: a #GvnParamSpec * @def: the default #GValue * * Sets the default value. **/ void gvn_param_spec_set_default (GvnParamSpec * obj, const GValue * def) { g_return_if_fail (obj); g_return_if_fail (G_IS_VALUE (def) || !def); if (obj->def) { g_value_unset (obj->def); g_free (obj->def); obj->def = NULL; } if (def) { GValue * value = g_new0 (GValue, 1); g_value_init (value, G_VALUE_TYPE (def)); g_value_copy (def, value); obj->def = value; } } /** * gvn_param_spec_merge: * @obj: a #GvnParamSpec * @merge: (allow-none): a #GvnParamSpec * * Merges the attributes of @merge into @obj remaining the most restrictive. **/ void gvn_param_spec_merge (GvnParamSpec * obj, const GvnParamSpec * merge) { g_return_if_fail (obj); if (merge) { obj->editable = obj->editable && merge->editable; obj->null = obj->null && merge->null; if (obj->gtype == G_TYPE_NONE) obj->gtype = merge->gtype; if (!obj->def && merge->def) gvn_param_spec_set_default (obj, merge->def); } } /** * gvn_param_spec_ccopy_value: * @obj: a #GvnParamSpec * @src: source value to be copied * @dst: destination for the copied value * * Return value: %TRUE if the value has been copied, %FALSE otherwise **/ gboolean gvn_param_spec_ccopy_value (const GvnParamSpec * obj, const GValue * src, GValue * dst) { g_return_val_if_fail (obj, FALSE); g_return_val_if_fail (G_IS_VALUE (src), FALSE); g_return_val_if_fail (G_IS_VALUE (dst), FALSE); if (!gvn_value_is_null (src) && G_VALUE_TYPE (src) != obj->gtype && obj->gtype != G_TYPE_NONE) { if (gvn_value_is_null (dst)) { g_value_unset (dst); g_value_init (dst, obj->gtype); } g_value_transform (src, dst); } else return gvn_value_ccopy (src, dst); return TRUE; } /** * gvn_param_spec_validate: * @obj: #GvnParamSpec object where @GValue wants to be validated * @value: new value * @err: (out) (allow-none): the return location for an allocated @GError, or * %NULL to ignore errors. * * It checks if the value is valid to be saved into @obj * * Return value: gboolean **/ gboolean gvn_param_spec_validate (const GvnParamSpec * obj, const GValue * value, GError ** err) { g_return_val_if_fail (obj, FALSE); gboolean is_null = gvn_value_is_null (value); if (!obj->editable) g_set_error (err ,GVN_PARAM_SPEC_LOG_DOMAIN ,GVN_PARAM_SPEC_ERROR_NOT_EDITABLE ,_("Param not editable")); else if (is_null && !obj->null) g_set_error (err ,GVN_PARAM_SPEC_LOG_DOMAIN ,GVN_PARAM_SPEC_ERROR_NOT_NULL ,_("Param can't be NULL")); else if (!is_null && obj->gtype != G_TYPE_NONE && !g_value_type_transformable (obj->gtype, G_VALUE_TYPE (value))) g_set_error (err ,GVN_PARAM_SPEC_LOG_DOMAIN ,GVN_PARAM_SPEC_ERROR_WRONG_TYPE ,_("Incompatible type for this param")); else return TRUE; return FALSE; } /** * gvn_param_spec_unset: * @obj: a #GvnParamSpec **/ void gvn_param_spec_unset (GvnParamSpec * obj) { g_return_if_fail (obj); obj->null = TRUE; obj->editable = TRUE; obj->gtype = G_TYPE_NONE; gvn_param_spec_set_default (obj, NULL); } /** * gvn_param_spec_copy: * @obj: a #GvnParamSpec * * Makes a copy of @obj with the same attributes. * * Return value: the new created #GvnParamSpec **/ GvnParamSpec * gvn_param_spec_copy (const GvnParamSpec * obj) { g_return_val_if_fail (obj, NULL); return gvn_param_spec_new_with_attrs (obj->gtype, obj->editable, obj->null, obj->def); } /** * gvn_param_spec_free: * @obj: a #GvnParamSpec * * Frees the memory used by @obj **/ void gvn_param_spec_free (GvnParamSpec * obj) { g_return_if_fail (obj); gvn_param_spec_set_default (obj, NULL); g_free (obj); } G_DEFINE_BOXED_TYPE (GvnParamSpec, gvn_param_spec, gvn_param_spec_copy, gvn_param_spec_free);