[pulseaudio-discuss] [PATCH 7/7] format: Add API to query a property's type

David Henningsson david.henningsson at canonical.com
Tue Feb 7 01:26:29 PST 2012


On 02/07/2012 09:20 AM, Arun Raghavan wrote:
> Since a given property can be single-valued, an array or (in the case of
> ints) a range, clients need an API to figure out what type of value a
> property holds. This adds such an API. The actual property type
> enumeration is kept in the PA_PROP_* namespace and not the
> PA_FORMAT_INFO* namespace so that it can later be reused for properties
> generically if required.
> ---
>   src/map-file            |    1 +
>   src/pulse/format.c      |   74 +++++++++++++++++++++++++++++++++++++++++++++++
>   src/pulse/format.h      |   24 +++++++++++++++
>   src/tests/format-test.c |    5 +++
>   4 files changed, 104 insertions(+), 0 deletions(-)
>
> diff --git a/src/map-file b/src/map-file
> index ee3d31d..5730fdf 100644
> --- a/src/map-file
> +++ b/src/map-file
> @@ -168,6 +168,7 @@ pa_format_info_free;
>   pa_format_info_free2;
>   pa_format_info_from_string;
>   pa_format_info_from_sample_spec;
> +pa_format_info_get_prop_type;
>   pa_format_info_get_prop_int;
>   pa_format_info_get_prop_int_range;
>   pa_format_info_get_prop_int_array;
> diff --git a/src/pulse/format.c b/src/pulse/format.c
> index 6176846..aee3dfc 100644
> --- a/src/pulse/format.c
> +++ b/src/pulse/format.c
> @@ -280,6 +280,80 @@ int pa_format_info_to_sample_spec_fake(pa_format_info *f, pa_sample_spec *ss) {
>       return 0;
>   }
>
> +pa_prop_type_t pa_format_info_get_prop_type(pa_format_info *f, const char *key) {
> +    const char *str;
> +    json_object *o, *o1;
> +    pa_prop_type_t type;
> +
> +    pa_assert(f);
> +    pa_assert(key);
> +
> +    str = pa_proplist_gets(f->plist, key);
> +    if (!str)
> +        return PA_PROP_TYPE_INVALID;
> +
> +    o = json_tokener_parse(str);
> +    if (is_error(o))
> +        return PA_PROP_TYPE_INVALID;
> +
> +    switch (json_object_get_type(o)) {
> +        case json_type_int:
> +            type = PA_PROP_TYPE_INT;
> +            break;
> +
> +        case json_type_string:
> +            type = PA_PROP_TYPE_STRING;
> +            break;
> +
> +        case json_type_array:
> +            if (json_object_array_length(o) == 0) {
> +                /* Unlikely, but let's account for this anyway. We need at
> +                 * least one element to figure out the array type. */
> +                type = PA_PROP_TYPE_INVALID;
> +                break;
> +            }
> +
> +            o1 = json_object_array_get_idx(o, 1);
> +
> +            if (json_object_get_type(o1) == json_type_int)
> +                type = PA_PROP_TYPE_INT_ARRAY;
> +            else if (json_object_get_type(o1) == json_type_string)
> +                type = PA_PROP_TYPE_STRING_ARRAY;
> +            else
> +                type = PA_PROP_TYPE_INVALID;
> +
> +            json_object_put(o1);
> +            break;
> +
> +        case json_type_object:
> +            /* We actually know at this point that it's a int range, but let's
> +             * confirm. */
> +            o1 = json_object_object_get(o, PA_JSON_MIN_KEY);
> +            if (!o1) {
> +                type = PA_PROP_TYPE_INVALID;
> +                break;
> +            }
> +            json_object_put(o1);
> +
> +            o1 = json_object_object_get(o, PA_JSON_MIN_KEY);

Shouldn't this be PA_JSON_MAX_KEY - and if it should, how come that the 
test succeed anyway? (Assuming you have actually tested that it does 
before submitting?)

> +            if (!o1) {
> +                type = PA_PROP_TYPE_INVALID;
> +                break;
> +            }
> +            json_object_put(o1);
> +
> +            type = PA_PROP_TYPE_INT_RANGE;
> +            break;
> +
> +        default:
> +            type = PA_PROP_TYPE_INVALID;
> +            break;
> +    }
> +
> +    json_object_put(o);
> +    return type;
> +}
> +
>   int pa_format_info_get_prop_int(pa_format_info *f, const char *key, int *v) {
>       const char *str;
>       json_object *o;
> diff --git a/src/pulse/format.h b/src/pulse/format.h
> index 5f71044..643a099 100644
> --- a/src/pulse/format.h
> +++ b/src/pulse/format.h
> @@ -122,6 +122,30 @@ pa_format_info* pa_format_info_from_sample_spec(pa_sample_spec *ss, pa_channel_m
>    * a negative integer if conversion failed and 0 on success. \since 2.0 */
>   int pa_format_info_to_sample_spec(pa_format_info *f, pa_sample_spec *ss, pa_channel_map *map);
>
> +/** Represents the type of value type of a property on a \ref pa_format_info. \since 2.0 */
> +typedef enum pa_prop_type_t {
> +    PA_PROP_TYPE_INT,
> +    /**<  Integer property */
> +
> +    PA_PROP_TYPE_INT_RANGE,
> +    /**<  Integer range property */
> +
> +    PA_PROP_TYPE_INT_ARRAY,
> +    /**<  Integer array property */
> +
> +    PA_PROP_TYPE_STRING,
> +    /**<  String property */
> +
> +    PA_PROP_TYPE_STRING_ARRAY,
> +    /**<  String array property */
> +
> +    PA_PROP_TYPE_INVALID = -1,
> +    /**<  Represents an invalid type */
> +} pa_prop_type_t;
> +
> +/** Gets the type of property \a key in a given \ref pa_format_info. \since 2.0 */
> +pa_prop_type_t pa_format_info_get_prop_type(pa_format_info *f, const char *key);
> +
>   /** Gets an integer property from the given format info. Returns 0 on success and a negative integer on failure. \since 2.0 */
>   int pa_format_info_get_prop_int(pa_format_info *f, const char *key, int *v);
>   /** Gets an integer range property from the given format info. Returns 0 on success and a negative integer on failure.
> diff --git a/src/tests/format-test.c b/src/tests/format-test.c
> index 1a3aade..bb66c85 100644
> --- a/src/tests/format-test.c
> +++ b/src/tests/format-test.c
> @@ -105,18 +105,21 @@ int main(int argc, char *argv[]) {
>       /* 9. Verify setting/getting an int */
>       REINIT(f1);
>       pa_format_info_set_prop_int(f1, "format.test_string", 42);
> +    pa_assert(pa_format_info_get_prop_type(f1, "format.test_string") == PA_PROP_TYPE_INT);
>       pa_assert(pa_format_info_get_prop_int(f1, "format.test_string",&temp_int1) == 0);
>       pa_assert(temp_int1 == 42);
>
>       /* 10. Verify setting/getting an int range */
>       REINIT(f1);
>       pa_format_info_set_prop_int_range(f1, "format.test_string", 0, 100);
> +    pa_assert(pa_format_info_get_prop_type(f1, "format.test_string") == PA_PROP_TYPE_INT_RANGE);
>       pa_assert(pa_format_info_get_prop_int_range(f1, "format.test_string",&temp_int1,&temp_int2) == 0);
>       pa_assert(temp_int1 == 0&&  temp_int2 == 100);
>
>       /* 11. Verify setting/getting an int array */
>       REINIT(f1);
>       pa_format_info_set_prop_int_array(f1, "format.test_string", rates1, PA_ELEMENTSOF(rates1));
> +    pa_assert(pa_format_info_get_prop_type(f1, "format.test_string") == PA_PROP_TYPE_INT_ARRAY);
>       pa_assert(pa_format_info_get_prop_int_array(f1, "format.test_string",&temp_int_array,&temp_int1) == 0);
>       pa_assert(temp_int1 == PA_ELEMENTSOF(rates1));
>       for (i = 0; i<  temp_int1; i++)
> @@ -126,6 +129,7 @@ int main(int argc, char *argv[]) {
>       /* 12. Verify setting/getting a string */
>       REINIT(f1);
>       pa_format_info_set_prop_string(f1, "format.test_string", "foo");
> +    pa_assert(pa_format_info_get_prop_type(f1, "format.test_string") == PA_PROP_TYPE_STRING);
>       pa_assert(pa_format_info_get_prop_string(f1, "format.test_string",&temp_str) == 0);
>       pa_assert(pa_streq(temp_str, "foo"));
>       pa_xfree(temp_str);
> @@ -133,6 +137,7 @@ int main(int argc, char *argv[]) {
>       /* 13. Verify setting/getting an int array */
>       REINIT(f1);
>       pa_format_info_set_prop_string_array(f1, "format.test_string", strings, PA_ELEMENTSOF(strings));
> +    pa_assert(pa_format_info_get_prop_type(f1, "format.test_string") == PA_PROP_TYPE_STRING_ARRAY);
>       pa_assert(pa_format_info_get_prop_string_array(f1, "format.test_string",&temp_str_array,&temp_int1) == 0);
>       pa_assert(temp_int1 == PA_ELEMENTSOF(strings));
>       for (i = 0; i<  temp_int1; i++)



-- 
David Henningsson, Canonical Ltd.
http://launchpad.net/~diwic


More information about the pulseaudio-discuss mailing list