--- rpl/src/types.c 2010/01/27 22:22:18 1.2 +++ rpl/src/types.c 2011/07/25 07:45:01 1.38 @@ -1,7 +1,7 @@ /* ================================================================================ - RPL/2 (R) version 4.0.10 - Copyright (C) 1989-2010 Dr. BERTRAND Joël + RPL/2 (R) version 4.1.2 + Copyright (C) 1989-2011 Dr. BERTRAND Joël This file is part of RPL/2. @@ -20,7 +20,7 @@ */ -#include "rpl.conv.h" +#include "rpl-conv.h" /* @@ -75,9 +75,11 @@ recherche_type(struct_processus *s_etat_ unsigned char registre_instruction_valide; unsigned char registre_interruption; unsigned char registre_mode_execution_programme; + unsigned char registre_recherche_type; unsigned char registre_test; unsigned char registre_test_bis; unsigned char *tampon; + unsigned char variable_implicite; unsigned long i; unsigned long j; @@ -176,6 +178,9 @@ recherche_type(struct_processus *s_etat_ (*s_objet).type = FCT; (*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, &((*s_etat_processus).l_base_pile), s_objet) == d_erreur) @@ -367,12 +372,18 @@ 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) { + (*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).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).niveau_courant = sauvegarde_niveau_courant; @@ -393,6 +404,7 @@ recherche_type(struct_processus *s_etat_ return; } + (*s_etat_processus).recherche_type = registre_recherche_type; (*s_etat_processus).instruction_courante = tampon; (*s_etat_processus).mode_execution_programme = registre_mode_execution_programme; @@ -1073,7 +1085,7 @@ recherche_type(struct_processus *s_etat_ /* -- Sauvegarde des paramètres du processus pour analyser le vecteur ------------- --- Analyse récursive en appelant l'interpréteur sur le vecteur moins ----------- +-- Analyse récursive en appelant l'interprète sur le vecteur moins ------------- -- ses délimiteurs ------------------------------------------------------------- */ @@ -1158,8 +1170,15 @@ 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) { + (*s_etat_processus).erreur_execution = d_ex_syntaxe; + (*s_etat_processus).recherche_type = + registre_recherche_type; (*s_etat_processus).mode_execution_programme = registre_mode_execution_programme; nombre_lignes_a_supprimer = @@ -1182,6 +1201,7 @@ recherche_type(struct_processus *s_etat_ (*s_etat_processus).instruction_courante = tampon; + effacement_pile_systeme(s_etat_processus); (*s_etat_processus).l_base_pile_systeme = s_sauvegarde_pile; (*s_etat_processus).niveau_courant = @@ -1205,6 +1225,8 @@ recherche_type(struct_processus *s_etat_ return; } + (*s_etat_processus).recherche_type = + registre_recherche_type; (*s_etat_processus).mode_execution_programme = registre_mode_execution_programme; @@ -1230,6 +1252,7 @@ recherche_type(struct_processus *s_etat_ (*s_etat_processus).instruction_courante = tampon; + effacement_pile_systeme(s_etat_processus); (*s_etat_processus).l_base_pile_systeme = s_sauvegarde_pile; (*s_etat_processus).niveau_courant = @@ -1564,9 +1587,16 @@ recherche_type(struct_processus *s_etat_ return; } } + + registre_recherche_type = (*s_etat_processus) + .recherche_type; + (*s_etat_processus).recherche_type = 'Y'; 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 = registre_mode_execution_programme; nombre_lignes_a_supprimer = @@ -1589,6 +1619,7 @@ recherche_type(struct_processus *s_etat_ (*s_etat_processus).instruction_courante = tampon; + effacement_pile_systeme(s_etat_processus); (*s_etat_processus).l_base_pile_systeme = s_sauvegarde_pile; (*s_etat_processus).niveau_courant = @@ -1613,6 +1644,8 @@ recherche_type(struct_processus *s_etat_ return; } + (*s_etat_processus).recherche_type = + registre_recherche_type; (*s_etat_processus).mode_execution_programme = registre_mode_execution_programme; @@ -1638,6 +1671,7 @@ recherche_type(struct_processus *s_etat_ (*s_etat_processus).instruction_courante = tampon; + effacement_pile_systeme(s_etat_processus); (*s_etat_processus).l_base_pile_systeme = s_sauvegarde_pile; (*s_etat_processus).niveau_courant = @@ -2248,6 +2282,7 @@ recherche_type(struct_processus *s_etat_ (*s_etat_processus).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).niveau_courant = sauvegarde_niveau_courant; @@ -2284,11 +2319,24 @@ 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) { + (*s_etat_processus).autorisation_nom_implicite = + variable_implicite; + (*s_etat_processus).recherche_type = registre_recherche_type; (*s_etat_processus).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 = (*s_etat_processus).hauteur_pile_operationnelle @@ -2315,6 +2363,7 @@ recherche_type(struct_processus *s_etat_ (*s_etat_processus).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).niveau_courant = sauvegarde_niveau_courant; @@ -2333,6 +2382,8 @@ recherche_type(struct_processus *s_etat_ return; } + (*s_etat_processus).autorisation_nom_implicite = variable_implicite; + (*s_etat_processus).recherche_type = registre_recherche_type; (*s_etat_processus).mode_execution_programme = registre_mode_execution_programme; @@ -2363,6 +2414,7 @@ recherche_type(struct_processus *s_etat_ (*s_etat_processus).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).niveau_courant = sauvegarde_niveau_courant; @@ -2731,7 +2783,7 @@ recherche_type(struct_processus *s_etat_ (*s_sous_objet).type = FCT; if (((*s_sous_objet).objet = (void *) - allocation(s_etat_processus, FCT)) + malloc(sizeof(struct_fonction))) == NULL) { (*s_etat_processus).erreur_systeme = @@ -2811,62 +2863,11 @@ recherche_type(struct_processus *s_etat_ while((*ptr_lecture) != d_code_fin_chaine) { - if ((*ptr_lecture) == '\\') - { - if ((*(ptr_lecture + 1)) == '"') - { - if ((*(ptr_lecture + 2)) != d_code_fin_chaine) - { - ptr_lecture++; - } - } - else if ((*(ptr_lecture + 1)) == 'b') - { - if ((*(ptr_lecture + 2)) != d_code_fin_chaine) - { - ptr_lecture++; - (*ptr_lecture) = '\b'; - } - } - else if ((*(ptr_lecture + 1)) == 'n') - { - if ((*(ptr_lecture + 2)) != d_code_fin_chaine) - { - ptr_lecture++; - (*ptr_lecture) = '\n'; - } - } - else if ((*(ptr_lecture + 1)) == 't') - { - if ((*(ptr_lecture + 2)) != d_code_fin_chaine) - { - ptr_lecture++; - (*ptr_lecture) = '\t'; - } - } - else if ((*(ptr_lecture + 1)) == '\\') - { - if ((*(ptr_lecture + 2)) != d_code_fin_chaine) - { - ptr_lecture++; - } - } - } - *ptr_ecriture++ = *ptr_lecture++; } (*(--ptr_ecriture)) = d_code_fin_chaine; - if ((element = realloc(element, (strlen((unsigned char *) - element) + 1) * sizeof(unsigned char))) == NULL) - { - (*s_etat_processus).erreur_systeme = d_es_allocation_memoire; - (*s_etat_processus).traitement_interruptible = - registre_interruption; - return; - } - break; } @@ -2963,8 +2964,20 @@ 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) { + (*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 = registre_mode_execution_programme; nombre_lignes_a_supprimer = @@ -2987,6 +3000,7 @@ recherche_type(struct_processus *s_etat_ (*s_etat_processus).instruction_courante = tampon; + effacement_pile_systeme(s_etat_processus); (*s_etat_processus).l_base_pile_systeme = s_sauvegarde_pile; (*s_etat_processus).niveau_courant = @@ -3011,6 +3025,9 @@ recherche_type(struct_processus *s_etat_ return; } + (*s_etat_processus).autorisation_nom_implicite = + variable_implicite; + (*s_etat_processus).recherche_type = registre_recherche_type; (*s_etat_processus).mode_execution_programme = registre_mode_execution_programme; @@ -3036,6 +3053,7 @@ recherche_type(struct_processus *s_etat_ (*s_etat_processus).instruction_courante = tampon; + effacement_pile_systeme(s_etat_processus); (*s_etat_processus).l_base_pile_systeme = s_sauvegarde_pile; (*s_etat_processus).niveau_courant = @@ -3086,10 +3104,7 @@ recherche_type(struct_processus *s_etat_ nombre_lignes = profondeur_finale - profondeur_initiale; - element = (void *) ((struct_tableau *) malloc( - sizeof(struct_tableau))); - - if (element == NULL) + if ((element = malloc(sizeof(struct_tableau))) == NULL) { (*s_etat_processus).erreur_systeme = d_es_allocation_memoire; @@ -3169,6 +3184,8 @@ recherche_type(struct_processus *s_etat_ d_es_allocation_memoire; } + free(s_objet); + (*s_etat_processus).traitement_interruptible = registre_interruption; return; @@ -3196,95 +3213,6 @@ recherche_type(struct_processus *s_etat_ /* -------------------------------------------------------------------------------- - Adresse --------------------------------------------------------------------------------- -*/ - - case '@' : - { - if ((*s_etat_processus).recherche_types_speciaux == 'Y') - { - if (strlen((*s_etat_processus).instruction_courante) > 2) - { - tampon = (*s_etat_processus).instruction_courante; - - if (((*s_etat_processus).instruction_courante = - malloc((strlen(tampon) + 2) * - sizeof(unsigned char))) == NULL) - { - (*s_etat_processus).erreur_systeme = - d_es_allocation_memoire; - (*s_etat_processus).traitement_interruptible = - registre_interruption; - return; - } - - strcpy((*s_etat_processus).instruction_courante, tampon); - (*s_etat_processus).instruction_courante[0] = '#'; - (*s_etat_processus).instruction_courante - [strlen((*s_etat_processus).instruction_courante) - + 1] = d_code_fin_chaine; - (*s_etat_processus).instruction_courante - [strlen((*s_etat_processus).instruction_courante)] - = 'h'; - - recherche_type(s_etat_processus); - - free((*s_etat_processus).instruction_courante); - (*s_etat_processus).instruction_courante = tampon; - - if (((*s_etat_processus).erreur_systeme == d_es) && - ((*s_etat_processus).erreur_execution == d_ex)) - { - if (depilement(s_etat_processus, - &((*s_etat_processus).l_base_pile), - &s_sous_objet) == d_absence_erreur) - { - if ((*s_sous_objet).type == BIN) - { - (*s_objet).type = ADR; - - if ((element = - malloc(sizeof(unsigned long))) == NULL) - { - (*s_etat_processus).erreur_systeme = - d_es_allocation_memoire; - (*s_etat_processus) - .traitement_interruptible = - registre_interruption; - return; - } - - (*((unsigned long *) element)) = (*((logical8 *) - (*s_sous_objet).objet)); - } - else - { - (*s_etat_processus).erreur_execution = - d_ex_syntaxe; - } - - liberation(s_etat_processus, s_sous_objet); - } - else - { - (*s_etat_processus).traitement_interruptible = - registre_interruption; - return; - } - } - } - else - { - (*s_etat_processus).erreur_execution = d_ex_syntaxe; - } - - break; - } - } - -/* --------------------------------------------------------------------------------- Entier ou réel -------------------------------------------------------------------------------- */ @@ -3505,6 +3433,26 @@ recherche_type(struct_processus *s_etat_ if ((drapeau_valeur_reelle == 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; element = malloc(sizeof(struct_nom)); @@ -3608,7 +3556,8 @@ recherche_type(struct_processus *s_etat_ &((*s_etat_processus).l_base_pile), s_objet) == d_erreur) { (*s_etat_processus).erreur_systeme = d_es_allocation_memoire; - (*s_etat_processus).traitement_interruptible = registre_interruption; + (*s_etat_processus).traitement_interruptible = + registre_interruption; return; }