StringArray.hpp

Go to the documentation of this file.
00001 /*
00002 Copyright 2007, 2008, 2009, 2010, 2011 Instituto de Sistemas e Robotica, Instituto Superior Tecnico
00003 
00004 This file is part of MeRMaID.
00005 
00006 MeRMaID is free software: you can redistribute it and/or modify
00007 it under the terms of the GNU Lesser General Public License as published by
00008 the Free Software Foundation, either version 3 of the License, or
00009 (at your option) any later version.
00010 
00011 MeRMaID is distributed in the hope that it will be useful,
00012 but WITHOUT ANY WARRANTY; without even the implied warranty of
00013 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
00014 GNU Lesser General Public License for more details.
00015 
00016 You should have received a copy of the GNU Lesser General Public License
00017 along with MeRMaID.  If not, see <http://www.gnu.org/licenses/>.
00018 */
00019 
00020 
00021 
00022 /**
00023  * @Filename StringArray.hpp
00024  * @Description StringArray class definition.
00025  * @Status Implementing
00026  * @Version $Id: StringArray.hpp 1 2011-03-04 18:13:18Z jreis $
00027  * @Maintainer Marco Barbosa
00028  */
00029 
00030 #ifndef __DATASTRUCTURE_STRINGARRAY_H_
00031 #define __DATASTRUCTURE_STRINGARRAY_H_
00032 
00033 #include <DataArray.hpp>
00034 #include <String.hpp>
00035 
00036 namespace mermaid
00037 {
00038   namespace support
00039   {
00040     namespace data
00041     {
00042       /**
00043        * @Class StringArray StringArray.hpp "StringArray.hpp"
00044        * @Description Class representing an array of string values
00045        * @Author Marco Barbosa
00046        */
00047       class StringArray : public DataArray<String>
00048       {
00049         public:
00050         
00051           /**
00052            * @Description Default constructor. This initializes the array as dynamic.
00053            */
00054           StringArray();
00055           
00056           /**
00057            * @Description Constructor. This initializes the array as static, with the given size.
00058            * @Argument size Size of the static string array.
00059            */
00060           StringArray (int size);
00061           
00062           /**
00063            * @Description Clone method. This clones the array.
00064            */
00065           virtual DataValue * clone();
00066           
00067           /**
00068            * @Description String cast operation. Converts the string array into its string representation.
00069            */
00070           virtual operator std::string() const;
00071           
00072           /**
00073            * @Description Operation that appends a string value to the end of the array. This is only valid in dynamic arrays.
00074            * @Argument s String value to be appended.
00075            */
00076           void pushBack (std::string s);
00077           
00078       }; // class StringArray
00079     } // namespace data
00080   } // namespace support
00081 } // namespace mermaid
00082 
00083 #endif // __DATASTRUCTURE_STRINGARRAY_H_
Generated on Fri Mar 4 22:14:58 2011 for MeRMaID::support by  doxygen 1.6.3