mirror of
				https://gitlab.freedesktop.org/pulseaudio/pulseaudio.git
				synced 2025-11-03 09:01:50 -05:00 
			
		
		
		
	format: Add API to query a property's type
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.
This commit is contained in:
		
							parent
							
								
									8f850403c0
								
							
						
					
					
						commit
						8baf8e90c2
					
				
					 4 changed files with 104 additions and 0 deletions
				
			
		| 
						 | 
					@ -168,6 +168,7 @@ pa_format_info_free;
 | 
				
			||||||
pa_format_info_free2;
 | 
					pa_format_info_free2;
 | 
				
			||||||
pa_format_info_from_string;
 | 
					pa_format_info_from_string;
 | 
				
			||||||
pa_format_info_from_sample_spec;
 | 
					pa_format_info_from_sample_spec;
 | 
				
			||||||
 | 
					pa_format_info_get_prop_type;
 | 
				
			||||||
pa_format_info_get_prop_int;
 | 
					pa_format_info_get_prop_int;
 | 
				
			||||||
pa_format_info_get_prop_int_range;
 | 
					pa_format_info_get_prop_int_range;
 | 
				
			||||||
pa_format_info_get_prop_int_array;
 | 
					pa_format_info_get_prop_int_array;
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -280,6 +280,80 @@ int pa_format_info_to_sample_spec_fake(pa_format_info *f, pa_sample_spec *ss) {
 | 
				
			||||||
    return 0;
 | 
					    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_MAX_KEY);
 | 
				
			||||||
 | 
					            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) {
 | 
					int pa_format_info_get_prop_int(pa_format_info *f, const char *key, int *v) {
 | 
				
			||||||
    const char *str;
 | 
					    const char *str;
 | 
				
			||||||
    json_object *o;
 | 
					    json_object *o;
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -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 */
 | 
					 * 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);
 | 
					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 */
 | 
					/** 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);
 | 
					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.
 | 
					/** Gets an integer range property from the given format info. Returns 0 on success and a negative integer on failure.
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -105,18 +105,21 @@ int main(int argc, char *argv[]) {
 | 
				
			||||||
    /* 9. Verify setting/getting an int */
 | 
					    /* 9. Verify setting/getting an int */
 | 
				
			||||||
    REINIT(f1);
 | 
					    REINIT(f1);
 | 
				
			||||||
    pa_format_info_set_prop_int(f1, "format.test_string", 42);
 | 
					    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(pa_format_info_get_prop_int(f1, "format.test_string", &temp_int1) == 0);
 | 
				
			||||||
    pa_assert(temp_int1 == 42);
 | 
					    pa_assert(temp_int1 == 42);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /* 10. Verify setting/getting an int range */
 | 
					    /* 10. Verify setting/getting an int range */
 | 
				
			||||||
    REINIT(f1);
 | 
					    REINIT(f1);
 | 
				
			||||||
    pa_format_info_set_prop_int_range(f1, "format.test_string", 0, 100);
 | 
					    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(pa_format_info_get_prop_int_range(f1, "format.test_string", &temp_int1, &temp_int2) == 0);
 | 
				
			||||||
    pa_assert(temp_int1 == 0 && temp_int2 == 100);
 | 
					    pa_assert(temp_int1 == 0 && temp_int2 == 100);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
    /* 11. Verify setting/getting an int array */
 | 
					    /* 11. Verify setting/getting an int array */
 | 
				
			||||||
    REINIT(f1);
 | 
					    REINIT(f1);
 | 
				
			||||||
    pa_format_info_set_prop_int_array(f1, "format.test_string", rates1, PA_ELEMENTSOF(rates1));
 | 
					    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(pa_format_info_get_prop_int_array(f1, "format.test_string", &temp_int_array, &temp_int1) == 0);
 | 
				
			||||||
    pa_assert(temp_int1 == PA_ELEMENTSOF(rates1));
 | 
					    pa_assert(temp_int1 == PA_ELEMENTSOF(rates1));
 | 
				
			||||||
    for (i = 0; i < temp_int1; i++)
 | 
					    for (i = 0; i < temp_int1; i++)
 | 
				
			||||||
| 
						 | 
					@ -126,6 +129,7 @@ int main(int argc, char *argv[]) {
 | 
				
			||||||
    /* 12. Verify setting/getting a string */
 | 
					    /* 12. Verify setting/getting a string */
 | 
				
			||||||
    REINIT(f1);
 | 
					    REINIT(f1);
 | 
				
			||||||
    pa_format_info_set_prop_string(f1, "format.test_string", "foo");
 | 
					    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_format_info_get_prop_string(f1, "format.test_string", &temp_str) == 0);
 | 
				
			||||||
    pa_assert(pa_streq(temp_str, "foo"));
 | 
					    pa_assert(pa_streq(temp_str, "foo"));
 | 
				
			||||||
    pa_xfree(temp_str);
 | 
					    pa_xfree(temp_str);
 | 
				
			||||||
| 
						 | 
					@ -133,6 +137,7 @@ int main(int argc, char *argv[]) {
 | 
				
			||||||
    /* 13. Verify setting/getting an int array */
 | 
					    /* 13. Verify setting/getting an int array */
 | 
				
			||||||
    REINIT(f1);
 | 
					    REINIT(f1);
 | 
				
			||||||
    pa_format_info_set_prop_string_array(f1, "format.test_string", strings, PA_ELEMENTSOF(strings));
 | 
					    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(pa_format_info_get_prop_string_array(f1, "format.test_string", &temp_str_array, &temp_int1) == 0);
 | 
				
			||||||
    pa_assert(temp_int1 == PA_ELEMENTSOF(strings));
 | 
					    pa_assert(temp_int1 == PA_ELEMENTSOF(strings));
 | 
				
			||||||
    for (i = 0; i < temp_int1; i++)
 | 
					    for (i = 0; i < temp_int1; i++)
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue