version 1.6, 2011/06/24 21:01:57
|
version 1.73, 2025/04/15 10:17:56
|
Line 1
|
Line 1
|
/* |
/* |
================================================================================ |
================================================================================ |
RPL/2 (R) version 4.1.0.prerelease.4 |
RPL/2 (R) version 4.1.36 |
Copyright (C) 1989-2011 Dr. BERTRAND Joël |
Copyright (C) 1989-2025 Dr. BERTRAND Joël |
|
|
This file is part of RPL/2. |
This file is part of RPL/2. |
|
|
Line 20
|
Line 20
|
*/ |
*/ |
|
|
|
|
#include "giac.h" |
#ifdef RPLCAS |
|
# define RPLCXX |
|
|
#undef PACKAGE |
// Giac inclut <semaphore.h> et définit sem_t. Or l'émulation |
#undef PACKAGE_NAME |
// des IPCS POSIX requiert une redéfinition de sem_t. |
#undef PACKAGE_STRING |
|
#undef PACKAGE_TARNAME |
# ifdef IPCS_SYSV |
#undef PACKAGE_VERSION |
// NetBSD : _SEMAPHORE_H_ |
#undef VERSION |
# define _SEMAPHORE_H_ |
|
// Linux : _SEMAPHORE_H |
|
# define _SEMAPHORE_H |
|
# endif |
|
|
|
# pragma GCC diagnostic push |
|
# pragma GCC diagnostic ignored "-Wstrict-aliasing" |
|
# pragma GCC diagnostic ignored "-Wunused-parameter" |
|
# pragma GCC diagnostic ignored "-Wempty-body" |
|
# pragma GCC diagnostic ignored "-Wunknown-pragmas" |
|
# include "giacPCH.h" |
|
# pragma GCC diagnostic pop |
|
|
|
# undef PACKAGE |
|
# undef PACKAGE_NAME |
|
# undef PACKAGE_STRING |
|
# undef PACKAGE_TARNAME |
|
# undef PACKAGE_VERSION |
|
# undef VERSION |
|
#endif |
|
|
extern "C" |
extern "C" |
{ |
{ |
Line 35 extern "C"
|
Line 55 extern "C"
|
# include "rpl-conv.h" |
# include "rpl-conv.h" |
} |
} |
|
|
#include <iostream> |
#ifdef RPLCAS |
|
# include <iostream> |
|
#endif |
|
|
using namespace std; |
using namespace std; |
using namespace giac; |
|
|
|
|
#ifdef RPLCAS |
|
using namespace giac; |
|
#endif |
|
|
|
void |
|
initialisation_contexte_cas(struct_processus *s_etat_processus) |
|
{ |
|
s_etat_processus->contexte_cas = NULL; |
|
return; |
|
} |
|
|
|
void |
|
liberation_contexte_cas(struct_processus *s_etat_processus) |
|
{ |
|
if (s_etat_processus->contexte_cas != NULL) |
|
{ |
|
# ifdef RPLCAS |
|
delete reinterpret_cast<giac::context *>( |
|
s_etat_processus->contexte_cas); |
|
# endif |
|
s_etat_processus->contexte_cas = NULL; |
|
} |
|
|
|
return; |
|
} |
|
|
|
#ifdef RPLCAS |
static unsigned char * |
static unsigned char * |
conversion_rpl_vers_cas(struct_processus *s_etat_processus, |
conversion_rpl_vers_cas(struct_processus *s_etat_processus, |
struct_objet **s_objet) |
struct_objet **s_objet) |
{ |
{ |
|
logical1 drapeau; |
|
|
struct_liste_chainee *l_element_courant; |
struct_liste_chainee *l_element_courant; |
|
|
struct_objet *s_objet_temporaire; |
struct_objet *s_objet_temporaire; |
Line 52 conversion_rpl_vers_cas(struct_processus
|
Line 101 conversion_rpl_vers_cas(struct_processus
|
t_8_bits registre[8]; |
t_8_bits registre[8]; |
|
|
unsigned char *resultat; |
unsigned char *resultat; |
|
unsigned char *index; |
|
|
for(int i = 0; i < 8; i++) |
for(int i = 0; i < 8; i++) |
{ |
{ |
registre[i] = s_etat_processus->drapeaux_etat[i]; |
registre[i] = s_etat_processus->drapeaux_etat[i]; |
} |
} |
|
|
|
sf(s_etat_processus, 35); |
cf(s_etat_processus, 48); |
cf(s_etat_processus, 48); |
cf(s_etat_processus, 49); |
cf(s_etat_processus, 49); |
cf(s_etat_processus, 50); |
cf(s_etat_processus, 50); |
Line 71 conversion_rpl_vers_cas(struct_processus
|
Line 122 conversion_rpl_vers_cas(struct_processus
|
// les noms de fonction. Les fonctions ne peuvent apparaître que dans le |
// les noms de fonction. Les fonctions ne peuvent apparaître que dans le |
// cas d'un objet de type ALG. |
// cas d'un objet de type ALG. |
|
|
if ((*s_objet)->type == ALG) |
if ((*s_objet)->type == NOM) |
{ |
{ |
if ((*s_objet)->nombre_occurrences > 1) |
if (strcmp((const char *) reinterpret_cast<unsigned char *>( |
|
reinterpret_cast<struct_nom *>((*s_objet)->objet)->nom), |
|
"infinity") == 0) |
{ |
{ |
if ((s_objet_temporaire = copie_objet(s_etat_processus, |
if (evaluation(s_etat_processus, *s_objet, 'N') == d_erreur) |
(*s_objet), 'O')) == NULL) |
|
{ |
{ |
s_etat_processus->erreur_systeme = d_es_allocation_memoire; |
|
return(NULL); |
return(NULL); |
} |
} |
|
|
liberation(s_etat_processus, (*s_objet)); |
liberation(s_etat_processus, *s_objet); |
(*s_objet) = s_objet_temporaire; |
|
|
if (depilement(s_etat_processus, &(s_etat_processus->l_base_pile), |
|
s_objet) == d_erreur) |
|
{ |
|
return(NULL); |
|
} |
|
} |
|
} |
|
else if ((*s_objet)->type == ALG) |
|
{ |
|
if ((s_objet_temporaire = copie_objet(s_etat_processus, |
|
(*s_objet), 'O')) == NULL) |
|
{ |
|
s_etat_processus->erreur_systeme = d_es_allocation_memoire; |
|
return(NULL); |
} |
} |
|
|
|
liberation(s_etat_processus, (*s_objet)); |
|
(*s_objet) = s_objet_temporaire; |
|
|
|
// Si l'expression contient la fonction infinity, on commence par |
|
// forcer une évaluation numérique. |
|
|
|
l_element_courant = reinterpret_cast<struct_liste_chainee *>( |
|
(*s_objet)->objet); |
|
drapeau = d_faux; |
|
|
|
while(l_element_courant != NULL) |
|
{ |
|
if (l_element_courant->donnee->type == NOM) |
|
{ |
|
if (strcmp((const char *) reinterpret_cast<unsigned char *>( |
|
reinterpret_cast<struct_nom *>( |
|
l_element_courant->donnee->objet)->nom), |
|
"infinity") == 0) |
|
{ |
|
drapeau = d_vrai; |
|
break; |
|
} |
|
} |
|
|
|
l_element_courant = l_element_courant->suivant; |
|
} |
|
|
|
if (drapeau == d_vrai) |
|
{ |
|
if (evaluation(s_etat_processus, *s_objet, 'N') == d_erreur) |
|
{ |
|
return(NULL); |
|
} |
|
|
|
liberation(s_etat_processus, *s_objet); |
|
|
|
if (depilement(s_etat_processus, &(s_etat_processus |
|
->l_base_pile), s_objet) == d_erreur) |
|
{ |
|
return(NULL); |
|
} |
|
} |
|
} |
|
|
|
if ((*s_objet)->type == ALG) |
|
{ |
|
|
l_element_courant = reinterpret_cast<struct_liste_chainee *>( |
l_element_courant = reinterpret_cast<struct_liste_chainee *>( |
(*s_objet)->objet); |
(*s_objet)->objet); |
|
|
Line 118 conversion_rpl_vers_cas(struct_processus
|
Line 230 conversion_rpl_vers_cas(struct_processus
|
} |
} |
|
|
resultat = formateur(s_etat_processus, 0, (*s_objet)); |
resultat = formateur(s_etat_processus, 0, (*s_objet)); |
resultat[0] = ' '; |
|
resultat[strlen((const char *) resultat) - 1] = ' '; |
// Il faut remplacer les occurrences de 'relax' par ' +'. |
|
|
|
index = resultat; |
|
while((index = reinterpret_cast<unsigned char *>( |
|
strstr(reinterpret_cast<char *>(index), |
|
(const char *) "relax"))) != NULL) |
|
{ |
|
memcpy(reinterpret_cast<char *>(index), " +", 5); |
|
} |
|
|
|
// Si le résultat vaut infinity, on rajoute le signe +. |
|
|
|
if (strcmp(reinterpret_cast<char *>(resultat), "infinity") == 0) |
|
{ |
|
if ((resultat = reinterpret_cast<unsigned char *>( |
|
realloc(resultat, (strlen(reinterpret_cast<char *>( |
|
resultat)) + 2) * sizeof(unsigned char)))) == NULL) |
|
{ |
|
s_etat_processus->erreur_systeme = d_es_allocation_memoire; |
|
return(NULL); |
|
} |
|
|
|
strcpy(reinterpret_cast<char *>(resultat), "+infinity"); |
|
} |
|
|
|
if (resultat[0] == '\'') |
|
{ |
|
resultat[0] = ' '; |
|
resultat[strlen((const char *) resultat) - 1] = ' '; |
|
} |
|
|
for(int i = 0; i < 8; i++) |
for(int i = 0; i < 8; i++) |
{ |
{ |
Line 132 conversion_rpl_vers_cas(struct_processus
|
Line 273 conversion_rpl_vers_cas(struct_processus
|
|
|
static void |
static void |
conversion_cas_vers_rpl(struct_processus *s_etat_processus, |
conversion_cas_vers_rpl(struct_processus *s_etat_processus, |
struct_objet *s_objet) |
unsigned char *expression) |
{ |
{ |
|
logical1 drapeau; |
|
|
struct_liste_chainee *l_element_courant; |
struct_liste_chainee *l_element_courant; |
struct_liste_chainee *l_element_precedent; |
|
|
struct_objet *s_objet; |
|
|
|
unsigned char *registre; |
|
|
|
registre = s_etat_processus->instruction_courante; |
|
s_etat_processus->instruction_courante = expression; |
|
recherche_type(s_etat_processus); |
|
s_etat_processus->instruction_courante = registre; |
|
|
|
if ((s_etat_processus->l_base_pile == NULL) || |
|
(s_etat_processus->erreur_execution != d_ex) || |
|
(s_etat_processus->erreur_systeme != d_es)) |
|
{ |
|
return; |
|
} |
|
|
|
// Le niveau 1 de la pile opérationnelle contient l'expression |
|
// à convertir. |
|
|
|
if (depilement(s_etat_processus, &(s_etat_processus |
|
->l_base_pile), &s_objet) == d_erreur) |
|
{ |
|
return; |
|
} |
|
|
if ((s_objet->type == ALG) || (s_objet->type == RPN)) |
if ((s_objet->type == ALG) || (s_objet->type == RPN)) |
{ |
{ |
// On transcrit les fonctions de GIAC vers le RPL/2. |
// On transcrit les fonctions de GIAC vers le RPL/2. |
|
|
l_element_precedent = NULL; |
l_element_courant = reinterpret_cast<struct_liste_chainee *>( |
|
s_objet->objet); |
|
drapeau = d_faux; |
|
|
|
// S'il y a une valeur infini, on force l'évaluation de l'expression. |
|
|
|
while(l_element_courant != NULL) |
|
{ |
|
if (l_element_courant->donnee->type == NOM) |
|
{ |
|
if (strcmp((const char *) reinterpret_cast<unsigned char *>( |
|
reinterpret_cast<struct_nom *>( |
|
l_element_courant->donnee->objet)->nom), |
|
"infinity") == 0) |
|
{ |
|
drapeau = d_vrai; |
|
break; |
|
} |
|
} |
|
|
|
l_element_courant = l_element_courant->suivant; |
|
} |
|
|
|
if (drapeau == d_vrai) |
|
{ |
|
if (evaluation(s_etat_processus, s_objet, 'N') == d_erreur) |
|
{ |
|
return; |
|
} |
|
|
|
liberation(s_etat_processus, s_objet); |
|
|
|
if (depilement(s_etat_processus, &(s_etat_processus |
|
->l_base_pile), &s_objet) == d_erreur) |
|
{ |
|
return; |
|
} |
|
} |
|
} |
|
|
|
if ((s_objet->type == ALG) || (s_objet->type == RPN)) |
|
{ |
l_element_courant = reinterpret_cast<struct_liste_chainee *>( |
l_element_courant = reinterpret_cast<struct_liste_chainee *>( |
s_objet->objet); |
s_objet->objet); |
|
|
Line 153 conversion_cas_vers_rpl(struct_processus
|
Line 361 conversion_cas_vers_rpl(struct_processus
|
// qui n'est pas reconnu comme un mot-clef du RPL/2. S'il |
// qui n'est pas reconnu comme un mot-clef du RPL/2. S'il |
// s'agit d'un mot-clef de GIAC, on le convertit. |
// s'agit d'un mot-clef de GIAC, on le convertit. |
|
|
if (strcmp((const char *) |
if ((strcmp((const char *) |
|
reinterpret_cast<struct_fonction *>(l_element_courant |
|
->donnee->objet)->nom_fonction, "quote") == 0) || |
|
(strcmp((const char *) |
reinterpret_cast<struct_fonction *>(l_element_courant |
reinterpret_cast<struct_fonction *>(l_element_courant |
->donnee->objet)->nom_fonction, "quote") == 0) |
->donnee->objet)->nom_fonction, "nop") == 0)) |
{ |
{ |
liberation(s_etat_processus, l_element_courant->donnee); |
liberation(s_etat_processus, l_element_courant->donnee); |
|
|
Line 184 conversion_cas_vers_rpl(struct_processus
|
Line 395 conversion_cas_vers_rpl(struct_processus
|
} |
} |
} |
} |
|
|
l_element_precedent = l_element_courant; |
|
l_element_courant = l_element_courant->suivant; |
l_element_courant = l_element_courant->suivant; |
} |
} |
} |
} |
|
|
|
if (empilement(s_etat_processus, &(s_etat_processus->l_base_pile), |
|
s_objet) == d_erreur) |
|
{ |
|
return; |
|
} |
|
|
return; |
return; |
} |
} |
|
#endif |
|
|
|
|
/* |
/* |
Line 206 conversion_cas_vers_rpl(struct_processus
|
Line 423 conversion_cas_vers_rpl(struct_processus
|
================================================================================ |
================================================================================ |
*/ |
*/ |
|
|
|
#pragma GCC diagnostic push |
|
#pragma GCC diagnostic ignored "-Wunused-parameter" |
void |
void |
interface_cas(struct_processus *s_etat_processus, |
interface_cas(struct_processus *s_etat_processus, |
enum t_rplcas_commandes commande) |
enum t_rplcas_commandes commande) |
{ |
{ |
|
#ifdef RPLCAS |
struct_objet *s_objet_argument_1; |
struct_objet *s_objet_argument_1; |
struct_objet *s_objet_argument_2; |
struct_objet *s_objet_argument_2; |
|
struct_objet *s_objet_temporaire; |
|
|
|
struct_liste_chainee *l_element_courant; |
|
|
unsigned char *argument_1; |
unsigned char *argument_1; |
unsigned char *argument_2; |
unsigned char *argument_2; |
unsigned char *registre; |
unsigned char *argument_3; |
|
unsigned char *argument_4; |
|
|
|
unsigned int position; |
|
|
|
giac::context *contexte; |
|
|
|
if (s_etat_processus->contexte_cas == NULL) |
|
{ |
|
try |
|
{ |
|
s_etat_processus->contexte_cas = new giac::context; |
|
} |
|
catch(bad_alloc &exception) |
|
{ |
|
s_etat_processus->erreur_systeme = d_es_allocation_memoire; |
|
return; |
|
} |
|
catch(...) |
|
{ |
|
s_etat_processus->erreur_execution = d_ex_erreur_interne_rplcas; |
|
return; |
|
} |
|
} |
|
|
|
contexte = reinterpret_cast<giac::context *>( |
|
s_etat_processus->contexte_cas); |
|
|
|
giac::angle_radian((test_cfsf(s_etat_processus, 60) == d_vrai) ? 1 : 0, |
|
contexte); |
|
|
|
if ((s_etat_processus->erreur_execution != d_ex) || |
|
(s_etat_processus->erreur_systeme != d_es)) |
|
{ |
|
return; |
|
} |
|
|
switch(commande) |
switch(commande) |
{ |
{ |
Line 224 interface_cas(struct_processus *s_etat_p
|
Line 482 interface_cas(struct_processus *s_etat_p
|
if (depilement(s_etat_processus, &(s_etat_processus->l_base_pile), |
if (depilement(s_etat_processus, &(s_etat_processus->l_base_pile), |
&s_objet_argument_1) == d_erreur) |
&s_objet_argument_1) == d_erreur) |
{ |
{ |
(*s_etat_processus).erreur_execution = d_ex_manque_argument; |
s_etat_processus->erreur_execution = d_ex_manque_argument; |
return; |
return; |
} |
} |
|
|
Line 232 interface_cas(struct_processus *s_etat_p
|
Line 490 interface_cas(struct_processus *s_etat_p
|
&s_objet_argument_2) == d_erreur) |
&s_objet_argument_2) == d_erreur) |
{ |
{ |
liberation(s_etat_processus, s_objet_argument_1); |
liberation(s_etat_processus, s_objet_argument_1); |
(*s_etat_processus).erreur_execution = d_ex_manque_argument; |
s_etat_processus->erreur_execution = d_ex_manque_argument; |
return; |
return; |
} |
} |
|
|
Line 253 interface_cas(struct_processus *s_etat_p
|
Line 511 interface_cas(struct_processus *s_etat_p
|
liberation(s_etat_processus, s_objet_argument_1); |
liberation(s_etat_processus, s_objet_argument_1); |
liberation(s_etat_processus, s_objet_argument_2); |
liberation(s_etat_processus, s_objet_argument_2); |
|
|
gen variable(string(reinterpret_cast<const char *>(argument_1)), |
try |
giac::context0); |
{ |
gen expression(string(reinterpret_cast<const char *>(argument_2)), |
gen variable( |
giac::context0); |
string(reinterpret_cast<const char *>(argument_1)), |
|
contexte); |
|
gen expression( |
|
string(reinterpret_cast<const char *>(argument_2)), |
|
contexte); |
|
|
|
gen resultat = integrate_gen(expression, variable, |
|
contexte); |
|
string chaine = "'" + resultat.print() + "'"; |
|
|
|
conversion_cas_vers_rpl(s_etat_processus, |
|
reinterpret_cast<unsigned char *>(const_cast<char *>( |
|
chaine.c_str()))); |
|
} |
|
catch(bad_alloc &exception) |
|
{ |
|
s_etat_processus->erreur_systeme = d_es_allocation_memoire; |
|
} |
|
catch(...) |
|
{ |
|
s_etat_processus->erreur_execution = d_ex_erreur_interne_rplcas; |
|
} |
|
|
free(argument_1); |
free(argument_1); |
free(argument_2); |
free(argument_2); |
|
|
gen resultat = integrate(expression, variable, giac::context0); |
break; |
string chaine = "'" + resultat.print() + "'"; |
} |
|
|
|
case RPLCAS_LIMITE: |
|
{ |
|
if (depilement(s_etat_processus, &(s_etat_processus->l_base_pile), |
|
&s_objet_argument_1) == d_erreur) |
|
{ |
|
s_etat_processus->erreur_execution = d_ex_manque_argument; |
|
return; |
|
} |
|
|
|
if (depilement(s_etat_processus, &(s_etat_processus->l_base_pile), |
|
&s_objet_argument_2) == d_erreur) |
|
{ |
|
liberation(s_etat_processus, s_objet_argument_1); |
|
s_etat_processus->erreur_execution = d_ex_manque_argument; |
|
return; |
|
} |
|
|
|
// Fonction |
|
|
|
if ((argument_2 = conversion_rpl_vers_cas(s_etat_processus, |
|
&s_objet_argument_2)) == NULL) |
|
{ |
|
s_etat_processus->erreur_systeme = d_es_allocation_memoire; |
|
return; |
|
} |
|
|
|
// On parcourt la liste. Cette liste est tout d'abord copiée |
|
// car on est susceptible de modifier le second élément. |
|
|
|
if ((s_objet_temporaire = copie_objet(s_etat_processus, |
|
s_objet_argument_1, 'O')) == NULL) |
|
{ |
|
s_etat_processus->erreur_systeme = d_es_allocation_memoire; |
|
return; |
|
} |
|
|
|
liberation(s_etat_processus, s_objet_argument_1); |
|
s_objet_argument_1 = s_objet_temporaire; |
|
|
|
l_element_courant = reinterpret_cast<struct_liste_chainee *> |
|
(s_objet_argument_1->objet); |
|
position = 1; |
|
argument_1 = NULL; |
|
argument_3 = NULL; |
|
argument_4 = NULL; |
|
|
|
while(l_element_courant != NULL) |
|
{ |
|
switch(position) |
|
{ |
|
case 1: |
|
{ |
|
// Variable |
|
|
|
if ((argument_1 = reinterpret_cast<unsigned char *> |
|
(malloc((strlen((const char *) |
|
((struct_variable *) (l_element_courant |
|
->donnee->objet))->nom) |
|
+ 1) * sizeof(unsigned char)))) == NULL) |
|
{ |
|
s_etat_processus->erreur_systeme = |
|
d_es_allocation_memoire; |
|
return; |
|
} |
|
|
|
strcpy(reinterpret_cast<char *>(argument_1), |
|
(const char *) ((struct_variable *) |
|
(l_element_courant->donnee->objet))->nom); |
|
break; |
|
} |
|
|
|
case 2: |
|
{ |
|
// Valeur |
|
if ((argument_3 = conversion_rpl_vers_cas( |
|
s_etat_processus, |
|
&(l_element_courant->donnee))) == NULL) |
|
{ |
|
s_etat_processus->erreur_systeme = |
|
d_es_allocation_memoire; |
|
return; |
|
} |
|
|
|
break; |
|
} |
|
|
|
case 3: |
|
{ |
|
// Direction |
|
|
|
if ((argument_4 = reinterpret_cast<unsigned char *> |
|
(malloc((strlen((const char *) |
|
((struct_fonction *) (l_element_courant |
|
->donnee->objet))->nom_fonction) |
|
+ 1) * sizeof(unsigned char)))) == NULL) |
|
{ |
|
s_etat_processus->erreur_systeme = |
|
d_es_allocation_memoire; |
|
return; |
|
} |
|
|
|
strcpy(reinterpret_cast<char *>(argument_4), |
|
(const char *) ((struct_fonction *) |
|
(l_element_courant->donnee->objet)) |
|
->nom_fonction); |
|
break; |
|
} |
|
} |
|
|
registre = s_etat_processus->instruction_courante; |
l_element_courant = (*l_element_courant).suivant; |
s_etat_processus->instruction_courante = |
position++; |
reinterpret_cast<unsigned char *>(const_cast<char *> |
} |
(chaine.c_str())); |
|
|
|
recherche_type(s_etat_processus); |
liberation(s_etat_processus, s_objet_argument_1); |
|
liberation(s_etat_processus, s_objet_argument_2); |
|
|
if (s_etat_processus->l_base_pile != NULL) |
try |
{ |
{ |
|
int direction; |
|
|
|
if (argument_4 == NULL) |
|
{ |
|
direction = 0; |
|
} |
|
else |
|
{ |
|
direction = (strcmp((const char *) argument_4, "+") == 0) |
|
? 1 : -1; |
|
} |
|
|
|
gen expression( |
|
string(reinterpret_cast<const char *>(argument_2)), |
|
contexte); |
|
identificateur variable( |
|
string(reinterpret_cast<const char *>(argument_1))); |
|
gen valeur(string(reinterpret_cast<const char *> |
|
(argument_3)), contexte); |
|
|
|
gen resultat = limit(expression, variable, valeur, direction, |
|
contexte); |
|
string chaine = "'" + resultat.print() + "'"; |
|
|
conversion_cas_vers_rpl(s_etat_processus, |
conversion_cas_vers_rpl(s_etat_processus, |
s_etat_processus->l_base_pile->donnee); |
reinterpret_cast<unsigned char *>(const_cast<char *>( |
|
chaine.c_str()))); |
} |
} |
|
catch(bad_alloc &exception) |
|
{ |
|
s_etat_processus->erreur_systeme = d_es_allocation_memoire; |
|
} |
|
catch(...) |
|
{ |
|
s_etat_processus->erreur_execution = d_ex_erreur_interne_rplcas; |
|
} |
|
|
|
free(argument_1); |
|
free(argument_2); |
|
free(argument_3); |
|
|
s_etat_processus->instruction_courante = registre; |
if (argument_4 != NULL) |
|
{ |
|
free(argument_4); |
|
} |
|
|
break; |
break; |
} |
} |
|
|
case RPLCAS_LIMITE: |
case RPLCAS_SIMPLIFICATION: |
{ |
{ |
|
if (depilement(s_etat_processus, &(s_etat_processus->l_base_pile), |
|
&s_objet_argument_1) == d_erreur) |
|
{ |
|
s_etat_processus->erreur_execution = d_ex_manque_argument; |
|
return; |
|
} |
|
|
|
if ((argument_1 = conversion_rpl_vers_cas(s_etat_processus, |
|
&s_objet_argument_1)) == NULL) |
|
{ |
|
s_etat_processus->erreur_systeme = d_es_allocation_memoire; |
|
return; |
|
} |
|
|
|
liberation(s_etat_processus, s_objet_argument_1); |
|
|
|
try |
|
{ |
|
gen expression( |
|
string(reinterpret_cast<const char *>(argument_1)), |
|
contexte); |
|
|
|
gen resultat = simplify(expression, contexte); |
|
string chaine = "'" + resultat.print() + "'"; |
|
|
|
conversion_cas_vers_rpl(s_etat_processus, |
|
reinterpret_cast<unsigned char *>(const_cast<char *>( |
|
chaine.c_str()))); |
|
} |
|
catch(bad_alloc &exception) |
|
{ |
|
s_etat_processus->erreur_systeme = d_es_allocation_memoire; |
|
} |
|
catch(...) |
|
{ |
|
s_etat_processus->erreur_execution = d_ex_erreur_interne_rplcas; |
|
} |
|
|
|
free(argument_1); |
|
|
break; |
break; |
} |
} |
} |
} |
|
|
return; |
return; |
|
#else |
|
|
|
if (s_etat_processus->langue == 'F') |
|
{ |
|
printf("+++Attention : RPL/CAS non compilé !\n"); |
|
} |
|
else |
|
{ |
|
printf("+++Warning : RPL/CAS not available !\n"); |
|
} |
|
|
|
fflush(stdout); |
|
|
|
return; |
|
|
|
#endif |
} |
} |
|
#pragma GCC diagnostic pop |
|
|
// vim: ts=4 |
// vim: ts=4 |