docs/gst/tmpl/gstcaps.sgml: Fix stuff that mentions GstProps

Original commit message from CVS:
* docs/gst/tmpl/gstcaps.sgml:  Fix stuff that mentions GstProps
* docs/gst/tmpl/gstpadtemplate.sgml: same
* docs/gst/tmpl/gstreamer-unused.sgml: Remove GstProps
* gst/gstobject.c: (gst_object_set_name_default): Do the memleak
fixing dance.
* gst/gstutils.c: Remove disabled code that uses GstProps.
* gst/registries/gstxmlregistry.h: same
* docs/random/ds/0.9-suggested-changes: random notes
This commit is contained in:
David Schleef 2004-02-11 20:16:33 +00:00
parent 5fe57b5dc4
commit 7e6017aac1
8 changed files with 43 additions and 244 deletions

View file

@ -1,3 +1,14 @@
2004-02-11 David Schleef <ds@schleef.org>
* docs/gst/tmpl/gstcaps.sgml: Fix stuff that mentions GstProps
* docs/gst/tmpl/gstpadtemplate.sgml: same
* docs/gst/tmpl/gstreamer-unused.sgml: Remove GstProps
* gst/gstobject.c: (gst_object_set_name_default): Do the memleak
fixing dance.
* gst/gstutils.c: Remove disabled code that uses GstProps.
* gst/registries/gstxmlregistry.h: same
* docs/random/ds/0.9-suggested-changes: random notes
2004-02-11 kost@imn.htwk-leipzig.de 2004-02-11 kost@imn.htwk-leipzig.de
reviewed by: David Schleef <ds@schleef.org> reviewed by: David Schleef <ds@schleef.org>

View file

@ -11,32 +11,24 @@ a mime-type and a set of properties. GstCaps can be named and chained into
a list, which is then a GstCaps on its own. a list, which is then a GstCaps on its own.
</para> </para>
<para> <para>
GstCaps are created with gst_caps_new(), which takes a name, a mime type and GstCaps are created with gst_caps_new_simpl(), which takes a mime type and
a pointer to a #GstProps. A convenience macro with a cleaner syntax is a list of arguments in sets of 3, terminated with NULL. Each set of 3
available to create a caps with GST_CAPS_NEW(). The following example shows how arguments is the name of a field, the GType of the field, and the value
to create a GstCaps. of the field. The following example shows how to create a GstCaps.
<programlisting> <programlisting>
GstCaps *caps; GstCaps *caps;
caps = gst_caps_new ( caps = gst_caps_new (
"my_caps", /* capability name */ "audio/x-raw-int", /* mime type */
"audio/raw", /* mime type */ "channels", G_TYPE_INT, 5,
gst_props_new ( /* properties */ NULL);
"format", GST_PROPS_STRING ("float"),
"channels", GST_PROPS_INT (5),
NULL));
</programlisting> </programlisting>
The following code example is equivalent to the above example: The following code example is equivalent to the above example:
<programlisting> <programlisting>
GstCaps *caps; GstCaps *caps;
caps = GST_CAPS_NEW ( caps = gst_caps_from_string ("audio/x-raw-int, channels = (int) 5");
"my_caps", /* capability name */
"audio/raw", /* mime type */
"format", GST_PROPS_STRING ("float"),
"channels", GST_PROPS_INT (5)
);
</programlisting> </programlisting>
</para> </para>
<para> <para>
@ -53,15 +45,16 @@ gst_caps_get_boolean(), gst_caps_get_fourcc_int(), gst_caps_get_int(),
gst_caps_get_string(), gst_caps_get_float(), which all take a property name as an argument. gst_caps_get_string(), gst_caps_get_float(), which all take a property name as an argument.
</para> </para>
<para> <para>
The properties of the caps structure can be modified with gst_caps_set, which The fields of the caps structure can be modified with gst_caps_set_simple,
takes a list of key value pairs in the #GstProps syntax as shown by this example: which takes the caps structure to be modified, a list of arguments in
sets of 3, terminated by NULL. The format of these arguments is the
same as above.
<programlisting> <programlisting>
GstCaps *caps; GstCaps *caps;
.... ....
gst_caps_set (caps, "format", GST_PROPS_STRING ("int"), NULL); gst_caps_set_simple (caps, "channels", G_TYPE_INT, 20, NULL);
gst_caps_set (caps, "channels", GST_PROPS_INT (20), NULL);
</programlisting> </programlisting>
</para> </para>
@ -73,25 +66,18 @@ gst_caps_copy_on_write(). This will copy the GstCaps if the refcount is &gt;1.
If you need a unique instance of a GstCaps you can use the convenient If you need a unique instance of a GstCaps you can use the convenient
GST_CAPS_FACTORY() macro as shown below. GST_CAPS_FACTORY() macro as shown below.
<programlisting> <programlisting>
GST_CAPS_FACTORY (my_caps, GstStaticCaps my_caps = GST_STATIC_CAPS (
GST_CAPS_NEW ( "audio/x-raw-float, "
"caps1", "channels = (int) 5; "
"audio/raw", "audio/x-raw-int, "
"format", GST_PROPS_STRING ("float"), "channels = (int) 5"
"channels", GST_PROPS_INT (5)
),
GST_CAPS_NEW (
"caps2",
"audio/raw",
"format", GST_PROPS_STRING ("int"),
"channels", GST_PROPS_INT (5)
) )
) )
void void
some_function (void) some_function (void)
{ {
GstCaps *caps = GST_CAPS_GET (my_caps); GstCaps *caps = gst_caps_copy (gst_static_caps_get (&amp;my_caps));
... ...
} }
@ -108,7 +94,7 @@ of the capabilities.
<!-- ##### SECTION See_Also ##### --> <!-- ##### SECTION See_Also ##### -->
<para> <para>
#GstProps, #GstPad #GstStructure, #GstPad
</para> </para>
<!-- ##### MACRO GST_TYPE_CAPS ##### --> <!-- ##### MACRO GST_TYPE_CAPS ##### -->

