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