Annotation of fam/fam/Set.h, Revision 1.1
1.1 ! trev 1: // Copyright (C) 1999 Silicon Graphics, Inc. All Rights Reserved.
! 2: //
! 3: // This program is free software; you can redistribute it and/or modify it
! 4: // under the terms of version 2 of the GNU General Public License as
! 5: // published by the Free Software Foundation.
! 6: //
! 7: // This program is distributed in the hope that it would be useful, but
! 8: // WITHOUT ANY WARRANTY; without even the implied warranty of
! 9: // MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. Further, any
! 10: // license provided herein, whether implied or otherwise, is limited to
! 11: // this program in accordance with the express provisions of the GNU
! 12: // General Public License. Patent licenses, if any, provided herein do not
! 13: // apply to combinations of this program with other product or programs, or
! 14: // any other product whatsoever. This program is distributed without any
! 15: // warranty that the program is delivered free of the rightful claim of any
! 16: // third person by way of infringement or the like. See the GNU General
! 17: // Public License for more details.
! 18: //
! 19: // You should have received a copy of the GNU General Public License along
! 20: // with this program; if not, write the Free Software Foundation, Inc., 59
! 21: // Temple Place - Suite 330, Boston MA 02111-1307, USA.
! 22:
! 23: #ifndef Set_included
! 24: #define Set_included
! 25:
! 26: #include "Boolean.h"
! 27: #include "BTree.h"
! 28:
! 29: // This implementation of a Set is sub-optimal! It should
! 30: // be reimplemented as a separate type.
! 31: // Object of type "class T" will will be cast to
! 32: // unsigned int's internally, so they must have a conversion to
! 33: // unsigned int and there should be a one-to-one mapping to unsigned
! 34: // ints.
! 35: template <class T> class Set : public BTree<T, bool> {
! 36:
! 37: public:
! 38:
! 39: typedef BTree<T, bool> inherited;
! 40:
! 41: Set() { }
! 42:
! 43: void insert(const T& e) { (void) inherited::insert(e, true); }
! 44: bool contains(const T& e) { return inherited::find(e); }
! 45: // Inherit remove(), first(), next(), size(), sizeofnode() methods.
! 46:
! 47: private:
! 48:
! 49: Set(const Set&); // Do not copy
! 50: Set & operator = (const Set&); // or assign.
! 51:
! 52: };
! 53:
! 54: #endif /* !Set_included */
FreeBSD-CVSweb <freebsd-cvsweb@FreeBSD.org>