Diff for /rpl/src/instructions_n2.c between versions 1.8 and 1.73

version 1.8, 2010/05/24 10:58:34 version 1.73, 2024/01/17 16:57:15
Line 1 Line 1
 /*  /*
 ================================================================================  ================================================================================
   RPL/2 (R) version 4.0.16    RPL/2 (R) version 4.1.36
   Copyright (C) 1989-2010 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 20 Line 20
 */  */
   
   
 #include "rpl.conv.h"  #include "rpl-conv.h"
   
   
 /*  /*
Line 38 Line 38
 void  void
 instruction_num(struct_processus *s_etat_processus)  instruction_num(struct_processus *s_etat_processus)
 {  {
       integer8                    longueur;
   
     struct_objet                *s_objet_argument;      struct_objet                *s_objet_argument;
     struct_objet                *s_objet_resultat;      struct_objet                *s_objet_resultat;
   
       unsigned char               *chaine;
   
     (*s_etat_processus).erreur_execution = d_ex;      (*s_etat_processus).erreur_execution = d_ex;
   
     if ((*s_etat_processus).affichage_arguments == 'Y')      if ((*s_etat_processus).affichage_arguments == 'Y')
Line 90  instruction_num(struct_processus *s_etat Line 94  instruction_num(struct_processus *s_etat
   
     if ((*s_objet_argument).type == CHN)      if ((*s_objet_argument).type == CHN)
     {      {
         if (strlen((unsigned char *) (*s_objet_argument).objet) != 1)          if (longueur_chaine(s_etat_processus, (unsigned char *)
                   (*s_objet_argument).objet) != 1)
         {          {
             liberation(s_etat_processus, s_objet_argument);              liberation(s_etat_processus, s_objet_argument);
   
Line 98  instruction_num(struct_processus *s_etat Line 103  instruction_num(struct_processus *s_etat
             return;              return;
         }          }
   
           if ((chaine = formateur_flux(s_etat_processus, (unsigned char *)
                   (*s_objet_argument).objet, &longueur)) == NULL)
           {
               (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
               return;
           }
   
         if ((s_objet_resultat = allocation(s_etat_processus, INT)) == NULL)          if ((s_objet_resultat = allocation(s_etat_processus, INT)) == NULL)
         {          {
             (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;              (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
             return;              return;
         }          }
   
         (*((integer8 *) (*s_objet_resultat).objet)) =          (*((integer8 *) (*s_objet_resultat).objet)) = chaine[0];
                 (integer8) ((unsigned char *) (*s_objet_argument).objet)[0];          free(chaine);
     }      }
   
 /*  /*
Line 149  instruction_num(struct_processus *s_etat Line 161  instruction_num(struct_processus *s_etat
 void  void
 instruction_ns(struct_processus *s_etat_processus)  instruction_ns(struct_processus *s_etat_processus)
 {  {
     logical1                    presence_variable;  
   
     long                        i;  
   
     struct_objet                *s_objet_resultat;      struct_objet                *s_objet_resultat;
   
     (*s_etat_processus).erreur_execution = d_ex;      (*s_etat_processus).erreur_execution = d_ex;
Line 194  instruction_ns(struct_processus *s_etat_ Line 202  instruction_ns(struct_processus *s_etat_
         return;          return;
     }      }
   
     if (recherche_variable(s_etat_processus, ds_sdat) == d_faux)      if (recherche_variable_globale(s_etat_processus, ds_sdat) == d_faux)
     {      {
         /*          /*
          * Aucune variable SIGMA           * Aucune variable SIGMA
          */           */
   
         (*s_etat_processus).erreur_systeme = d_es;          (*s_etat_processus).erreur_systeme = d_es;
           (*s_etat_processus).erreur_execution = d_ex;
   
         (*((integer8 *) (*s_objet_resultat).objet)) = 0;          (*((integer8 *) (*s_objet_resultat).objet)) = 0;
     }      }
     else      else
     {      {
         /*          if (((*(*(*s_etat_processus).pointeur_variable_courante).objet)
          * Il existe une variable locale SIGMA. Reste à vérifier l'existence                  .type != MIN) && ((*(*(*s_etat_processus)
          * d'une variable SIGMA globale...                  .pointeur_variable_courante).objet).type != MRL))
          */  
   
         i = (*s_etat_processus).position_variable_courante;  
         presence_variable = d_faux;  
   
         while(i >= 0)  
         {          {
             if ((strcmp((*s_etat_processus).s_liste_variables[i].nom,              liberation(s_etat_processus, s_objet_resultat);
                     ds_sdat) == 0) && ((*s_etat_processus)  
                     .s_liste_variables[i].niveau == 1))  
             {  
                 presence_variable = d_vrai;  
                 break;  
             }  
   
             i--;  
         }  
   
         if (presence_variable == d_faux)              (*s_etat_processus).erreur_execution =
         {                      d_ex_matrice_statistique_invalide;
             (*((integer8 *) (*s_objet_resultat).objet)) = 0;              return;
         }          }
         else  
         {  
             (*s_etat_processus).position_variable_courante = i;  
   
             if (((*s_etat_processus).s_liste_variables[i]).objet == NULL)          (*((integer8 *) (*s_objet_resultat).objet)) =
             {                  (*((struct_matrice *) (*(*(*s_etat_processus)
                 liberation(s_etat_processus, s_objet_resultat);                  .pointeur_variable_courante).objet).objet)).nombre_lignes;
   
                 (*s_etat_processus).erreur_execution = d_ex_variable_partagee;  
                 return;  
             }  
   
             if (((*((*s_etat_processus).s_liste_variables  
                     [(*s_etat_processus).position_variable_courante].objet))  
                     .type != MIN) && ((*((*s_etat_processus)  
                     .s_liste_variables[(*s_etat_processus)  
                     .position_variable_courante].objet)).type != MRL))  
             {  
                 liberation(s_etat_processus, s_objet_resultat);  
   
                 (*s_etat_processus).erreur_execution =  
                         d_ex_matrice_statistique_invalide;  
                 return;  
             }  
   
             (*((integer8 *) (*s_objet_resultat).objet)) =  
                     (*((struct_matrice *) (*((*s_etat_processus)  
                     .s_liste_variables[(*s_etat_processus)  
                     .position_variable_courante].objet)).objet))  
                     .nombre_lignes;  
         }  
     }      }
   
     if (empilement(s_etat_processus, &((*s_etat_processus).l_base_pile),      if (empilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
Line 381  instruction_nrproc(struct_processus *s_e Line 349  instruction_nrproc(struct_processus *s_e
   
     return;      return;
 }  }
   
   
   /*
   ================================================================================
     Fonction 'nbrcpus'
   ================================================================================
     Entrées : structure processus
   --------------------------------------------------------------------------------
     Sorties :
   --------------------------------------------------------------------------------
     Effets de bord : néant
   ================================================================================
   */
   
   void
   instruction_nbrcpus(struct_processus *s_etat_processus)
   {
       struct_objet                *s_objet_resultat;
   
       (*s_etat_processus).erreur_execution = d_ex;
   
       if ((*s_etat_processus).affichage_arguments == 'Y')
       {
           printf("\n  NBRCPUS ");
   
           if ((*s_etat_processus).langue == 'F')
           {
               printf("(nombre de processeurs sur le système)\n\n");
               printf("->  1: %s\n", d_INT);
           }
           else
           {
               printf("(number of processors on system)\n\n");
               printf("->  1: %s\n", d_INT);
           }
   
           return;
       }
       else if ((*s_etat_processus).test_instruction == 'Y')
       {
           (*s_etat_processus).nombre_arguments = -1;
           return;
       }
       
       if (test_cfsf(s_etat_processus, 31) == d_vrai)
       {
           if (empilement_pile_last(s_etat_processus, 0) == d_erreur)
           {
               return;
           }
       }
   
       if ((s_objet_resultat = allocation(s_etat_processus, INT)) == NULL)
       {
           (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
           return;
       }
   
       (*((integer8 *) (*s_objet_resultat).objet)) = omp_get_num_procs();
   
       if (empilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
               s_objet_resultat) == d_erreur)
       {
           return;
       }
   
       return;
   }
   
 // vim: ts=4  // vim: ts=4

Removed from v.1.8  
changed lines
  Added in v.1.73


CVSweb interface <joel.bertrand@systella.fr>