summaryrefslogtreecommitdiff
path: root/TAO/orbsvcs/orbsvcs/FtRtEvent/EventChannel/Dynamic_Bitset.h
blob: cc7a0410df6005161d820e11c5f80a0e679e2d5f (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
// -*- C++ -*-

//=============================================================================
/**
 *  @file   Dynamic_Bitset.h
 *
 *  $Id$
 *
 *  @author Huang-Ming Huang <hh1@cse.wustl.edu>
 */
//=============================================================================
#ifndef DYNAMIC_BITSET_H
#define DYNAMIC_BITSET_H

#include <memory.h>

/**
 *
 */

class Dynamic_Bitset
{
  typedef unsigned block;
  typedef unsigned size_type;
  enum {
    BYTES_PER_BLOCK = sizeof(block),
    BITS_PER_BLOCK = sizeof(block)*8
  };
public:
  class reference {
  public:
    reference(Dynamic_Bitset* bitset, size_type bit);
    reference operator = (bool val);
    operator bool () const;
  private:
    Dynamic_Bitset* bitset_;
    size_type bit_;
  };

  Dynamic_Bitset(size_type size=0);
  ~Dynamic_Bitset();
  Dynamic_Bitset(const Dynamic_Bitset& other);
  Dynamic_Bitset& operator = (const Dynamic_Bitset& other);
    Dynamic_Bitset& operator &=(const Dynamic_Bitset& other);

  reference operator[](size_type bit);

  size_type size() const;
  bool test(size_type bit) const;

  void set(size_type bit, bool val = true);
  void flip();
  void resize(size_type num_bits, bool value = false);
    friend bool operator == (const Dynamic_Bitset& lhs, const Dynamic_Bitset& rhs);
private:
  block* buffer_;
  size_type buffer_size_;
  size_type bit_size_;
};

bool operator == (const Dynamic_Bitset& lhs, const Dynamic_Bitset& rhs);

inline Dynamic_Bitset operator & (const Dynamic_Bitset& lhs, const Dynamic_Bitset& rhs)
{
  Dynamic_Bitset tmp(lhs);
  tmp &= rhs;
  return tmp;
}



inline Dynamic_Bitset::reference::reference(Dynamic_Bitset* bitset, size_type bit)
: bitset_(bitset), bit_(bit)
{
}

inline Dynamic_Bitset::reference Dynamic_Bitset::reference::operator = (bool val)
{
  bitset_->set(bit_, val);
  return *this;
}

inline Dynamic_Bitset::reference::operator bool () const
{
  return bitset_->test(bit_);
}



inline Dynamic_Bitset::~Dynamic_Bitset()
{
  delete[] buffer_;
}

inline Dynamic_Bitset::Dynamic_Bitset(const Dynamic_Bitset& other)
: buffer_(new block[other.buffer_size_])
, buffer_size_(other.buffer_size_)
, bit_size_(other.bit_size_)
{
  memcpy(buffer_, other.buffer_, buffer_size_*BYTES_PER_BLOCK);
}




inline Dynamic_Bitset::size_type Dynamic_Bitset::size() const
{
  return bit_size_;
}

inline Dynamic_Bitset::reference Dynamic_Bitset::operator[](size_type bit)
{
  return Dynamic_Bitset::reference(this, bit);
}


#endif