ViewVC Help
View File | Revision Log | Show Annotations | View Changeset | Root Listing
root/REPOS_ERICCA/magic/lib/outil/src/ot_parametres.cpp
Revision: 964
Committed: Mon Aug 27 20:05:12 2018 UTC (6 years, 8 months ago) by couturad
File size: 5065 byte(s)
Log Message:
MICROSTRUCTURE: Ajout d'informations pour l'utilisateur

File Contents

# User Rev Content
1 francois 258 #include "gestionversion.h"
2 francois 265 #include <stdio.h>
3 couturad 926 #include <iostream>
4 francois 258 #include "ot_parametres.h"
5    
6    
7    
8    
9    
10    
11    
12    
13    
14    
15    
16    
17    
18     OT_PARAMETRES::OT_PARAMETRES()
19     {
20     }
21    
22     OT_PARAMETRES::OT_PARAMETRES(OT_PARAMETRES &mdd)
23     {
24 francois 283 int taille=nom_param.size();
25     for (int i=0;i<taille;i++)
26     {
27     nom_param.insert(nom_param.end(),mdd.nom_param[i]);
28     valeur_param.insert(valeur_param.end(),mdd.valeur_param[i]);
29 francois 396 aide_param.insert(aide_param.end(),mdd.aide_param[i]);
30     type_param.insert(type_param.end(),mdd.type_param[i]);
31 francois 283 }
32 francois 258 }
33    
34    
35     OT_PARAMETRES::~OT_PARAMETRES()
36     {
37     }
38    
39    
40 francois 396 void OT_PARAMETRES::ajouter(std::string chaine,double valeur,int typep,std::string aide)
41 francois 258 {
42 francois 603 int res=get_num_param(chaine);
43     if (res==-1)
44     {
45     nom_param.insert(nom_param.end(),chaine);
46     char mess[255];
47     sprintf(mess,"%lf",valeur);
48     valeur_param.insert(valeur_param.end(),mess);
49     aide_param.insert(aide_param.end(),aide);
50     type_param.insert(type_param.end(),typep);
51     }
52     else
53     {
54     char mess[255];
55     sprintf(mess,"%lf",valeur);
56     valeur_param[res]=mess;
57     if (aide.length()>aide_param[res].length()) aide_param[res]=aide;
58     }
59 francois 258 }
60    
61 francois 396 void OT_PARAMETRES::ajouter(std::string chaine,std::string valeurstring,int typep,std::string aide)
62 francois 258 {
63 francois 603 int res=get_num_param(chaine);
64     if (res==-1)
65     {
66     nom_param.insert(nom_param.end(),chaine);
67     valeur_param.insert(valeur_param.end(),valeurstring);
68     aide_param.insert(aide_param.end(),aide);
69     type_param.insert(type_param.end(),typep);
70     }
71     else
72     {
73     valeur_param[res]=valeurstring;
74     if (aide.length()>aide_param[res].length()) aide_param[res]=aide;
75     }
76    
77 francois 258 }
78    
79     void OT_PARAMETRES::enregistrer(char *nom)
80     {
81 francois 283 FILE* in=fopen(nom,"wt");
82     int taille=nom_param.size();
83     for (int i=0;i<taille;i++)
84     fprintf(in,"%s = %s //%s\n",nom_param[i].c_str(),valeur_param[i].c_str(),aide_param[i].c_str());
85     fclose(in);
86 francois 258 }
87    
88 couturad 964 int OT_PARAMETRES::lire(char *nom)
89 francois 258 {
90 francois 283 FILE* in=fopen(nom,"rt");
91 couturad 964 if (in==NULL) return 0; // return FAIL
92 couturad 929 // if (in==NULL)
93     // {
94     // std::cerr << "*** OT_PARAMETRES::lire : Erreur de lecture du fichier (" << nom <<") ***" << std::endl;
95     // return;
96     // }
97 francois 283 while (!feof(in))
98     {
99     char chaine[4000];
100     char* res=fgets(chaine,4000,in);
101     if (!feof(in))
102     {
103     char nom[255],c;
104     char nom2[255];
105     nom2[0]=0;
106     int nb=sscanf(chaine,"%s %c %s",nom,&c,nom2);
107 francois 681 if (nb!=3) continue;
108     double val;
109 francois 738 char *aide=strstr(chaine,"//");
110     if (aide==NULL) aide=chaine+strlen(chaine)-1; else aide=aide+2;
111 francois 737 for (int i=0;i<strlen(aide);i++)
112     if (aide[i]=='\n') aide[i]=0;
113 francois 396 int num=sscanf(nom2,"%lf",&val);
114 francois 737 if (num==1) ajouter(nom,nom2,DOUBLE,aide);
115     else ajouter(nom,nom2,STRING,aide);
116 francois 283 }
117     }
118     fclose(in);
119 couturad 964 return 1; // return OK;
120 francois 258 }
121    
122    
123    
124     double OT_PARAMETRES::get_valeur(std::string chaine)
125     {
126 francois 283 int taille=nom_param.size();
127     for (int i=0;i<taille;i++)
128     {
129     std::string valtmp=nom_param[i];
130     if (valtmp==chaine)
131     {
132     double val;
133     sscanf(valeur_param[i].c_str(),"%lf",&val);
134     return val;
135     }
136    
137     }
138     return 0.;
139 francois 258 }
140    
141 francois 512 void OT_PARAMETRES::change_valeur(std::string chaine,double val)
142     {
143     int taille=nom_param.size();
144     for (int i=0;i<taille;i++)
145     {
146     std::string valtmp=nom_param[i];
147     if (valtmp==chaine)
148     {
149     char mess[255];
150     sprintf(mess,"%lf",val);
151     valeur_param[i]=mess;
152     }
153    
154     }
155     }
156    
157     void OT_PARAMETRES::change_valeur(std::string chaine,std::string val)
158     {
159     int taille=nom_param.size();
160     for (int i=0;i<taille;i++)
161     {
162     std::string valtmp=nom_param[i];
163     if (valtmp==chaine)
164     {
165     valeur_param[i]=val;
166     }
167    
168     }
169     }
170    
171 francois 603 int OT_PARAMETRES::get_num_param(std::string chaine)
172     {
173     int taille=nom_param.size();
174     for (int i=0;i<taille;i++)
175     {
176     std::string valtmp=nom_param[i];
177     if (valtmp==chaine)
178     {
179     return i;
180     }
181    
182     }
183     return -1;
184     }
185    
186    
187 francois 258 std::string OT_PARAMETRES::get_nom(std::string chaine)
188     {
189 francois 283 int taille=nom_param.size();
190     for (int i=0;i<taille;i++)
191     {
192     std::string valtmp=nom_param[i];
193     if (valtmp==chaine)
194     {
195 cuillier 338 return valeur_param[i];
196 francois 283 }
197    
198     }
199     return "";
200 francois 258 }
201    
202 francois 396 int OT_PARAMETRES::get_type(std::string chaine)
203     {
204     int taille=nom_param.size();
205     for (int i=0;i<taille;i++)
206     {
207     std::string valtmp=nom_param[i];
208     if (valtmp==chaine)
209     {
210     return type_param[i];
211     }
212    
213     }
214     return 0;
215     }
216 francois 271 double OT_PARAMETRES::get_valeur(int num)
217     {
218 francois 283 double val;
219     sscanf(valeur_param[num].c_str(),"%lf",&val);
220     return val;
221 francois 271 }
222    
223     std::string OT_PARAMETRES::get_nom(int num)
224     {
225 francois 283 return nom_param[num];
226 francois 271 }
227    
228 francois 396 int OT_PARAMETRES::get_type(int num)
229     {
230     return type_param[num];
231     }
232 francois 271 int OT_PARAMETRES::get_nb(void)
233     {
234 francois 283 return nom_param.size();
235 francois 271 }
236    
237    
238 francois 258 void OT_PARAMETRES::vide(void)
239     {
240 francois 283 nom_param.clear();
241     valeur_param.clear();
242     aide_param.clear();
243 francois 396 type_param.clear();
244 francois 258 }
245