1
0
mirror of https://github.com/mpv-player/mpv synced 2025-01-09 08:29:36 +00:00

client API: treat MPV_FORMAT_STRING differently in mpv_set_property

Always map MPV_FORMAT_STRING to setting property value directly through
M_PROPERTY_SET_STRING, instead of trying to go through
M_PROPERTY_SET_NODE.

This treats a direct MPV_FORMAT_STRING query differently from a
MPV_FORMAT_STRING wrapped in a mpv_node. This was already the case in
mpv_get_property(). The reason for all this is that mpv_node is supposed
to be the exact type, while a direct MPV_FORMAT_STRING goes through all
possible conversions.

Not sure if these semantics are good.
This commit is contained in:
wm4 2014-02-26 20:39:15 +01:00
parent a0b1d5f888
commit eca9210399

View File

@ -677,32 +677,33 @@ static void setproperty_fn(void *arg)
struct setproperty_request *req = arg;
const struct m_option *type = get_mp_type(req->format);
struct mpv_node node;
node.format = req->format;
req->status = 0;
int err;
switch (req->format) {
case MPV_FORMAT_NODE:
node = *(struct mpv_node *)req->data;
break;
case MPV_FORMAT_STRING:
case MPV_FORMAT_FLAG:
case MPV_FORMAT_INT64:
case MPV_FORMAT_DOUBLE:
// These are basically emulated via mpv_node.
memcpy(&node.u, req->data, type->type->size);
break;
default:
abort();
}
int err = mp_property_do(req->name, M_PROPERTY_SET_NODE, &node, req->mpctx);
if (err == M_PROPERTY_NOT_IMPLEMENTED && req->format == MPV_FORMAT_STRING) {
case MPV_FORMAT_STRING: {
// Go through explicit string conversion. M_PROPERTY_SET_NODE doesn't
// do this, because it tries to be somewhat type-strict. But the client
// needs a way to set everything by string.
err = mp_property_do(req->name, M_PROPERTY_SET_STRING, node.u.string,
req->mpctx);
char *s = *(char **)req->data;
err = mp_property_do(req->name, M_PROPERTY_SET_STRING, s, req->mpctx);
break;
}
case MPV_FORMAT_NODE:
case MPV_FORMAT_FLAG:
case MPV_FORMAT_INT64:
case MPV_FORMAT_DOUBLE: {
struct mpv_node node;
if (req->format == MPV_FORMAT_NODE) {
node = *(struct mpv_node *)req->data;
} else {
// These are basically emulated via mpv_node.
node.format = req->format;
memcpy(&node.u, req->data, type->type->size);
}
err = mp_property_do(req->name, M_PROPERTY_SET_NODE, &node, req->mpctx);
break;
}
default:
abort();
}
req->status = translate_property_error(err);