00001 
00004 
00005 
00006 
00007 
00008 
00009 
00010 
00011 
00012 
00013 
00014 
00015 
00016 
00017 
00018 
00019 
00020 
00021 
00022 
00023 
00024 
00025 
00026 
00027 
00028 
00029 
00030 
00031 
00032 
00034 
00035 #ifndef GROOVX_RUTZ_ARRAYVALUE_H_UTC20050626084020_DEFINED
00036 #define GROOVX_RUTZ_ARRAYVALUE_H_UTC20050626084020_DEFINED
00037 
00038 #include "rutz/fstring.h"
00039 #include "rutz/value.h"
00040 
00041 #include <iomanip>
00042 #include <vector>
00043 
00044 namespace rutz
00045 {
00047   template <class T>
00048   class array_value : public rutz::value
00049   {
00050   public:
00051     array_value() : m_array() {}
00052     array_value(const rutz::fstring& s) { set_string(s); }
00053     virtual ~array_value() {}
00054 
00055     virtual rutz::fstring value_typename() const
00056     {
00057       return rutz::fstring("array_value");
00058     }
00059 
00060     virtual void print_to(std::ostream& os) const
00061     {
00062       for (unsigned int i = 0; i < m_array.size(); ++i)
00063         os << m_array[i] << "   ";
00064     }
00065 
00066     virtual void scan_from(std::istream& is)
00067     {
00068       std::vector<T> newarray;
00069 
00070       while (!is.eof() && !is.fail())
00071         {
00072           T val;
00073           is >> val >> std::ws;
00074           newarray.push_back(val);
00075         }
00076       m_array.swap(newarray);
00077     }
00078 
00079     unsigned int array_size() const { return m_array.size(); }
00080 
00081     T& array_at(unsigned int i)       { return m_array[i]; }
00082     const T& array_at(unsigned int i) const { return m_array[i]; }
00083 
00084   private:
00085     std::vector<T> m_array;
00086   };
00087 }
00088 
00089 static const char __attribute__((used)) vcid_groovx_rutz_arrayvalue_h_utc20050626084020[] = "$Id: arrayvalue.h 10065 2007-04-12 05:54:56Z rjpeters $ $HeadURL: file:
00090 #endif // !GROOVX_RUTZ_ARRAYVALUE_H_UTC20050626084020_DEFINED