// // aegis - project change supervisor // Copyright (C) 1994, 2002, 2005-2008, 2012 Peter Miller. // // This program 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 3 of the License, or (at // your option) any later version. // // This program 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. // // You should have received a copy of the GNU General Public License // along with this program. If not, see . // #ifndef FMTGEN_TYPE_STRING_H #define FMTGEN_TYPE_STRING_H #include /** * The type_string class is used to represent the type of a valied * with a string value. */ class type_string: public type { public: /** * The destructor. */ virtual ~type_string(); protected: /** * The constructor. * It is protected on purpose, only derived classes may call it. * * @param gen * where to write the generated code */ type_string(generator *gen); protected: // See base class for documentation. nstring c_name_inner() const; // See base class for documentation. bool has_a_mask() const; private: /** * The default constructor. Do not use. */ type_string(); /** * The copy constructor. Do not use. */ type_string(const type_string &); /** * The assignment operator. Do not use. */ type_string &operator=(const type_string &); }; #endif // FMTGEN_TYPE_STRING_H // vim: set ts=8 sw=4 et :