Diff for /rpl/src/types.c between versions 1.7 and 1.28

version 1.7, 2010/02/26 19:22:05 version 1.28, 2011/04/11 12:10:13
Line 1 Line 1
 /*  /*
 ================================================================================  ================================================================================
   RPL/2 (R) version 4.0.11    RPL/2 (R) version 4.1.0.prerelease.0
   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;
Line 370  recherche_type(struct_processus *s_etat_ Line 371  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 396  recherche_type(struct_processus *s_etat_ Line 403  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 1161  recherche_type(struct_processus *s_etat_ Line 1169  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 1185  recherche_type(struct_processus *s_etat_ Line 1200  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 1208  recherche_type(struct_processus *s_etat_ Line 1224  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 1233  recherche_type(struct_processus *s_etat_ Line 1251  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 1567  recherche_type(struct_processus *s_etat_ Line 1586  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 1592  recherche_type(struct_processus *s_etat_ Line 1618  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 1616  recherche_type(struct_processus *s_etat_ Line 1643  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 1641  recherche_type(struct_processus *s_etat_ Line 1670  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 2251  recherche_type(struct_processus *s_etat_ Line 2281  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 2287  recherche_type(struct_processus *s_etat_ Line 2318  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).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;                  (*s_etat_processus).erreur_execution = d_ex_syntaxe;
Line 2318  recherche_type(struct_processus *s_etat_ Line 2353  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 2336  recherche_type(struct_processus *s_etat_ Line 2372  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 2366  recherche_type(struct_processus *s_etat_ Line 2403  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 2734  recherche_type(struct_processus *s_etat_ Line 2772  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 2915  recherche_type(struct_processus *s_etat_ Line 2953  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 2939  recherche_type(struct_processus *s_etat_ Line 2983  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 2963  recherche_type(struct_processus *s_etat_ Line 3008  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 2988  recherche_type(struct_processus *s_etat_ Line 3034  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 3038  recherche_type(struct_processus *s_etat_ Line 3085  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 3121  recherche_type(struct_processus *s_etat_ Line 3165  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 3368  recherche_type(struct_processus *s_etat_ Line 3414  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));

Removed from v.1.7  
changed lines
  Added in v.1.28


CVSweb interface <joel.bertrand@systella.fr>