153a5a1b3Sopenharmony_ci#ifndef foosharedshfoo 253a5a1b3Sopenharmony_ci#define foosharedshfoo 353a5a1b3Sopenharmony_ci 453a5a1b3Sopenharmony_ci/*** 553a5a1b3Sopenharmony_ci This file is part of PulseAudio. 653a5a1b3Sopenharmony_ci 753a5a1b3Sopenharmony_ci Copyright 2004-2006 Lennart Poettering 853a5a1b3Sopenharmony_ci 953a5a1b3Sopenharmony_ci PulseAudio is free software; you can redistribute it and/or modify 1053a5a1b3Sopenharmony_ci it under the terms of the GNU Lesser General Public License as published 1153a5a1b3Sopenharmony_ci by the Free Software Foundation; either version 2.1 of the License, 1253a5a1b3Sopenharmony_ci or (at your option) any later version. 1353a5a1b3Sopenharmony_ci 1453a5a1b3Sopenharmony_ci PulseAudio is distributed in the hope that it will be useful, but 1553a5a1b3Sopenharmony_ci WITHOUT ANY WARRANTY; without even the implied warranty of 1653a5a1b3Sopenharmony_ci MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 1753a5a1b3Sopenharmony_ci General Public License for more details. 1853a5a1b3Sopenharmony_ci 1953a5a1b3Sopenharmony_ci You should have received a copy of the GNU Lesser General Public License 2053a5a1b3Sopenharmony_ci along with PulseAudio; if not, see <http://www.gnu.org/licenses/>. 2153a5a1b3Sopenharmony_ci***/ 2253a5a1b3Sopenharmony_ci 2353a5a1b3Sopenharmony_ci#include <pulsecore/core.h> 2453a5a1b3Sopenharmony_ci#include <pulsecore/strbuf.h> 2553a5a1b3Sopenharmony_ci 2653a5a1b3Sopenharmony_ci/* The shared property subsystem is to be used to share data between 2753a5a1b3Sopenharmony_ci * modules. Consider them to be kind of "global" variables for a 2853a5a1b3Sopenharmony_ci * core. Why not use the hashmap functions directly? The hashmap 2953a5a1b3Sopenharmony_ci * functions copy neither the key nor value, while this property 3053a5a1b3Sopenharmony_ci * system copies the key. Users of this system have to think about 3153a5a1b3Sopenharmony_ci * reference counting themselves. */ 3253a5a1b3Sopenharmony_ci 3353a5a1b3Sopenharmony_ci/* Note: please don't confuse this with the proplist framework in 3453a5a1b3Sopenharmony_ci * pulse/proplist.[ch]! */ 3553a5a1b3Sopenharmony_ci 3653a5a1b3Sopenharmony_ci/* Return a pointer to the value of the specified shared property. */ 3753a5a1b3Sopenharmony_civoid* pa_shared_get(pa_core *c, const char *name); 3853a5a1b3Sopenharmony_ci 3953a5a1b3Sopenharmony_ci/* Set the shared property 'name' to 'data'. This function fails in 4053a5a1b3Sopenharmony_ci * case a property by this name already exists. The property data is 4153a5a1b3Sopenharmony_ci * not copied or reference counted. This is the caller's job. */ 4253a5a1b3Sopenharmony_ciint pa_shared_set(pa_core *c, const char *name, void *data); 4353a5a1b3Sopenharmony_ci 4453a5a1b3Sopenharmony_ci/* Remove the specified shared property. Return non-zero on failure */ 4553a5a1b3Sopenharmony_ciint pa_shared_remove(pa_core *c, const char *name); 4653a5a1b3Sopenharmony_ci 4753a5a1b3Sopenharmony_ci/* A combination of pa_shared_remove() and pa_shared_set(); this function 4853a5a1b3Sopenharmony_ci * first tries to remove the property by this name and then sets the 4953a5a1b3Sopenharmony_ci * property. Return non-zero on failure. */ 5053a5a1b3Sopenharmony_ciint pa_shared_replace(pa_core *c, const char *name, void *data); 5153a5a1b3Sopenharmony_ci 5253a5a1b3Sopenharmony_ci/* Dump the current set of shared properties */ 5353a5a1b3Sopenharmony_civoid pa_shared_dump(pa_core *c, pa_strbuf *s); 5453a5a1b3Sopenharmony_ci 5553a5a1b3Sopenharmony_ci#endif 56