source: XIOS3/trunk/src/attribute_template_impl.hpp @ 2433

Last change on this file since 2433 was 2388, checked in by jderouillat, 23 months ago

Manage hash values with size_t in hash tables of elements associated to output files

  • Property copyright set to
    Software name : XIOS (Xml I/O Server)
    http://forge.ipsl.jussieu.fr/ioserver
    Creation date : January 2009
    Licence : CeCCIL version2
    see license file in root directory : Licence_CeCILL_V2-en.txt
    or http://www.cecill.info/licences/Licence_CeCILL_V2-en.html
    Holder : CEA/LSCE (Laboratoire des Sciences du CLimat et de l'Environnement)
    CNRS/IPSL (Institut Pierre Simon Laplace)
    Project Manager : Yann Meurdesoif
    yann.meurdesoif@cea.fr
File size: 12.2 KB
RevLine 
[591]1#ifndef __XIOS_CAttributeTemplate_impl__
2#define __XIOS_CAttributeTemplate_impl__
[219]3
[300]4#include "type.hpp"
5#include "buffer_in.hpp"
6#include "buffer_out.hpp"
[352]7#include "generate_interface.hpp"
8#include "attribute_template.hpp"
[219]9
[775]10
[335]11namespace xios
[219]12{
[313]13
[219]14      /// ////////////////////// Définitions ////////////////////// ///
15      template <class T>
16         CAttributeTemplate<T>::CAttributeTemplate(const StdString & id)
17         : CAttribute(id)
18      { /* Ne rien faire de plus */ }
19
20      template <class T>
21         CAttributeTemplate<T>::CAttributeTemplate(const StdString & id, const T & value)
22         : CAttribute(id)
23      {
24         this->setValue(value);
25      }
[369]26/*
[219]27      template <class T>
28         CAttributeTemplate<T>::CAttributeTemplate(const CAttribute & attribut)
29         throw (CException)
30         : CAttribute(attribut)
31      {
32         if (!attribut.isEmpty() && !attribut.isType<T>())
33            ERROR("CAttributeTemplate", << "Invalid instantiation !");
34      }
[369]35*/
[219]36      template <class T>
37         CAttributeTemplate<T>::CAttributeTemplate(const StdString & id,
38                              xios_map<StdString, CAttribute*> & umap)
39         : CAttribute(id)
40      {
41         umap.insert(umap.end(), std::make_pair(id, this));
42      }
43
44      template <class T>
45         CAttributeTemplate<T>::CAttributeTemplate
46            (const StdString & id, const T & value,
47             xios_map<StdString, CAttribute*> & umap)
48         : CAttribute(id)
49      {
50         this->setValue(value);
51         umap.insert(umap.end(), std::make_pair(id, this));
52      }
[369]53/*
[219]54      template <class T>
[369]55      CAttributeTemplate<T>::~CAttributeTemplate(void)
[775]56      {
[369]57//         this->CType<T>::reset() ;
58//         this->clear();
[219]59      }
[369]60*/
[219]61      ///--------------------------------------------------------------
[460]62      template <class T>
63      void CAttributeTemplate<T>::reset(void)
64      {
65        CType<T>::reset() ;
66        inheritedValue.reset() ;
67      }
[219]68
69      template <class T>
[1478]70      void CAttributeTemplate<T>::checkEmpty(void) const
[219]71      {
[1478]72        if (CType<T>::empty)
[1477]73        {
74          StdString msg("On checking attribute with id=");
75          msg.append(this->getId());
76          msg.append(" : ");
77          msg.append("data is not initialized\n");
78          ERROR("template <typename T> void CType<T>::checkEmpty(void) const", << msg);
79        }
[1478]80      }
[1477]81
[1478]82
83      template <class T>
84         T CAttributeTemplate<T>::getValue(void) const
85      {
86        return CType<T>::get() ;
87
[369]88/*
[1158]89        if (SuperClass::isEmpty())
90        {
91           ERROR("T CAttributeTemplate<T>::getValue(void) const",
92                 << "[ id = " << this->getId() << "]"
93                 << " L'attribut est requis mais n'est pas défini !");
94         }
95        return (SuperClass::getValue<T>());
[369]96*/
[219]97      }
98
[369]99/*
[219]100      template <class T>
[300]101         T* CAttributeTemplate<T>::getRef(void)
102      {
103         if (SuperClass::isEmpty())
104         {
105            ERROR("T CAttributeTemplate<T>::getValue(void) const",
106                  << "[ id = " << this->getId() << "]"
107                  << " L'attribut est requis mais n'est pas défini !");
108          }
109         return (SuperClass::getRef<T>());
110      }
[369]111*/
[300]112
113      template <class T>
[219]114         void CAttributeTemplate<T>::setValue(const T & value)
115      {
[369]116         CType<T>::set(value) ;
117//         SuperClass::setValue<T>(value);
[219]118      }
119
[369]120    template <class T>
121    void CAttributeTemplate<T>::set(const CAttribute& attr)
122    {
123      this->set(dynamic_cast<const CAttributeTemplate<T>& >(attr)) ;
[775]124    }
[369]125
126   template <class T>
127    void CAttributeTemplate<T>::set(const CAttributeTemplate& attr)
128    {
129      CType<T>::set(attr) ;
[775]130    }
[369]131
[445]132    template <class T>
133    void CAttributeTemplate<T>::setInheritedValue(const CAttribute& attr)
134    {
135      this->setInheritedValue(dynamic_cast<const CAttributeTemplate<T>& >(attr)) ;
[775]136    }
[445]137
138    template <class T>
139    void CAttributeTemplate<T>::setInheritedValue(const CAttributeTemplate& attr)
140    {
[1158]141      if (this->isEmpty() && _canInherite && attr.hasInheritedValue()) inheritedValue.set(attr.getInheritedValue()) ;
[775]142    }
[445]143
144    template <class T>
145    T CAttributeTemplate<T>::getInheritedValue(void) const
146    {
147      if (this->isEmpty()) return inheritedValue.get() ;
148      else return getValue() ;
[775]149    }
150
[445]151    template <class T>
152    bool CAttributeTemplate<T>::hasInheritedValue(void) const
153    {
154      return !this->isEmpty() || !inheritedValue.isEmpty() ;
[775]155    }
156
[1158]157    template <class T>
158    bool CAttributeTemplate<T>::isEqual(const CAttribute& attr)
159    {
160      const CAttributeTemplate<T>& tmp = dynamic_cast<const CAttributeTemplate<T>& >(attr);
161      return this->isEqual_(tmp);
162    }
163
164    template <class T>
165    bool CAttributeTemplate<T>::isEqual_(const CAttributeTemplate& attr)
166    {
[2305]167      if (this->isEmpty() && attr.isEmpty()) return true ;
168      if (!this->isEmpty() && !attr.isEmpty())  return (this->getValue() == attr.getValue());
169      else return false;
[1158]170    }
171
[2386]172    template <class T>
[2388]173    size_t CAttributeTemplate<T>::computeHash(void)
[2386]174    {
175      // Basic hash computation through string
176      return std::hash<string>{}( toString() );
177    }
178
[219]179      //---------------------------------------------------------------
180
181      template <class T>
[369]182         CAttributeTemplate<T>& CAttributeTemplate<T>::operator=(const T & value)
[219]183      {
184         this->setValue(value);
[369]185//         return (this->getValue());
186         return *this;
[219]187      }
188
189      //---------------------------------------------------------------
190
191      template <class T>
[369]192         StdString CAttributeTemplate<T>::_toString(void) const
[219]193      {
194         StdOStringStream oss;
[369]195         if (!CType<T>::isEmpty() && this->hasId())
196            oss << this->getName() << "=\"" << CType<T>::toString() << "\"";
[219]197         return (oss.str());
198      }
199
200      template <class T>
[369]201         void CAttributeTemplate<T>::_fromString(const StdString & str)
[219]202      {
[369]203        CType<T>::fromString(str) ;
[219]204      }
205
206      //---------------------------------------------------------------
[1622]207
208      template <class T>
209         StdString CAttributeTemplate<T>::_dump(void) const
210      {
211         StdOStringStream oss;
212         if (!CType<T>::isEmpty() && this->hasId())
213            oss << this->getName() << "=\"" << CType<T>::dump() << "\"";
214         return (oss.str());
215      }
[2146]216     
217      template <class T>
218         StdString CAttributeTemplate<T>::_dumpGraph(void) const
219      {
220         StdOStringStream oss;
221         if (!CType<T>::isEmpty() && this->hasId())
222            oss << this->getName() << "=" << CType<T>::dump() << "</br>";
223         return (oss.str());
224      }
[1622]225
226
227      //---------------------------------------------------------------
[369]228/*
[219]229      template <class T>
230         void CAttributeTemplate<T>::toBinary (StdOStream & os) const
231      {
232         this->getValue()->toBinary(os);
233      }
234
235      template <class T>
236         void CAttributeTemplate<T>::fromBinary(StdIStream & is)
237      {
238         T value;
239         FromBinary(is, value);
240         this->setValue(value);
241      }
[369]242*/
[300]243      template <class T>
[369]244         bool CAttributeTemplate<T>::_toBuffer (CBufferOut& buffer) const
[300]245      {
[369]246         return CType<T>::toBuffer(buffer) ;
[775]247/*
[300]248         if (isEmpty()) return buffer.put(true) ;
249         else
250         {
251           bool ret=true ;
252           CType<T> val(*boost::any_cast<T>(&value)) ;
253           ret&=buffer.put(false) ;
254           ret&=val.toBuffer(buffer) ;
255           return ret ;
256         }
[369]257*/
[300]258      }
259
260      template <class T>
[369]261      bool CAttributeTemplate<T>::_fromBuffer(CBufferIn& buffer)
[300]262      {
[369]263        return CType<T>::fromBuffer(buffer) ;
[775]264/*
[300]265        bool empty ;
266        bool ret=true ;
267        ret&=buffer.get(empty) ;
[775]268        if (empty)
[300]269        {
270          clear() ;
271          return ret ;
272        }
273        else
274        {
275          if (isEmpty())
276          {
277            T val ;
278            setValue(val) ;
279          }
280          T* V=const_cast<T*>(boost::any_cast<T>(&value)) ;
281          CType<T> val(*V) ;
282          return val.fromBuffer(buffer) ;
283        }
[369]284*/
[300]285      }
[369]286/*
[300]287      template <class T>
288      size_t CAttributeTemplate<T>::size(void) const
[775]289      {
[369]290        return CType<T>::size() ;*/
[775]291/*
[300]292        if (isEmpty()) return sizeof(bool) ;
293        else
294        {
295          CType<T> val(*const_cast<T*>(boost::any_cast<T>(&value))) ;
296          return val.size()+sizeof(bool) ;
297        }
[369]298*/
299 /*     }*/
[300]300
[313]301      template <typename T>
302      void CAttributeTemplate<T>::generateCInterface(ostream& oss,const string& className)
303      {
[778]304        CInterface::AttributeCInterface<T>(oss, className, this->getName());
[313]305      }
[775]306
[313]307      template <typename T>
308      void CAttributeTemplate<T>::generateFortran2003Interface(ostream& oss,const string& className)
309      {
[778]310        CInterface::AttributeFortran2003Interface<T>(oss, className, this->getName());
[313]311      }
[775]312
[313]313      template <typename T>
314      void CAttributeTemplate<T>::generateFortranInterfaceDeclaration_(ostream& oss,const string& className)
315      {
[778]316        CInterface::AttributeFortranInterfaceDeclaration<T>(oss, className, this->getName() + "_");
[313]317      }
[775]318
[313]319      template <typename T>
320      void CAttributeTemplate<T>::generateFortranInterfaceBody_(ostream& oss,const string& className)
321      {
[778]322        CInterface::AttributeFortranInterfaceBody<T>(oss, className, this->getName());
[313]323      }
324
325      template <typename T>
326      void CAttributeTemplate<T>::generateFortranInterfaceDeclaration(ostream& oss,const string& className)
327      {
[778]328        CInterface::AttributeFortranInterfaceDeclaration<T>(oss, className, this->getName());
[313]329      }
[775]330
[313]331      template <typename T>
332      void CAttributeTemplate<T>::generateFortranInterfaceGetDeclaration_(ostream& oss,const string& className)
333      {
[778]334        CInterface::AttributeFortranInterfaceGetDeclaration<T>(oss, className, this->getName() + "_");
[313]335      }
[775]336
337
[313]338      template <typename T>
339      void CAttributeTemplate<T>::generateFortranInterfaceGetBody_(ostream& oss,const string& className)
340      {
[778]341        CInterface::AttributeFortranInterfaceGetBody<T>(oss, className, this->getName());
[313]342      }
343
344      template <typename T>
345      void CAttributeTemplate<T>::generateFortranInterfaceGetDeclaration(ostream& oss,const string& className)
346      {
[778]347        CInterface::AttributeFortranInterfaceGetDeclaration<T>(oss, className, this->getName());
[313]348      }
[432]349
[775]350
351/*
[219]352      //---------------------------------------------------------------
353
[775]354      // Spécialisations des templates pour la fonction [toString]
[219]355
356      template <>
357         StdString CAttributeTemplate<bool>::toString(void) const;
358
359      //---------------------------------------------------------------
360
[775]361      // Spécialisations des templates pour la fonction [fromString]
[219]362
363      template <> // Chaîne de caractÚres.
364         void CAttributeTemplate<StdString>::fromString(const StdString & str);
365
366      template <> // Entier
367         void CAttributeTemplate<int>::fromString(const StdString & str);
368
369      template <> // Booléen
370         void CAttributeTemplate<bool>::fromString(const StdString & str);
371
372      template <> // Double
373         void CAttributeTemplate<double>::fromString(const StdString & str);
374
375      template<> // Tableau
376         void CAttributeTemplate<ARRAY(double, 1)>::fromString(const StdString & str);
377
378      //---------------------------------------------------------------
379
[369]380      // Spécialisations des templates pour la fonction [toBinary] //
[219]381
382      template <> // Chaîne de caractÚres.
383         void CAttributeTemplate<StdString>::toBinary (StdOStream & os) const;
384
385      template <> // Entier
386         void CAttributeTemplate<int>::toBinary(StdOStream & os) const;
387
388      template <> // Booléen
389         void CAttributeTemplate<bool>::toBinary(StdOStream & os) const;
[775]390
[219]391      template <> // Double
392         void CAttributeTemplate<double>::toBinary(StdOStream & os) const;
393
394      //---------------------------------------------------------------
395
[369]396      // Spécialisations des templates pour la fonction [fromBinary] //
[219]397
398      template <> // Chaîne de caractÚres.
399         void CAttributeTemplate<StdString>::fromBinary(StdIStream & is);
400
401      template <> // Entier
402         void CAttributeTemplate<int>::fromBinary(StdIStream & is);
403
404      template <> // Booléen
405         void CAttributeTemplate<bool>::fromBinary(StdIStream & is);
[775]406
[219]407      template <> // Double
408         void CAttributeTemplate<double>::fromBinary(StdIStream & is);
409
410      ///--------------------------------------------------------------
[775]411*/
[335]412} // namespace xios
[219]413
[591]414#endif // __XIOS_CAttributeTemplate_impl__
Note: See TracBrowser for help on using the repository browser.