view anagram/support/sparse.h @ 8:ec2b657edf13

Add explicit lint-comment-style fallthrough annotations. GCC now assumes that if you don't have these you're making a mistake, which is annoying. XXX: This changeset updates the AG output files only (by hand) and is XXX: abusive - rebuilding them will erase the change. However, I need XXX: to get things to build before I can try to get AG to issue the XXX: annotations itself, so this seems like a reasonable expedient.
author David A. Holland
date Mon, 30 May 2022 23:51:43 -0400 (2022-05-31)
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.
 *
 * sparse.h
 */

#ifndef SPARSE_H
#define SPARSE_H

#include "agbaltree.h"

class AgSparseIntArray {
public:
  struct Pair {
    int key;
    int value;
    Pair(int k, int v = 0) : key(k), value(v) {}
    int operator < (const Pair &p) const { return key < p.key; }
  };

protected:
  AgBalancedTree<Pair> tree;

public:
  AgSparseIntArray() {}
  ~AgSparseIntArray() {}
  int &operator [] (int k) {
    Pair pair(k), *pointer = &pair;
    tree.identify(pointer);
    return pointer->value;
  }
  void reset() { tree.reset(); }
};


#endif /* SPARSE_H */