Diff for /rpl/src/instructions_w1.c between versions 1.52 and 1.116

version 1.52, 2011/09/26 15:57:16 version 1.116, 2019/02/11 09:45:52
Line 1 Line 1
 /*  /*
 ================================================================================  ================================================================================
   RPL/2 (R) version 4.1.4    RPL/2 (R) version 4.1.31
   Copyright (C) 1989-2011 Dr. BERTRAND Joël    Copyright (C) 1989-2019 Dr. BERTRAND Joël
   
   This file is part of RPL/2.    This file is part of RPL/2.
   
Line 245  instruction_wait(struct_processus *s_eta Line 245  instruction_wait(struct_processus *s_eta
             return;              return;
         }          }
   
         temporisation.tv_sec = (long) floor((double) attente);          temporisation.tv_sec = (time_t) floor((double) attente);
         temporisation.tv_nsec = (attente - temporisation.tv_sec) *          temporisation.tv_nsec = (long) ((attente -
                 (long) 1000000000;                  ((real8) temporisation.tv_sec)) * (integer8) 1000000000);
   
         if ((*s_etat_processus).profilage == d_vrai)          if ((*s_etat_processus).profilage == d_vrai)
         {          {
Line 289  instruction_wait(struct_processus *s_eta Line 289  instruction_wait(struct_processus *s_eta
   
             scrutation_injection(s_etat_processus);              scrutation_injection(s_etat_processus);
   
               if (pthread_mutex_lock(&(*s_etat_processus).mutex_interruptions)
                       != 0)
               {
                   (*s_etat_processus).erreur_systeme = d_es_processus;
                   return;
               }
   
             if ((*s_etat_processus).nombre_interruptions_non_affectees != 0)              if ((*s_etat_processus).nombre_interruptions_non_affectees != 0)
             {              {
                 affectation_interruptions_logicielles(s_etat_processus);                  affectation_interruptions_logicielles(s_etat_processus);
             }              }
   
               if (pthread_mutex_unlock(&(*s_etat_processus).mutex_interruptions)
                       != 0)
               {
                   (*s_etat_processus).erreur_systeme = d_es_processus;
                   return;
               }
   
             if ((*s_etat_processus).nombre_interruptions_en_queue != 0)              if ((*s_etat_processus).nombre_interruptions_en_queue != 0)
             {              {
                 traitement_interruptions_logicielles(s_etat_processus);                  traitement_interruptions_logicielles(s_etat_processus);
Line 385  instruction_write(struct_processus *s_et Line 399  instruction_write(struct_processus *s_et
   
     int                                 adresse[16];      int                                 adresse[16];
     int                                 port;      int                                 port;
       int                                 sqlite_status;
   
     integer8                            clef;      integer8                            clef;
     integer8                            compteur;      integer8                            compteur;
     integer8                            id;      integer8                            id;
       integer8                            longueur;
       integer8                            longueur_effective;
     integer8                            ordre;      integer8                            ordre;
       integer8                            recursivite;
   
       logical1                            format_degenere;
       logical1                            format_oriente_ligne;
     logical1                            mise_a_jour;      logical1                            mise_a_jour;
   
     long                                longueur_effective;  
     long                                recursivite;  
   
     sqlite3_stmt                        *ppStmt;      sqlite3_stmt                        *ppStmt;
   
     ssize_t                             ios;      ssize_t                             ios;
Line 422  instruction_write(struct_processus *s_et Line 439  instruction_write(struct_processus *s_et
   
     struct flock                        lock;      struct flock                        lock;
   
       struct timespec                     attente;
   
     uint32_t                            calcul_adresse;      uint32_t                            calcul_adresse;
   
     unsigned char                       *chaine;      unsigned char                       *chaine;
     unsigned char                       *chaine_utf8;      unsigned char                       *chaine_utf8;
     unsigned char                       *clef_utf8;      unsigned char                       *clef_utf8;
     unsigned char                       *commande;      unsigned char                       *commande;
       unsigned char                       *format_chaine;
   
     unsigned long                       i;      unsigned long                       i;
   
Line 586  instruction_write(struct_processus *s_et Line 606  instruction_write(struct_processus *s_et
                 if ((chaine = formateur_fichier(s_etat_processus,                  if ((chaine = formateur_fichier(s_etat_processus,
                         s_objet_argument_2, (*((struct_fichier *)                          s_objet_argument_2, (*((struct_fichier *)
                         (*s_objet_argument_1).objet)).format, 0, 0, ' ', 'F',                          (*s_objet_argument_1).objet)).format, 0, 0, ' ', 'F',
                         &longueur_effective, &recursivite)) == NULL)                          &longueur_effective, &recursivite, d_vrai)) == NULL)
                 {                  {
                     liberation(s_etat_processus, s_objet_argument_2);                      liberation(s_etat_processus, s_objet_argument_2);
                     liberation(s_etat_processus, s_objet_argument_1);                      liberation(s_etat_processus, s_objet_argument_1);
Line 668  instruction_write(struct_processus *s_et Line 688  instruction_write(struct_processus *s_et
                 if ((chaine = formateur_fichier(s_etat_processus,                  if ((chaine = formateur_fichier(s_etat_processus,
                         s_objet_argument_3, (*((struct_fichier *)                          s_objet_argument_3, (*((struct_fichier *)
                         (*s_objet_argument_1).objet)).format, 0, 0, ' ',                          (*s_objet_argument_1).objet)).format, 0, 0, ' ',
                         'F', &longueur_effective, &recursivite)) == NULL)                          'F', &longueur_effective, &recursivite, d_vrai))
                           == NULL)
                 {                  {
                     liberation(s_etat_processus, s_objet_argument_3);                      liberation(s_etat_processus, s_objet_argument_3);
                     liberation(s_etat_processus, s_objet_argument_2);                      liberation(s_etat_processus, s_objet_argument_2);
Line 691  instruction_write(struct_processus *s_et Line 712  instruction_write(struct_processus *s_et
   
                 free(chaine);                  free(chaine);
   
                 if (alsprintf(&commande, "insert or replace into data "                  if (alsprintf(s_etat_processus, &commande,
                           "insert or replace into data "
                         "(id, data) values (%lld, '%s')", (*((integer8 *)                          "(id, data) values (%lld, '%s')", (*((integer8 *)
                         (*s_objet_argument_2).objet)), chaine_utf8) < 0)                          (*s_objet_argument_2).objet)), chaine_utf8) < 0)
                 {                  {
Line 703  instruction_write(struct_processus *s_et Line 725  instruction_write(struct_processus *s_et
                 free(chaine_utf8);                  free(chaine_utf8);
   
                 if (sqlite3_prepare_v2((*descripteur).descripteur_sqlite,                  if (sqlite3_prepare_v2((*descripteur).descripteur_sqlite,
                         commande, strlen(commande), &ppStmt, &queue)                          commande, (int) strlen(commande), &ppStmt, &queue)
                         != SQLITE_OK)                          != SQLITE_OK)
                 {                  {
                     (*s_etat_processus).erreur_systeme = d_es_erreur_fichier;                      (*s_etat_processus).erreur_systeme = d_es_erreur_fichier;
Line 741  instruction_write(struct_processus *s_et Line 763  instruction_write(struct_processus *s_et
   
                 // Récupération de la position de la clef                  // Récupération de la position de la clef
   
                 if (alsprintf(&commande, "select key from control "                  if (alsprintf(s_etat_processus, &commande,
                         "where id = 1") < 0)                          "select key from control where id = 1") < 0)
                 {                  {
                     (*s_etat_processus).erreur_systeme =                      (*s_etat_processus).erreur_systeme =
                             d_es_allocation_memoire;                              d_es_allocation_memoire;
Line 750  instruction_write(struct_processus *s_et Line 772  instruction_write(struct_processus *s_et
                 }                  }
   
                 if (sqlite3_prepare_v2((*descripteur).descripteur_sqlite,                  if (sqlite3_prepare_v2((*descripteur).descripteur_sqlite,
                         commande, strlen(commande), &ppStmt, &queue)                          commande, (int) strlen(commande), &ppStmt, &queue)
                         != SQLITE_OK)                          != SQLITE_OK)
                 {                  {
                     (*s_etat_processus).erreur_systeme = d_es_erreur_fichier;                      (*s_etat_processus).erreur_systeme = d_es_erreur_fichier;
                     return;                      return;
                 }                  }
   
                 if (sqlite3_step(ppStmt) != SQLITE_ROW)                  attente.tv_sec = 0;
                   attente.tv_nsec = GRANULARITE_us * 1000;
   
                   do
                 {                  {
                     (*s_etat_processus).erreur_systeme = d_es_erreur_fichier;                      sqlite_status = sqlite3_step(ppStmt);
                     return;  
                 }                      if (sqlite_status == SQLITE_ROW)
                       {
                           break;
                       }
                       else if ((sqlite_status == SQLITE_BUSY) ||
                               (sqlite_status == SQLITE_LOCKED))
                       {
                           nanosleep(&attente, NULL);
                           INCR_GRANULARITE(attente.tv_nsec);
                       }
                       else
                       {
                           (*s_etat_processus).erreur_systeme =
                                   d_es_erreur_fichier;
                           return;
                       }
                   } while(sqlite_status != SQLITE_ROW);
   
                 if (sqlite3_column_type(ppStmt, 0) != SQLITE_INTEGER)                  if (sqlite3_column_type(ppStmt, 0) != SQLITE_INTEGER)
                 {                  {
Line 872  instruction_write(struct_processus *s_et Line 913  instruction_write(struct_processus *s_et
   
                 if ((chaine = formateur_fichier(s_etat_processus,                  if ((chaine = formateur_fichier(s_etat_processus,
                         s_element, s_format, 0, 0, ' ',                          s_element, s_format, 0, 0, ' ',
                         'F', &longueur_effective, &recursivite)) == NULL)                          'F', &longueur_effective, &recursivite, d_vrai))
                           == NULL)
                 {                  {
                     liberation(s_etat_processus, s_element);                      liberation(s_etat_processus, s_element);
                     liberation(s_etat_processus, s_format);                      liberation(s_etat_processus, s_format);
Line 898  instruction_write(struct_processus *s_et Line 940  instruction_write(struct_processus *s_et
   
                 // Récupération de l'identifiant de la clef                  // Récupération de l'identifiant de la clef
   
                 if (alsprintf(&commande, "select id from key where key = "                  if (alsprintf(s_etat_processus, &commande,
                         "'%s'", clef_utf8) < 0)                          "select id from key where key = '%s'", clef_utf8) < 0)
                 {                  {
                     (*s_etat_processus).erreur_systeme =                      (*s_etat_processus).erreur_systeme =
                             d_es_allocation_memoire;                              d_es_allocation_memoire;
Line 907  instruction_write(struct_processus *s_et Line 949  instruction_write(struct_processus *s_et
                 }                  }
   
                 if (sqlite3_prepare_v2((*descripteur).descripteur_sqlite,                  if (sqlite3_prepare_v2((*descripteur).descripteur_sqlite,
                         commande, strlen(commande), &ppStmt, &queue)                          commande, (int) strlen(commande), &ppStmt, &queue)
                         != SQLITE_OK)                          != SQLITE_OK)
                 {                  {
                     (*s_etat_processus).erreur_systeme = d_es_erreur_fichier;                      (*s_etat_processus).erreur_systeme = d_es_erreur_fichier;
                     return;                      return;
                 }                  }
   
                 switch(sqlite3_step(ppStmt))                  attente.tv_sec = 0;
                   attente.tv_nsec = GRANULARITE_us * 1000;
   
                   do
                 {                  {
                     case SQLITE_ROW:                      switch(sqlite_status = sqlite3_step(ppStmt))
                     {                      {
                         // Une clef existe.                          case SQLITE_ROW:
                           {
                               // Une clef existe.
   
                         mise_a_jour = d_vrai;                              mise_a_jour = d_vrai;
                         break;                              break;
                     }                          }
   
                     case SQLITE_DONE:                          case SQLITE_DONE:
                     {                          {
                         // Aucune clef n'existe.                              // Aucune clef n'existe.
   
                         mise_a_jour = d_faux;                              mise_a_jour = d_faux;
   
                         if (sqlite3_finalize(ppStmt) != SQLITE_OK)                              if (sqlite3_finalize(ppStmt) != SQLITE_OK)
                         {                              {
                             (*s_etat_processus).erreur_systeme =                                  (*s_etat_processus).erreur_systeme =
                                     d_es_erreur_fichier;                                          d_es_erreur_fichier;
                             return;                                  return;
                         }                              }
   
                         free(commande);                              free(commande);
   
                         if (alsprintf(&commande, "insert into key "                              if (alsprintf(s_etat_processus, &commande,
                                 "(key) values ('%s')", clef_utf8) < 0)                                      "insert into key (key) values ('%s')",
                         {                                      clef_utf8) < 0)
                             (*s_etat_processus).erreur_systeme =                              {
                                     d_es_allocation_memoire;                                  (*s_etat_processus).erreur_systeme =
                             return;                                          d_es_allocation_memoire;
                         }                                  return;
                               }
   
                         if (sqlite3_prepare_v2((*descripteur)                              if (sqlite3_prepare_v2((*descripteur)
                                 .descripteur_sqlite,                                      .descripteur_sqlite, commande,
                                 commande, strlen(commande), &ppStmt, &queue)                                      (int) strlen(commande), &ppStmt, &queue)
                                 != SQLITE_OK)                                      != SQLITE_OK)
                         {                              {
                             (*s_etat_processus).erreur_systeme =                                  (*s_etat_processus).erreur_systeme =
                                     d_es_erreur_fichier;                                          d_es_erreur_fichier;
                             return;                                  return;
                         }                              }
   
                         if (sqlite3_step(ppStmt) != SQLITE_DONE)                              if (sqlite3_step(ppStmt) != SQLITE_DONE)
                         {                              {
                             (*s_etat_processus).erreur_systeme =                                  (*s_etat_processus).erreur_systeme =
                                     d_es_erreur_fichier;                                          d_es_erreur_fichier;
                             return;                                  return;
                         }                              }
   
                         if (sqlite3_finalize(ppStmt) != SQLITE_OK)                              if (sqlite3_finalize(ppStmt) != SQLITE_OK)
                         {                              {
                             (*s_etat_processus).erreur_systeme =                                  (*s_etat_processus).erreur_systeme =
                                     d_es_erreur_fichier;                                          d_es_erreur_fichier;
                             return;                                  return;
                         }                              }
   
                         free(commande);                              free(commande);
   
                         if (alsprintf(&commande, "select id from key "                              if (alsprintf(s_etat_processus, &commande,
                                 "where key = '%s'", clef_utf8) < 0)                                      "select id from key where key = '%s'",
                         {                                      clef_utf8) < 0)
                             (*s_etat_processus).erreur_systeme =                              {
                                     d_es_allocation_memoire;                                  (*s_etat_processus).erreur_systeme =
                             return;                                          d_es_allocation_memoire;
                                   return;
                               }
   
                               if (sqlite3_prepare_v2((*descripteur)
                                       .descripteur_sqlite, commande,
                                       (int) strlen(commande), &ppStmt, &queue)
                                       != SQLITE_OK)
                               {
                                   (*s_etat_processus).erreur_systeme =
                                           d_es_erreur_fichier;
                                   return;
                               }
   
                               break;
                         }                          }
   
                         if (sqlite3_prepare_v2((*descripteur)                          case SQLITE_BUSY:
                                 .descripteur_sqlite,                          case SQLITE_LOCKED:
                                 commande, strlen(commande), &ppStmt, &queue)  
                                 != SQLITE_OK)  
                         {                          {
                             (*s_etat_processus).erreur_systeme =                              nanosleep(&attente, NULL);
                                     d_es_erreur_fichier;                              INCR_GRANULARITE(attente.tv_nsec);
                             return;                              break;
                         }                          }
   
                         if (sqlite3_step(ppStmt) != SQLITE_ROW)                          default:
                         {                          {
                             (*s_etat_processus).erreur_systeme =                              (*s_etat_processus).erreur_systeme =
                                     d_es_erreur_fichier;                                      d_es_erreur_fichier;
                             return;                              return;
                         }                          }
   
                         break;  
                     }                      }
                   } while(sqlite_status != SQLITE_ROW);
                     default:  
                     {  
                         (*s_etat_processus).erreur_systeme =  
                                 d_es_erreur_fichier;  
                         return;  
                     }  
                 }  
   
                 if (sqlite3_column_type(ppStmt, 0) != SQLITE_INTEGER)                  if (sqlite3_column_type(ppStmt, 0) != SQLITE_INTEGER)
                 {                  {
Line 1035  instruction_write(struct_processus *s_et Line 1086  instruction_write(struct_processus *s_et
   
                 if (mise_a_jour == d_vrai)                  if (mise_a_jour == d_vrai)
                 {                  {
                     if (alsprintf(&commande, "update key set key = '%s' where "                      if (alsprintf(s_etat_processus, &commande,
                             "id = %lld", clef_utf8, id) < 0)                              "update key set key = '%s' where id = %lld",
                               clef_utf8, id) < 0)
                     {                      {
                         (*s_etat_processus).erreur_systeme =                          (*s_etat_processus).erreur_systeme =
                                 d_es_allocation_memoire;                                  d_es_allocation_memoire;
Line 1044  instruction_write(struct_processus *s_et Line 1096  instruction_write(struct_processus *s_et
                     }                      }
   
                     if (sqlite3_prepare_v2((*descripteur).descripteur_sqlite,                      if (sqlite3_prepare_v2((*descripteur).descripteur_sqlite,
                             commande, strlen(commande), &ppStmt, &queue)                              commande, (int) strlen(commande), &ppStmt, &queue)
                             != SQLITE_OK)                              != SQLITE_OK)
                     {                      {
                         (*s_etat_processus).erreur_systeme =                          (*s_etat_processus).erreur_systeme =
Line 1071  instruction_write(struct_processus *s_et Line 1123  instruction_write(struct_processus *s_et
   
                 // Effacement de l'enregistrement existant                  // Effacement de l'enregistrement existant
   
                 if (alsprintf(&commande, "delete from data where "                  if (alsprintf(s_etat_processus, &commande,
                         "key_id = %lld", id) < 0)                          "delete from data where key_id = %lld", id) < 0)
                 {                  {
                     (*s_etat_processus).erreur_systeme =                      (*s_etat_processus).erreur_systeme =
                             d_es_allocation_memoire;                              d_es_allocation_memoire;
Line 1080  instruction_write(struct_processus *s_et Line 1132  instruction_write(struct_processus *s_et
                 }                  }
   
                 if (sqlite3_prepare_v2((*descripteur).descripteur_sqlite,                  if (sqlite3_prepare_v2((*descripteur).descripteur_sqlite,
                         commande, strlen(commande), &ppStmt, &queue)                          commande, (int) strlen(commande), &ppStmt, &queue)
                         != SQLITE_OK)                          != SQLITE_OK)
                 {                  {
                     (*s_etat_processus).erreur_systeme = d_es_erreur_fichier;                      (*s_etat_processus).erreur_systeme = d_es_erreur_fichier;
Line 1179  instruction_write(struct_processus *s_et Line 1231  instruction_write(struct_processus *s_et
   
                     if ((chaine = formateur_fichier(s_etat_processus,                      if ((chaine = formateur_fichier(s_etat_processus,
                             s_element, s_format, 0, 0, ' ',                              s_element, s_format, 0, 0, ' ',
                             'F', &longueur_effective, &recursivite)) == NULL)                              'F', &longueur_effective, &recursivite, d_vrai))
                               == NULL)
                     {                      {
                         free(clef_utf8);                          free(clef_utf8);
   
Line 1205  instruction_write(struct_processus *s_et Line 1258  instruction_write(struct_processus *s_et
   
                     free(chaine);                      free(chaine);
   
                     if (alsprintf(&commande, "insert into data "                      if (alsprintf(s_etat_processus, &commande,
                             "(data, key_id, sequence) values "                              "insert into data (data, key_id, sequence) values "
                             "('%s', %lld, %lld)", chaine_utf8, id, ordre) < 0)                              "('%s', %lld, %lld)", chaine_utf8, id, ordre) < 0)
                     {                      {
                         (*s_etat_processus).erreur_systeme =                          (*s_etat_processus).erreur_systeme =
Line 1215  instruction_write(struct_processus *s_et Line 1268  instruction_write(struct_processus *s_et
                     }                      }
   
                     if (sqlite3_prepare_v2((*descripteur).descripteur_sqlite,                      if (sqlite3_prepare_v2((*descripteur).descripteur_sqlite,
                             commande, strlen(commande), &ppStmt, &queue)                              commande, (int) strlen(commande), &ppStmt, &queue)
                             != SQLITE_OK)                              != SQLITE_OK)
                     {                      {
                         (*s_etat_processus).erreur_systeme =                          (*s_etat_processus).erreur_systeme =
Line 1272  instruction_write(struct_processus *s_et Line 1325  instruction_write(struct_processus *s_et
              * Fichiers non formatés               * Fichiers non formatés
              */               */
   
             if ((chaine = formateur_fichier(s_etat_processus,  
                     s_objet_argument_2, (*((struct_fichier *)  
                     (*s_objet_argument_1).objet)).format, 0, 0, ' ', 'U',  
                     &longueur_effective, &recursivite)) == NULL)  
             {  
                 liberation(s_etat_processus, s_objet_argument_2);  
                 liberation(s_etat_processus, s_objet_argument_1);  
   
                 return;  
             }  
   
             if ((*((struct_fichier *) (*s_objet_argument_1).objet)).acces              if ((*((struct_fichier *) (*s_objet_argument_1).objet)).acces
                     == 'S')                      == 'S')
             {              {
                   if ((*s_objet_argument_2).type != LST)
                   {
                       liberation(s_etat_processus, s_objet_argument_2);
                       liberation(s_etat_processus, s_objet_argument_1);
   
                       (*s_etat_processus).erreur_execution =
                               d_ex_erreur_type_argument;
                       return;
                   }
   
                   if ((chaine = formateur_fichier(s_etat_processus,
                           s_objet_argument_2, (*((struct_fichier *)
                           (*s_objet_argument_1).objet)).format, 0, 0, ' ', 'U',
                           &longueur_effective, &recursivite, d_vrai)) == NULL)
                   {
                       liberation(s_etat_processus, s_objet_argument_2);
                       liberation(s_etat_processus, s_objet_argument_1);
   
                       return;
                   }
   
                 BUG(((*descripteur).type != 'C'), uprintf("Bad filetype !\n"));                  BUG(((*descripteur).type != 'C'), uprintf("Bad filetype !\n"));
   
                 if (fseek((*descripteur).descripteur_c, (long) 0, SEEK_END)                  if (fseek((*descripteur).descripteur_c, (long) 0, SEEK_END)
Line 1298  instruction_write(struct_processus *s_et Line 1361  instruction_write(struct_processus *s_et
                     return;                      return;
                 }                  }
   
                 if (fwrite(chaine, sizeof(unsigned char), longueur_effective,                  if (fwrite(chaine, sizeof(unsigned char),
                           (size_t) longueur_effective,
                         (*descripteur).descripteur_c) !=                          (*descripteur).descripteur_c) !=
                         (size_t) longueur_effective)                          (size_t) longueur_effective)
                 {                  {
Line 1309  instruction_write(struct_processus *s_et Line 1373  instruction_write(struct_processus *s_et
             else if ((*((struct_fichier *) (*s_objet_argument_1).objet)).acces              else if ((*((struct_fichier *) (*s_objet_argument_1).objet)).acces
                     == 'D')                      == 'D')
             {              {
                   if ((*s_objet_argument_2).type != INT)
                   {
                       liberation(s_etat_processus, s_objet_argument_2);
                       liberation(s_etat_processus, s_objet_argument_1);
   
                       (*s_etat_processus).erreur_execution =
                               d_ex_erreur_type_argument;
                       return;
                   }
   
                   if (depilement(s_etat_processus, &((*s_etat_processus)
                           .l_base_pile), &s_objet_argument_3) == d_erreur)
                   {
                       (*s_etat_processus).erreur_execution = d_ex_manque_argument;
                       return;
                   }
   
                   if ((*s_objet_argument_3).type != LST)
                   {
                       liberation(s_etat_processus, s_objet_argument_3);
                       liberation(s_etat_processus, s_objet_argument_2);
                       liberation(s_etat_processus, s_objet_argument_1);
   
                       (*s_etat_processus).erreur_execution =
                               d_ex_erreur_type_argument;
                       return;
                   }
   
                   if ((chaine = formateur_fichier(s_etat_processus,
                           s_objet_argument_2, (*((struct_fichier *)
                           (*s_objet_argument_1).objet)).format, 0, 0, ' ', 'U',
                           &longueur_effective, &recursivite, d_faux)) == NULL)
                   {
                       liberation(s_etat_processus, s_objet_argument_2);
                       liberation(s_etat_processus, s_objet_argument_1);
   
                       return;
                   }
             }              }
             else              else // Fichiers indexés
             {              {
                 /* Fichiers indexés : panique totale ! */                  if ((*s_objet_argument_2).type != LST)
                   {
                       liberation(s_etat_processus, s_objet_argument_2);
                       liberation(s_etat_processus, s_objet_argument_1);
   
                       (*s_etat_processus).erreur_execution =
                               d_ex_erreur_type_argument;
                       return;
                   }
   
                   if ((chaine = formateur_fichier(s_etat_processus,
                           s_objet_argument_2, (*((struct_fichier *)
                           (*s_objet_argument_1).objet)).format, 0, 0, ' ', 'U',
                           &longueur_effective, &recursivite, d_faux)) == NULL)
                   {
                       liberation(s_etat_processus, s_objet_argument_2);
                       liberation(s_etat_processus, s_objet_argument_1);
   
                       return;
                   }
             }              }
   
             free(chaine);              free(chaine);
Line 1328  instruction_write(struct_processus *s_et Line 1449  instruction_write(struct_processus *s_et
             {              {
                 BUG(((*descripteur).type != 'C'), uprintf("Bad filetype !\n"));                  BUG(((*descripteur).type != 'C'), uprintf("Bad filetype !\n"));
   
                 if ((*((*((struct_liste_chainee *) (*s_objet_argument_2).objet))                  if ((*s_objet_argument_2).type != LST)
                         .donnee)).type != CHN)  
                 {                  {
                     liberation(s_etat_processus, s_objet_argument_2);                      liberation(s_etat_processus, s_objet_argument_2);
                     liberation(s_etat_processus, s_objet_argument_1);                      liberation(s_etat_processus, s_objet_argument_1);
Line 1339  instruction_write(struct_processus *s_et Line 1459  instruction_write(struct_processus *s_et
                     return;                      return;
                 }                  }
   
                 if ((chaine = formateur_flux(s_etat_processus, (unsigned char *)                  if ((*((struct_liste_chainee *) (*s_objet_argument_2).objet))
                         (*((*((struct_liste_chainee *) (*s_objet_argument_2)                          .donnee == NULL)
                         .objet)).donnee)).objet, &longueur_effective)) == NULL)  
                 {                  {
                     (*s_etat_processus).erreur_systeme =                      liberation(s_etat_processus, s_objet_argument_2);
                             d_es_allocation_memoire;                      liberation(s_etat_processus, s_objet_argument_1);
   
                       (*s_etat_processus).erreur_execution =
                               d_ex_erreur_type_argument;
                     return;                      return;
                 }                  }
   
                 if (fwrite(chaine, sizeof(unsigned char), longueur_effective,                  l_element_courant = (*s_objet_argument_2).objet;
                         (*descripteur).descripteur_c) !=                  l_element_courant_format = (struct_liste_chainee *)
                         (size_t) longueur_effective)                          (*(*((struct_fichier *) (*s_objet_argument_1).objet))
                           .format).objet;
   
                   while((l_element_courant != NULL) &&
                           (l_element_courant_format != NULL))
                 {                  {
                     (*s_etat_processus).erreur_systeme = d_es_erreur_fichier;                      if ((*(*l_element_courant).donnee).type != CHN)
                     return;                      {
                           liberation(s_etat_processus, s_objet_argument_2);
                           liberation(s_etat_processus, s_objet_argument_1);
   
                           (*s_etat_processus).erreur_execution =
                                   d_ex_erreur_type_argument;
                           return;
                       }
   
                       if ((*(*l_element_courant_format).donnee).type != CHN)
                       {
                           liberation(s_etat_processus, s_objet_argument_2);
                           liberation(s_etat_processus, s_objet_argument_1);
   
                           (*s_etat_processus).erreur_execution =
                                   d_ex_erreur_type_argument;
                           return;
                       }
   
                       if ((format_chaine = conversion_majuscule(s_etat_processus,
                               (unsigned char *) (*(*l_element_courant_format)
                               .donnee).objet)) == NULL)
                       {
                           (*s_etat_processus).erreur_systeme =
                                   d_es_allocation_memoire;
                           return;
                       }
   
                       if (strcmp("LINE*(*)", format_chaine) == 0)
                       {
                           format_oriente_ligne = d_vrai;
                           format_degenere = d_vrai;
                       }
                       else
                       {
                           format_oriente_ligne = d_faux;
                           
                           if (strncmp("LENGTH*(", format_chaine, 8) != 0)
                           {
                               free(format_chaine);
   
                               liberation(s_etat_processus, s_objet_argument_2);
                               liberation(s_etat_processus, s_objet_argument_1);
   
                               (*s_etat_processus).erreur_execution =
                                       d_ex_erreur_format_fichier;
                               return;
                           }
   
                           longueur = (integer8) strlen(format_chaine);
   
                           if (format_chaine[longueur - 1] != ')')
                           {
                               free(format_chaine);
   
                               liberation(s_etat_processus, s_objet_argument_2);
                               liberation(s_etat_processus, s_objet_argument_1);
   
                               (*s_etat_processus).erreur_execution =
                                       d_ex_erreur_format_fichier;
                               return;
                           }
   
                           format_chaine[longueur] = d_code_fin_chaine;
   
                           if (format_chaine[8] == '*')
                           {
                               format_degenere = d_vrai;
                           }
                           else
                           {
                               // Détermination de la longueur
                               format_degenere = d_faux;
   
                               if (sscanf(&(format_chaine[8]), "%lld", &longueur)
                                       != 1)
                               {
                                   free(format_chaine);
   
                                   liberation(s_etat_processus,
                                           s_objet_argument_2);
                                   liberation(s_etat_processus,
                                           s_objet_argument_1);
   
                                   (*s_etat_processus).erreur_execution =
                                           d_ex_erreur_format_fichier;
                                   return;
                               }
                           }
                       }
   
                       free(format_chaine);
   
                       if ((chaine = formateur_flux(s_etat_processus,
                               (unsigned char *) (*(*l_element_courant).donnee)
                               .objet, &longueur_effective)) == NULL)
                       {
                           (*s_etat_processus).erreur_systeme =
                                   d_es_allocation_memoire;
                           return;
                       }
   
                       if ((format_degenere == d_vrai) ||
                               (longueur_effective < longueur))
                       {
                           if (fwrite(chaine, sizeof(unsigned char),
                                   (size_t) longueur_effective,
                                   (*descripteur).descripteur_c) !=
                                   (size_t) longueur_effective)
                           {
                               (*s_etat_processus).erreur_systeme =
                                       d_es_erreur_fichier;
                               return;
                           }
                       }
                       else
                       {
                           if (fwrite(chaine, sizeof(unsigned char),
                                   (size_t) longueur_effective,
                                   (*descripteur).descripteur_c) !=
                                   (size_t) longueur)
                           {
                               (*s_etat_processus).erreur_systeme =
                                       d_es_erreur_fichier;
                               return;
                           }
                       }
   
                       free(chaine);
   
                       if (format_oriente_ligne == d_vrai)
                       {
                           if (fwrite("\n", 1, 1, (*descripteur).descripteur_c)
                                   != 1)
                           {
                               (*s_etat_processus).erreur_systeme =
                                       d_es_erreur_fichier;
                               return;
                           }
                       }
   
                       l_element_courant = (*l_element_courant).suivant;
                       l_element_courant_format = (*l_element_courant_format)
                               .suivant;
                 }                  }
   
                 free(chaine);                  if ((l_element_courant_format != NULL) ||
                           (l_element_courant != NULL))
                   {
                       liberation(s_etat_processus, s_objet_argument_2);
                       liberation(s_etat_processus, s_objet_argument_1);
   
                       (*s_etat_processus).erreur_execution =
                               d_ex_erreur_format_fichier;
                       return;
                   }
             }              }
             else              else
             {              {
Line 1395  instruction_write(struct_processus *s_et Line 1673  instruction_write(struct_processus *s_et
             if ((chaine = formateur_fichier(s_etat_processus,              if ((chaine = formateur_fichier(s_etat_processus,
                     s_objet_argument_2, (*((struct_socket *)                      s_objet_argument_2, (*((struct_socket *)
                     (*s_objet_argument_1).objet)).format, 0, 0, ' ', 'F',                      (*s_objet_argument_1).objet)).format, 0, 0, ' ', 'F',
                     &longueur_effective, &recursivite)) == NULL)                      &longueur_effective, &recursivite, d_faux)) == NULL)
             {              {
                 liberation(s_etat_processus, s_objet_argument_2);                  liberation(s_etat_processus, s_objet_argument_2);
                 liberation(s_etat_processus, s_objet_argument_1);                  liberation(s_etat_processus, s_objet_argument_1);
Line 1410  instruction_write(struct_processus *s_et Line 1688  instruction_write(struct_processus *s_et
              * Sockets non formatées               * Sockets non formatées
              */               */
   
             chaine = NULL;              if ((chaine = formateur_fichier(s_etat_processus,
                       s_objet_argument_2, (*((struct_socket *)
                       (*s_objet_argument_1).objet)).format, 0, 0, ' ', 'U',
                       &longueur_effective, &recursivite, d_faux)) == NULL)
               {
                   liberation(s_etat_processus, s_objet_argument_2);
                   liberation(s_etat_processus, s_objet_argument_1);
   
                   return;
               }
         }          }
         else          else
         {          {
Line 1445  instruction_write(struct_processus *s_et Line 1732  instruction_write(struct_processus *s_et
                 (*s_objet_argument_1).objet)).type,                  (*s_objet_argument_1).objet)).type,
                 "SEQUENTIAL DATAGRAM") == 0))                  "SEQUENTIAL DATAGRAM") == 0))
         { // Sockets connectées          { // Sockets connectées
               if (pthread_mutex_lock(&mutex_sigaction) != 0)
               {
                   (*s_etat_processus).erreur_systeme = d_es_processus;
                   return;
               }
   
             action.sa_handler = SIG_IGN;              action.sa_handler = SIG_IGN;
             action.sa_flags = SA_ONSTACK;              action.sa_flags = 0;
   
             if (sigaction(SIGPIPE, &action, &registre) != 0)              if (sigaction(SIGPIPE, &action, &registre) != 0)
             {              {
                   pthread_mutex_unlock(&mutex_sigaction);
                 (*s_etat_processus).erreur_systeme = d_es_signal;                  (*s_etat_processus).erreur_systeme = d_es_signal;
                 return;                  return;
             }              }
Line 1463  instruction_write(struct_processus *s_et Line 1756  instruction_write(struct_processus *s_et
             {              {
                 if (sigaction(SIGPIPE, &registre, NULL) != 0)                  if (sigaction(SIGPIPE, &registre, NULL) != 0)
                 {                  {
                       pthread_mutex_unlock(&mutex_sigaction);
                     (*s_etat_processus).erreur_systeme = d_es_signal;                      (*s_etat_processus).erreur_systeme = d_es_signal;
                     return;                      return;
                 }                  }
   
                   pthread_mutex_unlock(&mutex_sigaction);
                 (*s_etat_processus).erreur_systeme = d_es_processus;                  (*s_etat_processus).erreur_systeme = d_es_processus;
                 return;                  return;
             }              }
   
             if (send((*((struct_socket *) (*s_objet_argument_1).objet))              if (send((*((struct_socket *) (*s_objet_argument_1).objet))
                     .socket, chaine, longueur_effective, 0) < 0)                      .socket, chaine, (size_t) longueur_effective, 0) < 0)
             {              {
                 ios = errno;                  ios = errno;
   
                 if (sigaction(SIGPIPE, &registre, NULL) != 0)                  if (sigaction(SIGPIPE, &registre, NULL) != 0)
                 {                  {
                       pthread_mutex_unlock(&mutex_sigaction);
                     (*s_etat_processus).erreur_systeme = d_es_signal;                      (*s_etat_processus).erreur_systeme = d_es_signal;
                     return;                      return;
                 }                  }
   
                   if (pthread_mutex_unlock(&mutex_sigaction) != 0)
                   {
                       (*s_etat_processus).erreur_systeme = d_es_processus;
                       return;
                   }
   
 #               ifndef SEMAPHORES_NOMMES  #               ifndef SEMAPHORES_NOMMES
                     while(sem_wait(&((*s_etat_processus).semaphore_fork)) != 0)                      while(sem_wait(&((*s_etat_processus).semaphore_fork)) != 0)
 #               else  #               else
Line 1516  instruction_write(struct_processus *s_et Line 1818  instruction_write(struct_processus *s_et
                 {                  {
                     if (sigaction(SIGPIPE, &registre, NULL) != 0)                      if (sigaction(SIGPIPE, &registre, NULL) != 0)
                     {                      {
                           pthread_mutex_unlock(&mutex_sigaction);
                         (*s_etat_processus).erreur_systeme = d_es_signal;                          (*s_etat_processus).erreur_systeme = d_es_signal;
                         return;                          return;
                     }                      }
   
                       pthread_mutex_unlock(&mutex_sigaction);
                     (*s_etat_processus).erreur_systeme = d_es_processus;                      (*s_etat_processus).erreur_systeme = d_es_processus;
                     return;                      return;
                 }                  }
Line 1527  instruction_write(struct_processus *s_et Line 1831  instruction_write(struct_processus *s_et
   
             if (sigaction(SIGPIPE, &registre, NULL) != 0)              if (sigaction(SIGPIPE, &registre, NULL) != 0)
             {              {
                   pthread_mutex_unlock(&mutex_sigaction);
                 (*s_etat_processus).erreur_systeme = d_es_signal;                  (*s_etat_processus).erreur_systeme = d_es_signal;
                 return;                  return;
             }              }
   
               if (pthread_mutex_unlock(&mutex_sigaction) != 0)
               {
                   (*s_etat_processus).erreur_systeme = d_es_processus;
                   return;
               }
         }          }
         else          else
         { // Sockets non connectées          { // Sockets non connectées
Line 1575  instruction_write(struct_processus *s_et Line 1886  instruction_write(struct_processus *s_et
   
                 if (sendto((*((struct_socket *)                  if (sendto((*((struct_socket *)
                         (*s_objet_argument_1).objet)).socket, chaine,                          (*s_objet_argument_1).objet)).socket, chaine,
                         longueur_effective, 0, (struct sockaddr *)                          (size_t) longueur_effective, 0, (struct sockaddr *)
                         &adresse_unix, sizeof(adresse_unix)) < 0)                          &adresse_unix, sizeof(adresse_unix)) < 0)
                 {                  {
                     ios = errno;                      ios = errno;
Line 1601  instruction_write(struct_processus *s_et Line 1912  instruction_write(struct_processus *s_et
                         return;                          return;
                     }                      }
   
                       if (ios == EMSGSIZE)
                       {
                           (*s_etat_processus).erreur_execution =
                                   d_ex_taille_message;
                           return;
                       }
   
                     (*s_etat_processus).erreur_systeme = d_es_erreur_fichier;                      (*s_etat_processus).erreur_systeme = d_es_erreur_fichier;
                     return;                      return;
Line 1630  instruction_write(struct_processus *s_et Line 1947  instruction_write(struct_processus *s_et
                 { // Adresse IPv4                  { // Adresse IPv4
                     calcul_adresse = 0;                      calcul_adresse = 0;
                     for(i = 0; i < 4; calcul_adresse =                      for(i = 0; i < 4; calcul_adresse =
                             (256 * calcul_adresse) + adresse[i++]);                              (256 * calcul_adresse) +
                               ((unsigned char) adresse[i++]));
   
                     memset(&adresse_ipv4, 0, sizeof(adresse_ipv4));                      memset(&adresse_ipv4, 0, sizeof(adresse_ipv4));
                     adresse_ipv4.sin_family = AF_INET;                      adresse_ipv4.sin_family = AF_INET;
                     adresse_ipv4.sin_port = htons(port);                      adresse_ipv4.sin_port = htons((uint16_t) port);
                     adresse_ipv4.sin_addr.s_addr = htonl(calcul_adresse);                      adresse_ipv4.sin_addr.s_addr = htonl(calcul_adresse);
   
 #                   ifndef SEMAPHORES_NOMMES  #                   ifndef SEMAPHORES_NOMMES
Line 1650  instruction_write(struct_processus *s_et Line 1968  instruction_write(struct_processus *s_et
   
                     if (sendto((*((struct_socket *)                      if (sendto((*((struct_socket *)
                             (*s_objet_argument_1).objet)).socket, chaine,                              (*s_objet_argument_1).objet)).socket, chaine,
                             longueur_effective, 0, (struct sockaddr *)                              (size_t) longueur_effective, 0, (struct sockaddr *)
                             &adresse_ipv4, sizeof(adresse_ipv4)) < 0)                              &adresse_ipv4, sizeof(adresse_ipv4)) < 0)
                     {                      {
                           ios = errno;
   
 #                       ifndef SEMAPHORES_NOMMES  #                       ifndef SEMAPHORES_NOMMES
                             while(sem_wait(&((*s_etat_processus)                              while(sem_wait(&((*s_etat_processus)
                                     .semaphore_fork)) != 0)                                      .semaphore_fork)) != 0)
Line 1669  instruction_write(struct_processus *s_et Line 1989  instruction_write(struct_processus *s_et
                             }                              }
                         }                          }
   
                           if ((ios == EPIPE) || (ios == ECONNRESET))
                           {
                               (*s_etat_processus).erreur_execution =
                                       d_ex_erreur_acces_fichier;
                               return;
                           }
   
                           if (ios == EMSGSIZE)
                           {
                               (*s_etat_processus).erreur_execution =
                                       d_ex_taille_message;
                               return;
                           }
   
                         (*s_etat_processus).erreur_systeme =                          (*s_etat_processus).erreur_systeme =
                                 d_es_erreur_fichier;                                  d_es_erreur_fichier;
                         return;                          return;
Line 1718  instruction_write(struct_processus *s_et Line 2052  instruction_write(struct_processus *s_et
   
                     for(i = 0; i < 16;                      for(i = 0; i < 16;
                             adresse_ipv6.sin6_addr.s6_addr[i] =                              adresse_ipv6.sin6_addr.s6_addr[i] =
                             adresse[i], i++);                              (unsigned char) adresse[i], i++);
   
 #                   ifndef SEMAPHORES_NOMMES  #                   ifndef SEMAPHORES_NOMMES
                         if (sem_post(&((*s_etat_processus).semaphore_fork))                          if (sem_post(&((*s_etat_processus).semaphore_fork))
Line 1733  instruction_write(struct_processus *s_et Line 2067  instruction_write(struct_processus *s_et
   
                     if (sendto((*((struct_socket *)                      if (sendto((*((struct_socket *)
                             (*s_objet_argument_1).objet)).socket, chaine,                              (*s_objet_argument_1).objet)).socket, chaine,
                             longueur_effective, 0, (struct sockaddr *)                              (size_t) longueur_effective, 0, (struct sockaddr *)
                             &adresse_ipv6, sizeof(adresse_ipv6)) < 0)                              &adresse_ipv6, sizeof(adresse_ipv6)) < 0)
                     {                      {
                           ios = errno;
   
 #                       ifndef SEMAPHORES_NOMMES  #                       ifndef SEMAPHORES_NOMMES
                             while(sem_wait(&((*s_etat_processus)                              while(sem_wait(&((*s_etat_processus)
                                     .semaphore_fork)) != 0)                                      .semaphore_fork)) != 0)
Line 1752  instruction_write(struct_processus *s_et Line 2088  instruction_write(struct_processus *s_et
                             }                              }
                         }                          }
   
                           if ((ios == EPIPE) || (ios == ECONNRESET))
                           {
                               (*s_etat_processus).erreur_execution =
                                       d_ex_erreur_acces_fichier;
                               return;
                           }
   
                           if (ios == EMSGSIZE)
                           {
                               (*s_etat_processus).erreur_execution =
                                       d_ex_taille_message;
                               return;
                           }
   
                         (*s_etat_processus).erreur_systeme =                          (*s_etat_processus).erreur_systeme =
                                 d_es_erreur_fichier;                                  d_es_erreur_fichier;
                         return;                          return;
Line 1913  instruction_wflock(struct_processus *s_e Line 2263  instruction_wflock(struct_processus *s_e
   
         do          do
         {          {
             if ((chaine = conversion_majuscule((unsigned char *)              if ((chaine = conversion_majuscule(s_etat_processus,
                     (*s_objet_argument_1).objet)) == NULL)                      (unsigned char *) (*s_objet_argument_1).objet)) == NULL)
             {              {
                 (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;                  (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
                 return;                  return;
Line 1995  instruction_wflock(struct_processus *s_e Line 2345  instruction_wflock(struct_processus *s_e
             }              }
             else              else
             {              {
                   if (pthread_mutex_lock(&(*s_etat_processus).mutex_interruptions)
                           != 0)
                   {
                       (*s_etat_processus).erreur_systeme = d_es_processus;
                       return;
                   }
   
                 if ((*s_etat_processus).nombre_interruptions_non_affectees != 0)                  if ((*s_etat_processus).nombre_interruptions_non_affectees != 0)
                 {                  {
                     affectation_interruptions_logicielles(s_etat_processus);                      affectation_interruptions_logicielles(s_etat_processus);
                 }                  }
   
                 if ((*s_etat_processus).nombre_interruptions_en_queue                  if (pthread_mutex_unlock(&(*s_etat_processus)
                         != 0)                          .mutex_interruptions) != 0)
                   {
                       (*s_etat_processus).erreur_systeme = d_es_processus;
                       return;
                   }
   
                   if ((*s_etat_processus).nombre_interruptions_en_queue != 0)
                 {                  {
                     registre_instruction_valide =                      registre_instruction_valide =
                             (*s_etat_processus).instruction_valide;                              (*s_etat_processus).instruction_valide;
Line 2115  instruction_wfproc(struct_processus *s_e Line 2478  instruction_wfproc(struct_processus *s_e
             }              }
         }          }
   
         if (pthread_mutex_lock(&((*s_etat_processus).mutex)) != 0)          if (pthread_mutex_lock(&((*s_etat_processus).mutex_pile_processus))
                   != 0)
         {          {
             if ((*s_etat_processus).profilage == d_vrai)              if ((*s_etat_processus).profilage == d_vrai)
             {              {
Line 2180  instruction_wfproc(struct_processus *s_e Line 2544  instruction_wfproc(struct_processus *s_e
                     profilage(s_etat_processus, NULL);                      profilage(s_etat_processus, NULL);
                 }                  }
   
                 if (pthread_mutex_unlock(&((*s_etat_processus).mutex)) != 0)                  if (pthread_mutex_unlock(&((*s_etat_processus)
                           .mutex_pile_processus)) != 0)
                 {                  {
                     (*s_etat_processus).erreur_systeme = d_es_processus;                      (*s_etat_processus).erreur_systeme = d_es_processus;
                     return;                      return;
Line 2205  instruction_wfproc(struct_processus *s_e Line 2570  instruction_wfproc(struct_processus *s_e
                 {                  {
                     if (envoi_signal_processus((*(*((struct_processus_fils *)                      if (envoi_signal_processus((*(*((struct_processus_fils *)
                             (*(*l_element_courant).donnee).objet)).thread).pid,                              (*(*l_element_courant).donnee).objet)).thread).pid,
                             rpl_signull) != 0)                              rpl_signull, d_faux) != 0)
                     {                      {
                         drapeau_fin = d_vrai;                          drapeau_fin = d_vrai;
                     }                      }
Line 2260  instruction_wfproc(struct_processus *s_e Line 2625  instruction_wfproc(struct_processus *s_e
                      * Le processus n'est pas terminé                       * Le processus n'est pas terminé
                      */                       */
   
                     if (pthread_mutex_unlock(&((*s_etat_processus).mutex)) != 0)                      if (pthread_mutex_lock(&((*s_etat_processus)
                               .mutex_interruptions)) != 0)
                     {                      {
                           pthread_mutex_unlock(&((*s_etat_processus)
                                   .mutex_pile_processus));
   
                         if ((*s_etat_processus).profilage == d_vrai)                          if ((*s_etat_processus).profilage == d_vrai)
                         {                          {
                             profilage(s_etat_processus, NULL);                              profilage(s_etat_processus, NULL);
Line 2278  instruction_wfproc(struct_processus *s_e Line 2647  instruction_wfproc(struct_processus *s_e
                         affectation_interruptions_logicielles(s_etat_processus);                          affectation_interruptions_logicielles(s_etat_processus);
                     }                      }
   
                     if ((*s_etat_processus).nombre_interruptions_en_queue                      if (pthread_mutex_unlock(&((*s_etat_processus)
                             != 0)                              .mutex_interruptions)) != 0)
                       {
                           pthread_mutex_unlock(&((*s_etat_processus)
                                   .mutex_pile_processus));
   
                           if ((*s_etat_processus).profilage == d_vrai)
                           {
                               profilage(s_etat_processus, NULL);
                           }
   
                           (*s_etat_processus).erreur_systeme =
                                   d_es_processus;
                           return;
                       }
   
                       if (pthread_mutex_unlock(&((*s_etat_processus)
                               .mutex_pile_processus)) != 0)
                       {
                           if ((*s_etat_processus).profilage == d_vrai)
                           {
                               profilage(s_etat_processus, NULL);
                           }
   
                           (*s_etat_processus).erreur_systeme =
                                   d_es_processus;
                           return;
                       }
   
                       if ((*s_etat_processus).nombre_interruptions_en_queue != 0)
                     {                      {
                         registre_instruction_valide =                          registre_instruction_valide =
                                 (*s_etat_processus).instruction_valide;                                  (*s_etat_processus).instruction_valide;
Line 2318  instruction_wfproc(struct_processus *s_e Line 2715  instruction_wfproc(struct_processus *s_e
   
                     scrutation_injection(s_etat_processus);                      scrutation_injection(s_etat_processus);
   
                     if (pthread_mutex_lock(&((*s_etat_processus).mutex)) != 0)                      if (pthread_mutex_lock(&((*s_etat_processus)
                               .mutex_pile_processus)) != 0)
                     {                      {
                         if ((*s_etat_processus).profilage == d_vrai)                          if ((*s_etat_processus).profilage == d_vrai)
                         {                          {
Line 2340  instruction_wfproc(struct_processus *s_e Line 2738  instruction_wfproc(struct_processus *s_e
             profilage(s_etat_processus, NULL);              profilage(s_etat_processus, NULL);
         }          }
   
         if (pthread_mutex_unlock(&((*s_etat_processus).mutex)) != 0)          if (pthread_mutex_unlock(&((*s_etat_processus).mutex_pile_processus))
                   != 0)
         {          {
             (*s_etat_processus).erreur_systeme = d_es_processus;              (*s_etat_processus).erreur_systeme = d_es_processus;
             return;              return;
Line 2443  instruction_wfdata(struct_processus *s_e Line 2842  instruction_wfdata(struct_processus *s_e
             }              }
         }          }
   
         if (pthread_mutex_lock(&((*s_etat_processus).mutex)) != 0)          if (pthread_mutex_lock(&((*s_etat_processus).mutex_pile_processus))
                   != 0)
         {          {
             if ((*s_etat_processus).profilage == d_vrai)              if ((*s_etat_processus).profilage == d_vrai)
             {              {
Line 2503  instruction_wfdata(struct_processus *s_e Line 2903  instruction_wfdata(struct_processus *s_e
                     profilage(s_etat_processus, NULL);                      profilage(s_etat_processus, NULL);
                 }                  }
   
                 if (pthread_mutex_unlock(&((*s_etat_processus).mutex)) != 0)                  if (pthread_mutex_unlock(&((*s_etat_processus)
                           .mutex_pile_processus)) != 0)
                 {                  {
                     (*s_etat_processus).erreur_systeme = d_es_processus;                      (*s_etat_processus).erreur_systeme = d_es_processus;
                     return;                      return;
Line 2546  instruction_wfdata(struct_processus *s_e Line 2947  instruction_wfdata(struct_processus *s_e
                         return;                          return;
                     }                      }
   
                     if (pthread_mutex_unlock(&((*s_etat_processus).mutex)) != 0)                      if (pthread_mutex_unlock(&((*s_etat_processus)
                               .mutex_pile_processus)) != 0)
                     {                      {
                         if ((*s_etat_processus).profilage == d_vrai)                          if ((*s_etat_processus).profilage == d_vrai)
                         {                          {
Line 2587  instruction_wfdata(struct_processus *s_e Line 2989  instruction_wfdata(struct_processus *s_e
   
                     scrutation_injection(s_etat_processus);                      scrutation_injection(s_etat_processus);
   
                       if (pthread_mutex_lock(&(*s_etat_processus)
                               .mutex_interruptions) != 0)
                       {
                           (*s_etat_processus).erreur_systeme = d_es_processus;
                           return;
                       }
   
                     if ((*s_etat_processus).nombre_interruptions_non_affectees                      if ((*s_etat_processus).nombre_interruptions_non_affectees
                             != 0)                              != 0)
                     {                      {
                         affectation_interruptions_logicielles(s_etat_processus);                          affectation_interruptions_logicielles(s_etat_processus);
                     }                      }
   
                       if (pthread_mutex_unlock(&(*s_etat_processus)
                               .mutex_interruptions) != 0)
                       {
                           (*s_etat_processus).erreur_systeme = d_es_processus;
                           return;
                       }
   
                     if ((*s_etat_processus).nombre_interruptions_en_queue != 0)                      if ((*s_etat_processus).nombre_interruptions_en_queue != 0)
                     {                      {
                         registre_instruction_valide =                          registre_instruction_valide =
Line 2612  instruction_wfdata(struct_processus *s_e Line 3028  instruction_wfdata(struct_processus *s_e
                         return;                          return;
                     }                      }
   
                     if (pthread_mutex_lock(&((*s_etat_processus).mutex)) != 0)                      if (pthread_mutex_lock(&((*s_etat_processus)
                               .mutex_pile_processus)) != 0)
                     {                      {
                         if ((*s_etat_processus).profilage == d_vrai)                          if ((*s_etat_processus).profilage == d_vrai)
                         {                          {
Line 2639  instruction_wfdata(struct_processus *s_e Line 3056  instruction_wfdata(struct_processus *s_e
             profilage(s_etat_processus, NULL);              profilage(s_etat_processus, NULL);
         }          }
   
         if (pthread_mutex_unlock(&((*s_etat_processus).mutex)) != 0)          if (pthread_mutex_unlock(&((*s_etat_processus).mutex_pile_processus))
                   != 0)
         {          {
             (*s_etat_processus).erreur_systeme = d_es_processus;              (*s_etat_processus).erreur_systeme = d_es_processus;
             return;              return;
Line 2671  instruction_wfdata(struct_processus *s_e Line 3089  instruction_wfdata(struct_processus *s_e
 ================================================================================  ================================================================================
 */  */
   
   static inline logical1
   options_sockets(struct_processus *s_etat_processus, struct_socket *s_socket)
   {
       int                         drapeau;
   
       if (((*s_socket).options & (1 << d_BROADCAST)) != 0)
       {
           if (setsockopt((*s_socket).socket, SOL_SOCKET, SO_BROADCAST, &drapeau,
                   sizeof(drapeau)) != 0)
           {
               return(d_erreur);
           }
       }
   
       if (((*s_socket).options & (1 << d_DONT_ROUTE)) != 0)
       {
           if (setsockopt((*s_socket).socket, SOL_SOCKET, SO_DONTROUTE, &drapeau,
                   sizeof(drapeau)) != 0)
           {
               return(d_erreur);
           }
       }
   
       if (((*s_socket).options & (1 << d_KEEP_ALIVE)) != 0)
       {
           if (setsockopt((*s_socket).socket, SOL_SOCKET, SO_KEEPALIVE, &drapeau,
                   sizeof(drapeau)) != 0)
           {
               return(d_erreur);
           }
       }
   
   #   ifdef SO_PRIORITY
       if (((*s_socket).options & (1 << d_PRIORITY)) != 0)
       {
           if (setsockopt((*s_socket).socket, SOL_SOCKET, SO_PRIORITY,
                   &((*s_socket).priorite), sizeof((*s_socket).priorite)) != 0)
           {
               return(d_erreur);
           }
       }
   #   endif
   
       // Les deux options suivantes ne peuvent être positionnées simultanément.
   
       if (((*s_socket).options & (1 << d_RECEIVE_BUFFER)) != 0)
       {
           if (setsockopt((*s_socket).socket, SOL_SOCKET, SO_RCVBUF,
                   &((*s_socket).buffer_reception),
                   sizeof((*s_socket).buffer_reception)) != 0)
           {
               return(d_erreur);
           }
       }
   
   #   ifdef SO_RCVBUFFORCE
       if (((*s_socket).options & (1 << d_FORCE_RECEIVE_BUFFER)) != 0)
       {
           if (setsockopt((*s_socket).socket, SOL_SOCKET, SO_RCVBUFFORCE,
                   &((*s_socket).buffer_reception),
                   sizeof((*s_socket).buffer_reception)) != 0)
           {
               return(d_erreur);
           }
       }
   #   endif
   
       // Même remarque
   
       if (((*s_socket).options & (1 << d_SEND_BUFFER)) != 0)
       {
           if (setsockopt((*s_socket).socket, SOL_SOCKET, SO_SNDBUF,
                   &((*s_socket).buffer_emission),
                   sizeof((*s_socket).buffer_emission)) != 0)
           {
               return(d_erreur);
           }
       }
   
   #   ifdef SO_SNDBUFFORCE
       if (((*s_socket).options & (1 << d_FORCE_SEND_BUFFER)) != 0)
       {
           if (setsockopt((*s_socket).socket, SOL_SOCKET, SO_SNDBUFFORCE,
                   &((*s_socket).buffer_emission),
                   sizeof((*s_socket).buffer_emission)) != 0)
           {
               return(d_erreur);
           }
       }
   #   endif
   
       if (((*s_socket).options & (1 << d_RECEIVING_TIMEOUT)) != 0)
       {
           if (setsockopt((*s_socket).socket, SOL_SOCKET, SO_RCVTIMEO,
                   &((*s_socket).timeout_emission),
                   sizeof((*s_socket).timeout_emission)) != 0)
           {
               return(d_erreur);
           }
       }
   
       if (((*s_socket).options & (1 << d_SENDING_TIMEOUT)) != 0)
       {
           if (setsockopt((*s_socket).socket, SOL_SOCKET, SO_SNDTIMEO,
                   &((*s_socket).timeout_emission),
                   sizeof((*s_socket).timeout_emission)) != 0)
           {
               return(d_erreur);
           }
       }
   
       return(d_absence_erreur);;
   }
   
   
 void  void
 instruction_wfsock(struct_processus *s_etat_processus)  instruction_wfsock(struct_processus *s_etat_processus)
 {  {
Line 2685  instruction_wfsock(struct_processus *s_e Line 3218  instruction_wfsock(struct_processus *s_e
     struct_objet            *s_objet_argument;      struct_objet            *s_objet_argument;
     struct_objet            *s_objet_resultat;      struct_objet            *s_objet_resultat;
   
       struct pollfd           s_poll;
   
     struct sockaddr_in      adresse_ipv4;      struct sockaddr_in      adresse_ipv4;
 #   ifdef IPV6  #   ifdef IPV6
     struct sockaddr_in6     adresse_ipv6;      struct sockaddr_in6     adresse_ipv6;
 #   endif  #   endif
   
     unsigned long           i;  
   
     if ((*s_etat_processus).affichage_arguments == 'Y')      if ((*s_etat_processus).affichage_arguments == 'Y')
     {      {
         printf("\n  WFSOCK ");          printf("\n  WFSOCK ");
Line 2738  instruction_wfsock(struct_processus *s_e Line 3271  instruction_wfsock(struct_processus *s_e
                 "STREAM") != 0) && (strcmp((*((struct_socket *)                  "STREAM") != 0) && (strcmp((*((struct_socket *)
                 (*s_objet_argument).objet)).type, "SEQUENTIAL DATAGRAM") != 0))                  (*s_objet_argument).objet)).type, "SEQUENTIAL DATAGRAM") != 0))
         {          {
             liberation(s_etat_processus, s_objet_argument);              // Mode non connecté : l'attente se fait sur un poll()
   
             (*s_etat_processus).erreur_execution = d_ex_erreur_acces_fichier;  
             return;  
         }  
   
         if ((s_objet_resultat = copie_objet(s_etat_processus, s_objet_argument,  
                 'O')) == NULL)  
         {  
             (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;  
             return;  
         }  
   
         (*((struct_socket *) (*s_objet_resultat).objet)).socket_en_ecoute = 'N';              if ((s_objet_resultat = copie_objet(s_etat_processus,
         (*((struct_socket *) (*s_objet_resultat).objet)).effacement = 'N';                      s_objet_argument, 'P')) == NULL)
               {
                   (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
                   return;
               }
   
         if ((*((struct_socket *) (*s_objet_resultat).objet)).domaine == PF_INET)              s_poll.fd = (*((struct_socket *) (*s_objet_argument).objet)).socket;
         {              s_poll.events = POLLIN;
             longueur = sizeof(adresse_ipv4);              s_poll.revents = 0;
   
             do              do
             {              {
                 drapeau = d_vrai;                  drapeau = d_vrai;
   
 #               ifndef SEMAPHORES_NOMMES  #               ifndef SEMAPHORES_NOMMES
                     if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0)                  if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0)
 #               else  #               else
                     if (sem_post((*s_etat_processus).semaphore_fork) != 0)                  if (sem_post((*s_etat_processus).semaphore_fork) != 0)
 #               endif  #               endif
                 {                  {
                     (*s_etat_processus).erreur_systeme = d_es_processus;                      (*s_etat_processus).erreur_systeme = d_es_processus;
                     return;                      return;
                 }                  }
   
                 if (((*((struct_socket *) (*s_objet_resultat).objet)).socket =                  if (poll(&s_poll, 1, -1) < 0)
                         accept((*((struct_socket *) (*s_objet_argument).objet))  
                         .socket, (struct sockaddr *) &adresse_ipv4, &longueur))  
                         < 0)  
                 {                  {
                     erreur = errno;                      erreur = errno;
   
 #                   ifndef SEMAPHORES_NOMMES  #                   ifndef SEMAPHORES_NOMMES
                         while(sem_wait(&((*s_etat_processus).semaphore_fork))                      while(sem_wait(&((*s_etat_processus)
                                 != 0)                              .semaphore_fork)) != 0)
 #                   else  #                   else
                         while(sem_wait((*s_etat_processus).semaphore_fork) != 0)                      while(sem_wait((*s_etat_processus).semaphore_fork)
                               != 0)
 #                   endif  #                   endif
                     {  
                         if (errno != EINTR)  
                         {  
                             (*s_etat_processus).erreur_systeme = d_es_processus;  
                             return;  
                         }  
                     }  
   
                     if (erreur != EINTR)                      if (erreur != EINTR)
                     {                      {
Line 2817  instruction_wfsock(struct_processus *s_e Line 3334  instruction_wfsock(struct_processus *s_e
                 else                  else
                 {                  {
 #                   ifndef SEMAPHORES_NOMMES  #                   ifndef SEMAPHORES_NOMMES
                         while(sem_wait(&((*s_etat_processus).semaphore_fork))                          while(sem_wait(&((*s_etat_processus)
                                 != 0)                                  .semaphore_fork)) != 0)
 #                   else  #                   else
                         while(sem_wait((*s_etat_processus).semaphore_fork) != 0)                          while(sem_wait((*s_etat_processus).semaphore_fork)
                                   != 0)
 #                   endif  #                   endif
                     {                      {
                         if (errno != EINTR)                          if (errno != EINTR)
                         {                          {
                             (*s_etat_processus).erreur_systeme = d_es_processus;                              (*s_etat_processus).erreur_systeme =
                                       d_es_processus;
                             return;                              return;
                         }                          }
                     }                      }
                 }                  }
             } while(drapeau == d_faux);              } while(drapeau == d_faux);
   
             if (((*((struct_socket *) (*s_objet_resultat).objet))              if (empilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
                     .adresse_distante = malloc(22 *                      s_objet_argument) == d_erreur)
                     sizeof(unsigned char))) == NULL)  
             {              {
                 (*s_etat_processus).erreur_systeme =  
                         d_es_allocation_memoire;  
                 return;                  return;
             }              }
   
             sprintf((*((struct_socket *) (*s_objet_resultat).objet))              if (empilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
                     .adresse_distante, "%d.%d.%d.%d(%d)",                      s_objet_resultat) == d_erreur)
                     (ntohl(adresse_ipv4.sin_addr.s_addr) >> 24) & 0xFF,              {
                     (ntohl(adresse_ipv4.sin_addr.s_addr) >> 16) & 0xFF,                  return;
                     (ntohl(adresse_ipv4.sin_addr.s_addr) >> 8) & 0xFF,              }
                     ntohl(adresse_ipv4.sin_addr.s_addr) & 0xFF,  
                     ntohs(adresse_ipv4.sin_port));  
         }          }
         else if ((*((struct_socket *) (*s_objet_resultat).objet)).domaine ==          else
                 PF_INET6)  
         {          {
 #           ifdef IPV6              // Mode connecté
             longueur = sizeof(adresse_ipv6);  
   
             do              if ((s_objet_resultat = copie_objet(s_etat_processus,
                       s_objet_argument, 'O')) == NULL)
             {              {
                 drapeau = d_vrai;                  (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
                   return;
               }
   
 #               ifndef SEMAPHORES_NOMMES              (*((struct_socket *) (*s_objet_resultat).objet)).effacement = 'N';
                     if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0)              (*((struct_socket *) (*s_objet_resultat).objet)).socket_en_ecoute
 #               else                      = 'N';
                     if (sem_post((*s_etat_processus).semaphore_fork) != 0)  
 #               endif  
                 {  
                     (*s_etat_processus).erreur_systeme = d_es_processus;  
                     return;  
                 }  
   
                 if (((*((struct_socket *) (*s_objet_resultat).objet)).socket =              if ((*((struct_socket *) (*s_objet_resultat).objet)).domaine ==
                         accept((*((struct_socket *) (*s_objet_argument).objet))                      PF_INET)
                         .socket, (struct sockaddr *) &adresse_ipv6, &longueur))              {
                         < 0)                  longueur = sizeof(adresse_ipv4);
   
                   do
                 {                  {
                     erreur = errno;                      drapeau = d_vrai;
   
 #                   ifndef SEMAPHORES_NOMMES  #                   ifndef SEMAPHORES_NOMMES
                         while(sem_wait(&((*s_etat_processus).semaphore_fork))                          if (sem_post(&((*s_etat_processus).semaphore_fork))
                                 != 0)                                  != 0)
 #                   else  #                   else
                         while(sem_wait((*s_etat_processus).semaphore_fork) != 0)                          if (sem_post((*s_etat_processus).semaphore_fork) != 0)
 #                   endif  #                   endif
                     {                      {
                         if (errno != EINTR)                          (*s_etat_processus).erreur_systeme = d_es_processus;
                         {                          return;
                             (*s_etat_processus).erreur_systeme = d_es_processus;  
                             return;  
                         }  
                     }                      }
   
                     if (erreur != EINTR)                      if (((*((struct_socket *) (*s_objet_resultat).objet))
                               .socket = accept((*((struct_socket *)
                               (*s_objet_argument).objet)).socket,
                               (struct sockaddr *) &adresse_ipv4, &longueur))
                               < 0)
                     {                      {
                         liberation(s_etat_processus, s_objet_argument);                          erreur = errno;
                         liberation(s_etat_processus, s_objet_resultat);  
   
                         (*s_etat_processus).erreur_execution =  #                       ifndef SEMAPHORES_NOMMES
                                 d_ex_erreur_acces_fichier;                              while(sem_wait(&((*s_etat_processus)
                         return;                                      .semaphore_fork)) != 0)
                     }  #                       else
                               while(sem_wait((*s_etat_processus).semaphore_fork)
                                       != 0)
   #                       endif
                           {
                               if (errno != EINTR)
                               {
                                   (*s_etat_processus).erreur_systeme =
                                           d_es_processus;
                                   return;
                               }
                           }
   
                     scrutation_injection(s_etat_processus);                          if (erreur != EINTR)
                           {
                               liberation(s_etat_processus, s_objet_argument);
                               liberation(s_etat_processus, s_objet_resultat);
   
                     if ((*s_etat_processus).var_volatile_requete_arret != 0)                              (*s_etat_processus).erreur_execution =
                     {                                      d_ex_erreur_acces_fichier;
                         drapeau = d_vrai;                              return;
                           }
   
                           scrutation_injection(s_etat_processus);
   
                           if ((*s_etat_processus).var_volatile_requete_arret != 0)
                           {
                               drapeau = d_vrai;
                           }
                           else
                           {
                               drapeau = d_faux;
                           }
                     }                      }
                     else                      else
                     {                      {
                         drapeau = d_faux;  #                       ifndef SEMAPHORES_NOMMES
                               while(sem_wait(&((*s_etat_processus)
                                       .semaphore_fork)) != 0)
   #                       else
                               while(sem_wait((*s_etat_processus).semaphore_fork)
                                       != 0)
   #                       endif
                           {
                               if (errno != EINTR)
                               {
                                   (*s_etat_processus).erreur_systeme =
                                           d_es_processus;
                                   return;
                               }
                           }
   
                           if (options_sockets(s_etat_processus,
                                   (*s_objet_resultat).objet) != d_absence_erreur)
                           {
                               liberation(s_etat_processus, s_objet_argument);
                               liberation(s_etat_processus, s_objet_resultat);
   
                               (*s_etat_processus).erreur_execution =
                                       d_ex_erreur_parametre_fichier;
                               return;
                           }
                     }                      }
                   } while(drapeau == d_faux);
   
                   if (((*((struct_socket *) (*s_objet_resultat).objet))
                           .adresse_distante = malloc(22 *
                           sizeof(unsigned char))) == NULL)
                   {
                       (*s_etat_processus).erreur_systeme =
                               d_es_allocation_memoire;
                       return;
                 }                  }
                 else  
                   sprintf((*((struct_socket *) (*s_objet_resultat).objet))
                           .adresse_distante, "%d.%d.%d.%d(%d)",
                           (ntohl(adresse_ipv4.sin_addr.s_addr) >> 24) & 0xFF,
                           (ntohl(adresse_ipv4.sin_addr.s_addr) >> 16) & 0xFF,
                           (ntohl(adresse_ipv4.sin_addr.s_addr) >> 8) & 0xFF,
                           ntohl(adresse_ipv4.sin_addr.s_addr) & 0xFF,
                           ntohs(adresse_ipv4.sin_port));
               }
               else if ((*((struct_socket *) (*s_objet_resultat).objet)).domaine ==
                       PF_INET6)
               {
   #           ifdef IPV6
                   longueur = sizeof(adresse_ipv6);
   
                   do
                 {                  {
                       drapeau = d_vrai;
   
 #                   ifndef SEMAPHORES_NOMMES  #                   ifndef SEMAPHORES_NOMMES
                         while(sem_wait(&((*s_etat_processus).semaphore_fork))                          if (sem_post(&((*s_etat_processus).semaphore_fork))
                                 != 0)                                  != 0)
 #                   else  #                   else
                         while(sem_wait((*s_etat_processus).semaphore_fork) != 0)                          if (sem_post((*s_etat_processus).semaphore_fork) != 0)
 #                   endif  #                   endif
                     {                      {
                         if (errno != EINTR)                          (*s_etat_processus).erreur_systeme = d_es_processus;
                           return;
                       }
   
                       if (((*((struct_socket *) (*s_objet_resultat).objet))
                               .socket = accept((*((struct_socket *)
                               (*s_objet_argument).objet)).socket,
                               (struct sockaddr *) &adresse_ipv6, &longueur)) < 0)
                       {
                           erreur = errno;
   
   #                       ifndef SEMAPHORES_NOMMES
                               while(sem_wait(&((*s_etat_processus)
                                       .semaphore_fork)) != 0)
   #                       else
                               while(sem_wait((*s_etat_processus).semaphore_fork)
                                       != 0)
   #                       endif
                         {                          {
                             (*s_etat_processus).erreur_systeme = d_es_processus;                              if (errno != EINTR)
                               {
                                   (*s_etat_processus).erreur_systeme =
                                           d_es_processus;
                                   return;
                               }
                           }
   
                           if (erreur != EINTR)
                           {
                               liberation(s_etat_processus, s_objet_argument);
                               liberation(s_etat_processus, s_objet_resultat);
   
                               (*s_etat_processus).erreur_execution =
                                       d_ex_erreur_acces_fichier;
                             return;                              return;
                         }                          }
   
                           scrutation_injection(s_etat_processus);
   
                           if ((*s_etat_processus).var_volatile_requete_arret != 0)
                           {
                               drapeau = d_vrai;
                           }
                           else
                           {
                               drapeau = d_faux;
                           }
                     }                      }
                 }                      else
             } while(drapeau == d_faux);                      {
   #                       ifndef SEMAPHORES_NOMMES
                               while(sem_wait(&((*s_etat_processus)
                                       .semaphore_fork)) != 0)
   #                       else
                               while(sem_wait((*s_etat_processus).semaphore_fork)
                                       != 0)
   #                       endif
                           {
                               if (errno != EINTR)
                               {
                                   (*s_etat_processus).erreur_systeme =
                                           d_es_processus;
                                   return;
                               }
                           }
   
             if (((*((struct_socket *) (*s_objet_resultat).objet))                          if (options_sockets(s_etat_processus,
                     .adresse_distante = malloc(55 *                                  (*s_objet_resultat).objet) != d_absence_erreur)
                     sizeof(unsigned char))) == NULL)                          {
             {                              liberation(s_etat_processus, s_objet_argument);
                 (*s_etat_processus).erreur_systeme =                              liberation(s_etat_processus, s_objet_resultat);
                         d_es_allocation_memoire;  
                 return;  
             }  
   
             (*((struct_socket *) (*s_objet_resultat).objet))                              (*s_etat_processus).erreur_execution =
                     .adresse_distante = d_code_fin_chaine;                                      d_ex_erreur_parametre_fichier;
                               return;
                           }
                       }
                   } while(drapeau == d_faux);
   
                   if (((*((struct_socket *) (*s_objet_resultat).objet))
                           .adresse_distante = malloc(47 *
                           sizeof(unsigned char))) == NULL)
                   {
                       (*s_etat_processus).erreur_systeme =
                               d_es_allocation_memoire;
                       return;
                   }
   
             for(i = 0; i < 16; i++)  
             {  
                 sprintf((*((struct_socket *) (*s_objet_resultat)                  sprintf((*((struct_socket *) (*s_objet_resultat)
                         .objet)).adresse_distante, (i == 0) ? "%s%X" : "%s:%X",  
                         (*((struct_socket *) (*s_objet_resultat)  
                         .objet)).adresse_distante,                          .objet)).adresse_distante,
                         adresse_ipv6.sin6_addr.s6_addr[i]);                          "%02X%02X:%02X%02X:%02X%02X:%02X%02X:"
             }                          "%02X%02X:%02X%02X:%02X%02X:%02X%02X(%u)",
                           adresse_ipv6.sin6_addr.s6_addr[0],
             sprintf((*((struct_socket *) (*s_objet_resultat)                          adresse_ipv6.sin6_addr.s6_addr[1],
                     .objet)).adresse_distante, "%s(%u)",                          adresse_ipv6.sin6_addr.s6_addr[2],
                     (*((struct_socket *) (*s_objet_resultat)                          adresse_ipv6.sin6_addr.s6_addr[3],
                     .objet)).adresse_distante, ntohs(adresse_ipv6.sin6_port));                          adresse_ipv6.sin6_addr.s6_addr[4],
                           adresse_ipv6.sin6_addr.s6_addr[5],
                           adresse_ipv6.sin6_addr.s6_addr[6],
                           adresse_ipv6.sin6_addr.s6_addr[7],
                           adresse_ipv6.sin6_addr.s6_addr[8],
                           adresse_ipv6.sin6_addr.s6_addr[9],
                           adresse_ipv6.sin6_addr.s6_addr[10],
                           adresse_ipv6.sin6_addr.s6_addr[11],
                           adresse_ipv6.sin6_addr.s6_addr[12],
                           adresse_ipv6.sin6_addr.s6_addr[13],
                           adresse_ipv6.sin6_addr.s6_addr[14],
                           adresse_ipv6.sin6_addr.s6_addr[15],
                           ntohs(adresse_ipv6.sin6_port));
 #           else  #           else
             if ((*s_etat_processus).langue == 'F')                  if ((*s_etat_processus).langue == 'F')
             {                  {
                 printf("+++Attention : Support du protocole"                      printf("+++Attention : Support du protocole"
                         " IPv6 indisponible\n");                              " IPv6 indisponible\n");
                   }
                   else
                   {
                       printf("+++Warning : IPv6 support "
                               "unavailable\n");
                   }
   #           endif
             }              }
             else              else
             {              {
                 printf("+++Warning : IPv6 support "                  longueur = 0;
                         "unavailable\n");  
             }  
 #           endif  
         }  
         else  
         {  
             longueur = 0;  
   
             do  
             {  
                 drapeau = d_vrai;  
   
 #               ifndef SEMAPHORES_NOMMES  
                     if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0)  
 #               else  
                     if (sem_post((*s_etat_processus).semaphore_fork) != 0)  
 #               endif  
                 {  
                     (*s_etat_processus).erreur_systeme = d_es_processus;  
                     return;  
                 }  
   
                 if (((*((struct_socket *) (*s_objet_resultat).objet)).socket =                  do
                         accept((*((struct_socket *) (*s_objet_argument).objet))  
                         .socket, NULL, &longueur)) < 0)  
                 {                  {
                     erreur = errno;                      drapeau = d_vrai;
   
 #                   ifndef SEMAPHORES_NOMMES  #                   ifndef SEMAPHORES_NOMMES
                         while(sem_wait(&((*s_etat_processus).semaphore_fork))                          if (sem_post(&((*s_etat_processus).semaphore_fork))
                                 != 0)                                  != 0)
 #                   else  #                   else
                         while(sem_wait((*s_etat_processus).semaphore_fork) != 0)                          if (sem_post((*s_etat_processus).semaphore_fork) != 0)
 #                   endif  #                   endif
                     {                      {
                         if (errno != EINTR)                          (*s_etat_processus).erreur_systeme = d_es_processus;
                         {                          return;
                             (*s_etat_processus).erreur_systeme = d_es_processus;  
                             return;  
                         }  
                     }                      }
   
                     if (erreur != EINTR)                      if (((*((struct_socket *) (*s_objet_resultat).objet))
                               .socket = accept((*((struct_socket *)
                               (*s_objet_argument).objet)).socket, NULL,
                               &longueur)) < 0)
                     {                      {
                         liberation(s_etat_processus, s_objet_argument);                          erreur = errno;
                         liberation(s_etat_processus, s_objet_resultat);  
   
                         (*s_etat_processus).erreur_execution =  #                       ifndef SEMAPHORES_NOMMES
                                 d_ex_erreur_acces_fichier;                              while(sem_wait(&((*s_etat_processus)
                         return;                                      .semaphore_fork)) != 0)
                     }  #                       else
                               while(sem_wait((*s_etat_processus).semaphore_fork)
                                       != 0)
   #                       endif
                           {
                               if (errno != EINTR)
                               {
                                   (*s_etat_processus).erreur_systeme =
                                           d_es_processus;
                                   return;
                               }
                           }
   
                     scrutation_injection(s_etat_processus);                          if (erreur != EINTR)
                           {
                               liberation(s_etat_processus, s_objet_argument);
                               liberation(s_etat_processus, s_objet_resultat);
   
                     if ((*s_etat_processus).var_volatile_requete_arret != 0)                              (*s_etat_processus).erreur_execution =
                     {                                      d_ex_erreur_acces_fichier;
                         drapeau = d_vrai;                              return;
                           }
   
                           scrutation_injection(s_etat_processus);
   
                           if ((*s_etat_processus).var_volatile_requete_arret != 0)
                           {
                               drapeau = d_vrai;
                           }
                           else
                           {
                               drapeau = d_faux;
                           }
                     }                      }
                     else                      else
                     {                      {
                         drapeau = d_faux;  #                       ifndef SEMAPHORES_NOMMES
                     }                              while(sem_wait(&((*s_etat_processus)
                 }                                      .semaphore_fork)) != 0)
                 else  #                       else
                 {                              while(sem_wait((*s_etat_processus).semaphore_fork)
 #                   ifndef SEMAPHORES_NOMMES                                      != 0)
                         while(sem_wait(&((*s_etat_processus).semaphore_fork))  #                       endif
                                 != 0)  
 #                   else  
                         while(sem_wait((*s_etat_processus).semaphore_fork) != 0)  
 #                   endif  
                     {  
                         if (errno != EINTR)  
                         {                          {
                             (*s_etat_processus).erreur_systeme = d_es_processus;                              if (errno != EINTR)
                               {
                                   (*s_etat_processus).erreur_systeme =
                                           d_es_processus;
                                   return;
                               }
                           }
   
                           if (options_sockets(s_etat_processus,
                                   (*s_objet_resultat).objet) != d_absence_erreur)
                           {
                               liberation(s_etat_processus, s_objet_argument);
                               liberation(s_etat_processus, s_objet_resultat);
   
                               (*s_etat_processus).erreur_execution =
                                       d_ex_erreur_parametre_fichier;
                             return;                              return;
                         }                          }
                     }                      }
                 }                  } while(drapeau == d_faux);
             } while(drapeau == d_faux);              }
         }  
   
         // Si accept() renvoie une erreur non récupérée, il ne peut s'agir  
         // que de EINTR sachant qu'une requête d'arrêt est en court de  
         // traitement.  
   
         if ((*((struct_socket *) (*s_objet_resultat).objet)).socket >= 0)              // Si accept() renvoie une erreur non récupérée, il ne peut s'agir
         {              // que de EINTR sachant qu'une requête d'arrêt est en court de
             l_element_courant = (*s_etat_processus).s_sockets;              // traitement.
   
             if (l_element_courant == NULL)              if ((*((struct_socket *) (*s_objet_resultat).objet)).socket >= 0)
             {              {
                 if (((*s_etat_processus).s_sockets =                  l_element_courant = (*s_etat_processus).s_sockets;
                         allocation_maillon(s_etat_processus)) == NULL)  
                   if (l_element_courant == NULL)
                 {                  {
                     (*s_etat_processus).erreur_systeme =                      if (((*s_etat_processus).s_sockets =
                             d_es_allocation_memoire;                              allocation_maillon(s_etat_processus)) == NULL)
                     return;                      {
                           (*s_etat_processus).erreur_systeme =
                                   d_es_allocation_memoire;
                           return;
                       }
   
                       (*(*s_etat_processus).s_sockets).suivant = NULL;
                       l_element_courant = (*s_etat_processus).s_sockets;
                 }                  }
                   else
                   {
                       /*
                        * Ajout d'un élément à la fin de la liste chaînée
                        */
   
                 (*(*s_etat_processus).s_sockets).suivant = NULL;                      while((*l_element_courant).suivant != NULL)
                 l_element_courant = (*s_etat_processus).s_sockets;                      {
             }                          l_element_courant = (*l_element_courant).suivant;
             else                      }
             {  
                 /*                      if (((*l_element_courant).suivant =
                  * Ajout d'un élément à la fin de la liste chaînée                              allocation_maillon(s_etat_processus)) == NULL)
                  */                      {
                           (*s_etat_processus).erreur_systeme =
                                   d_es_allocation_memoire;
                           return;
                       }
   
                 while((*l_element_courant).suivant != NULL)  
                 {  
                     l_element_courant = (*l_element_courant).suivant;                      l_element_courant = (*l_element_courant).suivant;
                       (*l_element_courant).suivant = NULL;
                 }                  }
   
                 if (((*l_element_courant).suivant =                  if (((*l_element_courant).donnee = copie_objet(s_etat_processus,
                         allocation_maillon(s_etat_processus)) == NULL)                          s_objet_resultat, 'O')) == NULL)
                 {                  {
                     (*s_etat_processus).erreur_systeme =                      (*s_etat_processus).erreur_systeme =
                             d_es_allocation_memoire;                              d_es_allocation_memoire;
                     return;                      return;
                 }                  }
   
                 l_element_courant = (*l_element_courant).suivant;  
                 (*l_element_courant).suivant = NULL;  
             }              }
   
             if (((*l_element_courant).donnee = copie_objet(s_etat_processus,              if (empilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
                     s_objet_resultat, 'O')) == NULL)                      s_objet_argument) == d_erreur)
             {              {
                 (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;  
                 return;                  return;
             }              }
         }  
   
         if (empilement(s_etat_processus, &((*s_etat_processus).l_base_pile),              if (empilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
                 s_objet_argument) == d_erreur)                      s_objet_resultat) == d_erreur)
         {              {
             return;                  return;
         }              }
   
         if (empilement(s_etat_processus, &((*s_etat_processus).l_base_pile),  
                 s_objet_resultat) == d_erreur)  
         {  
             return;  
         }          }
     }      }
     else      else
Line 3209  instruction_wfswi(struct_processus *s_et Line 3891  instruction_wfswi(struct_processus *s_et
                 return;                  return;
             }              }
   
               if (pthread_mutex_lock(&(*s_etat_processus).mutex_interruptions)
                       != 0)
               {
                   (*s_etat_processus).erreur_systeme = d_es_processus;
                   return;
               }
   
             if ((*s_etat_processus).nombre_interruptions_non_affectees != 0)              if ((*s_etat_processus).nombre_interruptions_non_affectees != 0)
             {              {
                 affectation_interruptions_logicielles(s_etat_processus);                  affectation_interruptions_logicielles(s_etat_processus);
             }              }
   
               if (pthread_mutex_unlock(&(*s_etat_processus).mutex_interruptions)
                       != 0)
               {
                   (*s_etat_processus).erreur_systeme = d_es_processus;
                   return;
               }
   
             if ((*s_etat_processus).queue_interruptions[interruption - 1] > 0)              if ((*s_etat_processus).queue_interruptions[interruption - 1] > 0)
             {              {
                 drapeau_fin = d_vrai;                  drapeau_fin = d_vrai;
Line 3346  instruction_wfpoke(struct_processus *s_e Line 4042  instruction_wfpoke(struct_processus *s_e
   
         scrutation_injection(s_etat_processus);          scrutation_injection(s_etat_processus);
   
           if (pthread_mutex_lock(&(*s_etat_processus).mutex_interruptions) != 0)
           {
               (*s_etat_processus).erreur_systeme = d_es_processus;
               return;
           }
   
         if ((*s_etat_processus).nombre_interruptions_non_affectees != 0)          if ((*s_etat_processus).nombre_interruptions_non_affectees != 0)
         {          {
             affectation_interruptions_logicielles(s_etat_processus);              affectation_interruptions_logicielles(s_etat_processus);
         }          }
   
           if (pthread_mutex_unlock(&(*s_etat_processus).mutex_interruptions) != 0)
           {
               (*s_etat_processus).erreur_systeme = d_es_processus;
               return;
           }
   
         if ((*s_etat_processus).nombre_interruptions_en_queue != 0)          if ((*s_etat_processus).nombre_interruptions_en_queue != 0)
         {          {
             registre_instruction_valide =              registre_instruction_valide =
Line 3453  instruction_wfack(struct_processus *s_et Line 4161  instruction_wfack(struct_processus *s_et
     {      {
         scrutation_injection(s_etat_processus);          scrutation_injection(s_etat_processus);
   
           if (pthread_mutex_lock(&(*s_etat_processus).mutex_interruptions) != 0)
           {
               (*s_etat_processus).erreur_systeme = d_es_processus;
               return;
           }
   
         if ((*s_etat_processus).nombre_interruptions_non_affectees != 0)          if ((*s_etat_processus).nombre_interruptions_non_affectees != 0)
         {          {
             affectation_interruptions_logicielles(s_etat_processus);              affectation_interruptions_logicielles(s_etat_processus);
         }          }
   
           if (pthread_mutex_unlock(&(*s_etat_processus).mutex_interruptions) != 0)
           {
               (*s_etat_processus).erreur_systeme = d_es_processus;
               return;
           }
   
         if ((*s_etat_processus).nombre_interruptions_en_queue != 0)          if ((*s_etat_processus).nombre_interruptions_en_queue != 0)
         {          {
             registre_instruction_valide =              registre_instruction_valide =

Removed from v.1.52  
changed lines
  Added in v.1.116


CVSweb interface <joel.bertrand@systella.fr>