2001-11-27 11:52:11 +08:00
|
|
|
/* The GIMP -- an image manipulation program
|
|
|
|
* Copyright (C) 1995 Spencer Kimball and Peter Mattis
|
|
|
|
*
|
2001-12-14 04:19:41 +08:00
|
|
|
* Object properties serialization routines
|
2002-03-24 01:58:57 +08:00
|
|
|
* Copyright (C) 2001-2002 Sven Neumann <sven@gimp.org>
|
2001-11-27 11:52:11 +08:00
|
|
|
*
|
|
|
|
* 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 2 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, write to the Free Software
|
|
|
|
* Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
|
|
*/
|
|
|
|
|
|
|
|
#include "config.h"
|
|
|
|
|
|
|
|
#include <stdio.h>
|
|
|
|
#include <string.h>
|
2002-02-17 23:55:54 +08:00
|
|
|
#ifdef HAVE_UNISTD_H
|
2001-12-13 09:55:37 +08:00
|
|
|
#include <unistd.h>
|
2002-02-17 23:55:54 +08:00
|
|
|
#endif
|
2001-11-27 11:52:11 +08:00
|
|
|
|
|
|
|
#include <glib-object.h>
|
|
|
|
|
2002-03-28 08:10:56 +08:00
|
|
|
#ifdef G_OS_WIN32
|
|
|
|
#include <io.h>
|
|
|
|
#endif
|
|
|
|
|
2002-05-22 01:33:04 +08:00
|
|
|
#include "libgimpbase/gimpbase.h"
|
2002-05-21 23:01:57 +08:00
|
|
|
#include "libgimpcolor/gimpcolor.h"
|
|
|
|
|
2001-12-13 09:55:37 +08:00
|
|
|
#include "gimpconfig.h"
|
2002-05-22 01:33:04 +08:00
|
|
|
#include "gimpconfig-params.h"
|
2001-11-27 11:52:11 +08:00
|
|
|
#include "gimpconfig-serialize.h"
|
2001-12-11 02:31:35 +08:00
|
|
|
#include "gimpconfig-types.h"
|
2002-05-04 07:48:03 +08:00
|
|
|
#include "gimpconfig-utils.h"
|
2001-11-27 11:52:11 +08:00
|
|
|
|
|
|
|
|
2002-12-02 06:31:36 +08:00
|
|
|
static void serialize_unknown_token (const gchar *key,
|
|
|
|
const gchar *value,
|
|
|
|
gpointer data);
|
2002-03-24 01:58:57 +08:00
|
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
* gimp_config_serialize_properties:
|
|
|
|
* @object: a #GObject.
|
|
|
|
* @fd: a file descriptor to write to.
|
|
|
|
*
|
|
|
|
* This function writes all object properties to the file descriptor @fd.
|
|
|
|
**/
|
2002-05-15 19:05:32 +08:00
|
|
|
gboolean
|
2002-11-28 08:59:53 +08:00
|
|
|
gimp_config_serialize_properties (GObject *object,
|
|
|
|
gint fd,
|
|
|
|
gint indent_level)
|
2001-11-27 11:52:11 +08:00
|
|
|
{
|
2001-12-08 00:10:53 +08:00
|
|
|
GObjectClass *klass;
|
|
|
|
GParamSpec **property_specs;
|
|
|
|
guint n_property_specs;
|
|
|
|
guint i;
|
2001-12-13 09:55:37 +08:00
|
|
|
GString *str;
|
|
|
|
|
2002-05-15 19:05:32 +08:00
|
|
|
g_return_val_if_fail (G_IS_OBJECT (object), FALSE);
|
2001-11-27 11:52:11 +08:00
|
|
|
|
2001-12-08 00:10:53 +08:00
|
|
|
klass = G_OBJECT_GET_CLASS (object);
|
2001-11-27 11:52:11 +08:00
|
|
|
|
2001-12-08 00:10:53 +08:00
|
|
|
property_specs = g_object_class_list_properties (klass, &n_property_specs);
|
2001-11-27 11:52:11 +08:00
|
|
|
|
2002-05-15 19:05:32 +08:00
|
|
|
if (! property_specs)
|
|
|
|
return TRUE;
|
2001-12-13 09:55:37 +08:00
|
|
|
|
|
|
|
str = g_string_new (NULL);
|
|
|
|
|
2001-11-27 11:52:11 +08:00
|
|
|
for (i = 0; i < n_property_specs; i++)
|
|
|
|
{
|
2002-12-02 06:31:36 +08:00
|
|
|
GParamSpec *prop_spec = property_specs[i];
|
2001-11-27 11:52:11 +08:00
|
|
|
|
2002-05-22 01:33:04 +08:00
|
|
|
if (! (prop_spec->flags & GIMP_PARAM_SERIALIZE))
|
2001-11-27 11:52:11 +08:00
|
|
|
continue;
|
|
|
|
|
2002-05-24 10:53:20 +08:00
|
|
|
gimp_config_string_indent (str, indent_level);
|
|
|
|
|
2002-05-22 21:19:19 +08:00
|
|
|
if (gimp_config_serialize_property (object, prop_spec, str, TRUE))
|
2002-12-02 06:31:36 +08:00
|
|
|
{
|
2002-05-15 19:05:32 +08:00
|
|
|
if (write (fd, str->str, str->len) == -1)
|
|
|
|
return FALSE;
|
2001-12-08 00:10:53 +08:00
|
|
|
}
|
2002-12-02 06:31:36 +08:00
|
|
|
|
2003-02-27 04:34:58 +08:00
|
|
|
g_string_truncate (str, 0);
|
2001-12-13 09:55:37 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
g_free (property_specs);
|
|
|
|
g_string_free (str, TRUE);
|
2002-05-15 19:05:32 +08:00
|
|
|
|
|
|
|
return TRUE;
|
2001-12-13 09:55:37 +08:00
|
|
|
}
|
|
|
|
|
2002-03-24 01:58:57 +08:00
|
|
|
|
|
|
|
/**
|
|
|
|
* gimp_config_serialize_properties:
|
|
|
|
* @new: a #GObject.
|
|
|
|
* @old: a #GObject of the same type as @new.
|
|
|
|
* @fd: a file descriptor to write to.
|
|
|
|
*
|
|
|
|
* This function compares the objects @new and @old and writes all properties
|
|
|
|
* of @new that have different values than @old to the file descriptor @fd.
|
|
|
|
**/
|
2002-05-15 19:05:32 +08:00
|
|
|
gboolean
|
2002-03-24 01:58:57 +08:00
|
|
|
gimp_config_serialize_changed_properties (GObject *new,
|
|
|
|
GObject *old,
|
2002-05-24 10:53:20 +08:00
|
|
|
gint fd,
|
|
|
|
gint indent_level)
|
2002-03-24 01:58:57 +08:00
|
|
|
{
|
2002-11-25 21:48:24 +08:00
|
|
|
GObjectClass *klass;
|
|
|
|
GList *diff;
|
|
|
|
GList *list;
|
|
|
|
GString *str;
|
|
|
|
gboolean property_written = FALSE;
|
2002-03-24 01:58:57 +08:00
|
|
|
|
2002-05-15 19:05:32 +08:00
|
|
|
g_return_val_if_fail (G_IS_OBJECT (new), FALSE);
|
|
|
|
g_return_val_if_fail (G_IS_OBJECT (old), FALSE);
|
|
|
|
g_return_val_if_fail (G_TYPE_FROM_INSTANCE (new) ==
|
|
|
|
G_TYPE_FROM_INSTANCE (old), FALSE);
|
2002-03-24 01:58:57 +08:00
|
|
|
|
|
|
|
klass = G_OBJECT_GET_CLASS (new);
|
|
|
|
|
2002-11-25 21:48:24 +08:00
|
|
|
diff = gimp_config_diff (new, old, GIMP_PARAM_SERIALIZE);
|
2002-03-24 01:58:57 +08:00
|
|
|
|
2002-11-25 21:48:24 +08:00
|
|
|
if (! diff)
|
2002-05-15 19:05:32 +08:00
|
|
|
return TRUE;
|
2002-03-24 01:58:57 +08:00
|
|
|
|
|
|
|
str = g_string_new (NULL);
|
|
|
|
|
2002-11-25 21:48:24 +08:00
|
|
|
for (list = diff; list; list = g_list_next (list))
|
2002-03-24 01:58:57 +08:00
|
|
|
{
|
2002-11-28 23:33:15 +08:00
|
|
|
GParamSpec *prop_spec;
|
|
|
|
GValue new_value = { 0, };
|
2002-03-24 01:58:57 +08:00
|
|
|
|
2002-11-25 21:48:24 +08:00
|
|
|
prop_spec = (GParamSpec *) list->data;
|
2002-03-24 01:58:57 +08:00
|
|
|
|
2002-12-02 23:14:13 +08:00
|
|
|
if (! (prop_spec->flags & GIMP_PARAM_SERIALIZE))
|
|
|
|
continue;
|
|
|
|
|
2002-03-24 01:58:57 +08:00
|
|
|
g_value_init (&new_value, prop_spec->value_type);
|
2002-05-22 01:33:04 +08:00
|
|
|
|
2002-03-24 01:58:57 +08:00
|
|
|
g_object_get_property (new, prop_spec->name, &new_value);
|
|
|
|
|
2002-11-25 21:48:24 +08:00
|
|
|
if (property_written)
|
|
|
|
g_string_assign (str, "\n");
|
|
|
|
else
|
2003-02-27 04:34:58 +08:00
|
|
|
g_string_truncate (str, 0);
|
2002-05-24 10:53:20 +08:00
|
|
|
|
2002-11-25 21:48:24 +08:00
|
|
|
gimp_config_string_indent (str, indent_level);
|
2002-05-24 10:53:20 +08:00
|
|
|
|
2002-11-25 21:48:24 +08:00
|
|
|
g_string_append_printf (str, "(%s ", prop_spec->name);
|
2002-12-02 23:14:13 +08:00
|
|
|
|
2002-11-25 21:48:24 +08:00
|
|
|
if (gimp_config_serialize_value (&new_value, str, TRUE))
|
|
|
|
{
|
|
|
|
g_string_append (str, ")\n");
|
|
|
|
property_written = TRUE;
|
|
|
|
|
|
|
|
if (write (fd, str->str, str->len) == -1)
|
|
|
|
return FALSE;
|
|
|
|
}
|
2002-12-02 23:14:13 +08:00
|
|
|
else
|
2002-11-25 21:48:24 +08:00
|
|
|
{
|
2002-12-02 23:14:13 +08:00
|
|
|
/* don't warn for empty string properties */
|
|
|
|
if (prop_spec->value_type != G_TYPE_STRING)
|
|
|
|
g_warning ("couldn't serialize property %s::%s of type %s",
|
|
|
|
g_type_name (G_TYPE_FROM_INSTANCE (new)),
|
|
|
|
prop_spec->name,
|
|
|
|
g_type_name (prop_spec->value_type));
|
2002-03-24 01:58:57 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
g_value_unset (&new_value);
|
|
|
|
}
|
|
|
|
|
|
|
|
g_string_free (str, TRUE);
|
2002-11-25 21:48:24 +08:00
|
|
|
g_list_free (diff);
|
2002-05-15 19:05:32 +08:00
|
|
|
|
|
|
|
return TRUE;
|
2002-03-24 01:58:57 +08:00
|
|
|
}
|
|
|
|
|
2002-12-02 06:31:36 +08:00
|
|
|
|
|
|
|
gboolean
|
|
|
|
gimp_config_serialize_property (GObject *object,
|
|
|
|
GParamSpec *param_spec,
|
|
|
|
GString *str,
|
|
|
|
gboolean escaped)
|
|
|
|
{
|
|
|
|
GTypeClass *owner_class;
|
|
|
|
GimpConfigInterface *config_iface;
|
2003-02-08 23:27:51 +08:00
|
|
|
GimpConfigInterface *parent_iface = NULL;
|
2002-12-02 06:31:36 +08:00
|
|
|
GValue value = { 0, };
|
2003-02-08 23:27:51 +08:00
|
|
|
gboolean success = FALSE;
|
2002-12-02 06:31:36 +08:00
|
|
|
|
|
|
|
if (! (param_spec->flags & GIMP_PARAM_SERIALIZE))
|
|
|
|
return FALSE;
|
|
|
|
|
|
|
|
g_string_append_printf (str, "(%s ", param_spec->name);
|
|
|
|
|
|
|
|
g_value_init (&value, param_spec->value_type);
|
|
|
|
g_object_get_property (object, param_spec->name, &value);
|
|
|
|
|
|
|
|
owner_class = g_type_class_peek (param_spec->owner_type);
|
|
|
|
|
|
|
|
config_iface = g_type_interface_peek (owner_class,
|
|
|
|
GIMP_TYPE_CONFIG_INTERFACE);
|
|
|
|
|
|
|
|
/* We must call deserialize_property() *only* if the *exact* class
|
|
|
|
* which implements it is param_spec->owner_type's class.
|
|
|
|
*
|
|
|
|
* Therefore, we ask param_spec->owner_type's immediate parent class
|
|
|
|
* for it's GimpConfigInterface and check if we get a different pointer.
|
|
|
|
*
|
|
|
|
* (if the pointers are the same, param_spec->owner_type's
|
|
|
|
* GimpConfigInterface is inherited from one of it's parent classes
|
|
|
|
* and thus not able to handle param_spec->owner_type's properties).
|
|
|
|
*/
|
|
|
|
if (config_iface)
|
|
|
|
{
|
|
|
|
GTypeClass *owner_parent_class;
|
|
|
|
|
|
|
|
owner_parent_class = g_type_class_peek_parent (owner_class),
|
|
|
|
|
|
|
|
parent_iface = g_type_interface_peek (owner_parent_class,
|
|
|
|
GIMP_TYPE_CONFIG_INTERFACE);
|
|
|
|
}
|
|
|
|
|
|
|
|
if (config_iface &&
|
|
|
|
config_iface != parent_iface && /* see comment above */
|
2003-02-08 23:27:51 +08:00
|
|
|
config_iface->serialize_property &&
|
|
|
|
config_iface->serialize_property (object,
|
|
|
|
param_spec->param_id,
|
|
|
|
(const GValue *) &value,
|
|
|
|
param_spec,
|
|
|
|
str))
|
2002-12-02 06:31:36 +08:00
|
|
|
{
|
2003-02-08 23:27:51 +08:00
|
|
|
success = TRUE;
|
2002-12-02 06:31:36 +08:00
|
|
|
}
|
2003-02-08 23:27:51 +08:00
|
|
|
|
|
|
|
/* If there is no serialize_property() method *or* if it returned
|
|
|
|
* FALSE, continue with the default implementation
|
|
|
|
*/
|
|
|
|
|
|
|
|
if (! success && gimp_config_serialize_value (&value, str, escaped))
|
2002-12-02 06:31:36 +08:00
|
|
|
{
|
2003-02-08 23:27:51 +08:00
|
|
|
success = TRUE;
|
|
|
|
}
|
2002-12-02 23:14:13 +08:00
|
|
|
|
2003-02-08 23:27:51 +08:00
|
|
|
if (! success)
|
|
|
|
{
|
|
|
|
/* don't warn for empty string properties */
|
|
|
|
if (! G_VALUE_HOLDS_STRING (&value))
|
|
|
|
g_warning ("couldn't serialize property %s::%s of type %s",
|
|
|
|
g_type_name (G_TYPE_FROM_INSTANCE (object)),
|
|
|
|
param_spec->name,
|
|
|
|
g_type_name (param_spec->value_type));
|
2002-12-02 06:31:36 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
g_value_unset (&value);
|
|
|
|
|
2003-02-08 23:27:51 +08:00
|
|
|
if (success)
|
|
|
|
g_string_append (str, ")\n");
|
2002-12-02 06:31:36 +08:00
|
|
|
|
2003-02-08 23:27:51 +08:00
|
|
|
return success;
|
2002-12-02 06:31:36 +08:00
|
|
|
}
|
|
|
|
|
2002-03-24 01:58:57 +08:00
|
|
|
/**
|
|
|
|
* gimp_config_serialize_value:
|
|
|
|
* @value: a #GValue.
|
|
|
|
* @str: a #Gstring.
|
2002-05-06 19:04:39 +08:00
|
|
|
* @escaped: whether to escape string values.
|
2002-05-06 06:11:34 +08:00
|
|
|
*
|
2002-03-24 01:58:57 +08:00
|
|
|
* This utility function appends a string representation of #GValue to @str.
|
|
|
|
*
|
|
|
|
* Return value: %TRUE if serialization succeeded, %FALSE otherwise.
|
|
|
|
**/
|
2001-12-29 00:26:54 +08:00
|
|
|
gboolean
|
|
|
|
gimp_config_serialize_value (const GValue *value,
|
2002-05-06 19:04:39 +08:00
|
|
|
GString *str,
|
|
|
|
gboolean escaped)
|
2001-12-13 09:55:37 +08:00
|
|
|
{
|
|
|
|
if (G_VALUE_HOLDS_BOOLEAN (value))
|
|
|
|
{
|
|
|
|
gboolean bool;
|
|
|
|
|
|
|
|
bool = g_value_get_boolean (value);
|
2002-05-06 06:11:34 +08:00
|
|
|
g_string_append (str, bool ? "yes" : "no");
|
2001-12-13 09:55:37 +08:00
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (G_VALUE_HOLDS_ENUM (value))
|
|
|
|
{
|
|
|
|
GEnumClass *enum_class;
|
|
|
|
GEnumValue *enum_value;
|
|
|
|
|
|
|
|
enum_class = g_type_class_peek (G_VALUE_TYPE (value));
|
|
|
|
enum_value = g_enum_get_value (G_ENUM_CLASS (enum_class),
|
|
|
|
g_value_get_enum (value));
|
|
|
|
|
|
|
|
if (enum_value && enum_value->value_nick)
|
2001-12-12 07:10:59 +08:00
|
|
|
{
|
2001-12-13 09:55:37 +08:00
|
|
|
g_string_append (str, enum_value->value_nick);
|
|
|
|
return TRUE;
|
2001-12-12 07:10:59 +08:00
|
|
|
}
|
2001-12-13 09:55:37 +08:00
|
|
|
else
|
|
|
|
{
|
|
|
|
g_warning ("Couldn't get nick for enum_value of %s",
|
|
|
|
G_ENUM_CLASS_TYPE_NAME (enum_class));
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (G_VALUE_HOLDS_STRING (value))
|
|
|
|
{
|
2002-05-06 19:04:39 +08:00
|
|
|
gchar *esc;
|
2001-12-13 09:55:37 +08:00
|
|
|
const gchar *cstr = g_value_get_string (value);
|
2001-12-12 07:10:59 +08:00
|
|
|
|
2001-12-13 09:55:37 +08:00
|
|
|
if (!cstr)
|
|
|
|
return FALSE;
|
|
|
|
|
2002-05-06 19:04:39 +08:00
|
|
|
if (escaped)
|
|
|
|
{
|
|
|
|
esc = g_strescape (cstr, NULL);
|
|
|
|
g_string_append_printf (str, "\"%s\"", esc);
|
|
|
|
g_free (esc);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
g_string_append (str, cstr);
|
|
|
|
}
|
2001-12-13 09:55:37 +08:00
|
|
|
return TRUE;
|
2001-11-27 11:52:11 +08:00
|
|
|
}
|
2001-12-13 09:55:37 +08:00
|
|
|
|
2002-04-15 17:40:08 +08:00
|
|
|
if (G_VALUE_HOLDS_DOUBLE (value) || G_VALUE_HOLDS_FLOAT (value))
|
|
|
|
{
|
|
|
|
gdouble v_double;
|
|
|
|
gchar buf[G_ASCII_DTOSTR_BUF_SIZE];
|
|
|
|
|
|
|
|
if (G_VALUE_HOLDS_DOUBLE (value))
|
|
|
|
v_double = g_value_get_double (value);
|
|
|
|
else
|
|
|
|
v_double = (gdouble) g_value_get_float (value);
|
|
|
|
|
|
|
|
g_ascii_formatd (buf, sizeof (buf), "%f", v_double);
|
|
|
|
g_string_append (str, buf);
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
2002-05-21 23:01:57 +08:00
|
|
|
if (GIMP_VALUE_HOLDS_COLOR (value))
|
|
|
|
{
|
|
|
|
GimpRGB *color;
|
2002-05-24 21:07:12 +08:00
|
|
|
gchar buf[4][G_ASCII_DTOSTR_BUF_SIZE];
|
2002-05-21 23:01:57 +08:00
|
|
|
|
|
|
|
color = g_value_get_boxed (value);
|
2002-05-24 21:07:12 +08:00
|
|
|
|
|
|
|
g_ascii_formatd (buf[0], G_ASCII_DTOSTR_BUF_SIZE, "%f", color->r);
|
|
|
|
g_ascii_formatd (buf[1], G_ASCII_DTOSTR_BUF_SIZE, "%f", color->g);
|
|
|
|
g_ascii_formatd (buf[2], G_ASCII_DTOSTR_BUF_SIZE, "%f", color->b);
|
|
|
|
g_ascii_formatd (buf[3], G_ASCII_DTOSTR_BUF_SIZE, "%f", color->a);
|
|
|
|
|
|
|
|
g_string_append_printf (str, "(color-rgba %s %s %s %s)",
|
|
|
|
buf[0], buf[1], buf[2], buf[3]);
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (G_VALUE_TYPE (value) == G_TYPE_VALUE_ARRAY)
|
|
|
|
{
|
|
|
|
GValueArray *array;
|
|
|
|
|
|
|
|
array = g_value_get_boxed (value);
|
|
|
|
|
|
|
|
if (array)
|
|
|
|
{
|
|
|
|
gint i;
|
|
|
|
|
|
|
|
g_string_append_printf (str, "%d", array->n_values);
|
|
|
|
|
|
|
|
for (i = 0; i < array->n_values; i++)
|
|
|
|
{
|
|
|
|
g_string_append (str, " ");
|
|
|
|
|
2002-12-02 06:31:36 +08:00
|
|
|
if (! gimp_config_serialize_value (g_value_array_get_nth (array,
|
|
|
|
i),
|
2002-05-24 21:07:12 +08:00
|
|
|
str, escaped))
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
g_string_append (str, "NULL");
|
|
|
|
}
|
|
|
|
|
2002-05-21 23:01:57 +08:00
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
2001-12-13 09:55:37 +08:00
|
|
|
if (g_value_type_transformable (G_VALUE_TYPE (value), G_TYPE_STRING))
|
|
|
|
{
|
|
|
|
GValue tmp_value = { 0, };
|
|
|
|
|
|
|
|
g_value_init (&tmp_value, G_TYPE_STRING);
|
|
|
|
g_value_transform (value, &tmp_value);
|
|
|
|
|
|
|
|
g_string_append (str, g_value_get_string (&tmp_value));
|
|
|
|
|
|
|
|
g_value_unset (&tmp_value);
|
|
|
|
return TRUE;
|
|
|
|
}
|
|
|
|
|
|
|
|
return FALSE;
|
|
|
|
}
|
|
|
|
|
2002-03-24 01:58:57 +08:00
|
|
|
/**
|
|
|
|
* gimp_config_serialize_unknown_tokens:
|
|
|
|
* @object: a #GObject.
|
|
|
|
* @fd: a file descriptor to write to.
|
|
|
|
*
|
|
|
|
* Writes all unknown tokens attached to #object to the file descriptor @fd.
|
|
|
|
* See gimp_config_add_unknown_token().
|
|
|
|
**/
|
2002-05-15 19:05:32 +08:00
|
|
|
gboolean
|
2001-12-13 09:55:37 +08:00
|
|
|
gimp_config_serialize_unknown_tokens (GObject *object,
|
2002-05-24 10:53:20 +08:00
|
|
|
gint fd,
|
|
|
|
gint indent_level)
|
2001-12-13 09:55:37 +08:00
|
|
|
{
|
|
|
|
GString *str;
|
|
|
|
|
2002-05-15 19:05:32 +08:00
|
|
|
g_return_val_if_fail (G_IS_OBJECT (object), FALSE);
|
2001-12-13 09:55:37 +08:00
|
|
|
|
|
|
|
str = g_string_new (NULL);
|
|
|
|
|
|
|
|
gimp_config_foreach_unknown_token (object, serialize_unknown_token, str);
|
|
|
|
|
2002-05-15 19:05:32 +08:00
|
|
|
return (write (fd, str->str, str->len) != -1);
|
2001-12-13 09:55:37 +08:00
|
|
|
}
|
|
|
|
|
2003-01-13 07:57:26 +08:00
|
|
|
|
|
|
|
#define LINE_LENGTH 75
|
|
|
|
|
|
|
|
/**
|
|
|
|
* gimp_config_serialize_comment:
|
|
|
|
* @str: a #GString.
|
2003-02-09 08:22:42 +08:00
|
|
|
* @comment: the comment to serialize (ASCII only)
|
2003-01-13 07:57:26 +08:00
|
|
|
*
|
|
|
|
* Appends the @comment to @str and inserts linebreaks and hash-marks to
|
2003-02-09 08:22:42 +08:00
|
|
|
* format it as a comment. Note that this function does not handle non-ASCII
|
|
|
|
* characters.
|
2003-01-13 07:57:26 +08:00
|
|
|
**/
|
2002-12-02 06:31:36 +08:00
|
|
|
void
|
2002-11-28 23:19:19 +08:00
|
|
|
gimp_config_serialize_comment (GString *str,
|
|
|
|
const gchar *comment)
|
|
|
|
{
|
|
|
|
const gchar *s;
|
|
|
|
gint i, len, space;
|
|
|
|
|
|
|
|
len = strlen (comment);
|
|
|
|
|
|
|
|
while (len > 0)
|
|
|
|
{
|
|
|
|
for (s = comment, i = 0, space = 0;
|
2003-01-13 07:57:26 +08:00
|
|
|
*s != '\n' && (i <= LINE_LENGTH || space == 0) && i < len;
|
2002-11-28 23:19:19 +08:00
|
|
|
s++, i++)
|
|
|
|
{
|
|
|
|
if (g_ascii_isspace (*s))
|
|
|
|
space = i;
|
|
|
|
}
|
|
|
|
|
2003-01-13 07:57:26 +08:00
|
|
|
if (i > LINE_LENGTH && space && *s != '\n')
|
2002-11-28 23:19:19 +08:00
|
|
|
i = space;
|
|
|
|
|
|
|
|
g_string_append_len (str, "# ", 2);
|
|
|
|
g_string_append_len (str, comment, i);
|
|
|
|
g_string_append_c (str, '\n');
|
|
|
|
|
|
|
|
i++;
|
|
|
|
|
|
|
|
comment += i;
|
|
|
|
len -= i;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2001-12-13 09:55:37 +08:00
|
|
|
static void
|
|
|
|
serialize_unknown_token (const gchar *key,
|
|
|
|
const gchar *value,
|
|
|
|
gpointer data)
|
|
|
|
{
|
|
|
|
gchar *escaped = g_strescape (value, NULL);
|
|
|
|
|
|
|
|
g_string_append_printf ((GString *) data, "(%s \"%s\")\n", key, escaped);
|
|
|
|
|
|
|
|
g_free (escaped);
|
2001-11-27 11:52:11 +08:00
|
|
|
}
|