File: bitmap.h

package info (click to toggle)
polyml 5.2.1-1.1
  • links: PTS, VCS
  • area: main
  • in suites: jessie, jessie-kfreebsd, wheezy
  • size: 19,692 kB
  • ctags: 17,567
  • sloc: cpp: 37,221; sh: 9,591; asm: 4,120; ansic: 428; makefile: 203; ml: 191; awk: 91; sed: 10
file content (65 lines) | stat: -rw-r--r-- 2,239 bytes parent folder | download | duplicates (2)
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
/*
    Title:  Bitmap.  Generally used by the garbage collector to indicate allocated words

    Copyright (c) 2006  David C.J. Matthews

    This library is free software; you can redistribute it and/or
    modify it under the terms of the GNU Lesser General Public
    License as published by the Free Software Foundation; either
    version 2.1 of the License, or (at your option) any later version.
    
    This library 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
    Lesser General Public License for more details.
    
    You should have received a copy of the GNU Lesser General Public
    License along with this library; if not, write to the Free Software
    Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA  02110-1301  USA

*/

#ifndef BITMAP_H_DEFINED
#define BITMAP_H_DEFINED

#include "globals.h" // For POLYUNSIGNED

/* bitmaps using arrays of word */

#define BITS_PER_BYTE 8
#define BITS_PER_WORD (BITS_PER_BYTE * sizeof(POLYUNSIGNED))

class Bitmap
{
public:
    Bitmap(): m_bits(0) {}
    Bitmap(POLYUNSIGNED bits);
    ~Bitmap();

    bool Create(POLYUNSIGNED bits);

private:
    static POLYUNSIGNED BitN(POLYUNSIGNED n) { return (POLYUNSIGNED)1 << (n & (BITS_PER_WORD-1)); }
public:
    // Set a single bit
    void SetBit(POLYUNSIGNED n) { m_bits[n/BITS_PER_WORD] |=  BitN(n); }
    // Set a range of bits
    void SetBits(POLYUNSIGNED bitno, POLYUNSIGNED length);
    // Clear a bit
    void ClearBit(POLYUNSIGNED n) { m_bits[n/BITS_PER_WORD] &= ~BitN(n); }
    // Clear a range of bits.  May already be partly clear
    void ClearBits(POLYUNSIGNED bitno, POLYUNSIGNED length);
    // Test a bit
    bool TestBit(POLYUNSIGNED n) const { return (m_bits[n/BITS_PER_WORD] & BitN(n)) != 0; }
    // How many zero bits (maximum n) are there in the bitmap, starting at location start?
    POLYUNSIGNED CountZeroBits(POLYUNSIGNED bitno, POLYUNSIGNED n);
    //* search the bitmap from the high end down looking for n contiguous zeros
    POLYUNSIGNED FindFree(POLYUNSIGNED limit, POLYUNSIGNED bitno, POLYUNSIGNED n);
private:

    POLYUNSIGNED *m_bits;
};

#endif