View file

@ -23,15 +23,14 @@ to add to an elementfactory.
<para> <para>
The following code example shows the code to create a pad from a padtemplate. The following code example shows the code to create a pad from a padtemplate.
<programlisting> <programlisting>
GST_PAD_TEMPLATE_FACTORY (my_template_factory, GstStaticPadTemplate my_template =
GST_STATIC_PAD_TEMPLATE (
"sink", /* the name of the pad */ "sink", /* the name of the pad */
GST_PAD_SINK, /* the direction of the pad */ GST_PAD_SINK, /* the direction of the pad */
GST_PAD_ALWAYS, /* when this pad will be present */ GST_PAD_ALWAYS, /* when this pad will be present */
GST_CAPS_NEW ( /* the capabilities of the padtemplate */ GST_STATIC_CAPS ( /* the capabilities of the padtemplate */
"my_caps", "audio/x-raw-int, "
"audio/raw", "channels = (int) [ 1, 6 ]"
"format", GST_PROPS_STRING ("int"),
"channels", GST_PROPS_INT_RANGE (1, 6)
) )
) )

View file

@ -2163,13 +2163,6 @@ Set or get the flush flag of the discont event.
@event: The event to operate on @event: The event to operate on
<!-- ##### MACRO GST_EVENT_INFO_PROPS ##### -->
<para>
The properties of the info event
</para>
@event: The event to query
<!-- ##### MACRO GST_EVENT_SEEK_FLUSH ##### --> <!-- ##### MACRO GST_EVENT_SEEK_FLUSH ##### -->
<para> <para>
Qeury wether the seek event also needs a flush. Qeury wether the seek event also needs a flush.
@ -3035,65 +3028,6 @@ A macro used to define a statically linked plugin.
@name: The name of the plugin. @name: The name of the plugin.
@init: The init function of this plugin. @init: The init function of this plugin.
<!-- ##### MACRO GST_PROPS_BOOL_ID ##### -->
<para>
</para>
<!-- ##### MACRO GST_PROPS_ENTRY_IS_VARIABLE ##### -->
<para>
</para>
@a:
<!-- ##### MACRO GST_PROPS_FLOAT_RANGE_STRING ##### -->
<para>
</para>
@a:
@b:
<!-- ##### MACRO GST_PROPS_FLOAT_STRING ##### -->
<para>
</para>
@a:
<!-- ##### MACRO GST_PROPS_FOURCC_ID ##### -->
<para>
</para>
<!-- ##### MACRO GST_PROPS_FOURCC_INT ##### -->
<para>
Create a fourcc property out of an integer value.
</para>
@a: the integer value
<!-- ##### MACRO GST_PROPS_INT_ID ##### -->
<para>
</para>
<!-- ##### MACRO GST_PROPS_INT_RANGE_ID ##### -->
<para>
</para>
<!-- ##### MACRO GST_PROPS_LIST_ID ##### -->
<para>
</para>
<!-- ##### MACRO GST_QUEUE ##### --> <!-- ##### MACRO GST_QUEUE ##### -->
<para> <para>
@ -3791,12 +3725,6 @@ A type that can be used to indicate a filename.
</para> </para>
<!-- ##### MACRO GST_TYPE_PROPS_TYPE ##### -->
<para>
</para>
<!-- ##### MACRO GST_TYPE_QUEUE ##### --> <!-- ##### MACRO GST_TYPE_QUEUE ##### -->
<para> <para>
@ -5577,36 +5505,6 @@ Sets the command to be executed.
</para> </para>
<!-- ##### TYPEDEF GstPropsFactoryEntry ##### -->
<para>
</para>
<!-- ##### TYPEDEF GstPropsFactory[] ##### -->
<para>
</para>
<!-- ##### ENUM GstPropsId ##### -->
<para>
</para>
@GST_PROPS_END_ID_NUM:
@GST_PROPS_LIST_ID_NUM:
@GST_PROPS_INT_ID_NUM:
@GST_PROPS_INT_RANGE_ID_NUM:
@GST_PROPS_FOURCC_ID_NUM:
@GST_PROPS_BOOL_ID_NUM:
<!-- ##### TYPEDEF GstPropsListFactory[] ##### -->
<para>
</para>
<!-- ##### STRUCT GstQueue ##### --> <!-- ##### STRUCT GstQueue ##### -->
<para> <para>

