view anagram/support/agmap.h @ 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 1997-2002 Parsifal Software. All Rights Reserved.
 * See the file COPYING for license and usage terms.
 *
 * agmap.h
 */

#ifndef AGMAP_H
#define AGMAP_H

#include "agbaltree.h"


template <class Key, class Value>
class AgMap {
public:
  class Wrapper {
  public:
    Key key;
    Value value;
    int operator < (const Wrapper &w) const { return key < w.key; }
    Wrapper(const Key &k, const Value &v) : key(k), value(v) {}
  };

  AgBalancedTree<Wrapper> tree;
  friend class AgBalancedTree<Wrapper>;

public:
  Value &operator [] (const Key &k);
  int includes(const Key &k, Value &v);
};

template <class Key, class Value>
Value &AgMap<Key,Value>::operator [] (const Key &k) {
  Wrapper wrapper(k, Value());
  Wrapper *result = &wrapper;
  tree.identify(result);
  return result->value;
}

template <class Key, class Value>
int AgMap<Key,Value>::includes(const Key &k, Value &v) {
  Wrapper wrapper(k,v);
  Wrapper *result = &wrapper;
  int flag = tree.identify(result);
  v = result->value;
  return flag;
}


#endif /* AGMAP_H */