PipeWire 0.3.15
properties.h
Go to the documentation of this file.
1/* PipeWire
2 *
3 * Copyright © 2018 Wim Taymans
4 *
5 * Permission is hereby granted, free of charge, to any person obtaining a
6 * copy of this software and associated documentation files (the "Software"),
7 * to deal in the Software without restriction, including without limitation
8 * the rights to use, copy, modify, merge, publish, distribute, sublicense,
9 * and/or sell copies of the Software, and to permit persons to whom the
10 * Software is furnished to do so, subject to the following conditions:
11 *
12 * The above copyright notice and this permission notice (including the next
13 * paragraph) shall be included in all copies or substantial portions of the
14 * Software.
15 *
16 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
17 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
18 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
19 * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
20 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
21 * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
22 * DEALINGS IN THE SOFTWARE.
23 */
24
25#ifndef PIPEWIRE_PROPERTIES_H
26#define PIPEWIRE_PROPERTIES_H
27
28#ifdef __cplusplus
29extern "C" {
30#endif
31
32#include <stdarg.h>
33
34#include <spa/utils/dict.h>
35
46 struct spa_dict dict;
47 uint32_t flags;
48};
49
50struct pw_properties *
51pw_properties_new(const char *key, ...) SPA_SENTINEL;
52
53struct pw_properties *
54pw_properties_new_dict(const struct spa_dict *dict);
55
56struct pw_properties *
58
59struct pw_properties *
60pw_properties_copy(const struct pw_properties *properties);
61
63 const struct spa_dict *dict, const char *keys[]);
64
66 const struct spa_dict *dict);
67
68int pw_properties_add(struct pw_properties *oldprops,
69 const struct spa_dict *dict);
71 const struct spa_dict *dict, const char *keys[]);
72
73void pw_properties_clear(struct pw_properties *properties);
74
75void
77
78int
79pw_properties_set(struct pw_properties *properties, const char *key, const char *value);
80
81int
83 const char *key, const char *format, ...) SPA_PRINTF_FUNC(3, 4);
84int
86 const char *key, const char *format, va_list args) SPA_PRINTF_FUNC(3,0);
87const char *
88pw_properties_get(const struct pw_properties *properties, const char *key);
89
90const char *
91pw_properties_iterate(const struct pw_properties *properties, void **state);
92
93static inline bool pw_properties_parse_bool(const char *value) {
94 return (strcmp(value, "true") == 0 || atoi(value) == 1);
95}
96
97static inline int pw_properties_parse_int(const char *value) {
98 return strtol(value, NULL, 0);
99}
100
101static inline int64_t pw_properties_parse_int64(const char *value) {
102 return strtoll(value, NULL, 0);
103}
104
105static inline uint64_t pw_properties_parse_uint64(const char *value) {
106 return strtoull(value, NULL, 0);
107}
108
109static inline float pw_properties_parse_float(const char *value) {
110 return strtof(value, NULL);
111}
112
113static inline double pw_properties_parse_double(const char *value) {
114 return strtod(value, NULL);
115}
116
117#ifdef __cplusplus
118}
119#endif
120
121#endif /* PIPEWIRE_PROPERTIES_H */
static uint32_t int int const char va_list args
Definition: core.h:327
int int pw_properties_setva(struct pw_properties *properties, const char *key, const char *format, va_list args) SPA_PRINTF_FUNC(3
A collection of key/value pairs.
Definition: properties.h:45
SPA_EXPORT int pw_properties_add(struct pw_properties *props, const struct spa_dict *dict)
Add properties.
Definition: properties.c:286
SPA_EXPORT int pw_properties_update(struct pw_properties *props, const struct spa_dict *dict)
Update properties.
Definition: properties.c:263
SPA_EXPORT struct pw_properties * pw_properties_new_dict(const struct spa_dict *dict)
Make a new properties object from the given dictionary.
Definition: properties.c:128
SPA_EXPORT int pw_properties_setf(struct pw_properties *properties, const char *key, const char *format,...)
Set a property value by format.
Definition: properties.c:433
SPA_EXPORT int pw_properties_set(struct pw_properties *properties, const char *key, const char *value)
Set a property value.
Definition: properties.c:400
SPA_EXPORT void pw_properties_free(struct pw_properties *properties)
Free a properties object.
Definition: properties.c:335
SPA_EXPORT struct pw_properties * pw_properties_copy(const struct pw_properties *properties)
Copy a properties object.
Definition: properties.c:205
SPA_EXPORT int pw_properties_update_keys(struct pw_properties *props, const struct spa_dict *dict, const char *keys[])
Copy multiple keys from one property to another.
Definition: properties.c:220
struct spa_dict dict
dictionary of key/values
Definition: properties.h:46
SPA_EXPORT int pw_properties_add_keys(struct pw_properties *props, const struct spa_dict *dict, const char *keys[])
Add keys.
Definition: properties.c:312
SPA_EXPORT void pw_properties_clear(struct pw_properties *properties)
Clear a properties object.
Definition: properties.c:240
uint32_t flags
extra flags
Definition: properties.h:47
SPA_EXPORT const char * pw_properties_iterate(const struct pw_properties *properties, void **state)
Iterate property values.
Definition: properties.c:481
SPA_EXPORT struct pw_properties * pw_properties_new_string(const char *str)
Make a new properties object from the given str.
Definition: properties.c:159
SPA_EXPORT struct pw_properties * pw_properties_new(const char *key,...)
Make a new properties object.
Definition: properties.c:98
SPA_EXPORT const char * pw_properties_get(const struct pw_properties *properties, const char *key)
Get a property.
Definition: properties.c:456