version 1.5, 2010/02/10 08:09:30
|
version 1.34, 2011/06/23 12:41:15
|
Line 1
|
Line 1
|
/* |
/* |
================================================================================ |
================================================================================ |
RPL/2 (R) version 4.0.10 |
RPL/2 (R) version 4.1.0.prerelease.3 |
Copyright (C) 1989-2010 Dr. BERTRAND Joël |
Copyright (C) 1989-2011 Dr. BERTRAND Joël |
|
|
This file is part of RPL/2. |
This file is part of RPL/2. |
|
|
Line 20
|
Line 20
|
*/ |
*/ |
|
|
|
|
#include "rpl.conv.h" |
#include "rpl-conv.h" |
|
|
|
|
/* |
/* |
Line 75 recherche_type(struct_processus *s_etat_
|
Line 75 recherche_type(struct_processus *s_etat_
|
unsigned char registre_instruction_valide; |
unsigned char registre_instruction_valide; |
unsigned char registre_interruption; |
unsigned char registre_interruption; |
unsigned char registre_mode_execution_programme; |
unsigned char registre_mode_execution_programme; |
|
unsigned char registre_recherche_type; |
unsigned char registre_test; |
unsigned char registre_test; |
unsigned char registre_test_bis; |
unsigned char registre_test_bis; |
unsigned char *tampon; |
unsigned char *tampon; |
|
unsigned char variable_implicite; |
|
|
unsigned long i; |
unsigned long i; |
unsigned long j; |
unsigned long j; |
Line 176 recherche_type(struct_processus *s_etat_
|
Line 178 recherche_type(struct_processus *s_etat_
|
|
|
(*s_objet).type = FCT; |
(*s_objet).type = FCT; |
(*s_objet).objet = element; |
(*s_objet).objet = element; |
|
(*((struct_fonction *) (*s_objet).objet)).prediction_saut = NULL; |
|
(*((struct_fonction *) (*s_objet).objet)).prediction_execution |
|
= d_faux; |
|
|
if (empilement(s_etat_processus, |
if (empilement(s_etat_processus, |
&((*s_etat_processus).l_base_pile), s_objet) == d_erreur) |
&((*s_etat_processus).l_base_pile), s_objet) == d_erreur) |
Line 367 recherche_type(struct_processus *s_etat_
|
Line 372 recherche_type(struct_processus *s_etat_
|
} |
} |
} |
} |
|
|
|
registre_recherche_type = (*s_etat_processus).recherche_type; |
|
(*s_etat_processus).recherche_type = 'Y'; |
|
|
if (sequenceur(s_etat_processus) == d_erreur) |
if (sequenceur(s_etat_processus) == d_erreur) |
{ |
{ |
|
(*s_etat_processus).erreur_execution = d_ex_syntaxe; |
|
(*s_etat_processus).recherche_type = registre_recherche_type; |
(*s_etat_processus).instruction_courante = tampon; |
(*s_etat_processus).instruction_courante = tampon; |
(*s_etat_processus).mode_execution_programme = |
(*s_etat_processus).mode_execution_programme = |
registre_mode_execution_programme; |
registre_mode_execution_programme; |
|
|
|
effacement_pile_systeme(s_etat_processus); |
(*s_etat_processus).l_base_pile_systeme = s_sauvegarde_pile; |
(*s_etat_processus).l_base_pile_systeme = s_sauvegarde_pile; |
(*s_etat_processus).niveau_courant = sauvegarde_niveau_courant; |
(*s_etat_processus).niveau_courant = sauvegarde_niveau_courant; |
|
|
Line 393 recherche_type(struct_processus *s_etat_
|
Line 404 recherche_type(struct_processus *s_etat_
|
return; |
return; |
} |
} |
|
|
|
(*s_etat_processus).recherche_type = registre_recherche_type; |
(*s_etat_processus).instruction_courante = tampon; |
(*s_etat_processus).instruction_courante = tampon; |
(*s_etat_processus).mode_execution_programme = |
(*s_etat_processus).mode_execution_programme = |
registre_mode_execution_programme; |
registre_mode_execution_programme; |
Line 1158 recherche_type(struct_processus *s_etat_
|
Line 1170 recherche_type(struct_processus *s_etat_
|
} |
} |
} |
} |
|
|
|
registre_recherche_type = |
|
(*s_etat_processus).recherche_type; |
|
(*s_etat_processus).recherche_type = 'Y'; |
|
|
if (sequenceur(s_etat_processus) == d_erreur) |
if (sequenceur(s_etat_processus) == d_erreur) |
{ |
{ |
|
(*s_etat_processus).erreur_execution = d_ex_syntaxe; |
|
(*s_etat_processus).recherche_type = |
|
registre_recherche_type; |
(*s_etat_processus).mode_execution_programme = |
(*s_etat_processus).mode_execution_programme = |
registre_mode_execution_programme; |
registre_mode_execution_programme; |
nombre_lignes_a_supprimer = |
nombre_lignes_a_supprimer = |
Line 1182 recherche_type(struct_processus *s_etat_
|
Line 1201 recherche_type(struct_processus *s_etat_
|
|
|
(*s_etat_processus).instruction_courante = tampon; |
(*s_etat_processus).instruction_courante = tampon; |
|
|
|
effacement_pile_systeme(s_etat_processus); |
(*s_etat_processus).l_base_pile_systeme = |
(*s_etat_processus).l_base_pile_systeme = |
s_sauvegarde_pile; |
s_sauvegarde_pile; |
(*s_etat_processus).niveau_courant = |
(*s_etat_processus).niveau_courant = |
Line 1205 recherche_type(struct_processus *s_etat_
|
Line 1225 recherche_type(struct_processus *s_etat_
|
return; |
return; |
} |
} |
|
|
|
(*s_etat_processus).recherche_type = |
|
registre_recherche_type; |
(*s_etat_processus).mode_execution_programme = |
(*s_etat_processus).mode_execution_programme = |
registre_mode_execution_programme; |
registre_mode_execution_programme; |
|
|
Line 1230 recherche_type(struct_processus *s_etat_
|
Line 1252 recherche_type(struct_processus *s_etat_
|
|
|
(*s_etat_processus).instruction_courante = tampon; |
(*s_etat_processus).instruction_courante = tampon; |
|
|
|
effacement_pile_systeme(s_etat_processus); |
(*s_etat_processus).l_base_pile_systeme = |
(*s_etat_processus).l_base_pile_systeme = |
s_sauvegarde_pile; |
s_sauvegarde_pile; |
(*s_etat_processus).niveau_courant = |
(*s_etat_processus).niveau_courant = |
Line 1564 recherche_type(struct_processus *s_etat_
|
Line 1587 recherche_type(struct_processus *s_etat_
|
return; |
return; |
} |
} |
} |
} |
|
|
|
registre_recherche_type = (*s_etat_processus) |
|
.recherche_type; |
|
(*s_etat_processus).recherche_type = 'Y'; |
|
|
if (sequenceur(s_etat_processus) == d_erreur) |
if (sequenceur(s_etat_processus) == d_erreur) |
{ |
{ |
|
(*s_etat_processus).erreur_execution = d_ex_syntaxe; |
|
(*s_etat_processus).recherche_type = |
|
registre_recherche_type; |
(*s_etat_processus).mode_execution_programme = |
(*s_etat_processus).mode_execution_programme = |
registre_mode_execution_programme; |
registre_mode_execution_programme; |
nombre_lignes_a_supprimer = |
nombre_lignes_a_supprimer = |
Line 1589 recherche_type(struct_processus *s_etat_
|
Line 1619 recherche_type(struct_processus *s_etat_
|
|
|
(*s_etat_processus).instruction_courante = tampon; |
(*s_etat_processus).instruction_courante = tampon; |
|
|
|
effacement_pile_systeme(s_etat_processus); |
(*s_etat_processus).l_base_pile_systeme = |
(*s_etat_processus).l_base_pile_systeme = |
s_sauvegarde_pile; |
s_sauvegarde_pile; |
(*s_etat_processus).niveau_courant = |
(*s_etat_processus).niveau_courant = |
Line 1613 recherche_type(struct_processus *s_etat_
|
Line 1644 recherche_type(struct_processus *s_etat_
|
return; |
return; |
} |
} |
|
|
|
(*s_etat_processus).recherche_type = |
|
registre_recherche_type; |
(*s_etat_processus).mode_execution_programme = |
(*s_etat_processus).mode_execution_programme = |
registre_mode_execution_programme; |
registre_mode_execution_programme; |
|
|
Line 1638 recherche_type(struct_processus *s_etat_
|
Line 1671 recherche_type(struct_processus *s_etat_
|
|
|
(*s_etat_processus).instruction_courante = tampon; |
(*s_etat_processus).instruction_courante = tampon; |
|
|
|
effacement_pile_systeme(s_etat_processus); |
(*s_etat_processus).l_base_pile_systeme = |
(*s_etat_processus).l_base_pile_systeme = |
s_sauvegarde_pile; |
s_sauvegarde_pile; |
(*s_etat_processus).niveau_courant = |
(*s_etat_processus).niveau_courant = |
Line 2248 recherche_type(struct_processus *s_etat_
|
Line 2282 recherche_type(struct_processus *s_etat_
|
(*s_etat_processus).autorisation_evaluation_nom = |
(*s_etat_processus).autorisation_evaluation_nom = |
autorisation_evaluation_nom; |
autorisation_evaluation_nom; |
|
|
|
effacement_pile_systeme(s_etat_processus); |
(*s_etat_processus).l_base_pile_systeme = s_sauvegarde_pile; |
(*s_etat_processus).l_base_pile_systeme = s_sauvegarde_pile; |
(*s_etat_processus).niveau_courant = sauvegarde_niveau_courant; |
(*s_etat_processus).niveau_courant = sauvegarde_niveau_courant; |
|
|
Line 2284 recherche_type(struct_processus *s_etat_
|
Line 2319 recherche_type(struct_processus *s_etat_
|
} |
} |
} |
} |
|
|
|
variable_implicite = (*s_etat_processus).autorisation_nom_implicite; |
|
registre_recherche_type = (*s_etat_processus).recherche_type; |
|
(*s_etat_processus).recherche_type = 'Y'; |
|
(*s_etat_processus).autorisation_nom_implicite = 'Y'; |
|
|
if (sequenceur(s_etat_processus) == d_erreur) |
if (sequenceur(s_etat_processus) == d_erreur) |
{ |
{ |
|
(*s_etat_processus).autorisation_nom_implicite = |
|
variable_implicite; |
|
(*s_etat_processus).recherche_type = registre_recherche_type; |
(*s_etat_processus).mode_execution_programme = |
(*s_etat_processus).mode_execution_programme = |
registre_mode_execution_programme; |
registre_mode_execution_programme; |
(*s_etat_processus).erreur_execution = d_ex_syntaxe; |
|
|
if ((*s_etat_processus).erreur_execution != |
|
d_ex_nom_implicite) |
|
{ |
|
(*s_etat_processus).erreur_execution = d_ex_syntaxe; |
|
} |
|
|
nombre_lignes_a_supprimer = |
nombre_lignes_a_supprimer = |
(*s_etat_processus).hauteur_pile_operationnelle |
(*s_etat_processus).hauteur_pile_operationnelle |
Line 2315 recherche_type(struct_processus *s_etat_
|
Line 2363 recherche_type(struct_processus *s_etat_
|
(*s_etat_processus).autorisation_evaluation_nom = |
(*s_etat_processus).autorisation_evaluation_nom = |
autorisation_evaluation_nom; |
autorisation_evaluation_nom; |
|
|
|
effacement_pile_systeme(s_etat_processus); |
(*s_etat_processus).l_base_pile_systeme = s_sauvegarde_pile; |
(*s_etat_processus).l_base_pile_systeme = s_sauvegarde_pile; |
(*s_etat_processus).niveau_courant = sauvegarde_niveau_courant; |
(*s_etat_processus).niveau_courant = sauvegarde_niveau_courant; |
|
|
Line 2333 recherche_type(struct_processus *s_etat_
|
Line 2382 recherche_type(struct_processus *s_etat_
|
return; |
return; |
} |
} |
|
|
|
(*s_etat_processus).autorisation_nom_implicite = variable_implicite; |
|
(*s_etat_processus).recherche_type = registre_recherche_type; |
(*s_etat_processus).mode_execution_programme = |
(*s_etat_processus).mode_execution_programme = |
registre_mode_execution_programme; |
registre_mode_execution_programme; |
|
|
Line 2363 recherche_type(struct_processus *s_etat_
|
Line 2414 recherche_type(struct_processus *s_etat_
|
(*s_etat_processus).autorisation_evaluation_nom = |
(*s_etat_processus).autorisation_evaluation_nom = |
autorisation_evaluation_nom; |
autorisation_evaluation_nom; |
|
|
|
effacement_pile_systeme(s_etat_processus); |
(*s_etat_processus).l_base_pile_systeme = s_sauvegarde_pile; |
(*s_etat_processus).l_base_pile_systeme = s_sauvegarde_pile; |
(*s_etat_processus).niveau_courant = sauvegarde_niveau_courant; |
(*s_etat_processus).niveau_courant = sauvegarde_niveau_courant; |
|
|
Line 2731 recherche_type(struct_processus *s_etat_
|
Line 2783 recherche_type(struct_processus *s_etat_
|
(*s_sous_objet).type = FCT; |
(*s_sous_objet).type = FCT; |
|
|
if (((*s_sous_objet).objet = (void *) |
if (((*s_sous_objet).objet = (void *) |
allocation(s_etat_processus, FCT)) |
malloc(sizeof(struct_fonction))) |
== NULL) |
== NULL) |
{ |
{ |
(*s_etat_processus).erreur_systeme = |
(*s_etat_processus).erreur_systeme = |
Line 2912 recherche_type(struct_processus *s_etat_
|
Line 2964 recherche_type(struct_processus *s_etat_
|
} |
} |
} |
} |
|
|
|
registre_recherche_type = (*s_etat_processus).recherche_type; |
|
(*s_etat_processus).recherche_type = 'Y'; |
|
|
|
variable_implicite = |
|
(*s_etat_processus).autorisation_nom_implicite; |
|
(*s_etat_processus).autorisation_nom_implicite = 'Y'; |
|
|
if (sequenceur(s_etat_processus) == d_erreur) |
if (sequenceur(s_etat_processus) == d_erreur) |
{ |
{ |
|
(*s_etat_processus).autorisation_nom_implicite = |
|
variable_implicite; |
|
(*s_etat_processus).erreur_execution = d_ex_syntaxe; |
|
(*s_etat_processus).recherche_type = |
|
registre_recherche_type; |
(*s_etat_processus).mode_execution_programme = |
(*s_etat_processus).mode_execution_programme = |
registre_mode_execution_programme; |
registre_mode_execution_programme; |
nombre_lignes_a_supprimer = |
nombre_lignes_a_supprimer = |
Line 2936 recherche_type(struct_processus *s_etat_
|
Line 3000 recherche_type(struct_processus *s_etat_
|
|
|
(*s_etat_processus).instruction_courante = tampon; |
(*s_etat_processus).instruction_courante = tampon; |
|
|
|
effacement_pile_systeme(s_etat_processus); |
(*s_etat_processus).l_base_pile_systeme = |
(*s_etat_processus).l_base_pile_systeme = |
s_sauvegarde_pile; |
s_sauvegarde_pile; |
(*s_etat_processus).niveau_courant = |
(*s_etat_processus).niveau_courant = |
Line 2960 recherche_type(struct_processus *s_etat_
|
Line 3025 recherche_type(struct_processus *s_etat_
|
return; |
return; |
} |
} |
|
|
|
(*s_etat_processus).autorisation_nom_implicite = |
|
variable_implicite; |
|
(*s_etat_processus).recherche_type = registre_recherche_type; |
(*s_etat_processus).mode_execution_programme = |
(*s_etat_processus).mode_execution_programme = |
registre_mode_execution_programme; |
registre_mode_execution_programme; |
|
|
Line 2985 recherche_type(struct_processus *s_etat_
|
Line 3053 recherche_type(struct_processus *s_etat_
|
|
|
(*s_etat_processus).instruction_courante = tampon; |
(*s_etat_processus).instruction_courante = tampon; |
|
|
|
effacement_pile_systeme(s_etat_processus); |
(*s_etat_processus).l_base_pile_systeme = |
(*s_etat_processus).l_base_pile_systeme = |
s_sauvegarde_pile; |
s_sauvegarde_pile; |
(*s_etat_processus).niveau_courant = |
(*s_etat_processus).niveau_courant = |
Line 3035 recherche_type(struct_processus *s_etat_
|
Line 3104 recherche_type(struct_processus *s_etat_
|
|
|
nombre_lignes = profondeur_finale - profondeur_initiale; |
nombre_lignes = profondeur_finale - profondeur_initiale; |
|
|
element = (void *) ((struct_tableau *) malloc( |
if ((element = malloc(sizeof(struct_tableau))) == NULL) |
sizeof(struct_tableau))); |
|
|
|
if (element == NULL) |
|
{ |
{ |
(*s_etat_processus).erreur_systeme = |
(*s_etat_processus).erreur_systeme = |
d_es_allocation_memoire; |
d_es_allocation_memoire; |
Line 3118 recherche_type(struct_processus *s_etat_
|
Line 3184 recherche_type(struct_processus *s_etat_
|
d_es_allocation_memoire; |
d_es_allocation_memoire; |
} |
} |
|
|
|
free(s_objet); |
|
|
(*s_etat_processus).traitement_interruptible = |
(*s_etat_processus).traitement_interruptible = |
registre_interruption; |
registre_interruption; |
return; |
return; |
Line 3365 recherche_type(struct_processus *s_etat_
|
Line 3433 recherche_type(struct_processus *s_etat_
|
if ((drapeau_valeur_reelle == d_faux) && |
if ((drapeau_valeur_reelle == d_faux) && |
(drapeau_valeur_entiere == d_faux)) |
(drapeau_valeur_entiere == d_faux)) |
{ |
{ |
|
ptr = (*s_etat_processus).instruction_courante; |
|
|
|
while((*ptr) != d_code_fin_chaine) |
|
{ |
|
if ((isalnum((*ptr)) == 0) && |
|
((*ptr) != '_') && |
|
((*ptr) != '$')) |
|
{ |
|
free(s_objet); |
|
|
|
(*s_etat_processus).erreur_execution = d_ex_syntaxe; |
|
(*s_etat_processus).traitement_interruptible = |
|
registre_interruption; |
|
|
|
return; |
|
} |
|
|
|
ptr++; |
|
} |
|
|
(*s_objet).type = NOM; |
(*s_objet).type = NOM; |
|
|
element = malloc(sizeof(struct_nom)); |
element = malloc(sizeof(struct_nom)); |
Line 3468 recherche_type(struct_processus *s_etat_
|
Line 3556 recherche_type(struct_processus *s_etat_
|
&((*s_etat_processus).l_base_pile), s_objet) == d_erreur) |
&((*s_etat_processus).l_base_pile), s_objet) == d_erreur) |
{ |
{ |
(*s_etat_processus).erreur_systeme = d_es_allocation_memoire; |
(*s_etat_processus).erreur_systeme = d_es_allocation_memoire; |
(*s_etat_processus).traitement_interruptible = registre_interruption; |
(*s_etat_processus).traitement_interruptible = |
|
registre_interruption; |
return; |
return; |
} |
} |
|
|