#ifndef __BITARRAY_H__
#define __BITARRAY_H__ 1
/* 
   elmo - ELectronic Mail Operator

   Copyright (C) 2003 rzyjontko

   This program is free software; you can redistribute it and/or modify
   it under the terms of the GNU General Public License as published by
   the Free Software Foundation; version 2.

   This program is distributed in the hope that it will be useful,
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
   GNU General Public License for more details.

   You should have received a copy of the GNU General Public License
   along with this program; if not, write to the Free Software Foundation,
   Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.  

*/
/****************************************************************************
 *    INTERFACE REQUIRED HEADERS
 ****************************************************************************/
/****************************************************************************
 *    INTERFACE DEFINITIONS / ENUMERATIONS / SIMPLE TYPEDEFS
 ****************************************************************************/
/****************************************************************************
 *    INTERFACE CLASS PROTOTYPES / EXTERNAL CLASS REFERENCES
 ****************************************************************************/
/****************************************************************************
 *    INTERFACE STRUCTURES / UTILITY CLASSES
 ****************************************************************************/

typedef struct bitarray {
  unsigned *array;
  int       size;
  int       bits;
} bitarray_t;

/****************************************************************************
 *    INTERFACE DATA DECLARATIONS
 ****************************************************************************/
/****************************************************************************
 *    INTERFACE FUNCTION PROTOTYPES
 ****************************************************************************/

extern bitarray_t *bitarray_create (int bits);
extern bitarray_t *bitarray_reverse (bitarray_t *b);
extern void        bitarray_destroy (bitarray_t *a);
extern void        bitarray_resize (bitarray_t *a, int bits);
extern void        bitarray_remove (bitarray_t *a, int index);
extern void        bitarray_zeros (bitarray_t *a);
extern void        bitarray_ones (bitarray_t *a);
extern void        bitarray_set (bitarray_t *a, int bit);
extern void        bitarray_unset (bitarray_t *a, int bit);
extern void        bitarray_change_bit (bitarray_t *a, int bit);
extern void        bitarray_neg (bitarray_t *a);
extern void        bitarray_sum (bitarray_t *a, bitarray_t *b);
extern void        bitarray_intersect (bitarray_t *a, bitarray_t *b);
extern void        bitarray_subtract (bitarray_t *a, bitarray_t *b);
extern int         bitarray_equal (bitarray_t *a, bitarray_t *b);
extern void        bitarray_copy (bitarray_t *to, bitarray_t *from);
extern int         bitarray_is_set (bitarray_t *a, int bit);
extern void        bitarray_for_ones (bitarray_t *a, void (*fun)(int));
extern void        bitarray_print (bitarray_t *a);
extern int         bitarray_ones_count (bitarray_t *a);
extern int         bitarray_true_for_all (bitarray_t *a, int (*fun)(int));
extern int         bitarray_first_set (bitarray_t *a);
extern int         bitarray_none_is_set (bitarray_t *a);

/****************************************************************************
 *    INTERFACE OBJECT CLASS DEFINITIONS
 ****************************************************************************/
/****************************************************************************
 *    INTERFACE TRAILING HEADERS
 ****************************************************************************/
/****************************************************************************
 *
 *    END HEADER bitarray.h
 *
 ****************************************************************************/
#endif


syntax highlighted by Code2HTML, v. 0.9.1