ViewVC Help
View File | Revision Log | Show Annotations | View Changeset | Root Listing
root/REPOS_ERICCA/magic/lib/outil/src/ot_parametres.cpp
Revision: 603
Committed: Fri Nov 21 18:52:21 2014 UTC (10 years, 5 months ago) by francois
File size: 4590 byte(s)
Log Message:
ajout du calcul en elasticite 2D contrainte plane et deformation plane a partir d'une coque CAO plane en XY + OT_PARAMETRE gestion des parametres par default

File Contents

# User Rev Content
1 francois 258 #include "gestionversion.h"
2 francois 265 #include <stdio.h>
3 francois 258 #include "ot_parametres.h"
4    
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     void OT_PARAMETRES::lire(char *nom)
89     {
90 francois 283 FILE* in=fopen(nom,"rt");
91     while (!feof(in))
92     {
93     char chaine[4000];
94     char* res=fgets(chaine,4000,in);
95     if (!feof(in))
96     {
97     char nom[255],c;
98     char nom2[255];
99     nom2[0]=0;
100     int nb=sscanf(chaine,"%s %c %s",nom,&c,nom2);
101 francois 396 double val;
102     int num=sscanf(nom2,"%lf",&val);
103     if (num==1) ajouter(nom,nom2,DOUBLE);
104     else ajouter(nom,nom2,STRING);
105 francois 283 }
106     }
107     fclose(in);
108 francois 258 }
109    
110    
111    
112     double OT_PARAMETRES::get_valeur(std::string chaine)
113     {
114 francois 283 int taille=nom_param.size();
115     for (int i=0;i<taille;i++)
116     {
117     std::string valtmp=nom_param[i];
118     if (valtmp==chaine)
119     {
120     double val;
121     sscanf(valeur_param[i].c_str(),"%lf",&val);
122     return val;
123     }
124    
125     }
126     return 0.;
127 francois 258 }
128    
129 francois 512 void OT_PARAMETRES::change_valeur(std::string chaine,double val)
130     {
131     int taille=nom_param.size();
132     for (int i=0;i<taille;i++)
133     {
134     std::string valtmp=nom_param[i];
135     if (valtmp==chaine)
136     {
137     char mess[255];
138     sprintf(mess,"%lf",val);
139     valeur_param[i]=mess;
140     }
141    
142     }
143     }
144    
145     void OT_PARAMETRES::change_valeur(std::string chaine,std::string val)
146     {
147     int taille=nom_param.size();
148     for (int i=0;i<taille;i++)
149     {
150     std::string valtmp=nom_param[i];
151     if (valtmp==chaine)
152     {
153     valeur_param[i]=val;
154     }
155    
156     }
157     }
158    
159 francois 603 int OT_PARAMETRES::get_num_param(std::string chaine)
160     {
161     int taille=nom_param.size();
162     for (int i=0;i<taille;i++)
163     {
164     std::string valtmp=nom_param[i];
165     if (valtmp==chaine)
166     {
167     return i;
168     }
169    
170     }
171     return -1;
172     }
173    
174    
175 francois 258 std::string OT_PARAMETRES::get_nom(std::string chaine)
176     {
177 francois 283 int taille=nom_param.size();
178     for (int i=0;i<taille;i++)
179     {
180     std::string valtmp=nom_param[i];
181     if (valtmp==chaine)
182     {
183 cuillier 338 return valeur_param[i];
184 francois 283 }
185    
186     }
187     return "";
188 francois 258 }
189    
190 francois 396 int OT_PARAMETRES::get_type(std::string chaine)
191     {
192     int taille=nom_param.size();
193     for (int i=0;i<taille;i++)
194     {
195     std::string valtmp=nom_param[i];
196     if (valtmp==chaine)
197     {
198     return type_param[i];
199     }
200    
201     }
202     return 0;
203     }
204 francois 271 double OT_PARAMETRES::get_valeur(int num)
205     {
206 francois 283 double val;
207     sscanf(valeur_param[num].c_str(),"%lf",&val);
208     return val;
209 francois 271 }
210    
211     std::string OT_PARAMETRES::get_nom(int num)
212     {
213 francois 283 return nom_param[num];
214 francois 271 }
215    
216 francois 396 int OT_PARAMETRES::get_type(int num)
217     {
218     return type_param[num];
219     }
220 francois 271 int OT_PARAMETRES::get_nb(void)
221     {
222 francois 283 return nom_param.size();
223 francois 271 }
224    
225    
226 francois 258 void OT_PARAMETRES::vide(void)
227     {
228 francois 283 nom_param.clear();
229     valeur_param.clear();
230     aide_param.clear();
231 francois 396 type_param.clear();
232 francois 258 }
233