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

version 1.2, 2010/01/27 22:22:15 version 1.31, 2011/04/11 12:10:10
Line 1 Line 1
 /*  /*
 ================================================================================  ================================================================================
   RPL/2 (R) version 4.0.10    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 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 343  instruction_spawn(struct_processus *s_et Line 348  instruction_spawn(struct_processus *s_et
     pthread_mutex_init(&((*s_argument_thread).mutex), &attributs_mutex);      pthread_mutex_init(&((*s_argument_thread).mutex), &attributs_mutex);
     pthread_mutexattr_destroy(&attributs_mutex);      pthread_mutexattr_destroy(&attributs_mutex);
   
       pthread_mutexattr_init(&attributs_mutex);
       pthread_mutexattr_settype(&attributs_mutex, PTHREAD_MUTEX_RECURSIVE);
       pthread_mutex_init(&((*s_argument_thread).mutex_nombre_references),
               &attributs_mutex);
       pthread_mutexattr_destroy(&attributs_mutex);
   
     (*s_argument_thread).processus_detache = d_faux;      (*s_argument_thread).processus_detache = d_faux;
     (*s_argument_thread).thread_actif = d_faux;      (*s_argument_thread).thread_actif = d_faux;
     (*s_argument_thread).thread_pere = pthread_self();      (*s_argument_thread).thread_pere = pthread_self();
Line 392  instruction_spawn(struct_processus *s_et Line 403  instruction_spawn(struct_processus *s_et
         return;          return;
     }      }
   
   #   ifndef OS2
   #   ifndef Cygwin
     if (pthread_attr_setschedpolicy(&attributs, SCHED_OTHER) != 0)      if (pthread_attr_setschedpolicy(&attributs, SCHED_OTHER) != 0)
     {      {
         (*s_etat_processus).erreur_systeme = d_es_processus;          (*s_etat_processus).erreur_systeme = d_es_processus;
Line 409  instruction_spawn(struct_processus *s_et Line 422  instruction_spawn(struct_processus *s_et
         (*s_etat_processus).erreur_systeme = d_es_processus;          (*s_etat_processus).erreur_systeme = d_es_processus;
         return;          return;
     }      }
   #   endif
   #   endif
   
     /*      /*
      * Création de l'objet à retourner       * Création de l'objet à retourner
Line 454  instruction_spawn(struct_processus *s_et Line 469  instruction_spawn(struct_processus *s_et
   
     (*s_argument_thread).set = set;      (*s_argument_thread).set = set;
     (*s_argument_thread).oldset = oldset;      (*s_argument_thread).oldset = oldset;
       (*s_argument_thread).thread_actif = d_faux;
   
     if (pthread_create(&thread_id, &attributs, lancement_thread,      if (pthread_create(&thread_id, &attributs, lancement_thread,
             s_argument_thread) != 0)              s_argument_thread) != 0)
Line 462  instruction_spawn(struct_processus *s_et Line 478  instruction_spawn(struct_processus *s_et
         return;          return;
     }      }
   
       attente.tv_sec = 0;
       attente.tv_nsec = GRANULARITE_us * 1000;
   
       while((*s_argument_thread).thread_actif == d_faux)
       {
           nanosleep(&attente, NULL);
           INCR_GRANULARITE(attente.tv_nsec);
       }
   
     if (pthread_attr_destroy(&attributs) != 0)      if (pthread_attr_destroy(&attributs) != 0)
     {      {
         (*s_etat_processus).erreur_systeme = d_es_processus;          (*s_etat_processus).erreur_systeme = d_es_processus;
Line 481  instruction_spawn(struct_processus *s_et Line 506  instruction_spawn(struct_processus *s_et
         return;          return;
     }      }
   
   #   ifndef OS2
   #   ifndef Cygwin
     if (pthread_attr_setschedpolicy(&attributs, SCHED_OTHER) != 0)      if (pthread_attr_setschedpolicy(&attributs, SCHED_OTHER) != 0)
     {      {
         (*s_etat_processus).erreur_systeme = d_es_processus;          (*s_etat_processus).erreur_systeme = d_es_processus;
Line 499  instruction_spawn(struct_processus *s_et Line 526  instruction_spawn(struct_processus *s_et
         (*s_etat_processus).erreur_systeme = d_es_processus;          (*s_etat_processus).erreur_systeme = d_es_processus;
         return;          return;
     }      }
   #   endif
   #   endif
   
     // Attente de l'affectation de la grandeur processus.tid par le thread fils.      // Attente de l'affectation de la grandeur processus.tid par le thread fils.
   
Line 795  instruction_sqlconnect(struct_processus Line 824  instruction_sqlconnect(struct_processus
   
 /*  /*
 ================================================================================  ================================================================================
   Fonction 'sqlconnect'    Fonction 'sqldisconnect'
 ================================================================================  ================================================================================
   Entrées :    Entrées :
 --------------------------------------------------------------------------------  --------------------------------------------------------------------------------
Line 883  instruction_sqldisconnect(struct_process Line 912  instruction_sqldisconnect(struct_process
                         "MYSQL") == 0)                          "MYSQL") == 0)
                 {                  {
 #                   ifdef MYSQL_SUPPORT  #                   ifdef MYSQL_SUPPORT
   
                     if ((*((struct_connecteur_sql *) (*(*l_element_courant)                      if ((*((struct_connecteur_sql *) (*(*l_element_courant)
                             .donnee).objet)).descripteur.mysql ==                              .donnee).objet)).descripteur.mysql ==
                             (*((struct_connecteur_sql *) (*s_objet).objet))                              (*((struct_connecteur_sql *) (*s_objet).objet))
Line 894  instruction_sqldisconnect(struct_process Line 924  instruction_sqldisconnect(struct_process
                     {                      {
                         drapeau = d_faux;                          drapeau = d_faux;
                     }                      }
   
 #                   else  #                   else
   
                     if ((*s_etat_processus).langue == 'F')                      if ((*s_etat_processus).langue == 'F')
Line 915  instruction_sqldisconnect(struct_process Line 946  instruction_sqldisconnect(struct_process
                         .type, "POSTGRESQL") == 0)                          .type, "POSTGRESQL") == 0)
                 {                  {
 #                   ifdef POSTGRESQL_SUPPORT  #                   ifdef POSTGRESQL_SUPPORT
   
                     if ((*((struct_connecteur_sql *) (*(*l_element_courant)                      if ((*((struct_connecteur_sql *) (*(*l_element_courant)
                             .donnee).objet)).descripteur.postgresql ==                              .donnee).objet)).descripteur.postgresql ==
                             (*((struct_connecteur_sql *) (*s_objet).objet))                              (*((struct_connecteur_sql *) (*s_objet).objet))
Line 1155  instruction_smphrdecr(struct_processus * Line 1187  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 1218  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 1341  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 1393  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.31


CVSweb interface <joel.bertrand@systella.fr>