153a5a1b3Sopenharmony_ci/*** 253a5a1b3Sopenharmony_ci This file is part of PulseAudio. 353a5a1b3Sopenharmony_ci 453a5a1b3Sopenharmony_ci Copyright 2009 Lennart Poettering 553a5a1b3Sopenharmony_ci 653a5a1b3Sopenharmony_ci PulseAudio is free software; you can redistribute it and/or modify 753a5a1b3Sopenharmony_ci it under the terms of the GNU Lesser General Public License as published 853a5a1b3Sopenharmony_ci by the Free Software Foundation; either version 2.1 of the License, 953a5a1b3Sopenharmony_ci or (at your option) any later version. 1053a5a1b3Sopenharmony_ci 1153a5a1b3Sopenharmony_ci PulseAudio is distributed in the hope that it will be useful, but 1253a5a1b3Sopenharmony_ci WITHOUT ANY WARRANTY; without even the implied warranty of 1353a5a1b3Sopenharmony_ci MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 1453a5a1b3Sopenharmony_ci General Public License for more details. 1553a5a1b3Sopenharmony_ci 1653a5a1b3Sopenharmony_ci You should have received a copy of the GNU Lesser General Public License 1753a5a1b3Sopenharmony_ci along with PulseAudio; if not, see <http://www.gnu.org/licenses/>. 1853a5a1b3Sopenharmony_ci***/ 1953a5a1b3Sopenharmony_ci 2053a5a1b3Sopenharmony_ci#ifdef HAVE_CONFIG_H 2153a5a1b3Sopenharmony_ci#include <config.h> 2253a5a1b3Sopenharmony_ci#endif 2353a5a1b3Sopenharmony_ci 2453a5a1b3Sopenharmony_ci#include <string.h> 2553a5a1b3Sopenharmony_ci 2653a5a1b3Sopenharmony_ci#include <pulse/xmalloc.h> 2753a5a1b3Sopenharmony_ci 2853a5a1b3Sopenharmony_ci#include "bitset.h" 2953a5a1b3Sopenharmony_ci 3053a5a1b3Sopenharmony_civoid pa_bitset_set(pa_bitset_t *b, unsigned k, bool v) { 3153a5a1b3Sopenharmony_ci pa_assert(b); 3253a5a1b3Sopenharmony_ci 3353a5a1b3Sopenharmony_ci if (v) 3453a5a1b3Sopenharmony_ci b[k >> 5] |= 1 << (k & 31); 3553a5a1b3Sopenharmony_ci else 3653a5a1b3Sopenharmony_ci b[k >> 5] &= ~((uint32_t) (1 << (k & 31))); 3753a5a1b3Sopenharmony_ci} 3853a5a1b3Sopenharmony_ci 3953a5a1b3Sopenharmony_cibool pa_bitset_get(const pa_bitset_t *b, unsigned k) { 4053a5a1b3Sopenharmony_ci return !!(b[k >> 5] & (1 << (k & 31))); 4153a5a1b3Sopenharmony_ci} 4253a5a1b3Sopenharmony_ci 4353a5a1b3Sopenharmony_cibool pa_bitset_equals(const pa_bitset_t *b, unsigned n, ...) { 4453a5a1b3Sopenharmony_ci va_list ap; 4553a5a1b3Sopenharmony_ci pa_bitset_t *a; 4653a5a1b3Sopenharmony_ci bool equal; 4753a5a1b3Sopenharmony_ci 4853a5a1b3Sopenharmony_ci a = pa_xnew0(pa_bitset_t, PA_BITSET_ELEMENTS(n)); 4953a5a1b3Sopenharmony_ci 5053a5a1b3Sopenharmony_ci va_start(ap, n); 5153a5a1b3Sopenharmony_ci for (;;) { 5253a5a1b3Sopenharmony_ci int j = va_arg(ap, int); 5353a5a1b3Sopenharmony_ci 5453a5a1b3Sopenharmony_ci if (j < 0) 5553a5a1b3Sopenharmony_ci break; 5653a5a1b3Sopenharmony_ci 5753a5a1b3Sopenharmony_ci pa_bitset_set(a, j, true); 5853a5a1b3Sopenharmony_ci } 5953a5a1b3Sopenharmony_ci va_end(ap); 6053a5a1b3Sopenharmony_ci 6153a5a1b3Sopenharmony_ci equal = memcmp(a, b, PA_BITSET_SIZE(n)) == 0; 6253a5a1b3Sopenharmony_ci pa_xfree(a); 6353a5a1b3Sopenharmony_ci 6453a5a1b3Sopenharmony_ci return equal; 6553a5a1b3Sopenharmony_ci} 66