|  |  |  | GConf Reference Manual |  | 
|---|---|---|---|---|
| GConfValue, GConfEntry, GConfMetaInfoGConfValue, GConfEntry, GConfMetaInfo — A GConfValue stores a dynamically-typed value. A GConfEntry stores a key-value pair. A GConfMetaInfo stores metainformation about a key. | 
enum GConfValueType; GConfValue; #define GCONF_VALUE_TYPE_VALID (x) GConfValue* gconf_value_new (GConfValueType type); GConfValue* gconf_value_copy (const GConfValue *src); void gconf_value_free (GConfValue *value); const char* gconf_value_get_string (const GConfValue *value); int gconf_value_get_int (const GConfValue *value); double gconf_value_get_float (const GConfValue *value); GConfValueType gconf_value_get_list_type (const GConfValue *value); GSList* gconf_value_get_list (const GConfValue *value); GConfValue* gconf_value_get_car (const GConfValue *value); GConfValue* gconf_value_get_cdr (const GConfValue *value); gboolean gconf_value_get_bool (const GConfValue *value); GConfSchema* gconf_value_get_schema (const GConfValue *value); void gconf_value_set_int (GConfValue *value, gint the_int); void gconf_value_set_string (GConfValue *value, const gchar *the_str); void gconf_value_set_float (GConfValue *value, gdouble the_float); void gconf_value_set_bool (GConfValue *value, gboolean the_bool); void gconf_value_set_schema (GConfValue *value, const GConfSchema *sc); void gconf_value_set_schema_nocopy (GConfValue *value, GConfSchema *sc); void gconf_value_set_car (GConfValue *value, const GConfValue *car); void gconf_value_set_car_nocopy (GConfValue *value, GConfValue *car); void gconf_value_set_cdr (GConfValue *value, const GConfValue *cdr); void gconf_value_set_cdr_nocopy (GConfValue *value, GConfValue *cdr); void gconf_value_set_list_type (GConfValue *value, GConfValueType type); void gconf_value_set_list_nocopy (GConfValue *value, GSList *list); void gconf_value_set_list (GConfValue *value, GSList *list); gchar* gconf_value_to_string (const GConfValue *value); GConfMetaInfo; GConfMetaInfo* gconf_meta_info_new (void); void gconf_meta_info_free (GConfMetaInfo *gcmi); const char* gconf_meta_info_get_schema (GConfMetaInfo *gcmi); const char* gconf_meta_info_get_mod_user (GConfMetaInfo *gcmi); GTime gconf_meta_info_mod_time (GConfMetaInfo *gcmi); void gconf_meta_info_set_schema (GConfMetaInfo *gcmi, const gchar *schema_name); void gconf_meta_info_set_mod_user (GConfMetaInfo *gcmi, const gchar *mod_user); void gconf_meta_info_set_mod_time (GConfMetaInfo *gcmi, GTime mod_time); GConfEntry; GConfEntry* gconf_entry_new_nocopy (gchar *key, GConfValue *val); void gconf_entry_free (GConfEntry *entry); const char* gconf_entry_get_key (const GConfEntry *entry); GConfValue* gconf_entry_get_value (const GConfEntry *entry); GConfValue* gconf_entry_steal_value (GConfEntry *entry); gboolean gconf_entry_get_is_default (const GConfEntry *entry); const char* gconf_entry_get_schema_name (const GConfEntry *entry); void gconf_entry_set_is_default (GConfEntry *entry, gboolean is_default); void gconf_entry_set_schema_name (GConfEntry *entry, const gchar *name); void gconf_entry_set_value_nocopy (GConfEntry *entry, GConfValue *val);
GConfValue stores one of the value types GConf understands; GConf uses GConfValue to pass values around because it doesn't know the type of its values at compile time.
A GConfEntry pairs a relative key name with a value, for example if the value "10" is stored at the key "/foo/bar/baz", the GConfEntry will store "baz" and "10".
A GConfMetaInfo object holds metainformation about a key, such as its last modification time and the name of the schema associated with it. You should rarely if ever need to use GConfMetaInfo. (In fact you can't get the metainfo for a key using the current API.)
typedef enum {
  GCONF_VALUE_INVALID,
  GCONF_VALUE_STRING,
  GCONF_VALUE_INT,
  GCONF_VALUE_FLOAT,
  GCONF_VALUE_BOOL,
  GCONF_VALUE_SCHEMA,
  /* unfortunately these aren't really types; we want list_of_string,
     list_of_int, etc.  but it's just too complicated to implement.
     instead we'll complain in various places if you do something
     moronic like mix types in a list or treat pair<string,int> and
     pair<float,bool> as the same type. */
  GCONF_VALUE_LIST,
  GCONF_VALUE_PAIR
  
} GConfValueType;
Used to indicate the type of a GConfValue.
| GCONF_VALUE_INVALID | Never the type of a GConfValue obtained from GConf functions; used to indicate errors and the like. | 
| GCONF_VALUE_STRING | String value (gchar*). | 
| GCONF_VALUE_INT | Integer value (gint). | 
| GCONF_VALUE_FLOAT | Floating point value (gdouble). | 
| GCONF_VALUE_BOOL | Boolean value (gboolean). | 
| GCONF_VALUE_SCHEMA | Schema value (GConfSchema). | 
| GCONF_VALUE_LIST | List of GConfValue; GConfValue elements must have a primitive type (i.e. they may not be lists or pairs), and all elements of a list must have the same type. | 
| GCONF_VALUE_PAIR | Pair of GConfValue; the first field (car) and the second field (cdr) may have different types. The two elements of a pair must be primitive types, not lists or pairs. | 
typedef struct {
  GConfValueType type;
} GConfValue;
Represents a dynamically-typed value. The type field tells you the type of the value; the other fields should be accessed with the accessor functions and macros.
A GConfValue should always be initialized before use. That is, you should not use a GConfValue unless you have called one of the functions beginning with "gconf_value_set_".. For lists, initialization has two steps: first you must set the list element type, then you must set the list value.
| GConfValueType type; | The GConfValueType of this GConfValue. The only field of GConfValue you should access directly. | 
#define GCONF_VALUE_TYPE_VALID(x) (((x) > GCONF_VALUE_INVALID) && ((x) <= GCONF_VALUE_PAIR))
| x : | 
GConfValue* gconf_value_new (GConfValueType type);
Creates a new GConfValue with type type. The type is immutable after creation; values have a fixed type. You must initialize the GConfValue after creation; that is, you must set its value with one of the "setter" functions.
| type : | type of the new GConfValue. | 
| Returns : | newly-allocated GConfValue. | 
GConfValue* gconf_value_copy (const GConfValue *src);
Copies a GConfValue. The copy is a deep copy, that is, any allocated memory inside the GConfValue will also be copied.
| src : | a GConfValue to copy. | 
| Returns : | a newly-allocated GConfValue identical to src. | 
void gconf_value_free (GConfValue *value);
Deallocates a GConfValue. Also deallocates any allocated memory inside the GConfValue (such as lists, pair members, strings, and schemas).
| value : | a GConfValue to destroy. | 
const char* gconf_value_get_string (const GConfValue *value);
Returns a const gchar* for a GConfValue with type GCONF_VALUE_STRING. The returned string is not a copy, don't try to free it. It is "owned" by the GConfValue and will be destroyed when the GConfValue is destroyed.
If the GConfValue is not initialized (i.e. no one has called gconf_value_set_string()) then the string may be NULL, but of course you should not try to use an uninitialized GConfValue.
| value : | |
| Returns : | 
int gconf_value_get_int (const GConfValue *value);
Returns a gint for a GConfValue with type GCONF_VALUE_INT.
| value : | |
| Returns : | 
double gconf_value_get_float (const GConfValue *value);
Returns a gdouble for a GConfValue with type GCONF_VALUE_FLOAT.
| value : | |
| Returns : | 
GConfValueType gconf_value_get_list_type (const GConfValue *value);
Returns the type of the list elements in a GConfValue with type GCONF_VALUE_LIST.
| value : | |
| Returns : | 
GSList* gconf_value_get_list (const GConfValue *value);
Returns a GSList containing GConfValue objects. Each GConfValue in the returned list will have the type returned by gconf_value_get_list_type(). Remember that the empty GSList is equal to NULL. The list is not a copy; it is "owned" by the GConfValue and will be destroyed when the GConfValue is destroyed.
| value : | |
| Returns : | 
GConfValue* gconf_value_get_car (const GConfValue *value);
Returns the first member (car) of a GConfValue with type GCONF_VALUE_PAIR. The car is another GConfValue, with a primitive type (bool, int, float, string, schema).
The returned value is not a copy; it is "owned" by the pair and will be destroyed when the pair is destroyed.
| value : | |
| Returns : | 
GConfValue* gconf_value_get_cdr (const GConfValue *value);
Returns the second member (cdr) of a GConfValue with type GCONF_VALUE_PAIR. The cdr is another GConfValue, with a primitive type (bool, int, float, string, schema).
The returned value is not a copy; it is "owned" by the pair and will be destroyed when the pair is destroyed.
| value : | |
| Returns : | 
gboolean gconf_value_get_bool (const GConfValue *value);
Returns a gboolean for a GConfValue with type GCONF_VALUE_BOOL.
| value : | |
| Returns : | 
GConfSchema* gconf_value_get_schema (const GConfValue *value);
Returns a GConfSchema for a GConfValue with type GCONF_VALUE_SCHEMA. If the GConfValue is uninitialized, it may return NULL; but of course you should have initialized the GConfValue. The GConf library will not return values with a NULL schema.
The returned value is not a copy; it is "owned" by the GConfValue and will be destroyed when the GConfValue is destroyed.
| value : | |
| Returns : | 
void gconf_value_set_int (GConfValue *value, gint the_int);
Sets the value of a GConfValue with type GCONF_VALUE_INT.
| value : | a GConfValue of type GCONF_VALUE_INT. | 
| the_int : | the integer. | 
void gconf_value_set_string (GConfValue *value, const gchar *the_str);
Sets the value of a GConfValue with type GCONF_VALUE_STRING. the_str is copied.
| value : | a GConfValue of type GCONF_VALUE_STRING. | 
| the_str : | the string. | 
void gconf_value_set_float (GConfValue *value, gdouble the_float);
Sets the value of a GConfValue with type GCONF_VALUE_FLOAT.
| value : | a GConfValue of type GCONF_VALUE_FLOAT. | 
| the_float : | the floating point number. | 
void gconf_value_set_bool (GConfValue *value, gboolean the_bool);
Sets the value of a GConfValue with type GCONF_VALUE_BOOL.
| value : | a GConfValue of type GCONF_VALUE_BOOL. | 
| the_bool : | a boolean value (TRUE or FALSE). | 
void gconf_value_set_schema (GConfValue *value, const GConfSchema *sc);
Sets the value of a GConfValue with type GCONF_VALUE_SCHEMA. The GConfSchema is copied. Alternatively you can use gconf_value_set_schema_nocopy().
| value : | a GConfValue with type GCONF_VALUE_SCHEMA. | 
| sc : | the GConfSchema. | 
void gconf_value_set_schema_nocopy (GConfValue *value, GConfSchema *sc);
Sets the value of a GConfValue with type GCONF_VALUE_SCHEMA. The GConfSchema is not copied; the GConfValue takes ownership of it, and it should only be accessed via the gconf_value_get_schema() macro. This function is provided as a more efficient version of gconf_value_set_schema().
| value : | a GConfValue with type GCONF_VALUE_SCHEMA. | 
| sc : | the GConfSchema. | 
void gconf_value_set_car (GConfValue *value, const GConfValue *car);
Sets the value of the first field (car) of a GConfValue with type GCONF_VALUE_PAIR. The GConfValue is copied. Alternatively, use gconf_value_set_car_nocopy().
| value : | a GConfValue with type GCONF_VALUE_PAIR. | 
| car : | the GConfValue to set as the car of the pair. | 
void gconf_value_set_car_nocopy (GConfValue *value, GConfValue *car);
Sets the value of the first field (car) of a GConfValue with type GCONF_VALUE_PAIR. The GConfValue is not copied; the GConfValue takes ownership of it. Alternatively, use gconf_value_set_car().
| value : | a GConfValue with type GCONF_VALUE_PAIR. | 
| car : | the GConfValue to set as the car of the pair. | 
void gconf_value_set_cdr (GConfValue *value, const GConfValue *cdr);
Sets the value of the second field (cdr) of a GConfValue with type GCONF_VALUE_PAIR. The GConfValue is copied. Alternatively, use gconf_value_set_cdr_nocopy().
| value : | a GConfValue with type GCONF_VALUE_PAIR. | 
| cdr : | the GConfValue to set as the cdr of the pair. | 
void gconf_value_set_cdr_nocopy (GConfValue *value, GConfValue *cdr);
Sets the value of the second field (cdr) of a GConfValue with type GCONF_VALUE_PAIR. The GConfValue is not copied; the GConfValue takes ownership of it. Alternatively, use gconf_value_set_cdr().
| value : | a GConfValue with type GCONF_VALUE_PAIR. | 
| cdr : | the GConfValue to set as the cdr of the pair. | 
void gconf_value_set_list_type (GConfValue *value, GConfValueType type);
Sets the type of the elements in a GConfValue of type GCONF_VALUE_LIST. All the elements in the list must have the same type. You must set the list type before you can set the list value.
| value : | a GConfValue with type GCONF_VALUE_LIST. | 
| type : | the type of elements in this list. | 
void gconf_value_set_list_nocopy (GConfValue *value, GSList *list);
Sets the value of a GConfValue with type GCONF_VALUE_LIST. The list argument should be a GSList of GConfValue. Each GConfValue in the list must have the same type, and this type must be specified in advance with gconf_value_set_list_type(). This function does not copy the list; the GConfValue will take ownership of the list and its contents, and they will be destroyed when the GConfValue is destroyed. Alternatively, use gconf_value_set_list() to make a copy.
| value : | a GConfValue with type GCONF_VALUE_LIST. | 
| list : | the GSList of GConfValue to set as the list value. | 
void gconf_value_set_list (GConfValue *value, GSList *list);
Sets the value of a GConfValue with type GCONF_VALUE_LIST. The list argument should be a GSList of GConfValue. Each GConfValue in the list must have the same type, and this type must be specified in advance with gconf_value_set_list_type(). This function copies the list; it will not modify the list argument.
| value : | a GConfValue with type GCONF_VALUE_LIST. | 
| list : | the GSList of GConfValue to set as the list value. | 
gchar* gconf_value_to_string (const GConfValue *value);
Creates a human-readable string representation of a GConfValue. This is intended for debugging and the like; the string representation is not suitable for reliable machine parsing (that is, you shouldn't use this function to save a value to a file or anything like that). The exact nature of the string representation may change in future versions. The returned string is newly-allocated and must be freed with g_free().
| value : | a GConfValue. | 
| Returns : | a newly-allocated string representing the GConfValue. | 
typedef struct {
  gchar* schema;
  gchar* mod_user; /* user owning the daemon that made the last modification */
  GTime  mod_time; /* time of the modification */
} GConfMetaInfo;
const char* gconf_meta_info_get_schema (GConfMetaInfo *gcmi);
| gcmi : | |
| Returns : | 
const char* gconf_meta_info_get_mod_user (GConfMetaInfo *gcmi);
| gcmi : | |
| Returns : | 
void gconf_meta_info_set_schema (GConfMetaInfo *gcmi, const gchar *schema_name);
| gcmi : | |
| schema_name : | 
void gconf_meta_info_set_mod_user (GConfMetaInfo *gcmi, const gchar *mod_user);
| gcmi : | |
| mod_user : | 
void gconf_meta_info_set_mod_time (GConfMetaInfo *gcmi, GTime mod_time);
| gcmi : | |
| mod_time : | 
typedef struct {
  char *key;
  GConfValue *value;
} GConfEntry;
Stores an entry from a GConf "directory," including a key-value pair, the name of the schema applicable to this entry, whether the value is a default value, and whether GConf can write a new value at this key. key should be an absolute key, not a relative key. (Note that internally GConf breaks this rule sometimes; but in the public interface, key is always an absolute key.) To access the key and value, use gconf_entry_get_key() and gconf_entry_get_value().
Value can be NULL, indicating that the value is not set.
| char *key; | an absolute key name | 
| GConfValue *value; | 
GConfEntry* gconf_entry_new_nocopy (gchar *key, GConfValue *val);
Creates a new GConfEntry with key key and value val. key should be a full path to the key, starting with '/'. Neither the key nor the value is copied; both are freed when the GConfEntry is freed. The string will be freed with g_free() so should be allocated with a GLib function, not malloc().
| key : | the key name | 
| val : | the value | 
| Returns : | a new GConfentry. | 
void gconf_entry_free (GConfEntry *entry);
gconf_entry_free is deprecated and should not be used in newly-written code.
Destroys a GConfEntry, freeing the key, the value, and the entry itself.
| entry : | a GConfEntry to free. | 
const char* gconf_entry_get_key (const GConfEntry *entry);
Accesses the key field of a GConfEntry. The returned key is not a copy, and should not be freed or modified.
| entry : | |
| Returns : | 
GConfValue* gconf_entry_get_value (const GConfEntry *entry);
Accesses the value field of a GConfEntry. The returned value is not a copy, and should not be freed or modified. If you have called gconf_entry_steal_value(), the returned value will be NULL.
| entry : | |
| Returns : | 
GConfValue* gconf_entry_steal_value (GConfEntry *entry);
Extracts the value from a GConfEntry, leaving the value field in GConfEntry set to NULL. Destroying the GConfEntry will not destroy the value; the caller of gconf_entry_steal_value() assumes ownership of it.
| entry : | a GConfEntry. | 
| Returns : | a GConfValue that the caller must free. | 
gboolean gconf_entry_get_is_default (const GConfEntry *entry);
| entry : | |
| Returns : | 
const char* gconf_entry_get_schema_name (const GConfEntry *entry);
| entry : | |
| Returns : | 
void gconf_entry_set_is_default (GConfEntry *entry, gboolean is_default);
| entry : | |
| is_default : | 
void gconf_entry_set_schema_name (GConfEntry *entry, const gchar *name);
| entry : | |
| name : | 
void gconf_entry_set_value_nocopy (GConfEntry *entry, GConfValue *val);
| entry : | |
| val : |