• Classes
  • Modules
  • Namespaces
  • Files
  • Related Pages
  • File List
  • File Members

Param.h

Go to the documentation of this file.
00001 #ifndef _PARAM_H
00002 #define _PARAM_H
00003 /*******************************************************************************
00004 *    ALMA - Atacama Large Millimiter Array
00005 *    (c) Associated Universities Inc., 2002 
00006 *    (c) European Southern Observatory, 2002
00007 *    Copyright by ESO (in the framework of the ALMA collaboration)
00008 *    and Cosylab 2002, All rights reserved
00009 *
00010 *    This library is free software; you can redistribute it and/or
00011 *    modify it under the terms of the GNU Lesser General Public
00012 *    License as published by the Free Software Foundation; either
00013 *    version 2.1 of the License, or (at your option) any later version.
00014 *
00015 *    This library is distributed in the hope that it will be useful,
00016 *    but WITHOUT ANY WARRANTY; without even the implied warranty of
00017 *    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
00018 *    Lesser General Public License for more details.
00019 *
00020 *    You should have received a copy of the GNU Lesser General Public
00021 *    License along with this library; if not, write to the Free Software
00022 *    Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307  USA
00023 *
00024 * "@(#) $Id: Param.h,v 1.4 2006/11/29 23:01:26 sharring Exp $"
00025 *
00026 * who       when      what
00027 * --------  --------  ----------------------------------------------
00028 * sharring  10/27/04  created
00029 */
00030 
00031 #ifndef __cplusplus
00032 #error This is a C++ include file and cannot be used from plain C
00033 #endif
00034 
00035 #include <string>
00036 
00037 using std::string;
00038 
00041 namespace Parameters 
00042 {
00047         class Param
00048         {    
00049                 public:
00053                 Param();
00054 
00058                 Param(const string & nameVal);
00059             
00063                 virtual ~Param() = 0;
00064             
00065                 /*
00066                  * Accessor for the name.
00067                  * @return the name as a string.
00068                  */
00069                 virtual string getName();
00070 
00071                 /*
00072                  * Accessor for the type, e.g. "bool" or "int" etc.
00073                  * @return the type as a string. Each concrete implementation
00074                  * will return a different string in their implementation for 
00075                  * this method.
00076                  */
00077                 virtual string getType() = 0;
00078 
00079                 /*
00080                  * Returns an XML string representation of the param.
00081                  * @return the param as an XML string
00082                  * NOTE: the XML is not a complete document, just a fragment.
00083                  */
00084                 virtual string toString();
00085 
00086                 protected:
00092                 virtual string valueToString() = 0;
00093                 string name_m;
00094         };
00095 }
00096 #endif 

Generated on Thu Jan 12 2012 23:13:51 for ACS-10.0 C++ API by  doxygen 1.7.0