view anagram/agcore/csexp.h @ 15:f5acaf0c8a29

Don't cast through "volatile int". Causes a gcc warning nowadays. XXX: should put something else back here to frighten the optimizer
author David A. Holland
date Tue, 31 May 2022 01:00:55 -0400
parents 13d2b8934445
children
line wrap: on
line source

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

#ifndef CSEXP_H
#define CSEXP_H

#include <stdlib.h>
#include "port.h"

class AgString; // from agstring.h
#include "bitmap.h"
#include "minmax.h"

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


unsigned char agToUpper(unsigned char);

class CharSetExpression;
  class CharRange;
  class CodeRange;
  class IndividualChar;
  class IndividualCode;
  class NamedCharSet;
  class CharSetUnion;
  class CharSetIntersection;
  class CharSetDifference;
  class CharSetComplement;

class CharSetExpression {
protected:
  enum Precedence {
    additive=1,
    multiplicative,
    unary,
    atomic
  };

  Precedence precedence;

  class TranslateTable {
  private:
    int *table;
  public:
    TranslateTable() : table(new int[256]) {
      for (int i = 0; i < 256; i++) {
	table[i] = i;
      }
    }
    ~TranslateTable() {
      delete [] table;
    }
    int &operator [] (unsigned const x) {
      return table[x];
    }
  };

  static TranslateTable translateTable;

public:
  enum Type {
    notDefined = 1,
    charRange,
    codeRange,
    individualChar,
    individualCode,
    namedCharSet,
    charSetUnion,
    charSetIntersection,
    charSetDifference,
    charSetComplement,
  };

  Type type;

  void *operator new (size_t n) { return malloc(n); }
  void operator delete(void *p) { free(p); }

  static void checkMinimum(int f);

  CharSetExpression(Precedence p, Type t) : precedence(p), type(t) {}
  CharSetExpression(Type t) : precedence(atomic), type(t) {}
  CharSetExpression() : precedence(atomic), type(notDefined) {}
  virtual ~CharSetExpression() {}

  virtual int operator == (const CharSetExpression &) const {
    //LOGSECTION("CharSetExpression::operator==(CharSetExpression &)");
    return 0;
  }

  virtual int operator != (const CharSetExpression &x) const {
    return !(*this == x);
  }

  //virtual int operator > (const CharSetExpression &x) const = 0;

  virtual int operator < (const CharSetExpression &x) const {
    return type < x.type;
  }

  virtual AgString asString() const = 0;
  AgString asString(Precedence p) const;

  virtual int recursive(int) { return 0; }
  virtual int nameNode() { return 0; }
  virtual int char_node() { return 0; }

  virtual CharBitmap bitmap() const = 0;
  virtual void checkRange() {}
  virtual int sameType(const CharSetExpression &x) const {
    return type == x.type;
  }
};

class CharRange : public CharSetExpression {
private:
  int first;
  int last;
  CharRange(const CharRange &) : CharSetExpression() {}
public:
  CharRange(int f, int l)
    : CharSetExpression(charRange), first(min(f, l)), last(max(f, l))
  {
    //LOGSECTION("CharRange");
    //LOGV(first) LCV(last);
    checkRange();
  }
  ~CharRange() {}

  //virtual int operator == (const CharRange &x) const;
  virtual int operator == (const CharSetExpression &x) const;
  virtual int operator < (const CharSetExpression &x) const;
  virtual AgString asString() const;
  virtual CharBitmap bitmap() const;
  virtual void checkRange();
};

class CodeRange : public CharSetExpression {
private:
  int first;
  int last;
  CodeRange(const CharRange &) : CharSetExpression() {}
public:
  CodeRange(int f, int l)
    : CharSetExpression(codeRange), first(min(f, l)), last(max(f, l))
  {
    //LOGSECTION("CodeRange");
    //LOGV(first) LCV(last);
    checkRange();
    checkMinimum(f);
  }
  ~CodeRange() {}

  //virtual int operator == (const CodeRange &x) const;
  virtual int operator == (const CharSetExpression &x) const;
  virtual int operator < (const CharSetExpression &x) const;
  virtual AgString asString() const;
  virtual CharBitmap bitmap() const;
  virtual void checkRange();
};

class IndividualChar : public CharSetExpression {
private:
  IndividualChar(const IndividualChar &) : CharSetExpression() {}
public:
  int asciiValue;

  IndividualChar(int c) : CharSetExpression(individualChar), asciiValue(c) {
    //LOGSECTION("IndividualChar");
    //LOGV(asciiValue);
    checkRange();
  }
  ~IndividualChar() {}

