mirror of
https://gitlab.freedesktop.org/pipewire/pipewire.git
synced 2025-11-15 07:00:05 -05:00
props: move prop builder to pod-builder.h
This commit is contained in:
parent
e79a294816
commit
e2d930e394
5 changed files with 110 additions and 106 deletions
|
|
@ -44,108 +44,6 @@ spa_pod_builder_push_format (SpaPODBuilder *builder,
|
|||
return offset;
|
||||
}
|
||||
|
||||
static inline void
|
||||
spa_pod_builder_format_propv (SpaPODBuilder *builder,
|
||||
uint32_t propid,
|
||||
va_list args)
|
||||
{
|
||||
while (propid != 0) {
|
||||
int type, n_alternatives = -1;
|
||||
SpaPODProp *prop = NULL;
|
||||
SpaPODFrame f;
|
||||
off_t off;
|
||||
|
||||
if ((off = spa_pod_builder_push_prop (builder, &f, propid, SPA_POD_PROP_FLAG_READWRITE)) != -1)
|
||||
prop = SPA_MEMBER (builder->data, off, SpaPODProp);
|
||||
|
||||
type = va_arg (args, uint32_t);
|
||||
|
||||
while (n_alternatives != 0) {
|
||||
switch (type) {
|
||||
case SPA_POD_TYPE_INVALID:
|
||||
break;
|
||||
case SPA_POD_TYPE_BOOL:
|
||||
spa_pod_builder_bool (builder, va_arg (args, int));
|
||||
break;
|
||||
case SPA_POD_TYPE_INT:
|
||||
spa_pod_builder_int (builder, va_arg (args, int32_t));
|
||||
break;
|
||||
case SPA_POD_TYPE_LONG:
|
||||
spa_pod_builder_long (builder, va_arg (args, int64_t));
|
||||
break;
|
||||
case SPA_POD_TYPE_FLOAT:
|
||||
spa_pod_builder_float (builder, va_arg (args, double));
|
||||
break;
|
||||
case SPA_POD_TYPE_DOUBLE:
|
||||
spa_pod_builder_double (builder, va_arg (args, double));
|
||||
break;
|
||||
case SPA_POD_TYPE_STRING:
|
||||
{
|
||||
const char *str = va_arg (args, char *);
|
||||
uint32_t len = va_arg (args, uint32_t);
|
||||
spa_pod_builder_string (builder, str, len);
|
||||
break;
|
||||
}
|
||||
case SPA_POD_TYPE_RECTANGLE:
|
||||
{
|
||||
uint32_t width = va_arg (args, uint32_t), height = va_arg (args, uint32_t);
|
||||
spa_pod_builder_rectangle (builder, width, height);
|
||||
break;
|
||||
}
|
||||
case SPA_POD_TYPE_FRACTION:
|
||||
{
|
||||
uint32_t num = va_arg (args, uint32_t), denom = va_arg (args, uint32_t);
|
||||
spa_pod_builder_fraction (builder, num, denom);
|
||||
break;
|
||||
}
|
||||
case SPA_POD_TYPE_BITMASK:
|
||||
break;
|
||||
case SPA_POD_TYPE_ARRAY:
|
||||
case SPA_POD_TYPE_STRUCT:
|
||||
case SPA_POD_TYPE_OBJECT:
|
||||
case SPA_POD_TYPE_PROP:
|
||||
break;
|
||||
}
|
||||
if (n_alternatives == -1) {
|
||||
uint32_t flags = va_arg (args, uint32_t);
|
||||
if (prop)
|
||||
prop->body.flags = flags;
|
||||
|
||||
switch (flags & SPA_POD_PROP_RANGE_MASK) {
|
||||
case SPA_POD_PROP_RANGE_NONE:
|
||||
n_alternatives = 0;
|
||||
break;
|
||||
case SPA_POD_PROP_RANGE_MIN_MAX:
|
||||
n_alternatives = 2;
|
||||
break;
|
||||
case SPA_POD_PROP_RANGE_STEP:
|
||||
n_alternatives = 3;
|
||||
break;
|
||||
case SPA_POD_PROP_RANGE_ENUM:
|
||||
case SPA_POD_PROP_RANGE_MASK:
|
||||
n_alternatives = va_arg (args, int);
|
||||
break;
|
||||
}
|
||||
} else
|
||||
n_alternatives--;
|
||||
}
|
||||
spa_pod_builder_pop (builder, &f);
|
||||
|
||||
propid = va_arg (args, uint32_t);
|
||||
}
|
||||
}
|
||||
|
||||
static inline void
|
||||
spa_pod_builder_format_prop (SpaPODBuilder *builder,
|
||||
uint32_t propid, ...)
|
||||
{
|
||||
va_list args;
|
||||
|
||||
va_start (args, propid);
|
||||
spa_pod_builder_format_propv (builder, propid, args);
|
||||
va_end (args);
|
||||
}
|
||||
|
||||
static inline off_t
|
||||
spa_pod_builder_format (SpaPODBuilder *builder,
|
||||
uint32_t media_type,
|
||||
|
|
@ -159,7 +57,7 @@ spa_pod_builder_format (SpaPODBuilder *builder,
|
|||
off = spa_pod_builder_push_format (builder, &f, media_type, media_subtype);
|
||||
|
||||
va_start (args, propid);
|
||||
spa_pod_builder_format_propv (builder, propid, args);
|
||||
spa_pod_builder_propv (builder, propid, args);
|
||||
va_end (args);
|
||||
|
||||
spa_pod_builder_pop (builder, &f);
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue