1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82
|
/** List of names -*- c++ -*- */
#ifndef NAMELIST_H_
# define NAMELIST_H_
# ifdef __GNUC__
# pragma interface
# endif // __GNUC__
# include <list>
/** @file NameList.h
* List of names
*/
/* Copyright 1999-2001 Marko Mkel (msmakela@tcs.hut.fi).
This file is part of MARIA, a reachability analyzer and model checker
for high-level Petri nets.
MARIA is free software; you can redistribute it and/or modify it
under the terms of the GNU General Public License as published by
the Free Software Foundation; either version 2, or (at your option)
any later version.
MARIA is distributed in the hope that it will be useful, but
WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
General Public License for more details.
The GNU General Public License is often shipped with GNU software, and
is generally kept in a file called COPYING or LICENSE. If you do not
have a copy of the license, write to the Free Software Foundation,
59 Temple Place, Suite 330, Boston, MA 02111 USA. */
/** List of names */
class NameList
{
public:
/** List of names, or null-terminated character strings */
typedef std::list<char*> List;
/** Iterator to the list of names */
typedef List::iterator iterator;
/** Constant iterator to the list of names */
typedef List::const_iterator const_iterator;
/** Constructor */
NameList () : myList () {}
private:
/** Copy constructor */
NameList (const class NameList& old);
/** Assignment operator */
class NameList& operator= (const class NameList& old);
public:
/** Destructor */
~NameList ();
/** Append a name to the list
* @param name name to be appended
*/
void append (char* name) { myList.push_back (name); }
/** Remove a name from the list
* @param i iterator to the name
*/
void remove (iterator i) { delete[] *i; myList.erase (i); }
/** @name Accessors to the list of names */
/*@{*/
bool empty () const { return myList.empty (); }
size_t size () const { return myList.size (); }
iterator begin () { return myList.begin (); }
iterator end () { return myList.end (); }
const_iterator begin () const { return myList.begin (); }
const_iterator end () const { return myList.end (); }
/*@}*/
private:
/** The list */
List myList;
};
#endif // NAMELIST_H_
|