mirror of
https://gitlab.freedesktop.org/pipewire/pipewire.git
synced 2025-11-01 22:58:50 -04:00
types: more work on types
This commit is contained in:
parent
acedfe71c0
commit
5825c62d6d
76 changed files with 1713 additions and 1477 deletions
|
|
@ -23,7 +23,7 @@
|
|||
#include <unistd.h>
|
||||
#include <errno.h>
|
||||
|
||||
#include <spa/id-map.h>
|
||||
#include <spa/type-map.h>
|
||||
#include <spa/log.h>
|
||||
#include <spa/node.h>
|
||||
#include <spa/loop.h>
|
||||
|
|
@ -40,19 +40,19 @@
|
|||
*/
|
||||
|
||||
spa_build (SPA_MEDIA_TYPE_VIDEO, SPA_MEDIA_SUBTYPE_RAW,
|
||||
prop_video.format, SPA_PROP_TYPE_URI,
|
||||
video_formats.I420
|
||||
type.prop_video.format, SPA_PROP_TYPE_URI,
|
||||
video_format.I420
|
||||
SPA_POD_PROP_FLAG_UNSET |
|
||||
SPA_PROP_RANGE_ENUM, 2,
|
||||
video_formats.I420,
|
||||
video_formats.YUY2,
|
||||
prop_video.size , SPA_PROP_TYPE_RECTANGLE,
|
||||
video_format.I420,
|
||||
video_format.YUY2,
|
||||
type.prop_video.size , SPA_PROP_TYPE_RECTANGLE,
|
||||
320, 240,
|
||||
SPA_POD_PROP_FLAG_UNSET |
|
||||
SPA_PROP_RANGE_MIN_MAX,
|
||||
1, 1,
|
||||
INT32_MAX, INT32_MAX,
|
||||
prop_video.framerate, SPA_PROP_TYPE_FRACTION, 25, 1,
|
||||
type.prop_video.framerate, SPA_PROP_TYPE_FRACTION, 25, 1,
|
||||
SPA_POD_PROP_FLAG_UNSET |
|
||||
SPA_PROP_RANGE_MIN_MAX,
|
||||
0, 1,
|
||||
|
|
@ -60,11 +60,23 @@ spa_build (SPA_MEDIA_TYPE_VIDEO, SPA_MEDIA_SUBTYPE_RAW,
|
|||
0);
|
||||
#endif
|
||||
|
||||
static uint32_t format_type;
|
||||
static SpaMediaTypes media_types;
|
||||
static SpaMediaSubtypes media_subtypes;
|
||||
static SpaPropVideo prop_video;
|
||||
static SpaVideoFormats video_formats;
|
||||
static struct {
|
||||
uint32_t format;
|
||||
SpaTypeMediaType media_type;
|
||||
SpaTypeMediaSubtype media_subtype;
|
||||
SpaTypePropVideo prop_video;
|
||||
SpaTypeVideoFormat video_format;
|
||||
} type = { 0, };
|
||||
|
||||
static inline void
|
||||
type_init (SpaTypeMap *map)
|
||||
{
|
||||
type.format = spa_type_map_get_id (map, SPA_TYPE__Format);
|
||||
spa_type_media_type_map (map, &type.media_type);
|
||||
spa_type_media_subtype_map (map, &type.media_subtype);
|
||||
spa_type_prop_video_map (map, &type.prop_video);
|
||||
spa_type_video_format_map (map, &type.video_format);
|
||||
}
|
||||
|
||||
static void
|
||||
do_static_struct (void)
|
||||
|
|
@ -96,20 +108,20 @@ do_static_struct (void)
|
|||
} props;
|
||||
} test_format = {
|
||||
{ { sizeof (test_format.props) + sizeof (SpaFormatBody), SPA_POD_TYPE_OBJECT },
|
||||
{ { 0, format_type },
|
||||
{ { sizeof (uint32_t), SPA_POD_TYPE_URI }, media_types.video },
|
||||
{ { sizeof (uint32_t), SPA_POD_TYPE_URI }, media_subtypes.raw } },
|
||||
{ { 0, type.format },
|
||||
{ { sizeof (uint32_t), SPA_POD_TYPE_URI }, type.media_type.video },
|
||||
{ { sizeof (uint32_t), SPA_POD_TYPE_URI }, type.media_subtype.raw } },
|
||||
}, {
|
||||
{ { sizeof (test_format.props.format_vals) + sizeof (SpaPODPropBody),
|
||||
SPA_POD_TYPE_PROP } ,
|
||||
{ prop_video.format, SPA_POD_PROP_RANGE_ENUM | SPA_POD_PROP_FLAG_UNSET,
|
||||
{ type.prop_video.format, SPA_POD_PROP_RANGE_ENUM | SPA_POD_PROP_FLAG_UNSET,
|
||||
{ sizeof (uint32_t), SPA_POD_TYPE_URI } }, },
|
||||
{ video_formats.I420,
|
||||
{ video_formats.I420, video_formats.YUY2 } }, 0,
|
||||
{ type.video_format.I420,
|
||||
{ type.video_format.I420, type.video_format.YUY2 } }, 0,
|
||||
|
||||
{ { sizeof (test_format.props.size_vals) + sizeof (SpaPODPropBody),
|
||||
SPA_POD_TYPE_PROP } ,
|
||||
{ prop_video.size, SPA_POD_PROP_RANGE_MIN_MAX | SPA_POD_PROP_FLAG_UNSET,
|
||||
{ type.prop_video.size, SPA_POD_PROP_RANGE_MIN_MAX | SPA_POD_PROP_FLAG_UNSET,
|
||||
{ sizeof (SpaRectangle), SPA_POD_TYPE_RECTANGLE } }, },
|
||||
{ { 320, 243 },
|
||||
{ 1, 1 },
|
||||
|
|
@ -117,7 +129,7 @@ do_static_struct (void)
|
|||
|
||||
{ { sizeof (test_format.props.framerate_vals) + sizeof (SpaPODPropBody),
|
||||
SPA_POD_TYPE_PROP } ,
|
||||
{ prop_video.framerate, SPA_POD_PROP_RANGE_MIN_MAX | SPA_POD_PROP_FLAG_UNSET,
|
||||
{ type.prop_video.framerate, SPA_POD_PROP_RANGE_MIN_MAX | SPA_POD_PROP_FLAG_UNSET,
|
||||
{ sizeof (SpaFraction), SPA_POD_TYPE_FRACTION } }, },
|
||||
{ { 25, 1 },
|
||||
{ 0, 1 },
|
||||
|
|
@ -133,8 +145,8 @@ do_static_struct (void)
|
|||
SpaFraction frac = { 0, 0 };
|
||||
|
||||
match = spa_pod_contents_query (&test_format.fmt.pod, sizeof (SpaFormat),
|
||||
prop_video.format, SPA_POD_TYPE_INT, &format,
|
||||
prop_video.framerate, SPA_POD_TYPE_FRACTION, &frac,
|
||||
type.prop_video.format, SPA_POD_TYPE_INT, &format,
|
||||
type.prop_video.framerate, SPA_POD_TYPE_FRACTION, &frac,
|
||||
0);
|
||||
|
||||
printf ("%d %d %d %d\n", match, format, frac.num, frac.denom);
|
||||
|
|
@ -149,30 +161,25 @@ main (int argc, char *argv[])
|
|||
SpaPODFrame frame[4];
|
||||
uint8_t buffer[1024];
|
||||
SpaFormat *fmt;
|
||||
SpaIDMap *map = spa_id_map_get_default();
|
||||
|
||||
format_type = spa_id_map_get_id (map, SPA_TYPE__Format);
|
||||
spa_media_types_fill (&media_types, map);
|
||||
spa_media_subtypes_map (map, &media_subtypes);
|
||||
spa_prop_video_map (map, &prop_video);
|
||||
spa_video_formats_map (map, &video_formats);
|
||||
type_init (spa_type_map_get_default());
|
||||
|
||||
spa_pod_builder_init (&b, buffer, sizeof (buffer));
|
||||
|
||||
fmt = SPA_MEMBER (buffer, spa_pod_builder_push_format (&b, &frame[0], format_type,
|
||||
media_types.video,
|
||||
media_subtypes.raw), SpaFormat);
|
||||
fmt = SPA_MEMBER (buffer, spa_pod_builder_push_format (&b, &frame[0], type.format,
|
||||
type.media_type.video,
|
||||
type.media_subtype.raw), SpaFormat);
|
||||
spa_pod_builder_push_prop (&b, &frame[1],
|
||||
prop_video.format,
|
||||
type.prop_video.format,
|
||||
SPA_POD_PROP_RANGE_ENUM | SPA_POD_PROP_FLAG_UNSET | SPA_POD_PROP_FLAG_READWRITE);
|
||||
spa_pod_builder_uri (&b, video_formats.I420);
|
||||
spa_pod_builder_uri (&b, video_formats.I420);
|
||||
spa_pod_builder_uri (&b, video_formats.YUY2);
|
||||
spa_pod_builder_uri (&b, type.video_format.I420);
|
||||
spa_pod_builder_uri (&b, type.video_format.I420);
|
||||
spa_pod_builder_uri (&b, type.video_format.YUY2);
|
||||
spa_pod_builder_pop (&b, &frame[1]);
|
||||
|
||||
SpaRectangle size_min_max[] = { { 1, 1 }, { INT32_MAX, INT32_MAX } };
|
||||
spa_pod_builder_push_prop (&b, &frame[1],
|
||||
prop_video.size,
|
||||
type.prop_video.size,
|
||||
SPA_POD_PROP_RANGE_MIN_MAX | SPA_POD_PROP_FLAG_UNSET | SPA_POD_PROP_FLAG_READWRITE);
|
||||
spa_pod_builder_rectangle (&b, 320, 240);
|
||||
spa_pod_builder_raw (&b, size_min_max, sizeof(size_min_max));
|
||||
|
|
@ -180,7 +187,7 @@ main (int argc, char *argv[])
|
|||
|
||||
SpaFraction rate_min_max[] = { { 0, 1 }, { INT32_MAX, 1 } };
|
||||
spa_pod_builder_push_prop (&b, &frame[1],
|
||||
prop_video.framerate,
|
||||
type.prop_video.framerate,
|
||||
SPA_POD_PROP_RANGE_MIN_MAX | SPA_POD_PROP_FLAG_UNSET | SPA_POD_PROP_FLAG_READWRITE);
|
||||
spa_pod_builder_fraction (&b, 25, 1);
|
||||
spa_pod_builder_raw (&b, rate_min_max, sizeof(rate_min_max));
|
||||
|
|
@ -192,18 +199,18 @@ main (int argc, char *argv[])
|
|||
|
||||
spa_pod_builder_init (&b, buffer, sizeof (buffer));
|
||||
|
||||
spa_pod_builder_format (&b, &frame[0], format_type,
|
||||
media_types.video, media_subtypes.raw,
|
||||
spa_pod_builder_format (&b, &frame[0], type.format,
|
||||
type.media_type.video, type.media_subtype.raw,
|
||||
SPA_POD_TYPE_PROP, &frame[1],
|
||||
prop_video.format, SPA_POD_PROP_FLAG_UNSET |
|
||||
type.prop_video.format, SPA_POD_PROP_FLAG_UNSET |
|
||||
SPA_POD_PROP_RANGE_ENUM,
|
||||
SPA_POD_TYPE_URI, 3,
|
||||
video_formats.I420,
|
||||
video_formats.I420,
|
||||
video_formats.YUY2,
|
||||
type.video_format.I420,
|
||||
type.video_format.I420,
|
||||
type.video_format.YUY2,
|
||||
-SPA_POD_TYPE_PROP, &frame[1],
|
||||
SPA_POD_TYPE_PROP, &frame[1],
|
||||
prop_video.size, SPA_POD_PROP_FLAG_UNSET |
|
||||
type.prop_video.size, SPA_POD_PROP_FLAG_UNSET |
|
||||
SPA_POD_PROP_RANGE_MIN_MAX,
|
||||
SPA_POD_TYPE_RECTANGLE, 3,
|
||||
320, 241,
|
||||
|
|
@ -211,7 +218,7 @@ main (int argc, char *argv[])
|
|||
INT32_MAX, INT32_MAX,
|
||||
-SPA_POD_TYPE_PROP, &frame[1],
|
||||
SPA_POD_TYPE_PROP, &frame[1],
|
||||
prop_video.framerate, SPA_POD_PROP_FLAG_UNSET |
|
||||
type.prop_video.framerate, SPA_POD_PROP_FLAG_UNSET |
|
||||
SPA_POD_PROP_RANGE_MIN_MAX,
|
||||
SPA_POD_TYPE_FRACTION, 3,
|
||||
25, 1,
|
||||
|
|
@ -226,19 +233,19 @@ main (int argc, char *argv[])
|
|||
spa_pod_builder_init (&b, buffer, sizeof (buffer));
|
||||
|
||||
spa_pod_builder_add (&b,
|
||||
SPA_POD_TYPE_OBJECT, &frame[0], 0, format_type,
|
||||
SPA_POD_TYPE_URI, media_types.video,
|
||||
SPA_POD_TYPE_URI, media_subtypes.raw,
|
||||
SPA_POD_TYPE_OBJECT, &frame[0], 0, type.format,
|
||||
SPA_POD_TYPE_URI, type.media_type.video,
|
||||
SPA_POD_TYPE_URI, type.media_subtype.raw,
|
||||
SPA_POD_TYPE_PROP, &frame[1],
|
||||
prop_video.format, SPA_POD_PROP_FLAG_UNSET |
|
||||
type.prop_video.format, SPA_POD_PROP_FLAG_UNSET |
|
||||
SPA_POD_PROP_RANGE_ENUM,
|
||||
SPA_POD_TYPE_URI, 3,
|
||||
video_formats.I420,
|
||||
video_formats.I420,
|
||||
video_formats.YUY2,
|
||||
type.video_format.I420,
|
||||
type.video_format.I420,
|
||||
type.video_format.YUY2,
|
||||
-SPA_POD_TYPE_PROP, &frame[1],
|
||||
SPA_POD_TYPE_PROP, &frame[1],
|
||||
prop_video.size, SPA_POD_PROP_FLAG_UNSET |
|
||||
type.prop_video.size, SPA_POD_PROP_FLAG_UNSET |
|
||||
SPA_POD_PROP_RANGE_MIN_MAX,
|
||||
SPA_POD_TYPE_RECTANGLE, 3,
|
||||
320, 242,
|
||||
|
|
@ -246,7 +253,7 @@ main (int argc, char *argv[])
|
|||
INT32_MAX, INT32_MAX,
|
||||
-SPA_POD_TYPE_PROP, &frame[1],
|
||||
SPA_POD_TYPE_PROP, &frame[1],
|
||||
prop_video.framerate, SPA_POD_PROP_FLAG_UNSET |
|
||||
type.prop_video.framerate, SPA_POD_PROP_FLAG_UNSET |
|
||||
SPA_POD_PROP_RANGE_MIN_MAX,
|
||||
SPA_POD_TYPE_FRACTION, 3,
|
||||
25, 1,
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue