mirror of
https://gitlab.freedesktop.org/gstreamer/gstreamer.git
synced 2025-01-03 14:08:56 +00:00
tracer: use the new flags to create the optional field in the format string
This spares us explicitly listing the field in the spec. and thus hide this implementation detail.
This commit is contained in:
parent
8cd76a918a
commit
af91d23204
3 changed files with 21 additions and 7 deletions
|
@ -32,6 +32,7 @@
|
||||||
#define GST_USE_UNSTABLE_API
|
#define GST_USE_UNSTABLE_API
|
||||||
|
|
||||||
#include "gst_private.h"
|
#include "gst_private.h"
|
||||||
|
#include "gstenumtypes.h"
|
||||||
#include "gstinfo.h"
|
#include "gstinfo.h"
|
||||||
#include "gststructure.h"
|
#include "gststructure.h"
|
||||||
#include "gsttracerrecord.h"
|
#include "gsttracerrecord.h"
|
||||||
|
@ -73,14 +74,28 @@ build_field_template (GQuark field_id, const GValue * value, gpointer user_data)
|
||||||
const GstStructure *sub;
|
const GstStructure *sub;
|
||||||
GValue template_value = { 0, };
|
GValue template_value = { 0, };
|
||||||
GType type;
|
GType type;
|
||||||
|
GstTracerValueFlags flags;
|
||||||
gboolean res;
|
gboolean res;
|
||||||
|
|
||||||
g_return_val_if_fail (G_VALUE_TYPE (value) == GST_TYPE_STRUCTURE, FALSE);
|
g_return_val_if_fail (G_VALUE_TYPE (value) == GST_TYPE_STRUCTURE, FALSE);
|
||||||
|
|
||||||
sub = gst_value_get_structure (value);
|
sub = gst_value_get_structure (value);
|
||||||
type = g_value_get_gtype (gst_structure_get_value (sub, "type"));
|
gst_structure_get (sub, "type", G_TYPE_GTYPE, &type, "flags",
|
||||||
g_value_init (&template_value, type);
|
GST_TYPE_TRACER_VALUE_FLAGS, &flags, NULL);
|
||||||
|
|
||||||
|
if (flags & GST_TRACER_VALUE_FLAGS_OPTIONAL) {
|
||||||
|
gchar *opt_name = g_strconcat ("have-", g_quark_to_string (field_id), NULL);
|
||||||
|
|
||||||
|
/* add a boolean field, that indicates the presence of the next field */
|
||||||
|
g_value_init (&template_value, G_TYPE_BOOLEAN);
|
||||||
|
res =
|
||||||
|
priv__gst_structure_append_template_to_gstring (g_quark_from_string
|
||||||
|
(opt_name), &template_value, s);
|
||||||
|
g_value_unset (&template_value);
|
||||||
|
g_free (opt_name);
|
||||||
|
}
|
||||||
|
|
||||||
|
g_value_init (&template_value, type);
|
||||||
res = priv__gst_structure_append_template_to_gstring (field_id,
|
res = priv__gst_structure_append_template_to_gstring (field_id,
|
||||||
&template_value, s);
|
&template_value, s);
|
||||||
g_value_unset (&template_value);
|
g_value_unset (&template_value);
|
||||||
|
|
|
@ -70,7 +70,9 @@ typedef enum
|
||||||
/**
|
/**
|
||||||
* GstTracerValueFlags:
|
* GstTracerValueFlags:
|
||||||
* @GST_TRACER_VALUE_FLAGS_NONE: no flags
|
* @GST_TRACER_VALUE_FLAGS_NONE: no flags
|
||||||
* @GST_TRACER_VALUE_FLAGS_OPTIONAL: the value is optional
|
* @GST_TRACER_VALUE_FLAGS_OPTIONAL: the value is optional. When using this flag
|
||||||
|
* one need to have an additional boolean arg before this value in the
|
||||||
|
* var-args list passed to gst_tracer_record_log().
|
||||||
* @GST_TRACER_VALUE_FLAGS_AGGREGATED: the value is combined since the start of
|
* @GST_TRACER_VALUE_FLAGS_AGGREGATED: the value is combined since the start of
|
||||||
* tracing
|
* tracing
|
||||||
*
|
*
|
||||||
|
|
|
@ -657,13 +657,10 @@ gst_stats_tracer_class_init (GstStatsTracerClass * klass)
|
||||||
"type", G_TYPE_GTYPE, GST_TYPE_STRUCTURE,
|
"type", G_TYPE_GTYPE, GST_TYPE_STRUCTURE,
|
||||||
"description", G_TYPE_STRING, "query structure",
|
"description", G_TYPE_STRING, "query structure",
|
||||||
NULL),
|
NULL),
|
||||||
"have-res", GST_TYPE_STRUCTURE, gst_structure_new ("value",
|
|
||||||
"type", G_TYPE_GTYPE, G_TYPE_BOOLEAN,
|
|
||||||
"description", G_TYPE_STRING, "have query result",
|
|
||||||
NULL),
|
|
||||||
"res", GST_TYPE_STRUCTURE, gst_structure_new ("value",
|
"res", GST_TYPE_STRUCTURE, gst_structure_new ("value",
|
||||||
"type", G_TYPE_GTYPE, G_TYPE_BOOLEAN,
|
"type", G_TYPE_GTYPE, G_TYPE_BOOLEAN,
|
||||||
"description", G_TYPE_STRING, "query result",
|
"description", G_TYPE_STRING, "query result",
|
||||||
|
"flags", GST_TYPE_TRACER_VALUE_FLAGS, GST_TRACER_VALUE_FLAGS_OPTIONAL,
|
||||||
NULL),
|
NULL),
|
||||||
/* TODO(ensonic): "buffer-flags" */
|
/* TODO(ensonic): "buffer-flags" */
|
||||||
NULL));
|
NULL));
|
||||||
|
|
Loading…
Reference in a new issue