Main Page   Modules   Namespace List   Class Hierarchy   Compound List   File List   Compound Members   File Members   Related Pages  

bits.h

Go to the documentation of this file.
00001 // ----------------------------------------------------------------------
00002 //
00003 //  C-Breeze
00004 //  C Compiler Framework
00005 // 
00006 //  Copyright (c) 2000 University of Texas at Austin
00007 // 
00008 //  Samuel Z. Guyer
00009 //  Daniel A. Jimenez
00010 //  Calvin Lin
00011 // 
00012 //  Permission is hereby granted, free of charge, to any person
00013 //  obtaining a copy of this software and associated documentation
00014 //  files (the "Software"), to deal in the Software without
00015 //  restriction, including without limitation the rights to use, copy,
00016 //  modify, merge, publish, distribute, sublicense, and/or sell copies
00017 //  of the Software, and to permit persons to whom the Software is
00018 //  furnished to do so, subject to the following conditions:
00019 //  
00020 //  The above copyright notice and this permission notice shall be
00021 //  included in all copies or substantial portions of the Software.
00022 //  
00023 //  THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND,
00024 //  EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
00025 //  MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND
00026 //  NONINFRINGEMENT.  IN NO EVENT SHALL THE UNIVERSITY OF TEXAS AT
00027 //  AUSTIN BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
00028 //  IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF
00029 //  OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
00030 //  THE SOFTWARE.
00031 //
00032 //  We acknowledge the C-to-C Translator from MIT Laboratory for
00033 //  Computer Science for inspiring parts of the C-Breeze design.
00034 //
00035 // ----------------------------------------------------------------------
00036 
00037 #ifndef CBZ_BITS_H
00038 #define CBZ_BITS_H
00039 
00040 #define BITS_PER_INT (8*sizeof(int))
00041 
00042 class Bits {
00043 private:
00044         unsigned int *ints;
00045         int     n, nints;
00046 
00047 public:
00048         void reset_all (void) {
00049                 for (int i=0; i<nints; i++) ints[i] = 0;
00050         }
00051 
00052         Bits (int nn) {
00053                 n = nn;
00054                 nints = nn / BITS_PER_INT;
00055                 if (nn % BITS_PER_INT) nints++;
00056                 ints = new unsigned int[nints];
00057                 reset_all ();
00058         }
00059 
00060         ~Bits (void) {
00061                 delete [] ints;
00062         }
00063 
00064         void set (int pos, bool val) {
00065                 int i = pos / BITS_PER_INT;
00066                 int j = pos % BITS_PER_INT;
00067                 if (val) {
00068                         ints[i] |= (1<<j);
00069                 } else {
00070                         ints[i] &= ~(1<<j);
00071                 }
00072         }
00073 
00074         void set (int pos) {
00075                 set (pos, true);
00076         }
00077 
00078         void copy (Bits *b) {
00079                 for (int i=0; i<nints; i++) ints[i] = b->ints[i];
00080         }
00081 
00082         void reset (int pos) {
00083                 set (pos, false);
00084         }
00085 
00086         bool value (int pos) {
00087                 int i = pos / BITS_PER_INT;
00088                 int j = pos % BITS_PER_INT;
00089                 if (ints[i] & (1<<j)) 
00090                         return true;
00091                 return false;
00092         }
00093 
00094         void And (Bits *other) {
00095                 for (int i=0; i<nints; i++) 
00096                         ints[i] &= other->ints[i];
00097         }
00098 
00099         void Or (Bits *other) {
00100                 for (int i=0; i<nints; i++) 
00101                         ints[i] |= other->ints[i];
00102         }
00103 
00104         void Not (void) {
00105                 for (int i=0; i<nints; i++)
00106                         ints[i] = ~ints[i];
00107         }
00108 
00109         Bits *clone (void) {
00110                 Bits *b = new Bits (n);
00111                 for (int i=0; i<nints; i++) b->ints[i] = ints[i];
00112                 return b;
00113         }
00114 };
00115 
00116 #endif // CBZ_BITS_H

Generated on Thu Jan 10 12:06:18 2002 for C-Breeze by doxygen1.2.13.1 written by Dimitri van Heesch, © 1997-2001