Diff for /rpl/src/instructions_s10.c between versions 1.2 and 1.13

version 1.2, 2010/01/27 22:22:15 version 1.13, 2010/06/02 10:28:45
Line 1 Line 1
 /*  /*
 ================================================================================  ================================================================================
   RPL/2 (R) version 4.0.10    RPL/2 (R) version 4.0.16
   Copyright (C) 1989-2010 Dr. BERTRAND Joël    Copyright (C) 1989-2010 Dr. BERTRAND Joël
   
   This file is part of RPL/2.    This file is part of RPL/2.
Line 111  instruction_spawn(struct_processus *s_et Line 111  instruction_spawn(struct_processus *s_et
      * d'une fonction ou d'une expression RPN.       * d'une fonction ou d'une expression RPN.
      */       */
   
     if (((*s_objet).type != NOM) &&      if (((*s_objet).type != NOM) && ((*s_objet).type != RPN))
             ((*s_objet).type != RPN))  
     {      {
         liberation(s_etat_processus, s_objet);          liberation(s_etat_processus, s_objet);
   
Line 266  instruction_spawn(struct_processus *s_et Line 265  instruction_spawn(struct_processus *s_et
         return;          return;
     }      }
   
       if (sigaddset(&set, SIGFABORT) != 0)
       {
           (*s_etat_processus).erreur_systeme = d_es_processus;
           return;
       }
   
     if (sigaddset(&set, SIGURG) != 0)      if (sigaddset(&set, SIGURG) != 0)
     {      {
         (*s_etat_processus).erreur_systeme = d_es_processus;          (*s_etat_processus).erreur_systeme = d_es_processus;
Line 795  instruction_sqlconnect(struct_processus Line 800  instruction_sqlconnect(struct_processus
   
 /*  /*
 ================================================================================  ================================================================================
   Fonction 'sqlconnect'    Fonction 'sqldisconnect'
 ================================================================================  ================================================================================
   Entrées :    Entrées :
 --------------------------------------------------------------------------------  --------------------------------------------------------------------------------
Line 1155  instruction_smphrdecr(struct_processus * Line 1160  instruction_smphrdecr(struct_processus *
             }              }
         }          }
   
   #       ifndef SEMAPHORES_NOMMES
         if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0)          if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0)
         {          {
             (*s_etat_processus).erreur_systeme = d_es_processus;              (*s_etat_processus).erreur_systeme = d_es_processus;
             return;              return;
         }          }
   #       else
           if (sem_post((*s_etat_processus).semaphore_fork) != 0)
           {
               (*s_etat_processus).erreur_systeme = d_es_processus;
               return;
           }
   #       endif
   
         while(sem_wait((*((struct_semaphore *) (*s_objet_argument).objet))          while(sem_wait((*((struct_semaphore *) (*s_objet_argument).objet))
                 .semaphore) == -1)                  .semaphore) == -1)
Line 1178  instruction_smphrdecr(struct_processus * Line 1191  instruction_smphrdecr(struct_processus *
             }              }
         }          }
   
   #       ifndef SEMAPHORES_NOMMES
         while(sem_wait(&((*s_etat_processus).semaphore_fork)) == -1)          while(sem_wait(&((*s_etat_processus).semaphore_fork)) == -1)
   #       else
           while(sem_wait((*s_etat_processus).semaphore_fork) == -1)
   #       endif
         {          {
             if (errno != EINTR)              if (errno != EINTR)
             {              {
Line 1297  instruction_smphrtrydecr(struct_processu Line 1314  instruction_smphrtrydecr(struct_processu
             }              }
         }          }
   
   #       ifndef SEMAPHORES_NOMMES
         if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0)          if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0)
         {          {
             (*s_etat_processus).erreur_systeme = d_es_processus;              (*s_etat_processus).erreur_systeme = d_es_processus;
             return;              return;
         }          }
   #       else
           if (sem_post((*s_etat_processus).semaphore_fork) != 0)
           {
               (*s_etat_processus).erreur_systeme = d_es_processus;
               return;
           }
   #       endif
   
         (*((integer8 *) (*s_objet_resultat).objet)) = 0;          (*((integer8 *) (*s_objet_resultat).objet)) = 0;
   
Line 1341  instruction_smphrtrydecr(struct_processu Line 1366  instruction_smphrtrydecr(struct_processu
             }              }
         }          }
   
   #       ifndef SEMAPHORES_NOMMES
         while(sem_wait(&((*s_etat_processus).semaphore_fork)) == -1)          while(sem_wait(&((*s_etat_processus).semaphore_fork)) == -1)
   #       else
           while(sem_wait((*s_etat_processus).semaphore_fork) == -1)
   #       endif
         {          {
             if (errno != EINTR)              if (errno != EINTR)
             {              {

Removed from v.1.2  
changed lines
  Added in v.1.13


CVSweb interface <joel.bertrand@systella.fr>