view anagram/support/bitmap.cpp @ 9:60b08b68c750

Switch to static inline as an expedient build fix. Should probably set this up with working C99 inline but for the moment I don't have the energy.
author David A. Holland
date Mon, 30 May 2022 23:56:45 -0400
parents 13d2b8934445
children
line wrap: on
line source

/*
 * AnaGram, A System for Syntax Directed Programming
 * Copyright 1993-2000 Parsifal Software. All Rights Reserved.
 * See the file COPYING for license and usage terms.
 *
 * bitmap.cpp
 */

#include "assert.h"
#include "bitmap.h"

//#define INCLUDE_LOGGING
#include "log.h"


void CharBitmap::blurCase(int x) {
  assert((unsigned) x < nBits);
  unsigned mask = 1 << (x%8);
  int index = x/8;
  int truthValue = (map[index] | map[index ^ 4]) & mask;
  map[index] |= (unsigned char) truthValue;
  map[index ^ 4] |= (unsigned char) truthValue;
}

void CharBitmap::blurCase() {
  LOGSECTION("CharBitmap::blurCase()");
  int i;
  for (i = 'A'; i <= 'Z'; i++) {
    blurCase(i);
  }
  for (i = 0xc0; i <= 0xde; i++) {
    if (i != 0xd7) {
      blurCase(i);
    }
  }
  LOGS("blurCase complete");
}


int Bitmap::setBit(int x) {
  LOGSECTION("Bitmap::setBit");
  LOGV(x) LCV(nBits);
  assert((unsigned) x < nBits);
  unsigned mask = 1 << (x %8);
  int truthValue = (map[x/8] & mask) != 0;
  map[x/8] |= (unsigned char) mask;
  return truthValue;
}

int CharBitmap::setBit(int x) {
  return Bitmap::setBit(x - min_char_number);
}

int Bitmap::getBit(int x) {
  assert((unsigned) x < nBits);
  return (map[x/8] & (1 << (x % 8))) != 0;
}

int CharBitmap::getBit(int x) {
  return Bitmap::getBit(x - min_char_number);
}

int Bitmap::list(int *x) {
  LOGSECTION("Bitmap::list");
  unsigned char *p = (unsigned char *) map;
  unsigned i;
  int count = 0;
  for (i = 0; i < nBits; i++) {
    if ((p[i/8] & (1 << (i % 8))) == 0) {
      continue;
    }
    x[count++] = i;
  }
  return count;
}

int CharBitmap::list(int *x) {
  int count = Bitmap::list(x);
  for (int i = 0; i < count; i++) {
    x[i] += min_char_number;
  }
  return count;
}

Bitmap &Bitmap::setRange(unsigned first, unsigned last) {
  LOGSECTION("Bitmap::setRange");
  LOGV(first) LCV(last);
  assert(first <= last && last < nBits);
  int n = last/8;
  unsigned char bit = (unsigned char) (1 << (last %8));
  LOGV(n) LCV(bit);
  while (bit && first <= last) {
    map[n] |= bit;
    bit >>= 1;
    last--;
  }
  LOGV(bit) LCV(last);
  int x = first/8;
  bit = (unsigned char) (1 << (first % 8));
  LOGV(x) LCV(bit);
  while (bit && first <= last) {
    map[x] |= bit;
    bit <<= 1;
    first++;
  }
  LOGV(x) LCV(bit);
  x++;
  while (x < n) {
    map[x++] = 0xff;
  }
  return *this;
}

#ifdef _MSC_VER
Bitmap &CharBitmap::setRange(unsigned first, unsigned last) {
#else
CharBitmap &CharBitmap::setRange(unsigned first, unsigned last) {
#endif
  LOGSECTION("CharBitmap::setRange");
  LOGV(first) LCV(last);
  Bitmap::setRange(first - min_char_number, last - min_char_number);
  return *this;
}

Bitmap &Bitmap::operator |= (const Bitmap &b) {
  assert(nChars == b.nChars);
  int x = nChars;
  while (x--) {
    map[x] |= b.map[x];
  }
  return *this;
}

Bitmap &Bitmap::operator &= (const Bitmap &b) {
  assert(nChars == b.nChars);
  int x = nChars;
  while (x--) {
    map[x] &= b.map[x];
  }
  return *this;
}

Bitmap &Bitmap::operator -= (const Bitmap &b) {
  LOGSECTION("CharBitmap::operator -=");
  LOGV(nChars) LCV(b.nChars);
  assert(nChars == b.nChars);
  int x = nChars;
  while (x--) {
    map[x] &= (unsigned char) ~b.map[x];
  }
  return *this;
}

Bitmap &Bitmap::operator ~() {
  int x = nChars;
  while (x--) {
    map[x] = (unsigned char) ~map[x];
  }
  return *this;
}