version 1.41, 2013/02/26 19:56:14
|
version 1.75, 2024/01/09 07:33:50
|
Line 1
|
Line 1
|
/* |
/* |
================================================================================ |
================================================================================ |
RPL/2 (R) version 4.1.12 |
RPL/2 (R) version 4.1.35 |
Copyright (C) 1989-2013 Dr. BERTRAND Joël |
Copyright (C) 1989-2024 Dr. BERTRAND Joël |
|
|
This file is part of RPL/2. |
This file is part of RPL/2. |
|
|
Line 114 instruction_eval(struct_processus *s_eta
|
Line 114 instruction_eval(struct_processus *s_eta
|
return; |
return; |
} |
} |
|
|
if ((s_objet_simplifie = simplification(s_etat_processus, s_objet)) == NULL) |
if ((*s_etat_processus).l_base_pile_systeme == NULL) |
{ |
{ |
if (last_valide == d_vrai) |
(*s_etat_processus).erreur_systeme = d_es_pile_vide; |
|
return; |
|
} |
|
|
|
if (test_cfsf(s_etat_processus, 46) == d_vrai) |
|
{ |
|
(*(*s_etat_processus).l_base_pile_systeme).evaluation_expression = |
|
d_vrai; |
|
|
|
if (evaluation(s_etat_processus, s_objet, 'E') == d_erreur) |
{ |
{ |
sf(s_etat_processus, 31); |
(*(*s_etat_processus).l_base_pile_systeme) |
|
.evaluation_expression = d_faux; |
|
|
|
if (last_valide == d_vrai) |
|
{ |
|
sf(s_etat_processus, 31); |
|
} |
|
|
|
liberation(s_etat_processus, s_objet); |
|
return; |
} |
} |
|
|
return; |
(*(*s_etat_processus).l_base_pile_systeme).evaluation_expression = |
} |
d_faux; |
|
liberation(s_etat_processus, s_objet); |
|
|
liberation(s_etat_processus, s_objet); |
if (depilement(s_etat_processus, &((*s_etat_processus).l_base_pile), |
s_objet = s_objet_simplifie; |
&s_objet) == d_erreur) |
|
{ |
|
if (last_valide == d_vrai) |
|
{ |
|
sf(s_etat_processus, 31); |
|
} |
|
|
if ((*s_etat_processus).l_base_pile_systeme == NULL) |
(*s_etat_processus).erreur_execution = d_ex_manque_argument; |
{ |
return; |
(*s_etat_processus).erreur_systeme = d_es_pile_vide; |
} |
return; |
|
|
if ((s_objet_simplifie = simplification(s_etat_processus, s_objet)) |
|
== NULL) |
|
{ |
|
if (last_valide == d_vrai) |
|
{ |
|
sf(s_etat_processus, 31); |
|
} |
|
|
|
liberation(s_etat_processus, s_objet); |
|
return; |
|
} |
|
|
|
liberation(s_etat_processus, s_objet); |
|
s_objet = s_objet_simplifie; |
} |
} |
|
|
(*(*s_etat_processus).l_base_pile_systeme).evaluation_expression = d_vrai; |
(*(*s_etat_processus).l_base_pile_systeme).evaluation_expression = d_vrai; |
Line 475 instruction_else(struct_processus *s_eta
|
Line 513 instruction_else(struct_processus *s_eta
|
unsigned char *instruction_majuscule; |
unsigned char *instruction_majuscule; |
unsigned char *tampon; |
unsigned char *tampon; |
|
|
unsigned long niveau; |
integer8 niveau; |
|
|
void (*fonction)(); |
void (*fonction)(); |
|
|
Line 543 instruction_else(struct_processus *s_eta
|
Line 581 instruction_else(struct_processus *s_eta
|
} |
} |
|
|
if ((instruction_majuscule = conversion_majuscule( |
if ((instruction_majuscule = conversion_majuscule( |
|
s_etat_processus, |
(*s_etat_processus).instruction_courante)) == NULL) |
(*s_etat_processus).instruction_courante)) == NULL) |
{ |
{ |
free((*s_etat_processus).instruction_courante); |
free((*s_etat_processus).instruction_courante); |
Line 556 instruction_else(struct_processus *s_eta
|
Line 595 instruction_else(struct_processus *s_eta
|
{ |
{ |
if (strcmp(instruction_majuscule, "END") == 0) |
if (strcmp(instruction_majuscule, "END") == 0) |
{ |
{ |
(*s_etat_processus).position_courante -= (strlen( |
(*s_etat_processus).position_courante -= |
instruction_majuscule) + 1); |
(((integer8) strlen( |
|
instruction_majuscule)) + 1); |
drapeau_fin = d_vrai; |
drapeau_fin = d_vrai; |
} |
} |
else |
else |
Line 754 instruction_elseif(struct_processus *s_e
|
Line 794 instruction_elseif(struct_processus *s_e
|
unsigned char *instruction_majuscule; |
unsigned char *instruction_majuscule; |
unsigned char *tampon; |
unsigned char *tampon; |
|
|
unsigned long niveau; |
integer8 niveau; |
|
|
void (*fonction)(); |
void (*fonction)(); |
|
|
Line 833 instruction_elseif(struct_processus *s_e
|
Line 873 instruction_elseif(struct_processus *s_e
|
} |
} |
|
|
if ((instruction_majuscule = conversion_majuscule( |
if ((instruction_majuscule = conversion_majuscule( |
|
s_etat_processus, |
(*s_etat_processus).instruction_courante)) == NULL) |
(*s_etat_processus).instruction_courante)) == NULL) |
{ |
{ |
free((*s_etat_processus).instruction_courante); |
free((*s_etat_processus).instruction_courante); |
Line 846 instruction_elseif(struct_processus *s_e
|
Line 887 instruction_elseif(struct_processus *s_e
|
{ |
{ |
if (strcmp(instruction_majuscule, "END") == 0) |
if (strcmp(instruction_majuscule, "END") == 0) |
{ |
{ |
(*s_etat_processus).position_courante -= (strlen( |
(*s_etat_processus).position_courante -= |
instruction_majuscule) + 1); |
(((integer8) strlen( |
|
instruction_majuscule)) + 1); |
drapeau_fin = d_vrai; |
drapeau_fin = d_vrai; |
} |
} |
else |
else |
Line 1035 instruction_elseif(struct_processus *s_e
|
Line 1077 instruction_elseif(struct_processus *s_e
|
void |
void |
instruction_sensible_e(struct_processus *s_etat_processus) |
instruction_sensible_e(struct_processus *s_etat_processus) |
{ |
{ |
|
(*s_etat_processus).instruction_sensible = 'Y'; |
|
|
if (strcmp((*s_etat_processus).instruction_courante, "e") == 0) |
if (strcmp((*s_etat_processus).instruction_courante, "e") == 0) |
{ |
{ |
instruction_e(s_etat_processus); |
instruction_e(s_etat_processus); |
Line 1195 instruction_eng(struct_processus *s_etat
|
Line 1239 instruction_eng(struct_processus *s_etat
|
return; |
return; |
} |
} |
|
|
(*((logical8 *) (*s_objet).objet)) = |
(*((logical8 *) (*s_objet).objet)) = (logical8) |
(*((integer8 *) (*s_objet_argument).objet)); |
(*((integer8 *) (*s_objet_argument).objet)); |
|
|
i43 = test_cfsf(s_etat_processus, 43); |
i43 = test_cfsf(s_etat_processus, 43); |
Line 1233 instruction_eng(struct_processus *s_etat
|
Line 1277 instruction_eng(struct_processus *s_etat
|
{ |
{ |
if (valeur_binaire[i] == '0') |
if (valeur_binaire[i] == '0') |
{ |
{ |
cf(s_etat_processus, j++); |
cf(s_etat_processus, (unsigned char) j++); |
} |
} |
else |
else |
{ |
{ |
sf(s_etat_processus, j++); |
sf(s_etat_processus, (unsigned char) j++); |
} |
} |
} |
} |
|
|
for(; j <= 56; cf(s_etat_processus, j++)); |
for(; j <= 56; cf(s_etat_processus, (unsigned char) j++)); |
|
|
sf(s_etat_processus, 49); |
sf(s_etat_processus, 49); |
sf(s_etat_processus, 50); |
sf(s_etat_processus, 50); |