Copyright (C) 1994, Digital Equipment Corp.
INTERFACE GEFTable;
 A so-so table for a few hundred elements - uses linear search 
EXCEPTION NotFound;
TYPE
  T <: TPublic;
  TPublic = OBJECT
  METHODS
    init(initialSize := 10): T;
    put(key, value: REFANY); (* no check for duplicates *)
    get(key: REFANY): REFANY RAISES {NotFound};
    clear();
    enumerate(proc: EnumerateProc;
          data: REFANY;
          VAR (*OUT*) key: REFANY;
          VAR (*OUT*) value: REFANY;
        ): BOOLEAN;
    (*
          Invokes /proc(data, key, value)/ for each pair /(key,value)/ in the
          table.  If /proc/ returns TRUE, the enumeration is terminated, the
          terminating entry is stored into /key/ and /value/, and TRUE is
          returned.  If /proc/ never returns TRUE, /key/ and /value/ are set
          to /NIL/ and /NIL/, and FALSE is returned.
          The client is responsible for external locking of T.
          The client procedure /proc/ is allowed to modify the /value/ field
          of visited entries.
          *)
  END;
TYPE
  EnumerateProc = PROCEDURE(data: REFANY; key: REFANY; VAR value: REFANY): BOOLEAN;
  (*
    A client-defined procedure called by Enumerate on each key/value
    pair in the table.
    The /data/ parameter is the client data passed to
    Enumerate.  An EnumerateProc should return true to halt the
    enumeration, false to continue it.  *)
END GEFTable.