1 | |
---|
2 | #include <iostream> |
---|
3 | #include <cstring> |
---|
4 | #include "nomdElements.h" |
---|
5 | |
---|
6 | nomdElements::typedElement nomdElements::fromString(std::string s) |
---|
7 | { |
---|
8 | if( strstr(s.c_str(),"beam") ) return beam; |
---|
9 | else if( strstr(s.c_str(),"rfgun") ) return RFgun; |
---|
10 | else if( strstr(s.c_str(),"drift") ) return drift; |
---|
11 | else if( strstr(s.c_str(),"cell") ) return cell; |
---|
12 | else if( strstr(s.c_str(),"bend") ) return bend; |
---|
13 | else if( strstr(s.c_str(),"soleno") ) return soleno; |
---|
14 | else if( strstr(s.c_str(),"fit") ) return fit; |
---|
15 | else if( strstr(s.c_str(),"snapshot") ) return snapshot; |
---|
16 | return inconnu; |
---|
17 | } |
---|
18 | |
---|
19 | nomdElements::typedElement nomdElements::fromGenericLabel(std::string s) |
---|
20 | { |
---|
21 | if( s == "beam" ) return beam; |
---|
22 | else if( s == "rfgun" ) return RFgun; |
---|
23 | else if( s == "drift" ) return drift; |
---|
24 | else if( s == "cell" ) return cell; |
---|
25 | else if( s == "bend" ) return bend; |
---|
26 | else if( s == "solnd" ) return soleno; |
---|
27 | else if( s == "fit" ) return fit; |
---|
28 | else if( s == "snapshot" ) return snapshot; |
---|
29 | return inconnu; |
---|
30 | } |
---|
31 | |
---|
32 | std::string nomdElements::toExpandedName(nomdElements::typedElement eType) |
---|
33 | { |
---|
34 | switch(eType) { |
---|
35 | case beam : return "BEAM"; break; |
---|
36 | case RFgun : return "RF GUN"; break; |
---|
37 | case drift : return "DRIFT"; break; |
---|
38 | case cell : return "CELL"; break; |
---|
39 | case bend : return "BENDING MAGNET"; break; |
---|
40 | case soleno : return "SOLENOID"; break; |
---|
41 | case fit : return "FIT"; break; |
---|
42 | case snapshot : return "SNAPSHOT"; break; |
---|
43 | default : return "UNKNOWN"; |
---|
44 | } |
---|
45 | } |
---|
46 | |
---|
47 | std::string nomdElements::toGenericLabel(nomdElements::typedElement eType) |
---|
48 | { |
---|
49 | switch(eType) { |
---|
50 | case beam : return "beam"; |
---|
51 | case RFgun : return "rfgun"; |
---|
52 | case drift : return "drift"; |
---|
53 | case cell : return "cell"; |
---|
54 | case bend : return "bend"; |
---|
55 | case soleno : return "solnd"; |
---|
56 | case fit : return "fit"; |
---|
57 | case snapshot : return "snapshot"; |
---|
58 | default : return string(""); |
---|
59 | } |
---|
60 | } |
---|
61 | |
---|
62 | unsigned nomdElements::toNbParam(nomdElements::typedElement eType) |
---|
63 | { |
---|
64 | switch(eType) { |
---|
65 | case beam : return 8; |
---|
66 | case RFgun : return 9; |
---|
67 | case drift : return 3; |
---|
68 | case cell : return 10; |
---|
69 | case bend : return 7; |
---|
70 | case soleno : return 5; |
---|
71 | case fit : return 4; |
---|
72 | case snapshot : return 2; |
---|
73 | default : return 0; |
---|
74 | } |
---|
75 | } |
---|
76 | |
---|
77 | |
---|
78 | nomdElements::nomdElements() |
---|
79 | { |
---|
80 | e_= fromString(""); |
---|
81 | expandedName_ = toExpandedName(e_); |
---|
82 | genericLabel_ = toGenericLabel(e_); |
---|
83 | nbParam_ = toNbParam(e_); |
---|
84 | } |
---|
85 | |
---|
86 | nomdElements::nomdElements(nomdElements& ne) |
---|
87 | { |
---|
88 | e_= ne.e_; |
---|
89 | expandedName_ = ne.expandedName_; |
---|
90 | genericLabel_ = ne.genericLabel_; |
---|
91 | nbParam_ = ne.nbParam_; |
---|
92 | } |
---|
93 | |
---|
94 | nomdElements::nomdElements(const nomdElements& ne) |
---|
95 | { |
---|
96 | e_= ne.e_; |
---|
97 | expandedName_ = ne.expandedName_; |
---|
98 | genericLabel_ = ne.genericLabel_; |
---|
99 | nbParam_ = ne.nbParam_; |
---|
100 | } |
---|
101 | |
---|
102 | |
---|
103 | nomdElements::nomdElements(const std::string& s) |
---|
104 | { |
---|
105 | e_= fromString(s); |
---|
106 | expandedName_ = toExpandedName(e_); |
---|
107 | genericLabel_ = toGenericLabel(e_); |
---|
108 | nbParam_ = toNbParam(e_); |
---|
109 | } |
---|
110 | |
---|
111 | nomdElements::nomdElements(nomdElements::typedElement& eType) |
---|
112 | { |
---|
113 | e_= eType; |
---|
114 | expandedName_ = toExpandedName(e_); |
---|
115 | genericLabel_ = toGenericLabel(e_); |
---|
116 | nbParam_ = toNbParam(e_); |
---|
117 | } |
---|
118 | |
---|
119 | int nomdElements::getNumberOfElements() { |
---|
120 | return inconnu; |
---|
121 | } |
---|
122 | |
---|
123 | std::string nomdElements::getLabelFromType(nomdElements::typedElement tp) |
---|
124 | { |
---|
125 | return toGenericLabel(tp); |
---|
126 | } |
---|
127 | |
---|
128 | nomdElements::typedElement nomdElements::getTypeFromLabel(std::string lb) |
---|
129 | { |
---|
130 | return fromGenericLabel(lb); |
---|
131 | } |
---|
132 | |
---|
133 | |
---|
134 | nomdElements::typedElement nomdElements::getElementType() const { |
---|
135 | return e_; |
---|
136 | } |
---|
137 | |
---|
138 | std::string nomdElements::getExpandedName() const { |
---|
139 | return expandedName_; |
---|
140 | } |
---|
141 | |
---|
142 | std::string nomdElements::getGenericLabel() const { |
---|
143 | return genericLabel_; |
---|
144 | } |
---|
145 | |
---|
146 | unsigned nomdElements::getElementNbParameters() const |
---|
147 | { |
---|
148 | return nbParam_; |
---|
149 | } |
---|
150 | |
---|
151 | |
---|
152 | |
---|
153 | // operators |
---|
154 | |
---|
155 | nomdElements& nomdElements::operator= (const nomdElements& ne) |
---|
156 | { |
---|
157 | e_= ne.e_; |
---|
158 | expandedName_ = ne.expandedName_; |
---|
159 | genericLabel_ = ne.genericLabel_; |
---|
160 | nbParam_ = ne.nbParam_; |
---|
161 | return *this; |
---|
162 | } |
---|