identificateur.h
8.24 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
// -*- mode:C++ ; compile-command: "g++ -I.. -g -c identificateur.cc" -*-
/*
* Copyright (C) 2000,2014 B. Parisse, Institut Fourier, 38402 St Martin d'Heres
*
* This program is free software; you can redistribute it and/or modify
* it under the terms of the GNU General Public License as published by
* the Free Software Foundation; either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*
* You should have received a copy of the GNU General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
#ifndef _GIAC_IDENTIFICATEUR_H
#define _GIAC_IDENTIFICATEUR_H
#include "first.h"
#include <string>
#include <iostream>
#include "global.h"
#include "gen.h"
#ifndef NO_NAMESPACE_GIAC
namespace giac {
#endif // ndef NO_NAMESPACE_GIAC
extern int protection_level; // for local vars
const int MAXLENSIZE = 1000000; // max size of a line in files
// make g identificateurs evaluated as global in null context
gen global_eval(const gen & g,int level);
gen global_evalf(const gen & g,int level);
gen globalize(const gen & g);
// return the local value of i, if globalize is true, replace idnt with
// global idnt in returned value
gen do_local_eval(const identificateur & i,int level,bool globalize);
std::ostream & operator << (std::ostream & os,const identificateur & s);
#ifdef DOUBLEVAL // #ifdef GIAC_GENERIC_CONSTANTS_ID
extern const char string_euler_gamma[];
extern identificateur _IDNT_euler_gamma;
extern gen cst_euler_gamma;
extern const char string_pi[];
identificateur & _IDNT_pi();
extern alias_ref_identificateur ref_pi;
extern gen cst_pi;
extern const char string_infinity[];
identificateur & _IDNT_infinity();
extern alias_ref_identificateur ref_infinity;
extern gen unsigned_inf;
extern alias_gen & alias_unsigned_inf;
extern const char string_undef[];
identificateur & _IDNT_undef();
extern gen undef;
#else
extern const char string_euler_gamma[];
extern const gen & cst_euler_gamma;
extern const char string_pi[];
const identificateur & _IDNT_pi();
extern const alias_ref_identificateur ref_pi;
extern const alias_gen alias_cst_pi;
extern const gen & cst_pi;
extern const char string_infinity[];
const identificateur & _IDNT_infinity();
extern const alias_gen alias_unsigned_inf;
extern const gen & unsigned_inf;
extern const char string_undef[];
const identificateur & _IDNT_undef();
extern const alias_ref_identificateur ref_infinity;
extern const alias_gen alias_undef;
extern const gen & undef;
#endif
#if defined GIAC_HAS_STO_38 || defined NSPIRE || defined NSPIRE_NEWLIB
extern const identificateur & a__IDNT;
extern const alias_gen alias_a38;
#define a__IDNT_e (*(gen const *)&alias_a38)
extern const identificateur & b__IDNT;
extern const alias_gen alias_b38;
#define b__IDNT_e (*(gen const *)&alias_b38)
extern const identificateur & c__IDNT;
extern const alias_gen alias_c38;
#define c__IDNT_e (*(gen const *)&alias_c38)
extern const identificateur & d__IDNT;
extern const alias_gen alias_d38;
#define d__IDNT_e (*(gen const *)&alias_d38)
extern const identificateur & e__IDNT;
extern const alias_gen alias_e38;
#define e__IDNT_e (*(gen const *)&alias_e38)
extern const identificateur & f__IDNT;
extern const alias_gen alias_f38;
#define f__IDNT_e (*(gen const *)&alias_f38)
extern const identificateur & g__IDNT;
extern const alias_gen alias_g38;
#define g__IDNT_e (*(gen const *)&alias_g38)
extern const identificateur & h__IDNT;
extern const alias_gen alias_h38;
#define h__IDNT_e (*(gen const *)&alias_h38)
extern const identificateur & i__IDNT;
extern const alias_gen alias_i38;
#define i__IDNT_e (*(gen const *)&alias_i38)
extern const identificateur & I__IDNT;
extern const alias_gen alias_j38;
#define j__IDNT_e (*(gen const *)&alias_j38)
extern const identificateur & k__IDNT;
extern const alias_gen alias_k38;
#define k__IDNT_e (*(gen const *)&alias_k38)
extern const identificateur & l__IDNT;
extern const alias_gen alias_l38;
#define l__IDNT_e (*(gen const *)&alias_l38)
extern const identificateur & m__IDNT;
extern const alias_gen alias_m38;
#define m__IDNT_e (*(gen const *)&alias_m38)
extern const identificateur & n__IDNT;
extern const alias_gen alias_n38;
#define n__IDNT_e (*(gen const *)&alias_n38)
extern const identificateur & o__IDNT;
extern const alias_gen alias_o38;
#define o__IDNT_e (*(gen const *)&alias_o38)
extern const identificateur & p__IDNT;
extern const alias_gen alias_p38;
#define p__IDNT_e (*(gen const *)&alias_p38)
extern const identificateur & q__IDNT;
extern const alias_gen alias_q38;
#define q__IDNT_e (*(gen const *)&alias_q38)
extern const identificateur & r__IDNT;
extern const alias_gen alias_r38;
#define r__IDNT_e (*(gen const *)&alias_r38)
extern const identificateur & s__IDNT;
extern const alias_gen alias_s38;
#define s__IDNT_e (*(gen const *)&alias_s38)
extern const identificateur & t__IDNT;
extern const alias_gen alias_t38;
#define t__IDNT_e (*(gen const *)&alias_t38)
extern const identificateur & u__IDNT;
extern const alias_gen alias_u38;
#define u__IDNT_e (*(gen const *)&alias_u38)
extern const identificateur & v__IDNT;
extern const alias_gen alias_v38;
#define v__IDNT_e (*(gen const *)&alias_v38)
extern const identificateur & w__IDNT;
extern const alias_gen alias_w38;
#define w__IDNT_e (*(gen const *)&alias_w38)
extern const identificateur & x__IDNT;
extern const alias_gen alias_x38;
#define x__IDNT_e (*(gen const *)&alias_x38)
extern const identificateur & y__IDNT;
extern const alias_gen alias_y38;
#define y__IDNT_e (*(gen const *)&alias_y38)
extern const identificateur & z__IDNT;
extern const alias_gen alias_z38;
#define z__IDNT_e (*(gen const *)&alias_z38)
extern const identificateur & theta__IDNT;
extern const gen & theta__IDNT_e;
extern const identificateur & _IDNT_id_at;
extern const identificateur & CST__IDNT;
extern const identificateur & laplace_var;
extern const gen & CST__IDNT_e;
// extern gen & vx_var;
// commented otherwise can not make assign/assumptions on vx_var
// if must uncomment, check extern gen vx_var declaration after endif
#else
extern identificateur a__IDNT;
extern gen a__IDNT_e;
extern identificateur b__IDNT;
extern gen b__IDNT_e;
extern identificateur c__IDNT;
extern gen c__IDNT_e;
extern identificateur d__IDNT;
extern gen d__IDNT_e;
extern identificateur e__IDNT;
extern gen e__IDNT_e;
extern identificateur f__IDNT;
extern gen f__IDNT_e;
extern identificateur g__IDNT;
extern gen g__IDNT_e;
extern identificateur h__IDNT;
extern gen h__IDNT_e;
extern identificateur i__IDNT;
extern gen i__IDNT_e;
extern identificateur I__IDNT;
extern gen j__IDNT_e;
extern identificateur k__IDNT;
extern gen k__IDNT_e;
extern identificateur l__IDNT;
extern gen l__IDNT_e;
extern identificateur m__IDNT;
extern gen m__IDNT_e;
extern identificateur n__IDNT;
extern gen n__IDNT_e;
extern identificateur o__IDNT;
extern gen o__IDNT_e;
extern identificateur p__IDNT;
extern gen p__IDNT_e;
extern identificateur q__IDNT;
extern gen q__IDNT_e;
extern identificateur r__IDNT;
extern gen r__IDNT_e;
extern identificateur s__IDNT;
extern gen s__IDNT_e;
extern identificateur t__IDNT;
extern gen t__IDNT_e;
extern identificateur u__IDNT;
extern gen u__IDNT_e;
extern identificateur v__IDNT;
extern gen v__IDNT_e;
extern identificateur w__IDNT;
extern gen w__IDNT_e;
extern identificateur x__IDNT;
extern gen x__IDNT_e;
extern identificateur y__IDNT;
extern gen y__IDNT_e;
extern identificateur z__IDNT;
extern gen z__IDNT_e;
extern identificateur laplace_var;
extern identificateur theta__IDNT;
extern gen theta__IDNT_e;
extern identificateur _IDNT_id_at;
extern identificateur CST__IDNT;
extern gen CST__IDNT_e;
#endif
extern gen vx_var;
extern const gen * const tab_one_letter_idnt[];
// small utility to remove #...
int removecomments(const char * ss,char * ss2);
#ifndef NO_NAMESPACE_GIAC
}
#endif // ndef NO_NAMESPACE_GIAC
#endif // _GIAC_IDENTIFICATEUR_H