2 * Copyright (C) 2003 David A. Schleef <ds@schleef.org>
4 * This library is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU Library General Public
6 * License as published by the Free Software Foundation; either
7 * version 2 of the License, or (at your option) any later version.
9 * This library is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
12 * Library General Public License for more details.
14 * You should have received a copy of the GNU Library General Public
15 * License along with this library; if not, write to the
16 * Free Software Foundation, Inc., 59 Temple Place - Suite 330,
17 * Boston, MA 02111-1307, USA.
20 #ifndef __GST_STRUCTURE_H__
21 #define __GST_STRUCTURE_H__
23 #include <gst/gstconfig.h>
24 #include <glib-object.h>
25 #include <gst/gstclock.h>
26 #include <gst/glib-compat.h>
30 #define GST_TYPE_STRUCTURE (gst_structure_get_type ())
31 #define GST_STRUCTURE(object) ((GstStructure *)(object))
32 #define GST_IS_STRUCTURE(object) ((object) && (GST_STRUCTURE(object)->type == GST_TYPE_STRUCTURE))
34 typedef struct _GstStructure GstStructure;
37 * GstStructureForeachFunc:
38 * @field_id: the #GQuark of the field name
39 * @value: the #GValue of the field
40 * @user_data: user data
42 * A function that will be called in gst_structure_foreach(). The function may
45 * Returns: TRUE if the foreach operation should continue, FALSE if
46 * the foreach operation should stop with FALSE.
48 typedef gboolean (*GstStructureForeachFunc) (GQuark field_id,
53 * GstStructureMapFunc:
54 * @field_id: the #GQuark of the field name
55 * @value: the #GValue of the field
56 * @user_data: user data
58 * A function that will be called in gst_structure_map_in_place(). The function
61 * Returns: TRUE if the map operation should continue, FALSE if
62 * the map operation should stop with FALSE.
64 typedef gboolean (*GstStructureMapFunc) (GQuark field_id,
70 * @type: the GType of a structure
72 * The GstStructure object. Most fields are private.
74 struct _GstStructure {
80 /* owned by parent structure, NULL if no parent */
81 gint *parent_refcount;
85 gpointer _gst_reserved;
88 GType gst_structure_get_type (void);
90 GstStructure * gst_structure_empty_new (const gchar * name);
91 GstStructure * gst_structure_id_empty_new (GQuark quark);
92 GstStructure * gst_structure_new (const gchar * name,
93 const gchar * firstfield,
95 GstStructure * gst_structure_new_valist (const gchar * name,
96 const gchar * firstfield,
98 GstStructure * gst_structure_copy (const GstStructure *structure);
99 void gst_structure_set_parent_refcount (GstStructure *structure,
101 void gst_structure_free (GstStructure *structure);
103 G_CONST_RETURN gchar * gst_structure_get_name (const GstStructure *structure);
104 GQuark gst_structure_get_name_id (const GstStructure *structure);
105 gboolean gst_structure_has_name (const GstStructure *structure,
107 void gst_structure_set_name (GstStructure *structure,
110 void gst_structure_id_set_value (GstStructure *structure,
112 const GValue *value);
113 void gst_structure_set_value (GstStructure *structure,
114 const gchar *fieldname,
115 const GValue *value);
116 void gst_structure_set (GstStructure *structure,
117 const gchar *fieldname,
118 ...) G_GNUC_NULL_TERMINATED;
119 void gst_structure_set_valist (GstStructure *structure,
120 const gchar *fieldname,
122 G_CONST_RETURN GValue * gst_structure_id_get_value (const GstStructure *structure,
124 G_CONST_RETURN GValue * gst_structure_get_value (const GstStructure *structure,
125 const gchar *fieldname);
126 void gst_structure_remove_field (GstStructure *structure,
127 const gchar *fieldname);
128 void gst_structure_remove_fields (GstStructure *structure,
129 const gchar *fieldname,
130 ...) G_GNUC_NULL_TERMINATED;
131 void gst_structure_remove_fields_valist (GstStructure *structure,
132 const gchar *fieldname,
134 void gst_structure_remove_all_fields (GstStructure *structure);
136 GType gst_structure_get_field_type (const GstStructure *structure,
137 const gchar *fieldname);
138 gboolean gst_structure_foreach (const GstStructure *structure,
139 GstStructureForeachFunc func,
141 gboolean gst_structure_map_in_place (GstStructure *structure,
142 GstStructureMapFunc func,
144 gint gst_structure_n_fields (const GstStructure *structure);
145 const gchar * gst_structure_nth_field_name (const GstStructure *structure, guint index);
146 gboolean gst_structure_has_field (const GstStructure *structure,
147 const gchar *fieldname);
148 gboolean gst_structure_has_field_typed (const GstStructure *structure,
149 const gchar *fieldname,
152 /* utility functions */
153 gboolean gst_structure_get_boolean (const GstStructure *structure,
154 const gchar *fieldname,
156 gboolean gst_structure_get_int (const GstStructure *structure,
157 const gchar *fieldname,
159 gboolean gst_structure_get_fourcc (const GstStructure *structure,
160 const gchar *fieldname,
162 gboolean gst_structure_get_double (const GstStructure *structure,
163 const gchar *fieldname,
165 gboolean gst_structure_get_date (const GstStructure *structure,
166 const gchar *fieldname,
168 gboolean gst_structure_get_clock_time (const GstStructure *structure,
169 const gchar *fieldname,
170 GstClockTime *value);
171 G_CONST_RETURN gchar * gst_structure_get_string (const GstStructure *structure,
172 const gchar *fieldname);
173 gboolean gst_structure_get_enum (const GstStructure *structure,
174 const gchar *fieldname,
177 gboolean gst_structure_get_fraction (const GstStructure *structure,
178 const gchar *fieldname,
179 gint *value_numerator,
180 gint *value_denominator);
182 gchar * gst_structure_to_string (const GstStructure *structure);
183 GstStructure * gst_structure_from_string (const gchar *string,
186 gboolean gst_structure_fixate_field_nearest_int (GstStructure *structure,
187 const char *field_name,
189 gboolean gst_structure_fixate_field_nearest_double (GstStructure *structure,
190 const char *field_name,
193 gboolean gst_structure_fixate_field_boolean (GstStructure *structure,
194 const char *field_name,
196 gboolean gst_structure_fixate_field_nearest_fraction (GstStructure *structure,
197 const char *field_name,
198 const gint target_numerator,
199 const gint target_denominator);