bitlist.h 735 B

1234567891011121314151617181920212223242526272829303132333435363738394041
  1. #ifndef _BITLIST_H
  2. #define _BITLIST_H
  3. #include "memblock.h"
  4. class BitList {
  5. public:
  6. BitList(unsigned int size=0) {
  7. setSize(size);
  8. }
  9. int getitem(int n) const {
  10. if (n < 0 || n >= m_size) return 0;
  11. return (m_list[n>>3]>>(n&7))&1;
  12. }
  13. void setitem(int n, int v) {
  14. if (n >= 0 && n < m_size) {
  15. int lv=1<<(n&7);
  16. if (v) m_list[n>>3]|=lv;
  17. else m_list[n>>3]&=~lv;
  18. }
  19. }
  20. int operator[](int n) const { return getitem(n); }
  21. int getSize() const { // in bits
  22. return m_size;
  23. }
  24. void setSize(unsigned int newsize) {
  25. m_list.setSize((newsize+7)>>3);
  26. m_size = newsize;
  27. }
  28. int getsize() const { return m_size; }
  29. private:
  30. MemBlock< uint8_t> m_list;
  31. int m_size;
  32. };
  33. #endif