gst.structure
Module for [Structure] class
Types 1
A #GstStructure is a collection of key/value pairs. The keys are expressed as GQuarks and the values can be of any GType.
In addition to the key/value pairs, a #GstStructure also has a name. The name starts with a letter and can be filled by letters, numbers and any of "/-_.:".
#GstStructure is used by various GStreamer subsystems to store information in a flexible and extensible way. A #GstStructure does not have a refcount because it usually is part of a higher level object such as #GstCaps, #GstMessage, #GstEvent, #GstQuery. It provides a means to enforce mutability using the refcount of the parent with the [gst.structure.Structure.setParentRefcount] method.
A #GstStructure can be created with [gst.structure.Structure.newEmpty] or [gst.structure.Structure.new_], which both take a name and an optional set of key/value pairs along with the types of the values.
Field values can be changed with [gst.structure.Structure.setValue] or [gst.structure.Structure.set].
Field values can be retrieved with [gst.structure.Structure.getValue] or the more convenient gst_structure_get_*() functions.
Fields can be removed with [gst.structure.Structure.removeField] or [gst.structure.Structure.removeFields].
Strings in structures must be ASCII or UTF-8 encoded. Other encodings are not allowed. Strings may be null however.
The serialization format
GstStructure serialization format serialize the GstStructure name, keys/GType/values in a comma separated list with the structure name as first field without value followed by separated key/value pairs in the form key=value, for example:
a-structure, key=value
The values type will be inferred if not explicitly specified with the
(GTypeName)value syntax, for example the following struct will have one
field called 'is-string' which has the string 'true' as a value:
CODEBLOCK1
*Note*: without specifying (string), field-is-string type would have been inferred as boolean.Note: we specified (string) as a type even if gchararray is the actual
GType name as for convenience some well known types have been aliased or abbreviated.
To avoid specifying the type, you can give some hints to the "type system". For example to specify a value as a double, you should add a decimal (ie. 1 is an [harfbuzz.types.int] while 1.0 is a double).
values are explicitly typed.
Some types have special delimiters:
- GstValueArray are inside curly brackets (`{` and `}`).
For example a-structure, array={1, 2, 3}
- Ranges are inside brackets (`[` and `]`). For example
a-structure, range=[1, 6, 2]1 being the min value, 6 the maximum and 2 the step. To
specify a #GST_TYPE_INT64_RANGE you need to explicitly specify it like: a-structure, a-int64-range=(gint64) [1, 5]
- GstValueList are inside "less and greater than" (`<` and
`>`). For example a-structure, list=<1, 2, 3>
)
Structures are delimited either by a null character \0 or a semicolon ;
the latter allowing to store multiple structures in the same string (see
#GstCaps).
Quotes are used as "default" delimiters and can be used around any types that
don't use other delimiters (for example a-struct, i=(int)"1"). They are use
to allow adding spaces or special characters (such as delimiters,
semicolumns, etc..) inside strings and you can use backslashes \ to escape
characters inside them, for example:
CODEBLOCK2
They also allow for nested structure, such as:
CODEBLOCK3
Since 1.20, nested structures and caps can be specified using brackets ([
and ]`, for example:
a-struct, nested=[nested-struct, nested=true]note: [gst.structure.Structure.toString_] won't use that syntax for backwardcompatibility reason, [gst.structure.Structure.serializeFull] has been added for that purpose.
void type(gobject.types.GType propval) @propertySet `type` field. Params: propval = the GType of a structuregst.structure.Structure fromString(string string_, out string end)Creates a #GstStructure from a string representation. If end is not null, a pointer to the place inside the given string where parsing ended will be returned.gst.structure.Structure newEmpty(string name)Creates a new, empty #GstStructure with the given name.gst.structure.Structure newFromString(string string_)Creates a #GstStructure from a string representation. If end is not null, a pointer to the place inside the given string where parsing ended will be returned.gst.structure.Structure newIdEmpty(glib.types.Quark quark)Creates a new, empty #GstStructure with the given name as a GQuark.bool canIntersect(gst.structure.Structure struct2)Tries intersecting struct1 and struct2 and reports whether the result would not be empty.gst.structure.Structure copy()Duplicates a #GstStructure and all its fields and values.void filterAndMapInPlace(gst.types.StructureFilterMapFunc func)Calls the provided function once for each field in the #GstStructure. In contrast to [gst.structure.Structure.foreach_], the function may modify the fields. In contrast to [gst.structure.Structure....void fixate()Fixate all values in structure using [gst.global.valueFixate]. structure will be modified in-place and should be writable.bool fixateField(string fieldName)Fixates a #GstStructure by changing the given field with its fixated value.bool fixateFieldBoolean(string fieldName, bool target)Fixates a #GstStructure by changing the given field_name field to the given target boolean if that field is not fixed yet.bool fixateFieldNearestDouble(string fieldName, double target)Fixates a #GstStructure by changing the given field to the nearest double to target that is a subset of the existing field.bool fixateFieldNearestFraction(string fieldName, int targetNumerator, int targetDenominator)Fixates a #GstStructure by changing the given field to the nearest fraction to targetnumerator/targetdenominator that is a subset of the existing field.bool fixateFieldNearestInt(string fieldName, int target)Fixates a #GstStructure by changing the given field to the nearest integer to target that is a subset of the existing field.bool fixateFieldString(string fieldName, string target)Fixates a #GstStructure by changing the given field_name field to the given target string if that field is not fixed yet.bool foreach_(gst.types.StructureForeachFunc func)Calls the provided function once for each field in the #GstStructure. The function must not modify the fields. Also see [gst.structure.Structure.mapInPlace] and [gst.structure.Structure.filterAndMa...bool getArray(string fieldname, out gobject.value_array.ValueArray array)This is useful in language bindings where unknown #GValue types are not supported. This function will convert the `GSTTYPEARRAY` into a newly allocated #GValueArray and return it through array. Be ...bool getBoolean(string fieldname, out bool value)Sets the boolean pointed to by value corresponding to the value of the given field. Caller is responsible for making sure the field exists and has the correct type.bool getClockTime(string fieldname, out gst.types.ClockTime value)Sets the clock time pointed to by value corresponding to the clock time of the given field. Caller is responsible for making sure the field exists and has the correct type.bool getDate(string fieldname, out glib.date.Date value)Sets the date pointed to by value corresponding to the date of the given field. Caller is responsible for making sure the field exists and has the correct type.bool getDateTime(string fieldname, out gst.date_time.DateTime value)Sets the datetime pointed to by value corresponding to the datetime of the given field. Caller is responsible for making sure the field exists and has the correct type.bool getDouble(string fieldname, out double value)Sets the double pointed to by value corresponding to the value of the given field. Caller is responsible for making sure the field exists and has the correct type.bool getEnum(string fieldname, gobject.types.GType enumtype, out int value)Sets the int pointed to by value corresponding to the value of the given field. Caller is responsible for making sure the field exists, has the correct type and that the enumtype is correct.gobject.types.GType getFieldType(string fieldname)Finds the field with the given name, and returns the type of the value it contains. If the field is not found, GTYPEINVALID is returned.bool getFlags(string fieldname, gobject.types.GType flagsType, out uint value)Sets the unsigned int pointed to by value corresponding to the value of the given field. Caller is responsible for making sure the field exists, has the correct type and that the flagstype is correct.bool getFlagset(string fieldname, out uint valueFlags, out uint valueMask)Read the GstFlagSet flags and mask out of the structure into the provided pointers.bool getFraction(string fieldname, out int valueNumerator, out int valueDenominator)Sets the integers pointed to by valuenumerator and valuedenominator corresponding to the value of the given field. Caller is responsible for making sure the field exists and has the correct type.bool getInt(string fieldname, out int value)Sets the int pointed to by value corresponding to the value of the given field. Caller is responsible for making sure the field exists and has the correct type.bool getInt64(string fieldname, out long value)Sets the #gint64 pointed to by value corresponding to the value of the given field. Caller is responsible for making sure the field exists and has the correct type.bool getList(string fieldname, out gobject.value_array.ValueArray array)This is useful in language bindings where unknown #GValue types are not supported. This function will convert the `GSTTYPELIST` into a newly allocated GValueArray and return it through array. Be aw...string getName()Get the name of structure as a string. Returns: the name of the structure.glib.types.Quark getNameId()Get the name of structure as a GQuark. Returns: the quark representing the name of the structure.string getString(string fieldname)Finds the field corresponding to fieldname, and returns the string contained in the field's value. Caller is responsible for making sure the field exists and has the correct type.bool getUint(string fieldname, out uint value)Sets the uint pointed to by value corresponding to the value of the given field. Caller is responsible for making sure the field exists and has the correct type.bool getUint64(string fieldname, out ulong value)Sets the #guint64 pointed to by value corresponding to the value of the given field. Caller is responsible for making sure the field exists and has the correct type.gobject.value.Value getValue(string fieldname)Get the value of the field with name fieldname.bool hasField(string fieldname)Check if structure contains a field named fieldname.bool hasFieldTyped(string fieldname, gobject.types.GType type)Check if structure contains a field named fieldname and with GType type.bool hasName(string name)Checks if the structure has the given namegobject.value.Value idGetValue(glib.types.Quark field)Get the value of the field with GQuark field.bool idHasField(glib.types.Quark field)Check if structure contains a field named field.bool idHasFieldTyped(glib.types.Quark field, gobject.types.GType type)Check if structure contains a field named field and with GType type.void idSetValue(glib.types.Quark field, gobject.value.Value value)Sets the field with the given GQuark field to value. If the field does not exist, it is created. If the field exists, the previous value is replaced and freed.void idTakeValue(glib.types.Quark field, gobject.value.Value value)Sets the field with the given GQuark field to value. If the field does not exist, it is created. If the field exists, the previous value is replaced and freed.gst.structure.Structure intersect(gst.structure.Structure struct2)Intersects struct1 and struct2 and returns the intersection.bool isEqual(gst.structure.Structure structure2)Tests if the two #GstStructure are equal.bool isSubset(gst.structure.Structure superset)Checks if subset is a subset of superset, i.e. has the same structure name and for all fields that are existing in superset, subset has a value that is a subset of the value in superset.bool mapInPlace(gst.types.StructureMapFunc func)Calls the provided function once for each field in the #GstStructure. In contrast to [gst.structure.Structure.foreach_], the function may modify but not delete the fields. The structure must be mut...int nFields()Get the number of fields in the structure. Returns: the number of fields in the structurestring nthFieldName(uint index)Get the name of the given field number, counting from 0 onwards.void removeAllFields()Removes all fields in a GstStructure.void removeField(string fieldname)Removes the field with the given name. If the field with the given name does not exist, the structure is unchanged.string serialize(gst.types.SerializeFlags flags)Converts structure to a human-readable string representation.string serializeFull(gst.types.SerializeFlags flags)Alias for [gst.structure.Structure.serialize] but with nullable annotation because it can return null when [gst.types.SerializeFlags.Strict] flag is set.void setArray(string fieldname, gobject.value_array.ValueArray array)This is useful in language bindings where unknown GValue types are not supported. This function will convert a array to `GSTTYPEARRAY` and set the field specified by fieldname. Be aware that this ...void setList(string fieldname, gobject.value_array.ValueArray array)This is useful in language bindings where unknown GValue types are not supported. This function will convert a array to `GSTTYPELIST` and set the field specified by fieldname. Be aware that this is...void setName(string name)Sets the name of the structure to the given name. The string provided is copied before being used. It must not be empty, start with a letter and can be followed by letters, numbers and any of "/-_...void setValue(string fieldname, gobject.value.Value value)Sets the field with the given name field to value. If the field does not exist, it is created. If the field exists, the previous value is replaced and freed.void takeValue(string fieldname, gobject.value.Value value)Sets the field with the given name field to value. If the field does not exist, it is created. If the field exists, the previous value is replaced and freed. The function will take ownership of v...string toString_()Converts structure to a human-readable string representation.bool take(gst.structure.Structure oldstrPtr = null, gst.structure.Structure newstr = null)Atomically modifies a pointer to point to a new structure. The #GstStructure oldstr_ptr is pointing to is freed and newstr is taken ownership over.