Mercurial > ~dholland > hg > ag > index.cgi
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 */