mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-03 14:08:56 +00:00
structure: Allow STRICT flag only in _serialize_full()
The STRICT flag makes _serialize() nullable which is an API break for bindings. Forbid it and add _serialize_full() that accepts it and is properly annotated. Part-of: <https://gitlab.freedesktop.org/gstreamer/gstreamer/-/merge_requests/5829>
This commit is contained in:
parent
2c8f232d79
commit
561f8b71ee
8 changed files with 44 additions and 14 deletions
|
@ -31,8 +31,8 @@ GST_START_TEST (test_resolve_variables)
|
||||||
NULL);
|
NULL);
|
||||||
fail_unless (gst_structure_is_equal (struct_with_vars, expected),
|
fail_unless (gst_structure_is_equal (struct_with_vars, expected),
|
||||||
"\nReplaced: `%s`\n!=\nExpected: `%s`",
|
"\nReplaced: `%s`\n!=\nExpected: `%s`",
|
||||||
gst_structure_serialize (struct_with_vars, GST_SERIALIZE_FLAG_NONE),
|
gst_structure_serialize_full (struct_with_vars, GST_SERIALIZE_FLAG_NONE),
|
||||||
gst_structure_serialize (expected, GST_SERIALIZE_FLAG_NONE));
|
gst_structure_serialize_full (expected, GST_SERIALIZE_FLAG_NONE));
|
||||||
|
|
||||||
gst_structure_free (variables);
|
gst_structure_free (variables);
|
||||||
gst_structure_free (struct_with_vars);
|
gst_structure_free (struct_with_vars);
|
||||||
|
|
|
@ -416,7 +416,7 @@ _cleanup_fields (const Property * field_names, GstStructure * structure,
|
||||||
exists = TRUE;
|
exists = TRUE;
|
||||||
|
|
||||||
if (gst_structure_has_field (structure, field_names[i].long_name)) {
|
if (gst_structure_has_field (structure, field_names[i].long_name)) {
|
||||||
gchar *str_info = gst_structure_serialize (structure, 0);
|
gchar *str_info = gst_structure_serialize_full (structure, 0);
|
||||||
|
|
||||||
*error =
|
*error =
|
||||||
g_error_new (GES_ERROR, 0,
|
g_error_new (GES_ERROR, 0,
|
||||||
|
|
|
@ -39,7 +39,7 @@ server_probe_cb (GstPad * pad, GstPadProbeInfo * info, gpointer user_data)
|
||||||
s = gst_custom_meta_get_structure (meta);
|
s = gst_custom_meta_get_structure (meta);
|
||||||
gst_structure_set (s, "foo", G_TYPE_STRING, "bar", "timestamp",
|
gst_structure_set (s, "foo", G_TYPE_STRING, "bar", "timestamp",
|
||||||
G_TYPE_UINT64, GST_BUFFER_PTS (buf), NULL);
|
G_TYPE_UINT64, GST_BUFFER_PTS (buf), NULL);
|
||||||
str = gst_structure_serialize (s, GST_SERIALIZE_FLAG_NONE);
|
str = gst_structure_serialize_full (s, GST_SERIALIZE_FLAG_NONE);
|
||||||
|
|
||||||
gst_println ("Added custom meta %s", str);
|
gst_println ("Added custom meta %s", str);
|
||||||
|
|
||||||
|
@ -93,7 +93,7 @@ client_probe_cb (GstPad * pad, GstPadProbeInfo * info, gpointer user_data)
|
||||||
gchar *str;
|
gchar *str;
|
||||||
|
|
||||||
s = gst_custom_meta_get_structure (meta);
|
s = gst_custom_meta_get_structure (meta);
|
||||||
str = gst_structure_serialize (s, GST_SERIALIZE_FLAG_NONE);
|
str = gst_structure_serialize_full (s, GST_SERIALIZE_FLAG_NONE);
|
||||||
gst_println ("Found custom meta \"%s\"", str);
|
gst_println ("Found custom meta \"%s\"", str);
|
||||||
g_free (str);
|
g_free (str);
|
||||||
}
|
}
|
||||||
|
|
|
@ -196,8 +196,8 @@ custom_serialize_func (const GstMeta * meta, GstByteArrayInterface * data,
|
||||||
guint8 * version)
|
guint8 * version)
|
||||||
{
|
{
|
||||||
const GstCustomMeta *cmeta = (const GstCustomMeta *) meta;
|
const GstCustomMeta *cmeta = (const GstCustomMeta *) meta;
|
||||||
gchar *str =
|
gchar *str = gst_structure_serialize_full (cmeta->structure,
|
||||||
gst_structure_serialize (cmeta->structure, GST_SERIALIZE_FLAG_STRICT);
|
GST_SERIALIZE_FLAG_STRICT);
|
||||||
if (str == NULL)
|
if (str == NULL)
|
||||||
return FALSE;
|
return FALSE;
|
||||||
|
|
||||||
|
|
|
@ -127,7 +127,7 @@
|
||||||
* ```
|
* ```
|
||||||
*
|
*
|
||||||
* > *note*: gst_structure_to_string() won't use that syntax for backward
|
* > *note*: gst_structure_to_string() won't use that syntax for backward
|
||||||
* > compatibility reason, gst_structure_serialize() has been added for
|
* > compatibility reason, gst_structure_serialize_full() has been added for
|
||||||
* > that purpose.
|
* > that purpose.
|
||||||
*/
|
*/
|
||||||
|
|
||||||
|
@ -2197,7 +2197,7 @@ structure_serialize (const GstStructure * structure, GstSerializeFlags flags)
|
||||||
*
|
*
|
||||||
* This function will lead to unexpected results when there are nested #GstCaps
|
* This function will lead to unexpected results when there are nested #GstCaps
|
||||||
* / #GstStructure deeper than one level, you should user
|
* / #GstStructure deeper than one level, you should user
|
||||||
* gst_structure_serialize() instead for those cases.
|
* gst_structure_serialize_full() instead for those cases.
|
||||||
*
|
*
|
||||||
* Free-function: g_free
|
* Free-function: g_free
|
||||||
*
|
*
|
||||||
|
@ -2222,16 +2222,42 @@ gst_structure_to_string (const GstStructure * structure)
|
||||||
* GStreamer prior to 1.20 unless #GST_SERIALIZE_FLAG_BACKWARD_COMPAT is passed
|
* GStreamer prior to 1.20 unless #GST_SERIALIZE_FLAG_BACKWARD_COMPAT is passed
|
||||||
* as @flag.
|
* as @flag.
|
||||||
*
|
*
|
||||||
|
* %GST_SERIALIZE_FLAG_STRICT flags is not allowed because it would make this
|
||||||
|
* function nullable which is an API break for bindings.
|
||||||
|
* Use gst_structure_serialize_full() instead.
|
||||||
|
*
|
||||||
* Free-function: g_free
|
* Free-function: g_free
|
||||||
*
|
*
|
||||||
* Returns: (transfer full): a pointer to string allocated by g_malloc().
|
* Returns: (transfer full): a pointer to string allocated by g_malloc().
|
||||||
* g_free() after usage.
|
* g_free() after usage.
|
||||||
*
|
*
|
||||||
* Since: 1.20
|
* Since: 1.20
|
||||||
|
* Deprecated: Use gst_structure_serialize_full() instead.
|
||||||
*/
|
*/
|
||||||
gchar *
|
gchar *
|
||||||
gst_structure_serialize (const GstStructure * structure,
|
gst_structure_serialize (const GstStructure * structure,
|
||||||
GstSerializeFlags flags)
|
GstSerializeFlags flags)
|
||||||
|
{
|
||||||
|
g_return_val_if_fail ((flags & GST_SERIALIZE_FLAG_STRICT) == 0, NULL);
|
||||||
|
return structure_serialize (structure, flags);
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* gst_structure_serialize_full:
|
||||||
|
* @structure: a #GstStructure
|
||||||
|
* @flags: The flags to use to serialize structure
|
||||||
|
*
|
||||||
|
* Alias for gst_structure_serialize() but with nullable annotation because it
|
||||||
|
* can return %NULL when %GST_SERIALIZE_FLAG_STRICT flag is set.
|
||||||
|
*
|
||||||
|
* Returns: (transfer full) (nullable): a pointer to string allocated by g_malloc().
|
||||||
|
* g_free() after usage.
|
||||||
|
*
|
||||||
|
* Since: 1.24
|
||||||
|
*/
|
||||||
|
gchar *
|
||||||
|
gst_structure_serialize_full (const GstStructure * structure,
|
||||||
|
GstSerializeFlags flags)
|
||||||
{
|
{
|
||||||
return structure_serialize (structure, flags);
|
return structure_serialize (structure, flags);
|
||||||
}
|
}
|
||||||
|
|
|
@ -364,9 +364,12 @@ gboolean gst_structure_get_flags (const GstStructure *
|
||||||
|
|
||||||
GST_API
|
GST_API
|
||||||
gchar * gst_structure_to_string (const GstStructure * structure) G_GNUC_MALLOC;
|
gchar * gst_structure_to_string (const GstStructure * structure) G_GNUC_MALLOC;
|
||||||
GST_API
|
GST_DEPRECATED_FOR(gst_structure_serialize_full)
|
||||||
gchar * gst_structure_serialize (const GstStructure * structure,
|
gchar * gst_structure_serialize (const GstStructure * structure,
|
||||||
GstSerializeFlags flags) G_GNUC_MALLOC;
|
GstSerializeFlags flags) G_GNUC_MALLOC;
|
||||||
|
GST_API
|
||||||
|
gchar * gst_structure_serialize_full (const GstStructure * structure,
|
||||||
|
GstSerializeFlags flags) G_GNUC_MALLOC;
|
||||||
|
|
||||||
GST_API
|
GST_API
|
||||||
GstStructure * gst_structure_from_string (const gchar * string,
|
GstStructure * gst_structure_from_string (const gchar * string,
|
||||||
|
|
|
@ -369,7 +369,8 @@ _priv_gst_value_serialize_any_list (const GValue * value, const gchar * begin,
|
||||||
s_val = gst_value_serialize (v);
|
s_val = gst_value_serialize (v);
|
||||||
} else {
|
} else {
|
||||||
if (GST_VALUE_HOLDS_STRUCTURE (v))
|
if (GST_VALUE_HOLDS_STRUCTURE (v))
|
||||||
s_val = gst_structure_serialize (gst_value_get_structure (v), flags);
|
s_val =
|
||||||
|
gst_structure_serialize_full (gst_value_get_structure (v), flags);
|
||||||
else if (GST_VALUE_HOLDS_CAPS (v))
|
else if (GST_VALUE_HOLDS_CAPS (v))
|
||||||
s_val = gst_caps_serialize (gst_value_get_caps (v), flags);
|
s_val = gst_caps_serialize (gst_value_get_caps (v), flags);
|
||||||
}
|
}
|
||||||
|
|
|
@ -792,7 +792,7 @@ GST_START_TEST (test_serialize_nested_structures)
|
||||||
fail_unless (gst_structure_has_field_typed (s, "main-sub1",
|
fail_unless (gst_structure_has_field_typed (s, "main-sub1",
|
||||||
GST_TYPE_STRUCTURE));
|
GST_TYPE_STRUCTURE));
|
||||||
|
|
||||||
str2 = gst_structure_serialize (s, GST_SERIALIZE_FLAG_NONE);
|
str2 = gst_structure_serialize_full (s, GST_SERIALIZE_FLAG_NONE);
|
||||||
fail_unless (str2 != NULL);
|
fail_unless (str2 != NULL);
|
||||||
|
|
||||||
fail_unless_equals_string (str1, str2);
|
fail_unless_equals_string (str1, str2);
|
||||||
|
@ -1041,13 +1041,13 @@ GST_START_TEST (test_strict)
|
||||||
GstElement *bin = gst_bin_new ("mybin");
|
GstElement *bin = gst_bin_new ("mybin");
|
||||||
s = gst_structure_new ("test-struct", "obj", GST_TYPE_BIN, bin, NULL);
|
s = gst_structure_new ("test-struct", "obj", GST_TYPE_BIN, bin, NULL);
|
||||||
fail_unless (s);
|
fail_unless (s);
|
||||||
fail_if (gst_structure_serialize (s, GST_SERIALIZE_FLAG_STRICT));
|
fail_if (gst_structure_serialize_full (s, GST_SERIALIZE_FLAG_STRICT));
|
||||||
gst_structure_free (s);
|
gst_structure_free (s);
|
||||||
gst_object_unref (bin);
|
gst_object_unref (bin);
|
||||||
|
|
||||||
s = gst_structure_new ("test-struct", "ptr", G_TYPE_POINTER, NULL, NULL);
|
s = gst_structure_new ("test-struct", "ptr", G_TYPE_POINTER, NULL, NULL);
|
||||||
fail_unless (s);
|
fail_unless (s);
|
||||||
fail_if (gst_structure_serialize (s, GST_SERIALIZE_FLAG_STRICT));
|
fail_if (gst_structure_serialize_full (s, GST_SERIALIZE_FLAG_STRICT));
|
||||||
gst_structure_free (s);
|
gst_structure_free (s);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in a new issue