  //virtual int operator == (const IndividualChar &x) const;
  virtual int operator == (const CharSetExpression &x) const;
  virtual int operator < (const CharSetExpression &x) const;
  virtual AgString asString() const;
  virtual CharBitmap bitmap() const;
  virtual void checkRange();
};

class IndividualCode : public CharSetExpression {
private:
  IndividualCode(const IndividualCode &) : CharSetExpression() {}
public:
  int value;

  IndividualCode(int c) : CharSetExpression(individualCode), value(c) {
    //LOGSECTION("IndividualCode");
    //LOGV(value);
    checkRange();
    checkMinimum(value);
  }
  ~IndividualCode() {}

  virtual int operator == (const CharSetExpression &x) const;
  virtual int operator < (const CharSetExpression &x) const;
  virtual AgString asString() const;
  virtual int char_node() { return 1; }
  virtual CharBitmap bitmap() const;
  virtual void checkRange();
};

class NamedCharSet : public CharSetExpression {
private:
  NamedCharSet(const NamedCharSet &) : CharSetExpression() {}
public:
  int name;

  NamedCharSet(int n) : CharSetExpression(namedCharSet), name(n) {
    //LOGSECTION("NamedCharSet");
    //LOGV(dict_str(tkn_dict, name));
  }
  ~NamedCharSet() {}

  virtual int operator == (const CharSetExpression &x) const;
  virtual int operator < (const CharSetExpression &x) const;
  virtual AgString asString() const;
  virtual int recursive(int n) { return n == name; }
  virtual int nameNode() { return 1; }
  virtual CharBitmap bitmap() const;
};

class CharSetUnion : public CharSetExpression {
private:
  CharSetExpression *left, *right;
  CharSetUnion(const CharSetUnion &) : CharSetExpression() {}
public:
  CharSetUnion(CharSetExpression *l, CharSetExpression *r)
    : CharSetExpression(additive, charSetUnion), left(l), right(r)
  {
    //LOGSECTION("CharSetUnion");
  }
  ~CharSetUnion() { delete left; delete right; }

  virtual int operator == (const CharSetExpression &x) const;
  virtual int operator < (const CharSetExpression &x) const;
  virtual AgString asString() const;
  virtual int recursive(int n) {
    return left->recursive(n) || right->recursive(n);
  }
  virtual CharBitmap bitmap() const;
  virtual void checkRange();
};

class CharSetIntersection : public CharSetExpression {
private:
  CharSetExpression *left, *right;
  CharSetIntersection(const CharSetIntersection &) : CharSetExpression() {}
public:
  CharSetIntersection(CharSetExpression *l, CharSetExpression *r)
    : CharSetExpression(multiplicative, charSetIntersection), left(l), right(r)
  {
    //LOGSECTION("CharSetIntersection");
  }
  ~CharSetIntersection() {delete left; delete right;}

  virtual int operator == (const CharSetExpression &x) const;
  virtual int operator < (const CharSetExpression &x) const;
  virtual AgString asString() const;
  virtual CharBitmap bitmap() const;
  virtual int recursive(int n) {
    return left->recursive(n) || right->recursive(n);
  }
  virtual void checkRange();
};

class CharSetDifference : public CharSetExpression {
private:
  CharSetExpression *left, *right;
  CharSetDifference(const CharSetDifference &) : CharSetExpression() {}
public:
  CharSetDifference(CharSetExpression *l, CharSetExpression *r)
    : CharSetExpression(additive, charSetDifference), left(l), right(r)
  {
    //LOGSECTION("CharSetDifference");
  }
  ~CharSetDifference() {delete left; delete right;}

  virtual int operator == (const CharSetExpression &x) const;
  virtual int operator < (const CharSetExpression &x) const;
  virtual AgString asString() const;
  virtual CharBitmap bitmap() const;
  virtual int recursive(int n) {
    return left->recursive(n) || right->recursive(n);
  }
  virtual void checkRange();
};

class CharSetComplement : public CharSetExpression {
private:
  CharSetExpression *operand;
  CharSetComplement(const CharSetComplement &) : CharSetExpression() {}
public:
  CharSetComplement(CharSetExpression *o)
    : CharSetExpression(unary, charSetComplement), operand(o)
  {
    //LOGSECTION("CharSetComplement");
  }
  ~CharSetComplement() {delete operand;}

  virtual int operator == (const CharSetExpression &x) const;
  virtual int operator < (const CharSetExpression &x) const;
  virtual AgString asString() const;
  virtual CharBitmap bitmap() const;
  virtual int recursive(int n) { return operand->recursive(n); }
  virtual void checkRange();
};


#endif /* CSEXP_H */