mirror of
https://gitlab.freedesktop.org/pipewire/pipewire.git
synced 2025-10-31 22:25:38 -04:00
modules: place floats in properties in JSON format
Using %f will result in a locale dependent format and might not parse with JSON parsers or even our own spa_atof() function.
This commit is contained in:
parent
c386c96ff0
commit
5e750f6fb8
4 changed files with 21 additions and 10 deletions
|
|
@ -192,10 +192,14 @@ static int rename_geometry(struct pw_properties *props, const char *pa_key, cons
|
||||||
fprintf(f, "[ ");
|
fprintf(f, "[ ");
|
||||||
while (true) {
|
while (true) {
|
||||||
float p[3];
|
float p[3];
|
||||||
|
char ps0[64], ps1[64], ps2[64];
|
||||||
if ((len = parse_point(&str, p)) < 0)
|
if ((len = parse_point(&str, p)) < 0)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
fprintf(f, "[ %f %f %f ] ", p[0], p[1], p[2]);
|
fprintf(f, "[ %s %s %s ] ",
|
||||||
|
spa_dtoa(ps0, sizeof(ps0), p[0]),
|
||||||
|
spa_dtoa(ps1, sizeof(ps1), p[1]),
|
||||||
|
spa_dtoa(ps2, sizeof(ps2), p[2]));
|
||||||
str += len;
|
str += len;
|
||||||
if (*str != ',')
|
if (*str != ',')
|
||||||
break;
|
break;
|
||||||
|
|
@ -216,6 +220,7 @@ static int rename_direction(struct pw_properties *props, const char *pa_key, con
|
||||||
const char *str;
|
const char *str;
|
||||||
int res;
|
int res;
|
||||||
float f[3];
|
float f[3];
|
||||||
|
char fs0[64], fs1[64], fs2[64];
|
||||||
|
|
||||||
if ((str = pw_properties_get(props, pa_key)) == NULL)
|
if ((str = pw_properties_get(props, pa_key)) == NULL)
|
||||||
return 0;
|
return 0;
|
||||||
|
|
@ -225,7 +230,10 @@ static int rename_direction(struct pw_properties *props, const char *pa_key, con
|
||||||
if ((res = parse_point(&str, f)) < 0)
|
if ((res = parse_point(&str, f)) < 0)
|
||||||
return res;
|
return res;
|
||||||
|
|
||||||
pw_properties_setf(props, pw_key, "[ %f %f %f ]", f[0], f[1], f[2]);
|
pw_properties_setf(props, pw_key, "[ %s %s %s ]",
|
||||||
|
spa_dtoa(fs0, sizeof(fs0), f[0]),
|
||||||
|
spa_dtoa(fs1, sizeof(fs1), f[1]),
|
||||||
|
spa_dtoa(fs2, sizeof(fs2), f[2]));
|
||||||
pw_properties_set(props, pa_key, NULL);
|
pw_properties_set(props, pa_key, NULL);
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -868,7 +868,7 @@ static struct session *session_new(struct impl *impl, struct sdp_info *info)
|
||||||
struct session *session;
|
struct session *session;
|
||||||
struct pw_properties *props;
|
struct pw_properties *props;
|
||||||
const char *str;
|
const char *str;
|
||||||
char dst_addr[64];
|
char dst_addr[64], tmp[64];
|
||||||
|
|
||||||
if (impl->n_sessions >= MAX_SESSIONS) {
|
if (impl->n_sessions >= MAX_SESSIONS) {
|
||||||
pw_log_warn("too many sessions (%u >= %u)", impl->n_sessions, MAX_SESSIONS);
|
pw_log_warn("too many sessions (%u >= %u)", impl->n_sessions, MAX_SESSIONS);
|
||||||
|
|
@ -908,7 +908,7 @@ static struct session *session_new(struct impl *impl, struct sdp_info *info)
|
||||||
pw_properties_setf(props, "rtp.destination.ip", "%s", dst_addr);
|
pw_properties_setf(props, "rtp.destination.ip", "%s", dst_addr);
|
||||||
pw_properties_setf(props, "rtp.destination.port", "%u", info->dst_port);
|
pw_properties_setf(props, "rtp.destination.port", "%u", info->dst_port);
|
||||||
pw_properties_setf(props, "rtp.payload", "%u", info->payload);
|
pw_properties_setf(props, "rtp.payload", "%u", info->payload);
|
||||||
pw_properties_setf(props, "rtp.ptime", "%f", info->ptime);
|
pw_properties_set(props, "rtp.ptime", spa_dtoa(tmp, sizeof(tmp), info->ptime));
|
||||||
pw_properties_setf(props, "rtp.media", "%s", info->media_type);
|
pw_properties_setf(props, "rtp.media", "%s", info->media_type);
|
||||||
pw_properties_setf(props, "rtp.mime", "%s", info->mime_type);
|
pw_properties_setf(props, "rtp.mime", "%s", info->mime_type);
|
||||||
pw_properties_setf(props, "rtp.rate", "%u", info->rate);
|
pw_properties_setf(props, "rtp.rate", "%u", info->rate);
|
||||||
|
|
|
||||||
|
|
@ -272,6 +272,7 @@ struct rtp_stream *rtp_stream_new(struct pw_core *core,
|
||||||
{
|
{
|
||||||
struct impl *impl;
|
struct impl *impl;
|
||||||
const char *str;
|
const char *str;
|
||||||
|
char tmp[64];
|
||||||
uint8_t buffer[1024];
|
uint8_t buffer[1024];
|
||||||
struct spa_pod_builder b;
|
struct spa_pod_builder b;
|
||||||
uint32_t n_params, min_samples, max_samples;
|
uint32_t n_params, min_samples, max_samples;
|
||||||
|
|
@ -421,8 +422,9 @@ struct rtp_stream *rtp_stream_new(struct pw_core *core,
|
||||||
impl->psamples = impl->mtu / impl->stride;
|
impl->psamples = impl->mtu / impl->stride;
|
||||||
impl->psamples = SPA_CLAMP(impl->psamples, min_samples, max_samples);
|
impl->psamples = SPA_CLAMP(impl->psamples, min_samples, max_samples);
|
||||||
if (direction == PW_DIRECTION_INPUT)
|
if (direction == PW_DIRECTION_INPUT)
|
||||||
pw_properties_setf(props, "rtp.ptime", "%f",
|
pw_properties_set(props, "rtp.ptime",
|
||||||
impl->psamples * 1000.0 / impl->rate);
|
spa_dtoa(tmp, sizeof(tmp),
|
||||||
|
impl->psamples * 1000.0 / impl->rate));
|
||||||
}
|
}
|
||||||
latency_msec = pw_properties_get_uint32(props,
|
latency_msec = pw_properties_get_uint32(props,
|
||||||
"sess.latency.msec", DEFAULT_SESS_LATENCY);
|
"sess.latency.msec", DEFAULT_SESS_LATENCY);
|
||||||
|
|
@ -583,6 +585,5 @@ int rtp_stream_update_params(struct rtp_stream *s,
|
||||||
uint32_t n_params)
|
uint32_t n_params)
|
||||||
{
|
{
|
||||||
struct impl *impl = (struct impl*)s;
|
struct impl *impl = (struct impl*)s;
|
||||||
|
|
||||||
return pw_stream_update_params(impl->stream, params, n_params);
|
return pw_stream_update_params(impl->stream, params, n_params);
|
||||||
}
|
}
|
||||||
|
|
|
||||||
|
|
@ -253,6 +253,7 @@ struct vban_stream *vban_stream_new(struct pw_core *core,
|
||||||
{
|
{
|
||||||
struct impl *impl;
|
struct impl *impl;
|
||||||
const char *str;
|
const char *str;
|
||||||
|
char tmp[64];
|
||||||
uint8_t buffer[1024];
|
uint8_t buffer[1024];
|
||||||
struct spa_pod_builder b;
|
struct spa_pod_builder b;
|
||||||
uint32_t n_params, min_samples, max_samples;
|
uint32_t n_params, min_samples, max_samples;
|
||||||
|
|
@ -370,8 +371,9 @@ struct vban_stream *vban_stream_new(struct pw_core *core,
|
||||||
impl->psamples = impl->mtu / impl->stride;
|
impl->psamples = impl->mtu / impl->stride;
|
||||||
impl->psamples = SPA_CLAMP(impl->psamples, min_samples, max_samples);
|
impl->psamples = SPA_CLAMP(impl->psamples, min_samples, max_samples);
|
||||||
if (direction == PW_DIRECTION_OUTPUT)
|
if (direction == PW_DIRECTION_OUTPUT)
|
||||||
pw_properties_setf(props, "vban.ptime", "%f",
|
pw_properties_set(props, "vban.ptime",
|
||||||
impl->psamples * 1000.0 / impl->rate);
|
spa_dtoa(tmp, sizeof(tmp),
|
||||||
|
impl->psamples * 1000.0 / impl->rate));
|
||||||
}
|
}
|
||||||
latency_msec = pw_properties_get_uint32(props,
|
latency_msec = pw_properties_get_uint32(props,
|
||||||
"sess.latency.msec", DEFAULT_SESS_LATENCY);
|
"sess.latency.msec", DEFAULT_SESS_LATENCY);
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue