| /* -*- c-basic-offset: 4; indent-tabs-mode: nil -*- */ | |
| /* ==================================================================== | |
| * Copyright (c) 1999-2004 Carnegie Mellon University. All rights | |
| * reserved. | |
| * | |
| * Redistribution and use in source and binary forms, with or without | |
| * modification, are permitted provided that the following conditions | |
| * are met: | |
| * | |
| * 1. Redistributions of source code must retain the above copyright | |
| * notice, this list of conditions and the following disclaimer. | |
| * | |
| * 2. Redistributions in binary form must reproduce the above copyright | |
| * notice, this list of conditions and the following disclaimer in | |
| * the documentation and/or other materials provided with the | |
| * distribution. | |
| * | |
| * This work was supported in part by funding from the Defense Advanced | |
| * Research Projects Agency and the National Science Foundation of the | |
| * United States of America, and the CMU Sphinx Speech Consortium. | |
| * | |
| * THIS SOFTWARE IS PROVIDED BY CARNEGIE MELLON UNIVERSITY ``AS IS'' AND | |
| * ANY EXPRESSED OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, | |
| * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR | |
| * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL CARNEGIE MELLON UNIVERSITY | |
| * NOR ITS EMPLOYEES BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, | |
| * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT | |
| * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, | |
| * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY | |
| * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT | |
| * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | |
| * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | |
| * | |
| * ==================================================================== | |
| * | |
| */ | |
| /** | |
| * @file bitvec.h | |
| * @brief An implementation of bit vectors. | |
| * | |
| * Implementation of basic operations of bit vectors. | |
| */ | |
| extern "C" { | |
| /* Fool Emacs. */ | |
| } | |
| typedef uint32 bitvec_t; | |
| /** | |
| * Number of bitvec_t in a bit vector | |
| */ | |
| /** | |
| * Allocate a bit vector, all bits are clear | |
| */ | |
| /** | |
| * Resize a bit vector, clear the remaining bits | |
| */ | |
| bitvec_t *bitvec_realloc(bitvec_t *vec, /* In: Bit vector to search */ | |
| size_t old_len, /* In: Old length */ | |
| size_t new_len); /* In: New lenght of above bit vector */ | |
| /** | |
| * Free a bit vector. | |
| */ | |
| /** | |
| * Set the b-th bit of bit vector v | |
| * @param v is a vector | |
| * @param b is the bit which will be set | |
| */ | |
| /** | |
| * Set all n bits in bit vector v | |
| * @param v is a vector | |
| * @param n is the number of bits | |
| */ | |
| /** | |
| * Clear the b-th bit of bit vector v | |
| * @param v is a vector | |
| * @param b is the bit which will be set | |
| */ | |
| /** | |
| * Clear all n bits in bit vector v | |
| * @param v is a vector | |
| * @param n is the number of bits | |
| */ | |
| /** | |
| * Check whether the b-th bit is set in vector v | |
| * @param v is a vector | |
| * @param b is the bit which will be checked | |
| */ | |
| /** | |
| * Check whether the b-th bit is cleared in vector v | |
| * @param v is a vector | |
| * @param b is the bit which will be checked | |
| */ | |
| /** | |
| * Return the number of bits set in the given bitvector. | |
| * | |
| * @param vec is the bit vector | |
| * @param len is the length of bit vector <code>vec</code> | |
| * @return the number of bits being set in vector <code>vec</code> | |
| */ | |
| size_t bitvec_count_set(bitvec_t *vec, /* In: Bit vector to search */ | |
| size_t len); /* In: Lenght of above bit vector */ | |
| } | |