--- rpl/src/types.c 2010/04/21 13:45:51 1.13 +++ rpl/src/types.c 2012/12/18 13:19:40 1.53 @@ -1,7 +1,7 @@ /* ================================================================================ - RPL/2 (R) version 4.0.15 - Copyright (C) 1989-2010 Dr. BERTRAND Joël + RPL/2 (R) version 4.1.12 + Copyright (C) 1989-2012 Dr. BERTRAND Joël This file is part of RPL/2. @@ -20,7 +20,7 @@ */ -#include "rpl.conv.h" +#include "rpl-conv.h" /* @@ -49,6 +49,7 @@ recherche_type(struct_processus *s_etat_ struct_liste_pile_systeme *s_sauvegarde_pile; struct_objet *s_objet; + struct_objet *s_objet_registre; struct_objet *s_sous_objet; logical1 drapeau_chaine; @@ -75,9 +76,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; @@ -99,18 +102,16 @@ recherche_type(struct_processus *s_etat_ void *element; - s_objet = (struct_objet *) malloc(sizeof(struct_objet)); - element = NULL; - nombre_egalites = 0; - i = 0; - - if (s_objet == NULL) + if ((s_objet = allocation(s_etat_processus, NON)) == NULL) { (*s_etat_processus).erreur_systeme = d_es_allocation_memoire; return; } - initialisation_objet(s_objet); + element = NULL; + nombre_egalites = 0; + i = 0; + registre_test = (*s_etat_processus).test_instruction; registre_instruction_valide = (*s_etat_processus).instruction_valide; registre_interruption = (*s_etat_processus).traitement_interruptible; @@ -206,7 +207,7 @@ recherche_type(struct_processus *s_etat_ (*s_etat_processus).test_instruction = 'N'; analyse(s_etat_processus, NULL); (*s_etat_processus).test_instruction = registre_test_bis; - free(s_objet); + liberation(s_etat_processus, s_objet); } else { @@ -271,8 +272,6 @@ recherche_type(struct_processus *s_etat_ case '(' : { - (*s_objet).type = CPL; - element = (void *) ((struct_complexe16 *) malloc( sizeof(struct_complexe16))); @@ -370,8 +369,13 @@ 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; @@ -390,13 +394,14 @@ recherche_type(struct_processus *s_etat_ sauvegarde_longueur_definitions_chainees; free(element); - free(s_objet); + liberation(s_etat_processus, s_objet); (*s_etat_processus).traitement_interruptible = registre_interruption; 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; @@ -424,7 +429,7 @@ recherche_type(struct_processus *s_etat_ { (*s_etat_processus).erreur_execution = d_ex_syntaxe; - free(s_objet); + liberation(s_etat_processus, s_objet); free(element); for(i = 0; i < (unsigned long) nombre_elements_convertis; i++) @@ -465,7 +470,7 @@ recherche_type(struct_processus *s_etat_ (*s_etat_processus).erreur_execution = d_ex_syntaxe; free(element); - free(s_objet); + liberation(s_etat_processus, s_objet); liberation(s_etat_processus, s_sous_objet); @@ -495,7 +500,7 @@ recherche_type(struct_processus *s_etat_ (*s_etat_processus).erreur_execution = d_ex_syntaxe; free(element); - free(s_objet); + liberation(s_etat_processus, s_objet); liberation(s_etat_processus, s_sous_objet); @@ -509,6 +514,7 @@ recherche_type(struct_processus *s_etat_ } } + (*s_objet).type = CPL; break; } @@ -520,8 +526,6 @@ recherche_type(struct_processus *s_etat_ case '#' : { - (*s_objet).type = BIN; - element = (void *) ((logical8 *) malloc( sizeof(logical8))); @@ -572,7 +576,7 @@ recherche_type(struct_processus *s_etat_ if (i != 0) { free(element); - free(s_objet); + liberation(s_etat_processus, s_objet); (*s_etat_processus).erreur_execution = d_ex_syntaxe; @@ -676,7 +680,7 @@ recherche_type(struct_processus *s_etat_ if (i != 0) { free(element); - free(s_objet); + liberation(s_etat_processus, s_objet); (*s_etat_processus).erreur_execution = d_ex_syntaxe; @@ -790,7 +794,7 @@ recherche_type(struct_processus *s_etat_ if (i != 0) { free(element); - free(s_objet); + liberation(s_etat_processus, s_objet); (*s_etat_processus).erreur_execution = d_ex_syntaxe; @@ -934,7 +938,7 @@ recherche_type(struct_processus *s_etat_ if (i != 0) { free(element); - free(s_objet); + liberation(s_etat_processus, s_objet); (*s_etat_processus).erreur_execution = d_ex_syntaxe; @@ -985,7 +989,7 @@ recherche_type(struct_processus *s_etat_ (erreur_lecture_binaire == d_vrai)) { free(element); - free(s_objet); + liberation(s_etat_processus, s_objet); (*s_etat_processus).erreur_execution = d_ex_syntaxe; (*s_etat_processus).traitement_interruptible = @@ -993,6 +997,7 @@ recherche_type(struct_processus *s_etat_ return; } + (*s_objet).type = BIN; break; } @@ -1053,7 +1058,7 @@ recherche_type(struct_processus *s_etat_ if (niveau != 0) { - free(s_objet); + liberation(s_etat_processus, s_objet); (*s_etat_processus).erreur_execution = d_ex_syntaxe; (*s_etat_processus).traitement_interruptible = @@ -1162,8 +1167,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 = @@ -1202,7 +1214,7 @@ recherche_type(struct_processus *s_etat_ (*s_etat_processus).longueur_definitions_chainees = sauvegarde_longueur_definitions_chainees; - free(s_objet); + liberation(s_etat_processus, s_objet); (*s_etat_processus).erreur_execution = d_ex_syntaxe; (*s_etat_processus).traitement_interruptible = @@ -1210,6 +1222,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; @@ -1251,7 +1265,7 @@ recherche_type(struct_processus *s_etat_ (*s_etat_processus).longueur_definitions_chainees = sauvegarde_longueur_definitions_chainees; - free(s_objet); + liberation(s_etat_processus, s_objet); (*s_etat_processus).erreur_execution = d_ex_syntaxe; (*s_etat_processus).traitement_interruptible = @@ -1328,7 +1342,7 @@ recherche_type(struct_processus *s_etat_ } erreur = d_absence_erreur; - free(s_objet); + s_objet_registre = s_objet; for(i = 0; (i < nombre_colonnes) && (erreur == d_absence_erreur); i++) @@ -1425,6 +1439,8 @@ recherche_type(struct_processus *s_etat_ (*s_etat_processus) .traitement_interruptible = registre_interruption; + liberation(s_etat_processus, + s_objet_registre); return; } @@ -1437,6 +1453,7 @@ recherche_type(struct_processus *s_etat_ free((*((struct_vecteur *) element)).tableau); free(element); + liberation(s_etat_processus, s_objet_registre); (*s_etat_processus).traitement_interruptible = registre_interruption; return; @@ -1444,6 +1461,8 @@ recherche_type(struct_processus *s_etat_ } else { + liberation(s_etat_processus, s_objet_registre); + (*s_etat_processus).erreur_systeme = d_es_pile_vide; (*s_etat_processus).traitement_interruptible = registre_interruption; @@ -1451,18 +1470,7 @@ recherche_type(struct_processus *s_etat_ } } - s_objet = (struct_objet *) malloc(sizeof(struct_objet)); - - if (s_objet == NULL) - { - (*s_etat_processus).erreur_systeme = - d_es_allocation_memoire; - (*s_etat_processus).traitement_interruptible = - registre_interruption; - return; - } - - initialisation_objet(s_objet); + s_objet = s_objet_registre; if (drapeau_complexe == d_vrai) { @@ -1570,9 +1578,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 = @@ -1612,7 +1627,7 @@ recherche_type(struct_processus *s_etat_ (*s_etat_processus).position_courante = position_courante; - free(s_objet); + liberation(s_etat_processus, s_objet); (*s_etat_processus).erreur_execution = d_ex_syntaxe; (*s_etat_processus).traitement_interruptible = @@ -1620,6 +1635,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; @@ -1662,7 +1679,7 @@ recherche_type(struct_processus *s_etat_ (*s_etat_processus).position_courante = position_courante; - free(s_objet); + liberation(s_etat_processus, s_objet); (*s_etat_processus).erreur_execution = d_ex_syntaxe; (*s_etat_processus).traitement_interruptible = @@ -1745,7 +1762,7 @@ recherche_type(struct_processus *s_etat_ } free(element); - free(s_objet); + liberation(s_etat_processus, s_objet); (*s_etat_processus).traitement_interruptible = registre_interruption; @@ -1766,7 +1783,7 @@ recherche_type(struct_processus *s_etat_ l_element_courant = (*l_element_courant).suivant; } - free(s_objet); + s_objet_registre = s_objet; if ((*s_etat_processus).erreur_execution == d_ex) { @@ -1777,6 +1794,8 @@ recherche_type(struct_processus *s_etat_ malloc(nombre_lignes * sizeof( struct_complexe16 *)))) == NULL) { + liberation(s_etat_processus, s_objet_registre); + (*s_etat_processus).erreur_systeme = d_es_allocation_memoire; (*s_etat_processus).traitement_interruptible = @@ -1794,6 +1813,9 @@ recherche_type(struct_processus *s_etat_ malloc(nombre_colonnes * sizeof( struct_complexe16)))) == NULL) { + liberation(s_etat_processus, + s_objet_registre); + (*s_etat_processus).erreur_systeme = d_es_allocation_memoire; (*s_etat_processus) @@ -1810,6 +1832,8 @@ recherche_type(struct_processus *s_etat_ malloc(nombre_lignes * sizeof(real8 *)))) == NULL) { + liberation(s_etat_processus, s_objet_registre); + (*s_etat_processus).erreur_systeme = d_es_allocation_memoire; (*s_etat_processus).traitement_interruptible = @@ -1826,6 +1850,9 @@ recherche_type(struct_processus *s_etat_ malloc(nombre_colonnes * sizeof(real8)))) == NULL) { + liberation(s_etat_processus, + s_objet_registre); + (*s_etat_processus).erreur_systeme = d_es_allocation_memoire; (*s_etat_processus) @@ -1842,6 +1869,8 @@ recherche_type(struct_processus *s_etat_ malloc(nombre_lignes * sizeof(integer8 *)))) == NULL) { + liberation(s_etat_processus, s_objet_registre); + (*s_etat_processus).erreur_systeme = d_es_allocation_memoire; (*s_etat_processus).traitement_interruptible = @@ -1859,6 +1888,9 @@ recherche_type(struct_processus *s_etat_ malloc(nombre_colonnes * sizeof(integer8)))) == NULL) { + liberation(s_etat_processus, + s_objet_registre); + (*s_etat_processus).erreur_systeme = d_es_allocation_memoire; (*s_etat_processus) @@ -2001,6 +2033,9 @@ recherche_type(struct_processus *s_etat_ .l_base_pile), &s_objet) == d_erreur) { + liberation(s_etat_processus, + s_objet_registre); + (*s_etat_processus) .traitement_interruptible = registre_interruption; @@ -2024,6 +2059,9 @@ recherche_type(struct_processus *s_etat_ .tableau); free(element); + liberation(s_etat_processus, + s_objet_registre); + (*s_etat_processus) .traitement_interruptible = registre_interruption; @@ -2032,6 +2070,9 @@ recherche_type(struct_processus *s_etat_ } else { + liberation(s_etat_processus, + s_objet_registre); + (*s_etat_processus).erreur_systeme = d_es_pile_vide; (*s_etat_processus).traitement_interruptible = @@ -2040,18 +2081,7 @@ recherche_type(struct_processus *s_etat_ } } - s_objet = (struct_objet *) malloc(sizeof(struct_objet)); - - if (s_objet == NULL) - { - (*s_etat_processus).erreur_systeme = - d_es_allocation_memoire; - (*s_etat_processus).traitement_interruptible = - registre_interruption; - return; - } - - initialisation_objet(s_objet); + s_objet = s_objet_registre; if (drapeau_complexe == d_vrai) { @@ -2261,7 +2291,7 @@ recherche_type(struct_processus *s_etat_ (*s_etat_processus).niveau_courant = sauvegarde_niveau_courant; free((*s_etat_processus).definitions_chainees); - free(s_objet); + liberation(s_etat_processus, s_objet); (*s_etat_processus).definitions_chainees = definitions_chainees_precedentes; @@ -2293,11 +2323,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 @@ -2329,7 +2372,7 @@ recherche_type(struct_processus *s_etat_ (*s_etat_processus).niveau_courant = sauvegarde_niveau_courant; free((*s_etat_processus).definitions_chainees); - free(s_objet); + liberation(s_etat_processus, s_objet); (*s_etat_processus).definitions_chainees = definitions_chainees_precedentes; @@ -2343,6 +2386,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; @@ -2378,7 +2423,7 @@ recherche_type(struct_processus *s_etat_ (*s_etat_processus).niveau_courant = sauvegarde_niveau_courant; free((*s_etat_processus).definitions_chainees); - free(s_objet); + liberation(s_etat_processus, s_objet); (*s_etat_processus).definitions_chainees = definitions_chainees_precedentes; @@ -2418,8 +2463,7 @@ recherche_type(struct_processus *s_etat_ profondeur_finale = (*s_etat_processus).hauteur_pile_operationnelle; l_element_courant = NULL; - - free(s_objet); + s_objet_registre = s_objet; for(i = 0; i < (profondeur_finale - profondeur_initiale); i++) { @@ -2427,6 +2471,7 @@ recherche_type(struct_processus *s_etat_ &((*s_etat_processus).l_base_pile), &s_objet) == d_erreur) { + liberation(s_etat_processus, s_objet_registre); (*s_etat_processus).traitement_interruptible = registre_interruption; return; @@ -2435,23 +2480,14 @@ recherche_type(struct_processus *s_etat_ if (empilement(s_etat_processus, &l_element_courant, s_objet) == d_erreur) { + liberation(s_etat_processus, s_objet_registre); (*s_etat_processus).traitement_interruptible = registre_interruption; return; } } - s_objet = (struct_objet *) malloc(sizeof(struct_objet)); - - if (s_objet == NULL) - { - (*s_etat_processus).erreur_systeme = d_es_allocation_memoire; - (*s_etat_processus).traitement_interruptible = - registre_interruption; - return; - } - - initialisation_objet(s_objet); + s_objet = s_objet_registre; (*s_objet).type = LST; element = (void *) l_element_courant; @@ -2487,7 +2523,7 @@ recherche_type(struct_processus *s_etat_ free(l_element_courant_fonctions); } - free(s_objet); + liberation(s_etat_processus, s_objet); (*s_etat_processus).traitement_interruptible = registre_interruption; @@ -2526,7 +2562,8 @@ recherche_type(struct_processus *s_etat_ * puis on renvoie une erreur. */ - free(s_objet); + (*s_objet).type = NON; + liberation(s_etat_processus, s_objet); l_element_courant = l_base_liste_decomposition; @@ -2827,6 +2864,16 @@ recherche_type(struct_processus *s_etat_ (*(--ptr_ecriture)) = d_code_fin_chaine; + if (validation_chaine((unsigned char *) element) == d_faux) + { + (*s_etat_processus).erreur_execution = d_ex_syntaxe; + (*s_etat_processus).traitement_interruptible = + registre_interruption; + + free(element); + return; + } + break; } @@ -2923,8 +2970,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 = @@ -2964,7 +3023,7 @@ recherche_type(struct_processus *s_etat_ (*s_etat_processus).position_courante = position_courante; - free(s_objet); + liberation(s_etat_processus, s_objet); (*s_etat_processus).erreur_execution = d_ex_syntaxe; (*s_etat_processus).traitement_interruptible = @@ -2972,6 +3031,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; @@ -3014,7 +3076,7 @@ recherche_type(struct_processus *s_etat_ (*s_etat_processus).position_courante = position_courante; - free(s_objet); + liberation(s_etat_processus, s_objet); (*s_etat_processus).erreur_execution = d_ex_syntaxe; (*s_etat_processus).traitement_interruptible = @@ -3095,7 +3157,7 @@ recherche_type(struct_processus *s_etat_ if (strlen((*s_etat_processus).instruction_courante) < 5) { - free(s_objet); + liberation(s_etat_processus, s_objet); (*s_etat_processus).erreur_execution = d_ex_syntaxe; (*s_etat_processus).traitement_interruptible = @@ -3107,7 +3169,7 @@ recherche_type(struct_processus *s_etat_ != 0) && (strcmp((*s_etat_processus) .instruction_courante, "<<") != 0)) { - free(s_objet); + liberation(s_etat_processus, s_objet); (*s_etat_processus).erreur_execution = d_ex_syntaxe; (*s_etat_processus).traitement_interruptible = @@ -3122,14 +3184,13 @@ recherche_type(struct_processus *s_etat_ if (element == NULL) { -// ICI if ((*s_etat_processus).erreur_systeme != d_es) { (*s_etat_processus).erreur_systeme = d_es_allocation_memoire; } - free(s_objet); + liberation(s_etat_processus, s_objet); (*s_etat_processus).traitement_interruptible = registre_interruption; @@ -3378,6 +3439,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) != '$')) + { + liberation(s_etat_processus, 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)); @@ -3437,28 +3518,64 @@ recherche_type(struct_processus *s_etat_ } else { - (*s_objet).type = INT; + // Le format ressemble à un entier mais il peut y avoir + // un dépassement de capacité lors de la conversion. + // On convertit donc en entier et en réel. Si les + // deux conversions donnent le même résultat, on + // considère que la conversion en entier est bonne. Dans + // le cas contraire, on garde la conversion en réel. - element = (void *) ((integer8 *) malloc( - sizeof(integer8))); + integer8 conversion_entiere; + real8 conversion_reelle; - if (element == NULL) + if (sscanf((*s_etat_processus).instruction_courante, "%lg", + &conversion_reelle) != 1) { - (*s_etat_processus).erreur_systeme = - d_es_allocation_memoire; - (*s_etat_processus).traitement_interruptible = - registre_interruption; - return; + (*s_etat_processus).erreur_execution = d_ex_syntaxe; } - nombre_elements_convertis = sscanf( - (*s_etat_processus).instruction_courante, "%lld", - (integer8 *) element); - - if (nombre_elements_convertis != 1) + if (sscanf((*s_etat_processus).instruction_courante, "%lld", + &conversion_entiere) != 1) { (*s_etat_processus).erreur_execution = d_ex_syntaxe; } + + if (abs(nextafter(conversion_reelle, conversion_entiere) + - conversion_reelle) >= abs(conversion_reelle + - conversion_entiere)) + { + (*s_objet).type = INT; + + element = malloc(sizeof(integer8)); + + if (element == NULL) + { + (*s_etat_processus).erreur_systeme = + d_es_allocation_memoire; + (*s_etat_processus).traitement_interruptible = + registre_interruption; + return; + } + + (*((integer8 *) element)) = conversion_entiere; + } + else + { + (*s_objet).type = REL; + + element = malloc(sizeof(real8)); + + if (element == NULL) + { + (*s_etat_processus).erreur_systeme = + d_es_allocation_memoire; + (*s_etat_processus).traitement_interruptible = + registre_interruption; + return; + } + + (*((real8 *) element)) = conversion_reelle; + } } }