View file

@ -16,6 +16,9 @@ API:
- gst_init() et al. need to work correctly when called multiple times - gst_init() et al. need to work correctly when called multiple times
and from libraries, etc. and from libraries, etc.
- gst_pad_get_pad_template_caps -> gst_pad_get_template_caps()
caps: caps:
(Company:) (Company:)

View file

@ -432,8 +432,10 @@ gst_object_set_name_default (GstObject *object)
* may ever assign a name */ * may ever assign a name */
G_LOCK (object_name_mutex); G_LOCK (object_name_mutex);
if (!object_name_counts) if (!object_name_counts) {
object_name_counts = g_hash_table_new (g_str_hash, g_str_equal); object_name_counts = g_hash_table_new_full (g_str_hash, g_str_equal,
g_free, NULL);
}
count = GPOINTER_TO_INT (g_hash_table_lookup (object_name_counts, type_name)); count = GPOINTER_TO_INT (g_hash_table_lookup (object_name_counts, type_name));
g_hash_table_insert (object_name_counts, g_strdup (type_name), g_hash_table_insert (object_name_counts, g_strdup (type_name),

View file

@ -274,104 +274,6 @@ string_append_indent (GString * str, gint count)
g_string_append_c (str, ' '); g_string_append_c (str, ' ');
} }
#if 0
static void
gst_print_props (GString *buf, gint indent, GList *props, gboolean showname)
{
GList *elem;
guint width = 0;
GstPropsType type;
if (showname)
for (elem = props; elem; elem = g_list_next (elem)) {
GstPropsEntry *prop = elem->data;
const gchar *name = gst_props_entry_get_name (prop);
if (width < strlen (name))
width = strlen (name);
}
for (elem = props; elem; elem = g_list_next (elem)) {
GstPropsEntry *prop = elem->data;
string_append_indent (buf, indent);
if (showname) {
const gchar *name = gst_props_entry_get_name (prop);
g_string_append (buf, name);
string_append_indent (buf, 2 + width - strlen (name));
}
type = gst_props_entry_get_props_type (prop);
switch (type) {
case GST_PROPS_INT_TYPE:
{
gint val;
gst_props_entry_get_int (prop, &val);
g_string_append_printf (buf, "%d (int)\n", val);
break;
}
case GST_PROPS_INT_RANGE_TYPE:
{
gint min, max;
gst_props_entry_get_int_range (prop, &min, &max);
g_string_append_printf (buf, "%d - %d (int)\n", min, max);
break;
}
case GST_PROPS_FLOAT_TYPE:
{
gfloat val;
gst_props_entry_get_float (prop, &val);
g_string_append_printf (buf, "%f (float)\n", val);
break;
}
case GST_PROPS_FLOAT_RANGE_TYPE:
{
gfloat min, max;
gst_props_entry_get_float_range (prop, &min, &max);
g_string_append_printf (buf, "%f - %f (float)\n", min, max);
break;
}
case GST_PROPS_BOOLEAN_TYPE:
{
gboolean val;
gst_props_entry_get_boolean (prop, &val);
g_string_append_printf (buf, "%s\n", val ? "TRUE" : "FALSE");
break;
}
case GST_PROPS_STRING_TYPE:
{
const gchar *val;
gst_props_entry_get_string (prop, &val);
g_string_append_printf (buf, "\"%s\"\n", val);
break;
}
case GST_PROPS_FOURCC_TYPE:
{
guint32 val;
gst_props_entry_get_fourcc_int (prop, &val);
g_string_append_printf (buf, "'%c%c%c%c' (fourcc)\n",
(gchar)( val & 0xff),
(gchar)((val >> 8) & 0xff),
(gchar)((val >> 16) & 0xff),
(gchar)((val >> 24) & 0xff));
break;
}
case GST_PROPS_LIST_TYPE:
{
const GList *list;
gst_props_entry_get_list (prop, &list);
gst_print_props (buf, indent + 2, (GList *)list, FALSE);
break;
}
default:
g_string_append_printf (buf, "unknown proptype %d\n", type);
break;
}
}
}
#endif
/** /**
* gst_print_pad_caps: * gst_print_pad_caps:
* @buf: the buffer to print the caps in * @buf: the buffer to print the caps in

View file

@ -104,8 +104,6 @@ struct _GstXMLRegistry {
gchar *caps_name; gchar *caps_name;
gchar *structure_name; gchar *structure_name;
//gchar *caps_mime;
//GstProps *props;
gboolean in_list; gboolean in_list;
GList *entry_list; GList *entry_list;