source: XMLIO_V2/dev/dev_rv/src/XMLIO/abstract_data_treatment.hpp @ 124

Last change on this file since 124 was 124, checked in by hozdoba, 14 years ago

Commit pour sauvegarde - diverses corrections de bogues et améliorations du code.

File size: 5.0 KB
Line 
1#ifndef __ABSTRACT_DATA_TREATMENT__
2#define __ABSTRACT_DATA_TREATMENT__
3
4namespace XMLIOSERVER
5{
6   class AbstractDataTreatment
7   {
8      public :
9
10         const Context* getCurrentContext(void) const
11         { return (currentContext); }
12
13         const std::vector<CFile*>& getEnabledFiles(void) const
14         { return (enabledFiles); }
15
16         void getEnabledFilesId(std::vector<std::string>& _vect) const
17         {
18            for (unsigned int i = 0; i < enabledFiles.size(); i++)
19               _vect.push_back(enabledFiles[i]->getId());
20         }
21
22         void printEnabledFilesId(std::ostream& out = std::clog) const
23         {
24            out << "Liste des fichiers à sortir dans le contexte analysé nommé \""
25                << currentContext->getId() << "\"" << std::endl;
26
27            std::vector<std::string> __vect;
28            this->getEnabledFilesId(__vect);
29
30            for (unsigned int i = 0; i < __vect.size(); i++)
31               out << __vect[i] << "|";
32            out << "fin" << std::endl;
33         }
34
35         template <class T>
36            bool writeData(const std::string& id, const T& arr)
37         {
38            const CField* const field_entry = CField::GetObject(id);
39            const vector<CField*>& vectRef = field_entry->getVectRefObject();
40
41            std::vector<CField*>::const_iterator it;
42            for (it = vectRef.begin(); it != vectRef.end(); it++ )
43            {
44               if ((*it)->isStorable(currentContext->getCalendar()->getCurrentDate()))
45               { // Stockage des données dans l'instance CField si nécessaire.
46                  Array<double, 1> data_uni;
47                  (*it)->getGrid()->storeField(arr, data_uni);
48                  (*it)->storeData(data_uni, currentContext->getCalendar()->getCurrentDate());
49               }
50            }
51
52            return (false);
53         }
54         virtual void createDataOutput(void) = 0;
55
56         virtual ~AbstractDataTreatment()
57         { /* Ne rien faire de plus */ }
58
59      protected :
60
61         AbstractDataTreatment(Context* const _ctxt, const AbstractCalendar& cal) : enabledFiles(), currentContext(_ctxt)
62         {
63            //std::cout << "(Message temporaire) Résolution des héritages ..." << std::endl;
64            // Résolution des héritages pour le context actuel (Context::ResolveInheritance() résoud les héritages pour tous les contextes).
65            solveAllInheritance();
66
67            // Initialisation du vecteur 'enabledFiles' contenant la liste des fichiers à sortir.
68            //std::cout << "(Message temporaire) Initialisation du vecteur enabledFiles ..." << std::endl;
69            findEnabledFiles();
70
71            // Recherche des champs à sortir (enable à true + niveau de sortie correct) pour chaque fichier précédemment listé.
72            //std::cout << "(Message temporaire) Recherche des champs à sortir ..." << std::endl;
73            findAllEnabledFields(cal.getInitDate());
74
75            // Résolution des références de grilles pour chacun des champs.
76            //std::cout << "(Message temporaire) Résolution des références de grilles ..." << std::endl;
77            solveAllGridRef();
78
79            //std::cout << "(Message temporaire) fin traitement sorties ..." << std::endl;
80         }
81
82         std::vector<CFile*> enabledFiles; // Liste des fichiers à créer dans un context donné.
83
84      private :
85
86         void findAllEnabledFields(const Date& iniDate)// <- ajouter attribut par défault ici.
87         {
88            for (unsigned int i = 0; i < enabledFiles.size(); i++)
89               enabledFiles[i]->findEnabledFields(iniDate);
90         }
91
92         void solveAllGridRef(void)
93         {
94            for (unsigned int i = 0; i < enabledFiles.size(); i++)
95               enabledFiles[i]->solveEFGridRef();
96         }
97
98         void solveAllInheritance(void) const
99         {
100            // Résolution des héritages descendants (càd des héritages de groupes) pour chacun des contextes.
101            currentContext->resolveDescInheritance();
102
103            // Résolution des héritages par référence au niveau des fichiers.
104            const std::vector<CFile*>& allFiles = CFile::GetCurrentListObject().getVector();
105            for (unsigned int i = 0; i < allFiles.size(); i++) allFiles[i]->resolveFieldRefInheritance();
106         }
107
108         void findEnabledFiles(void)
109         {
110            const std::vector<CFile*>& allFiles = CFile::GetCurrentListObject().getVector();
111
112            for (unsigned int i = 0; i < allFiles.size(); i++)
113               if (allFiles[i]->enabled.hasValue()) // Si l'attribut 'enabled' est défini.
114                  if ((bool)allFiles[i]->enabled) // Si l'attribut 'enabled' est fixé à vrai.
115                     enabledFiles.push_back ( allFiles[i] );
116
117            if (enabledFiles.size() == 0)
118               WARNING("Aucun fichier ne va être sorti dans le contexte nommé \"" + currentContext->getId() + "\" !");
119         }
120
121         Context* const currentContext;
122
123   }; //class AbstractDataTreatment
124
125}// namespace XMLIOSERVER
126
127#endif //__ABSTRACT_DATA_TREATMENT__
Note: See TracBrowser for help on using the repository browser.