source: XIOS/dev/dev_ym/XIOS_COUPLING/src/attribute_template_impl.hpp @ 2305

Last change on this file since 2305 was 2305, checked in by ymipsl, 2 years ago

Fix bug when calling to "xios_solve_inheritance" that inhibit transformation chaining.

YM

  • 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.0 KB
Line 
1#ifndef __XIOS_CAttributeTemplate_impl__
2#define __XIOS_CAttributeTemplate_impl__
3
4#include "type.hpp"
5#include "buffer_in.hpp"
6#include "buffer_out.hpp"
7#include "generate_interface.hpp"
8#include "attribute_template.hpp"
9
10
11namespace xios
12{
13
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      }
26/*
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      }
35*/
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      }
53/*
54      template <class T>
55      CAttributeTemplate<T>::~CAttributeTemplate(void)
56      {
57//         this->CType<T>::reset() ;
58//         this->clear();
59      }
60*/
61      ///--------------------------------------------------------------
62      template <class T>
63      void CAttributeTemplate<T>::reset(void)
64      {
65        CType<T>::reset() ;
66        inheritedValue.reset() ;
67      }
68
69      template <class T>
70      void CAttributeTemplate<T>::checkEmpty(void) const
71      {
72        if (CType<T>::empty)
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        }
80      }
81
82
83      template <class T>
84         T CAttributeTemplate<T>::getValue(void) const
85      {
86        return CType<T>::get() ;
87
88/*
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>());
96*/
97      }
98
99/*
100      template <class T>
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      }
111*/
112
113      template <class T>
114         void CAttributeTemplate<T>::setValue(const T & value)
115      {
116         CType<T>::set(value) ;
117//         SuperClass::setValue<T>(value);
118      }
119
120    template <class T>
121    void CAttributeTemplate<T>::set(const CAttribute& attr)
122    {
123      this->set(dynamic_cast<const CAttributeTemplate<T>& >(attr)) ;
124    }
125
126   template <class T>
127    void CAttributeTemplate<T>::set(const CAttributeTemplate& attr)
128    {
129      CType<T>::set(attr) ;
130    }
131
132    template <class T>
133    void CAttributeTemplate<T>::setInheritedValue(const CAttribute& attr)
134    {
135      this->setInheritedValue(dynamic_cast<const CAttributeTemplate<T>& >(attr)) ;
136    }
137
138    template <class T>
139    void CAttributeTemplate<T>::setInheritedValue(const CAttributeTemplate& attr)
140    {
141      if (this->isEmpty() && _canInherite && attr.hasInheritedValue()) inheritedValue.set(attr.getInheritedValue()) ;
142    }
143
144    template <class T>
145    T CAttributeTemplate<T>::getInheritedValue(void) const
146    {
147      if (this->isEmpty()) return inheritedValue.get() ;
148      else return getValue() ;
149    }
150
151    template <class T>
152    bool CAttributeTemplate<T>::hasInheritedValue(void) const
153    {
154      return !this->isEmpty() || !inheritedValue.isEmpty() ;
155    }
156
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    {
167      if (this->isEmpty() && attr.isEmpty()) return true ;
168      if (!this->isEmpty() && !attr.isEmpty())  return (this->getValue() == attr.getValue());
169      else return false;
170    }
171
172      //---------------------------------------------------------------
173
174      template <class T>
175         CAttributeTemplate<T>& CAttributeTemplate<T>::operator=(const T & value)
176      {
177         this->setValue(value);
178//         return (this->getValue());
179         return *this;
180      }
181
182      //---------------------------------------------------------------
183
184      template <class T>
185         StdString CAttributeTemplate<T>::_toString(void) const
186      {
187         StdOStringStream oss;
188         if (!CType<T>::isEmpty() && this->hasId())
189            oss << this->getName() << "=\"" << CType<T>::toString() << "\"";
190         return (oss.str());
191      }
192
193      template <class T>
194         void CAttributeTemplate<T>::_fromString(const StdString & str)
195      {
196        CType<T>::fromString(str) ;
197      }
198
199      //---------------------------------------------------------------
200
201      template <class T>
202         StdString CAttributeTemplate<T>::_dump(void) const
203      {
204         StdOStringStream oss;
205         if (!CType<T>::isEmpty() && this->hasId())
206            oss << this->getName() << "=\"" << CType<T>::dump() << "\"";
207         return (oss.str());
208      }
209     
210      template <class T>
211         StdString CAttributeTemplate<T>::_dumpGraph(void) const
212      {
213         StdOStringStream oss;
214         if (!CType<T>::isEmpty() && this->hasId())
215            oss << this->getName() << "=" << CType<T>::dump() << "</br>";
216         return (oss.str());
217      }
218
219
220      //---------------------------------------------------------------
221/*
222      template <class T>
223         void CAttributeTemplate<T>::toBinary (StdOStream & os) const
224      {
225         this->getValue()->toBinary(os);
226      }
227
228      template <class T>
229         void CAttributeTemplate<T>::fromBinary(StdIStream & is)
230      {
231         T value;
232         FromBinary(is, value);
233         this->setValue(value);
234      }
235*/
236      template <class T>
237         bool CAttributeTemplate<T>::_toBuffer (CBufferOut& buffer) const
238      {
239         return CType<T>::toBuffer(buffer) ;
240/*
241         if (isEmpty()) return buffer.put(true) ;
242         else
243         {
244           bool ret=true ;
245           CType<T> val(*boost::any_cast<T>(&value)) ;
246           ret&=buffer.put(false) ;
247           ret&=val.toBuffer(buffer) ;
248           return ret ;
249         }
250*/
251      }
252
253      template <class T>
254      bool CAttributeTemplate<T>::_fromBuffer(CBufferIn& buffer)
255      {
256        return CType<T>::fromBuffer(buffer) ;
257/*
258        bool empty ;
259        bool ret=true ;
260        ret&=buffer.get(empty) ;
261        if (empty)
262        {
263          clear() ;
264          return ret ;
265        }
266        else
267        {
268          if (isEmpty())
269          {
270            T val ;
271            setValue(val) ;
272          }
273          T* V=const_cast<T*>(boost::any_cast<T>(&value)) ;
274          CType<T> val(*V) ;
275          return val.fromBuffer(buffer) ;
276        }
277*/
278      }
279/*
280      template <class T>
281      size_t CAttributeTemplate<T>::size(void) const
282      {
283        return CType<T>::size() ;*/
284/*
285        if (isEmpty()) return sizeof(bool) ;
286        else
287        {
288          CType<T> val(*const_cast<T*>(boost::any_cast<T>(&value))) ;
289          return val.size()+sizeof(bool) ;
290        }
291*/
292 /*     }*/
293
294      template <typename T>
295      void CAttributeTemplate<T>::generateCInterface(ostream& oss,const string& className)
296      {
297        CInterface::AttributeCInterface<T>(oss, className, this->getName());
298      }
299
300      template <typename T>
301      void CAttributeTemplate<T>::generateFortran2003Interface(ostream& oss,const string& className)
302      {
303        CInterface::AttributeFortran2003Interface<T>(oss, className, this->getName());
304      }
305
306      template <typename T>
307      void CAttributeTemplate<T>::generateFortranInterfaceDeclaration_(ostream& oss,const string& className)
308      {
309        CInterface::AttributeFortranInterfaceDeclaration<T>(oss, className, this->getName() + "_");
310      }
311
312      template <typename T>
313      void CAttributeTemplate<T>::generateFortranInterfaceBody_(ostream& oss,const string& className)
314      {
315        CInterface::AttributeFortranInterfaceBody<T>(oss, className, this->getName());
316      }
317
318      template <typename T>
319      void CAttributeTemplate<T>::generateFortranInterfaceDeclaration(ostream& oss,const string& className)
320      {
321        CInterface::AttributeFortranInterfaceDeclaration<T>(oss, className, this->getName());
322      }
323
324      template <typename T>
325      void CAttributeTemplate<T>::generateFortranInterfaceGetDeclaration_(ostream& oss,const string& className)
326      {
327        CInterface::AttributeFortranInterfaceGetDeclaration<T>(oss, className, this->getName() + "_");
328      }
329
330
331      template <typename T>
332      void CAttributeTemplate<T>::generateFortranInterfaceGetBody_(ostream& oss,const string& className)
333      {
334        CInterface::AttributeFortranInterfaceGetBody<T>(oss, className, this->getName());
335      }
336
337      template <typename T>
338      void CAttributeTemplate<T>::generateFortranInterfaceGetDeclaration(ostream& oss,const string& className)
339      {
340        CInterface::AttributeFortranInterfaceGetDeclaration<T>(oss, className, this->getName());
341      }
342
343
344/*
345      //---------------------------------------------------------------
346
347      // Spécialisations des templates pour la fonction [toString]
348
349      template <>
350         StdString CAttributeTemplate<bool>::toString(void) const;
351
352      //---------------------------------------------------------------
353
354      // Spécialisations des templates pour la fonction [fromString]
355
356      template <> // Chaîne de caractÚres.
357         void CAttributeTemplate<StdString>::fromString(const StdString & str);
358
359      template <> // Entier
360         void CAttributeTemplate<int>::fromString(const StdString & str);
361
362      template <> // Booléen
363         void CAttributeTemplate<bool>::fromString(const StdString & str);
364
365      template <> // Double
366         void CAttributeTemplate<double>::fromString(const StdString & str);
367
368      template<> // Tableau
369         void CAttributeTemplate<ARRAY(double, 1)>::fromString(const StdString & str);
370
371      //---------------------------------------------------------------
372
373      // Spécialisations des templates pour la fonction [toBinary] //
374
375      template <> // Chaîne de caractÚres.
376         void CAttributeTemplate<StdString>::toBinary (StdOStream & os) const;
377
378      template <> // Entier
379         void CAttributeTemplate<int>::toBinary(StdOStream & os) const;
380
381      template <> // Booléen
382         void CAttributeTemplate<bool>::toBinary(StdOStream & os) const;
383
384      template <> // Double
385         void CAttributeTemplate<double>::toBinary(StdOStream & os) const;
386
387      //---------------------------------------------------------------
388
389      // Spécialisations des templates pour la fonction [fromBinary] //
390
391      template <> // Chaîne de caractÚres.
392         void CAttributeTemplate<StdString>::fromBinary(StdIStream & is);
393
394      template <> // Entier
395         void CAttributeTemplate<int>::fromBinary(StdIStream & is);
396
397      template <> // Booléen
398         void CAttributeTemplate<bool>::fromBinary(StdIStream & is);
399
400      template <> // Double
401         void CAttributeTemplate<double>::fromBinary(StdIStream & is);
402
403      ///--------------------------------------------------------------
404*/
405} // namespace xios
406
407#endif // __XIOS_CAttributeTemplate_impl__
Note: See TracBrowser for help on using the repository browser.