source: XIOS/trunk/src/object_template_impl.hpp @ 631

Last change on this file since 631 was 595, checked in by rlacroix, 9 years ago

Allow using more servers than clients.

This will be useful later when implementing server to client communications.

  • 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: 13.1 KB
Line 
1#ifndef __XIOS_CObjectTemplate_impl__
2#define __XIOS_CObjectTemplate_impl__
3
4#include "xios_spl.hpp"
5#include "context_client.hpp"
6#include "object_factory.hpp"
7#include "context.hpp"
8#include "buffer_in.hpp"
9#include "attribute.hpp"
10#include "event_client.hpp"
11#include "object_template.hpp"
12#include "context_client.hpp"
13#include "indent.hpp"
14#include "type_util.hpp"
15#include "message.hpp"
16#include "type.hpp"
17#include "type_util.hpp"
18#include "group_template.hpp"
19
20namespace xios
21{
22   /// ////////////////////// Définitions ////////////////////// ///
23   template <class T>
24      xios_map<StdString,
25      xios_map<StdString,
26      boost::shared_ptr<T> > > CObjectTemplate<T>::AllMapObj;
27
28   template <class T>
29      xios_map<StdString,
30      std::vector<boost::shared_ptr<T> > > CObjectTemplate<T>::AllVectObj;
31
32   template <class T>
33      xios_map<StdString,long int> CObjectTemplate<T>::GenId;
34
35   template <class T>
36      CObjectTemplate<T>::CObjectTemplate(void)
37         : CAttributeMap()
38         , CObject()
39   { /* Ne rien faire de plus */ }
40
41   template <class T>
42      CObjectTemplate<T>::CObjectTemplate(const StdString & id)
43         : CAttributeMap()
44         , CObject(id)
45   { /* Ne rien faire de plus */ }
46
47   template <class T>
48      CObjectTemplate<T>::CObjectTemplate
49         (const CObjectTemplate<T> & object, bool withAttrList, bool withId)
50         : CAttributeMap()
51         , CObject()
52   {
53      if (object.hasId() && withId)
54         this->setId(object.getId());
55      ERROR("CObjectTemplate<T> construtor 3", << "Not completly implemented yet !");
56   }
57
58   template <class T>
59      CObjectTemplate<T>::~CObjectTemplate(void)
60   { /* Ne rien faire de plus */ }
61
62   ///--------------------------------------------------------------
63
64   template <class T>
65      std::vector<boost::shared_ptr<T> > &
66         CObjectTemplate<T>::GetAllVectobject(const StdString & contextId)
67   {
68      return (CObjectTemplate<T>::AllVectObj[contextId]);
69   }
70
71   //---------------------------------------------------------------
72
73   template <class T>
74      StdString CObjectTemplate<T>::toString(void) const
75   {
76      StdOStringStream oss;
77      oss << "<" << T::GetName();
78      if (this->hasId())
79         oss << " id=\"" << this->getId() << "\"";
80      oss << " " << SuperClassMap::toString() << "/>";
81      return (oss.str());
82   }
83
84   template <class T>
85      void CObjectTemplate<T>::fromString(const StdString & str)
86   {
87      ERROR("CObjectTemplate<T>::fromString(str)",
88            << "[ str = " << str << "] Not implemented yet !");
89   }
90
91   //---------------------------------------------------------------
92
93/*
94   template <class T>
95      void CObjectTemplate<T>::toBinary(StdOStream & os) const
96   {
97      SuperClassMap::toBinary(os);
98   }
99
100   template <class T>
101      void CObjectTemplate<T>::fromBinary(StdIStream & is)
102   {
103      SuperClassMap::fromBinary(is);
104   }
105*/
106
107   //---------------------------------------------------------------
108
109   template <class T>
110      void CObjectTemplate<T>::parse(xml::CXMLNode & node)
111   {
112      xml::THashAttributes attributes = node.getAttributes();
113      CAttributeMap::setAttributes(attributes);
114   }
115
116   //---------------------------------------------------------------
117
118   template <class T>
119      ENodeType CObjectTemplate<T>::getType(void) const
120   {
121      return (T::GetType());
122   }
123
124   template <class T>
125   string CObjectTemplate<T>::getName(void) const
126   {
127      return (T::GetName());
128   }
129
130   //---------------------------------------------------------------
131
132   template <class T>
133      bool CObjectTemplate<T>::hasChild(void) const
134   {
135      return (false);
136   }
137
138   //---------------------------------------------------------------
139
140   template <class T>
141      void CObjectTemplate<T>::solveDescInheritance(bool apply, const CAttributeMap * const parent)
142   {
143      if (parent != NULL)
144         SuperClassMap::setAttributes(parent, apply);
145   }
146
147   //---------------------------------------------------------------
148
149   template <class T>
150      void CObjectTemplate<T>::ClearAllAttributes(void)
151   {
152      vector<T*> avect = CObjectTemplate<T>::getAll();
153      typename vector<T*>::iterator
154            it = avect.begin(), end = avect.end();
155
156      for (;it != end; it++)
157      {
158         CAttributeMap & amap = **it;
159         amap.clearAllAttributes();
160      }
161   }
162
163   template<typename T>
164   void CObjectTemplate<T>::sendAllAttributesToServer()
165   {
166     CAttributeMap& attrMap = *this;
167     CAttributeMap::const_iterator it = attrMap.begin(), itE = attrMap.end();
168     for (; it != itE; ++it)
169     {
170       if (!(it->second)->isEmpty()) sendAttributToServer(*(it->second));
171     }
172
173   }
174
175   template <class T>
176   void CObjectTemplate<T>::sendAttributToServer(const string& id)
177   {
178      CAttributeMap & attrMap = *this;
179      CAttribute* attr=attrMap[id];
180      sendAttributToServer(*attr);
181   }
182
183  template <class T>
184  void CObjectTemplate<T>::sendAttributToServer(CAttribute& attr)
185  {
186    CContext* context=CContext::getCurrent();
187
188    if (!context->hasServer)
189    {
190       CContextClient* client=context->client;
191
192       CEventClient event(getType(),EVENT_ID_SEND_ATTRIBUTE);
193       if (client->isServerLeader())
194       {
195         CMessage msg;
196//       msg << this->getId();
197         msg << this->getIdServer();
198         msg << attr.getName();
199         msg << attr;
200         const std::list<int>& ranks = client->getRanksServerLeader();
201         for (std::list<int>::const_iterator itRank = ranks.begin(), itRankEnd = ranks.end(); itRank != itRankEnd; ++itRank)
202           event.push(*itRank,1,msg);
203         client->sendEvent(event);
204       }
205       else client->sendEvent(event);
206    }
207
208  }
209
210  template <class T>
211  void CObjectTemplate<T>::recvAttributFromClient(CEventServer& event)
212  {
213
214    CBufferIn* buffer=event.subEvents.begin()->buffer;
215    string id,attrId;
216    *buffer>>id;
217    CAttributeMap & attrMap = *get(id);
218    *buffer>>attrId;
219    CAttribute* attr=attrMap[attrId];
220    info(50) << "attribut recu " << attrId << "  ";
221    if (attr->isEmpty()) info(50) << "--> empty" << endl;
222    else info(50) /*<attr->getValue()*/ << endl;
223    *buffer>>*attr;
224     info(50) << "attribut recu " << attrId << "  ";
225    if (attr->isEmpty()) info(50) << "--> empty" << endl;
226    else info(50) /*attr->getValue()*/ << endl;
227  }
228
229   template <class T>
230   bool CObjectTemplate<T>::dispatchEvent(CEventServer& event)
231   {
232      switch(event.type)
233      {
234         case EVENT_ID_SEND_ATTRIBUTE :
235           recvAttributFromClient(event);
236           return true;
237           break;
238
239         default :
240         return false;
241//           ERROR("void CObjectTemplate<T>::recvEvent(CEventServer& event)", << "Unknown Event");
242      }
243   }
244
245   template <typename T>
246   bool CObjectTemplate<T>::has(const string & id)
247   {
248     return CObjectFactory::HasObject<T>(id);
249   }
250
251   template <typename T>
252   bool CObjectTemplate<T>::has(const string& contextId, const string & id)
253   {
254     return CObjectFactory::HasObject<T>(contextId,id);
255   }
256
257   template <typename T>
258   T* CObjectTemplate<T>::get(const string & id)
259   {
260     return CObjectFactory::GetObject<T>(id).get();
261   }
262
263   template <typename T>
264   T* CObjectTemplate<T>::get(const T* ptr)
265   {
266     return CObjectFactory::GetObject<T>(ptr).get();
267   }
268
269   template <typename T>
270   shared_ptr<T> CObjectTemplate<T>::getShared(const T* ptr)
271   {
272     return CObjectFactory::GetObject<T>(ptr);
273   }
274
275   template <typename T>
276   shared_ptr<T> CObjectTemplate<T>::getShared(void)
277   {
278     return CObjectFactory::GetObject<T>((T*)this);
279   }
280
281   template <typename T>
282   const vector<T*> CObjectTemplate<T>::getAll()
283   {
284     const vector< shared_ptr<T> >& shared_vect= CObjectFactory::GetObjectVector<T>();
285     vector<T*> vect;
286
287     typename vector<shared_ptr<T> >::const_iterator it;
288     for(it=shared_vect.begin();it!=shared_vect.end();++it) vect.push_back(it->get());
289     return vect;
290   }
291
292   template <typename T>
293   const vector<T*> CObjectTemplate<T>::getAll(const string & id)
294   {
295     const vector< shared_ptr<T> >& shared_vect= CObjectFactory::GetObjectVector<T>(id);
296     vector<T*> vect;
297
298     typename vector<shared_ptr<T> >::const_iterator it;
299     for(it=shared_vect.begin();it!=shared_vect.end();++it) vect.push_back(it->get());
300     return vect;
301   }
302
303   template <typename T>
304   T* CObjectTemplate<T>::get(const string& contextId, const string & id)
305   {
306     return CObjectFactory::GetObject<T>(contextId,id).get();
307   }
308
309   template <typename T>
310   T* CObjectTemplate<T>::create(const string & id)
311   {
312     return CObjectFactory::CreateObject<T>(id).get();
313   }   ///--------------------------------------------------------------
314
315  template <typename T>
316  T* CObjectTemplate<T>::get(void)
317  {
318    return CObjectFactory::GetObject<T>((T*)this).get();
319  }
320
321   template <typename T>
322   void CObjectTemplate<T>::generateCInterface(ostream& oss)
323   {
324     string className=getName();
325     int found=className.rfind("_group");
326     if (found!=string::npos) className.replace(found,1,0,'x');
327
328     oss << "/* ************************************************************************** *" << iendl;
329     oss << " *               Interface auto generated - do not modify                     *" << iendl;
330     oss << " * ************************************************************************** */" << iendl;
331     oss << iendl;
332     oss << "#include <boost/multi_array.hpp>" << iendl;
333     oss << "#include <boost/shared_ptr.hpp>" << iendl;
334     oss << "#include \"xios.hpp\"" << iendl;
335     oss << "#include \"attribute_template.hpp\"" << iendl;
336     oss << "#include \"object_template.hpp\"" << iendl;
337     oss << "#include \"group_template.hpp\"" << iendl;
338     oss << "#include \"icutil.hpp\"" << iendl;
339     oss << "#include \"icdate.hpp\"" << iendl;
340     oss << "#include \"timer.hpp\"" << iendl;
341     oss << "#include \"node_type.hpp\"" << iendl;
342     oss << iendl;
343     oss << "extern \"C\"" << iendl;
344     oss << "{" << iendl++;
345     oss << "typedef xios::" << getStrType<T>() << "* " << className << "_Ptr;";
346     SuperClassMap::generateCInterface(oss,className);
347     oss << "}" << iendl--;
348   }
349
350   template <typename T>
351   void CObjectTemplate<T>::generateFortran2003Interface(ostream& oss)
352   {
353     string className=getName();
354     int found=className.rfind("_group");
355     if (found!=string::npos) className.replace(found,1,0,'x');
356
357     oss << "! * ************************************************************************** *" << iendl;
358     oss << "! *               Interface auto generated - do not modify                     *" << iendl;
359     oss << "! * ************************************************************************** *" << iendl;
360     oss << "#include \"../fortran/xios_fortran_prefix.hpp\"" << iendl;
361     oss << iendl;
362     oss << "MODULE " << className << "_interface_attr" << iendl++;
363     oss << "USE, INTRINSIC :: ISO_C_BINDING" << std::endl;
364     oss << iendl;
365     oss << "INTERFACE" << iendl++;
366     oss << "! Do not call directly / interface FORTRAN 2003 <-> C99";
367     SuperClassMap::generateFortran2003Interface(oss,className);
368     oss << iendl--;
369     oss << "END INTERFACE" << iendl--;
370     oss << iendl;
371     oss << "END MODULE " << className << "_interface_attr" << iendl;
372   }
373
374   template <typename T>
375   void CObjectTemplate<T>::generateFortranInterface(ostream& oss)
376   {
377     string className=getName();
378     int found=className.rfind("_group");
379     if (found!=string::npos) className.erase(found,1);
380     string superClassName=getName();
381     found=superClassName.find("_group");
382     if (found!=string::npos) superClassName.erase(found,6);
383
384     oss << "! * ************************************************************************** *" << iendl;
385     oss << "! *               Interface auto generated - do not modify                     *" << iendl;
386     oss << "! * ************************************************************************** *" << iendl;
387     oss << "#include \"xios_fortran_prefix.hpp\"" << iendl;
388     oss << iendl;
389     oss << "MODULE i" << className << "_attr" << iendl++;
390     oss << "USE, INTRINSIC :: ISO_C_BINDING" << iendl;
391     oss << "USE i" << superClassName << iendl;
392     oss << "USE " << className << "_interface_attr" << iendl--;
393//   oss << "TYPE txios(" << className << ")" << iendl;
394//   oss << "  INTEGER(kind = C_INTPTR_T) :: daddr" << iendl;
395//   oss << "END TYPE txios(" << className << ")" << iendl;
396     oss << iendl;
397     oss << "CONTAINS" << iendl;
398     oss << iendl++;
399     SuperClassMap::generateFortranInterface_id(oss,className);
400     oss << iendl;
401     SuperClassMap::generateFortranInterface_hdl(oss,className);
402     oss << iendl;
403     SuperClassMap::generateFortranInterface_hdl_(oss,className);
404     oss << iendl;
405     SuperClassMap::generateFortranInterfaceGet_id(oss,className);
406     oss << iendl;
407     SuperClassMap::generateFortranInterfaceGet_hdl(oss,className);
408     oss << iendl;
409     SuperClassMap::generateFortranInterfaceGet_hdl_(oss,className);
410     oss << iendl;
411     SuperClassMap::generateFortranInterfaceIsDefined_id(oss,className);
412     oss << iendl;
413     SuperClassMap::generateFortranInterfaceIsDefined_hdl(oss,className);
414     oss << iendl;
415     SuperClassMap::generateFortranInterfaceIsDefined_hdl_(oss,className);
416     oss << iendl--;
417     oss << "END MODULE i" << className << "_attr" << iendl;
418   }
419} // namespace xios
420
421#endif // __XIOS_CObjectTemplate_impl__
Note: See TracBrowser for help on using the repository browser.