Diff for /rpl/src/instructions_w1.c between versions 1.5 and 1.74

version 1.5, 2010/03/06 18:29:07 version 1.74, 2013/03/01 10:24:49
Line 1 Line 1
 /*  /*
 ================================================================================  ================================================================================
   RPL/2 (R) version 4.0.12    RPL/2 (R) version 4.1.13
   Copyright (C) 1989-2010 Dr. BERTRAND Joël    Copyright (C) 1989-2013 Dr. BERTRAND Joël
   
   This file is part of RPL/2.    This file is part of RPL/2.
   
Line 20 Line 20
 */  */
   
   
 #include "rpl.conv.h"  #include "rpl-conv.h"
   
   
 /*  /*
Line 124  instruction_while(struct_processus *s_et Line 124  instruction_while(struct_processus *s_et
 void  void
 instruction_warranty(struct_processus *s_etat_processus)  instruction_warranty(struct_processus *s_etat_processus)
 {  {
 #   include                 "garanties.conv.h"  #   include                 "garanties-conv.h"
   
     (*s_etat_processus).erreur_execution = d_ex;      (*s_etat_processus).erreur_execution = d_ex;
   
Line 226  instruction_wait(struct_processus *s_eta Line 226  instruction_wait(struct_processus *s_eta
         return;          return;
     }      }
           
     if (((*s_objet).type == INT) ||      if (((*s_objet).type == INT) || ((*s_objet).type == REL))
             ((*s_objet).type == REL))  
     {      {
         if ((*s_objet).type == INT)          if ((*s_objet).type == INT)
         {          {
Line 262  instruction_wait(struct_processus *s_eta Line 261  instruction_wait(struct_processus *s_eta
   
         do          do
         {          {
             if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0)  #           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;                  (*s_etat_processus).erreur_systeme = d_es_processus;
                 return;                  return;
Line 271  instruction_wait(struct_processus *s_eta Line 274  instruction_wait(struct_processus *s_eta
             code_retour = nanosleep(&temporisation, &temporisation);              code_retour = nanosleep(&temporisation, &temporisation);
             erreur = errno;              erreur = errno;
   
             while(sem_wait(&((*s_etat_processus).semaphore_fork)) == -1)  #           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)                  if (errno != EINTR)
                 {                  {
Line 374  instruction_wireframe(struct_processus * Line 381  instruction_wireframe(struct_processus *
 void  void
 instruction_write(struct_processus *s_etat_processus)  instruction_write(struct_processus *s_etat_processus)
 {  {
       const char                          *queue;
   
     int                                 adresse[16];      int                                 adresse[16];
     int                                 port;      int                                 port;
       int                                 sqlite_status;
   
       integer8                            clef;
       integer8                            compteur;
       integer8                            id;
       integer8                            ordre;
   
       logical1                            format_degenere;
       logical1                            mise_a_jour;
   
       long                                longueur;
     long                                longueur_effective;      long                                longueur_effective;
     long                                recursivite;      long                                recursivite;
   
       sqlite3_stmt                        *ppStmt;
   
     ssize_t                             ios;      ssize_t                             ios;
   
     struct_descripteur_fichier          *descripteur;      struct_descripteur_fichier          *descripteur;
   
     struct_objet                        *s_objet_argument_2;      struct_liste_chainee                *l_element_courant;
       struct_liste_chainee                *l_element_courant_format;
   
       struct_objet                        *s_format;
       struct_objet                        *s_element;
     struct_objet                        *s_objet_argument_1;      struct_objet                        *s_objet_argument_1;
       struct_objet                        *s_objet_argument_2;
       struct_objet                        *s_objet_argument_3;
   
     struct sigaction                    action;      struct sigaction                    action;
     struct sigaction                    registre;      struct sigaction                    registre;
   
     struct sockaddr_in                  adresse_ipv4;      struct sockaddr_in                  adresse_ipv4;
   #   ifdef IPV6
     struct sockaddr_in6                 adresse_ipv6;      struct sockaddr_in6                 adresse_ipv6;
   #   endif
     struct sockaddr_un                  adresse_unix;      struct sockaddr_un                  adresse_unix;
   
     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                       *commande;
       unsigned char                       *format_chaine;
   
     unsigned long                       i;      unsigned long                       i;
   
Line 419  instruction_write(struct_processus *s_et Line 453  instruction_write(struct_processus *s_et
         }          }
   
         printf("    2: %s\n", d_LST);          printf("    2: %s\n", d_LST);
         printf("    1: %s, %s\n", d_FCH, d_SCK);          printf("    1: %s, %s\n\n", d_FCH, d_SCK);
   
           printf("    3: %s\n", d_LST);
           printf("    2: %s\n", d_INT);
           printf("    1: %s\n", d_FCH);
         return;          return;
     }      }
     else if ((*s_etat_processus).test_instruction == 'Y')      else if ((*s_etat_processus).test_instruction == 'Y')
Line 431  instruction_write(struct_processus *s_et Line 468  instruction_write(struct_processus *s_et
   
     if (test_cfsf(s_etat_processus, 31) == d_vrai)      if (test_cfsf(s_etat_processus, 31) == d_vrai)
     {      {
         if (empilement_pile_last(s_etat_processus, 2) == d_erreur)          if ((*s_etat_processus).l_base_pile == NULL)
         {          {
               (*s_etat_processus).erreur_execution = d_ex_manque_argument;
             return;              return;
         }          }
   
           if ((*(*(*s_etat_processus).l_base_pile).donnee).type == FCH)
           {
               if ((*((struct_fichier *) (*(*(*s_etat_processus).l_base_pile)
                       .donnee).objet)).acces == 'D')
               {
                   if (empilement_pile_last(s_etat_processus, 3) == d_erreur)
                   {
                       return;
                   }
               }
               else
               {
                   if (empilement_pile_last(s_etat_processus, 2) == d_erreur)
                   {
                       return;
                   }
               }
           }
           else
           {
               if (empilement_pile_last(s_etat_processus, 2) == d_erreur)
               {
                   return;
               }
           }
     }      }
   
     if (depilement(s_etat_processus, &((*s_etat_processus).l_base_pile),      if (depilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
Line 453  instruction_write(struct_processus *s_et Line 517  instruction_write(struct_processus *s_et
         return;          return;
     }      }
           
     if (((*s_objet_argument_2).type == LST) &&      if ((*s_objet_argument_1).type == FCH)
             ((*s_objet_argument_1).type == FCH))  
     {      {
         if ((descripteur = descripteur_fichier(s_etat_processus,          if ((descripteur = descripteur_fichier(s_etat_processus,
                 (struct_fichier *) (*s_objet_argument_1).objet)) == NULL)                  (struct_fichier *) (*s_objet_argument_1).objet)) == NULL)
Line 513  instruction_write(struct_processus *s_et Line 576  instruction_write(struct_processus *s_et
              * Fichiers formatés               * Fichiers formatés
              */               */
   
             if ((chaine = formateur_fichier(s_etat_processus,  
                     s_objet_argument_2, (*((struct_fichier *)  
                     (*s_objet_argument_1).objet)).format, 0, 0, ' ', 'F',  
                     &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, ' ', 'F',
                           &longueur_effective, &recursivite)) == 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 542  instruction_write(struct_processus *s_et Line 615  instruction_write(struct_processus *s_et
                 if ((chaine_utf8 = transliteration(s_etat_processus,                  if ((chaine_utf8 = transliteration(s_etat_processus,
                         chaine, d_locale, "UTF-8")) == NULL)                          chaine, d_locale, "UTF-8")) == NULL)
                 {                  {
                       free(chaine);
   
                     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);
   
                     return;                      return;
                 }                  }
   
                 if (fprintf((*descripteur).descripteur_c, "%s\n", chaine) < 0)                  free(chaine);
   
                   if (fprintf((*descripteur).descripteur_c, "%s\n", chaine_utf8)
                           < 0)
                 {                  {
                     free(chaine_utf8);                      free(chaine_utf8);
   
Line 561  instruction_write(struct_processus *s_et Line 639  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')
             {              {
                   BUG(((*descripteur).type != 'S'), uprintf("Bad filetype !\n"));
   
                   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;
                   }
   
                   // Modification ou création d'un nouvel enregistrement
   
                   if ((chaine = formateur_fichier(s_etat_processus,
                           s_objet_argument_3, (*((struct_fichier *)
                           (*s_objet_argument_1).objet)).format, 0, 0, ' ',
                           'F', &longueur_effective, &recursivite)) == NULL)
                   {
                       liberation(s_etat_processus, s_objet_argument_3);
                       liberation(s_etat_processus, s_objet_argument_2);
                       liberation(s_etat_processus, s_objet_argument_1);
   
                       return;
                   }
   
                   if ((chaine_utf8 = transliteration(s_etat_processus,
                           chaine, d_locale, "UTF-8")) == NULL)
                   {
                       free(chaine);
   
                       liberation(s_etat_processus, s_objet_argument_3);
                       liberation(s_etat_processus, s_objet_argument_2);
                       liberation(s_etat_processus, s_objet_argument_1);
   
                       return;
                   }
   
                   free(chaine);
   
                   if (alsprintf(&commande, "insert or replace into data "
                           "(id, data) values (%lld, '%s')", (*((integer8 *)
                           (*s_objet_argument_2).objet)), chaine_utf8) < 0)
                   {
                       (*s_etat_processus).erreur_systeme =
                               d_es_allocation_memoire;
                       return;
                   }
   
                   free(chaine_utf8);
   
                   if (sqlite3_prepare_v2((*descripteur).descripteur_sqlite,
                           commande, strlen(commande), &ppStmt, &queue)
                           != SQLITE_OK)
                   {
                       (*s_etat_processus).erreur_systeme = d_es_erreur_fichier;
                       return;
                   }
   
                   if (sqlite3_step(ppStmt) != SQLITE_DONE)
                   {
                       (*s_etat_processus).erreur_systeme = d_es_erreur_fichier;
                       return;
                   }
   
                   if (sqlite3_finalize(ppStmt) != SQLITE_OK)
                   {
                       (*s_etat_processus).erreur_systeme = d_es_erreur_fichier;
                       return;
                   }
   
                   liberation(s_etat_processus, s_objet_argument_3);
                   free(commande);
             }              }
             else              else // Fichiers indexés
             {              {
                 /* Fichiers indexés : panique totale ! */                  BUG(((*descripteur).type != 'S'), uprintf("Bad filetype !\n"));
             }  
   
             free(chaine);                  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;
                   }
   
                   // Récupération de la position de la clef
   
                   if (alsprintf(&commande, "select key from control "
                           "where id = 1") < 0)
                   {
                       (*s_etat_processus).erreur_systeme =
                               d_es_allocation_memoire;
                       return;
                   }
   
                   if (sqlite3_prepare_v2((*descripteur).descripteur_sqlite,
                           commande, strlen(commande), &ppStmt, &queue)
                           != SQLITE_OK)
                   {
                       (*s_etat_processus).erreur_systeme = d_es_erreur_fichier;
                       return;
                   }
   
                   attente.tv_sec = 0;
                   attente.tv_nsec = GRANULARITE_us * 1000;
   
                   do
                   {
                       sqlite_status = sqlite3_step(ppStmt);
   
                       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)
                   {
                       (*s_etat_processus).erreur_systeme = d_es_erreur_fichier;
                       return;
                   }
   
                   clef = sqlite3_column_int64(ppStmt, 0);
   
                   if (sqlite3_step(ppStmt) != SQLITE_DONE)
                   {
                       (*s_etat_processus).erreur_systeme = d_es_erreur_fichier;
                       return;
                   }
   
                   if (sqlite3_finalize(ppStmt) != SQLITE_OK)
                   {
                       (*s_etat_processus).erreur_systeme = d_es_erreur_fichier;
                       return;
                   }
   
                   free(commande);
   
                   l_element_courant = (struct_liste_chainee *)
                           (*s_objet_argument_2).objet;
                   l_element_courant_format = (struct_liste_chainee *)
                           (*(*((struct_fichier *) (*s_objet_argument_1).objet))
                           .format).objet;
                   compteur = 1;
   
                   while((l_element_courant != NULL) &&
                           (l_element_courant_format != NULL))
                   {
                       if (compteur == clef)
                       {
                           break;
                       }
   
                       l_element_courant = (*l_element_courant).suivant;
                       l_element_courant_format = (*l_element_courant_format)
                               .suivant;
                       compteur++;
                   }
   
                   if ((l_element_courant == NULL) ||
                           (l_element_courant_format == NULL))
                   {
                       (*s_etat_processus).erreur_execution =
                               d_ex_clef_inexistante;
                           
                       liberation(s_etat_processus, s_objet_argument_2);
                       liberation(s_etat_processus, s_objet_argument_1);
   
                       return;
                   }
   
                   if ((s_element = allocation(s_etat_processus, LST)) == NULL)
                   {
                       (*s_etat_processus).erreur_systeme =
                               d_es_allocation_memoire;
                       return;
                   }
   
                   if (((*s_element).objet = allocation_maillon(s_etat_processus))
                           == NULL)
                   {
                       (*s_etat_processus).erreur_systeme =
                               d_es_allocation_memoire;
                       return;
                   }
   
                   (*((struct_liste_chainee *) (*s_element).objet)).suivant = NULL;
   
                   if (((*((struct_liste_chainee *) (*s_element).objet))
                           .donnee = copie_objet(s_etat_processus,
                           (*l_element_courant).donnee, 'N')) == NULL)
                   {
                       (*s_etat_processus).erreur_systeme =
                               d_es_allocation_memoire;
                       return;
                   }
   
                   if ((s_format = allocation(s_etat_processus, LST)) == NULL)
                   {
                       (*s_etat_processus).erreur_systeme =
                               d_es_allocation_memoire;
                       return;
                   }
   
                   if (((*s_format).objet = allocation_maillon(s_etat_processus))
                           == NULL)
                   {
                       (*s_etat_processus).erreur_systeme =
                               d_es_allocation_memoire;
                       return;
                   }
   
                   (*((struct_liste_chainee *) (*s_format).objet)).suivant = NULL;
   
                   if (((*((struct_liste_chainee *) (*s_format).objet))
                           .donnee = copie_objet(s_etat_processus,
                           (*l_element_courant_format).donnee, 'N')) == NULL)
                   {
                       (*s_etat_processus).erreur_systeme =
                               d_es_allocation_memoire;
                       return;
                   }
   
                   if ((chaine = formateur_fichier(s_etat_processus,
                           s_element, s_format, 0, 0, ' ',
                           'F', &longueur_effective, &recursivite)) == NULL)
                   {
                       liberation(s_etat_processus, s_element);
                       liberation(s_etat_processus, s_format);
                       liberation(s_etat_processus, s_objet_argument_2);
                       liberation(s_etat_processus, s_objet_argument_1);
   
                       return;
                   }
   
                   liberation(s_etat_processus, s_element);
                   liberation(s_etat_processus, s_format);
   
                   if ((clef_utf8 = transliteration(s_etat_processus,
                           chaine, d_locale, "UTF-8")) == NULL)
                   {
                       liberation(s_etat_processus, s_objet_argument_2);
                       liberation(s_etat_processus, s_objet_argument_1);
   
                       return;
                   }
   
                   free(chaine);
   
                   // Récupération de l'identifiant de la clef
   
                   if (alsprintf(&commande, "select id from key where key = "
                           "'%s'", clef_utf8) < 0)
                   {
                       (*s_etat_processus).erreur_systeme =
                               d_es_allocation_memoire;
                       return;
                   }
   
                   if (sqlite3_prepare_v2((*descripteur).descripteur_sqlite,
                           commande, strlen(commande), &ppStmt, &queue)
                           != SQLITE_OK)
                   {
                       (*s_etat_processus).erreur_systeme = d_es_erreur_fichier;
                       return;
                   }
   
                   attente.tv_sec = 0;
                   attente.tv_nsec = GRANULARITE_us * 1000;
   
                   do
                   {
                       switch(sqlite_status = sqlite3_step(ppStmt))
                       {
                           case SQLITE_ROW:
                           {
                               // Une clef existe.
   
                               mise_a_jour = d_vrai;
                               break;
                           }
   
                           case SQLITE_DONE:
                           {
                               // Aucune clef n'existe.
   
                               mise_a_jour = d_faux;
   
                               if (sqlite3_finalize(ppStmt) != SQLITE_OK)
                               {
                                   (*s_etat_processus).erreur_systeme =
                                           d_es_erreur_fichier;
                                   return;
                               }
   
                               free(commande);
   
                               if (alsprintf(&commande, "insert into key "
                                       "(key) values ('%s')", clef_utf8) < 0)
                               {
                                   (*s_etat_processus).erreur_systeme =
                                           d_es_allocation_memoire;
                                   return;
                               }
   
                               if (sqlite3_prepare_v2((*descripteur)
                                       .descripteur_sqlite,
                                       commande, strlen(commande), &ppStmt, &queue)
                                       != SQLITE_OK)
                               {
                                   (*s_etat_processus).erreur_systeme =
                                           d_es_erreur_fichier;
                                   return;
                               }
   
                               if (sqlite3_step(ppStmt) != SQLITE_DONE)
                               {
                                   (*s_etat_processus).erreur_systeme =
                                           d_es_erreur_fichier;
                                   return;
                               }
   
                               if (sqlite3_finalize(ppStmt) != SQLITE_OK)
                               {
                                   (*s_etat_processus).erreur_systeme =
                                           d_es_erreur_fichier;
                                   return;
                               }
   
                               free(commande);
   
                               if (alsprintf(&commande, "select id from key "
                                       "where key = '%s'", clef_utf8) < 0)
                               {
                                   (*s_etat_processus).erreur_systeme =
                                           d_es_allocation_memoire;
                                   return;
                               }
   
                               if (sqlite3_prepare_v2((*descripteur)
                                       .descripteur_sqlite,
                                       commande, strlen(commande), &ppStmt, &queue)
                                       != SQLITE_OK)
                               {
                                   (*s_etat_processus).erreur_systeme =
                                           d_es_erreur_fichier;
                                   return;
                               }
   
                               break;
                           }
   
                           case SQLITE_BUSY:
                           case SQLITE_LOCKED:
                           {
                               nanosleep(&attente, NULL);
                               INCR_GRANULARITE(attente.tv_nsec);
                               break;
                           }
   
                           default:
                           {
                               (*s_etat_processus).erreur_systeme =
                                       d_es_erreur_fichier;
                               return;
                           }
                       }
                   } while(sqlite_status != SQLITE_ROW);
   
                   if (sqlite3_column_type(ppStmt, 0) != SQLITE_INTEGER)
                   {
                       (*s_etat_processus).erreur_systeme = d_es_erreur_fichier;
                       return;
                   }
   
                   id = sqlite3_column_int64(ppStmt, 0);
   
                   if (sqlite3_step(ppStmt) != SQLITE_DONE)
                   {
                       (*s_etat_processus).erreur_systeme = d_es_erreur_fichier;
                       return;
                   }
   
                   if (sqlite3_finalize(ppStmt) != SQLITE_OK)
                   {
                       (*s_etat_processus).erreur_systeme = d_es_erreur_fichier;
                       return;
                   }
   
                   free(commande);
   
                   // Modification de la clef
   
                   if (mise_a_jour == d_vrai)
                   {
                       if (alsprintf(&commande, "update key set key = '%s' where "
                               "id = %lld", clef_utf8, id) < 0)
                       {
                           (*s_etat_processus).erreur_systeme =
                                   d_es_allocation_memoire;
                           return;
                       }
   
                       if (sqlite3_prepare_v2((*descripteur).descripteur_sqlite,
                               commande, strlen(commande), &ppStmt, &queue)
                               != SQLITE_OK)
                       {
                           (*s_etat_processus).erreur_systeme =
                                   d_es_erreur_fichier;
                           return;
                       }
   
                       if (sqlite3_step(ppStmt) != SQLITE_DONE)
                       {
                           (*s_etat_processus).erreur_systeme =
                                   d_es_erreur_fichier;
                           return;
                       }
   
                       if (sqlite3_finalize(ppStmt) != SQLITE_OK)
                       {
                           (*s_etat_processus).erreur_systeme =
                                   d_es_erreur_fichier;
                           return;
                       }
   
                       free(commande);
                   }
   
                   // Effacement de l'enregistrement existant
   
                   if (alsprintf(&commande, "delete from data where "
                           "key_id = %lld", id) < 0)
                   {
                       (*s_etat_processus).erreur_systeme =
                               d_es_allocation_memoire;
                       return;
                   }
   
                   if (sqlite3_prepare_v2((*descripteur).descripteur_sqlite,
                           commande, strlen(commande), &ppStmt, &queue)
                           != SQLITE_OK)
                   {
                       (*s_etat_processus).erreur_systeme = d_es_erreur_fichier;
                       return;
                   }
   
                   if (sqlite3_step(ppStmt) != SQLITE_DONE)
                   {
                       (*s_etat_processus).erreur_systeme = d_es_erreur_fichier;
                       return;
                   }
   
                   if (sqlite3_finalize(ppStmt) != SQLITE_OK)
                   {
                       (*s_etat_processus).erreur_systeme = d_es_erreur_fichier;
                       return;
                   }
   
                   free(commande);
   
                   // Modification ou création d'un nouvel enregistrement
   
                   l_element_courant = (struct_liste_chainee *)
                           (*s_objet_argument_2).objet;
                   l_element_courant_format = (struct_liste_chainee *)
                           (*(*((struct_fichier *) (*s_objet_argument_1).objet))
                           .format).objet;
                   compteur = 1;
                   ordre = 1;
   
                   while((l_element_courant != NULL) &&
                           (l_element_courant_format != NULL))
                   {
                       if (compteur == clef)
                       {
                           l_element_courant = (*l_element_courant).suivant;
                           l_element_courant_format = (*l_element_courant_format)
                                   .suivant;
                           compteur++;
                           continue;
                       }
   
                       if ((s_element = allocation(s_etat_processus, LST)) == NULL)
                       {
                           (*s_etat_processus).erreur_systeme =
                                   d_es_allocation_memoire;
                           return;
                       }
   
                       if (((*s_element).objet =
                               allocation_maillon(s_etat_processus)) == NULL)
                       {
                           (*s_etat_processus).erreur_systeme =
                                   d_es_allocation_memoire;
                           return;
                       }
   
                       (*((struct_liste_chainee *) (*s_element).objet)).suivant
                               = NULL;
   
                       if ((s_format = allocation(s_etat_processus, LST)) == NULL)
                       {
                           (*s_etat_processus).erreur_systeme =
                                   d_es_allocation_memoire;
                           return;
                       }
   
                       if (((*s_format).objet =
                               allocation_maillon(s_etat_processus)) == NULL)
                       {
                           (*s_etat_processus).erreur_systeme =
                                   d_es_allocation_memoire;
                           return;
                       }
   
                       (*((struct_liste_chainee *) (*s_format).objet)).suivant
                               = NULL;
   
                       if (((*((struct_liste_chainee *) (*s_element).objet))
                               .donnee = copie_objet(s_etat_processus,
                               (*l_element_courant).donnee, 'N')) == NULL)
                       {
                           (*s_etat_processus).erreur_systeme =
                                   d_es_allocation_memoire;
                           return;
                       }
   
                       if (((*((struct_liste_chainee *) (*s_format).objet))
                               .donnee = copie_objet(s_etat_processus,
                               (*l_element_courant_format).donnee, 'N')) == NULL)
                       {
                           (*s_etat_processus).erreur_systeme =
                                   d_es_allocation_memoire;
                           return;
                       }
   
                       if ((chaine = formateur_fichier(s_etat_processus,
                               s_element, s_format, 0, 0, ' ',
                               'F', &longueur_effective, &recursivite)) == NULL)
                       {
                           free(clef_utf8);
   
                           liberation(s_etat_processus, s_element);
                           liberation(s_etat_processus, s_format);
                           liberation(s_etat_processus, s_objet_argument_2);
                           liberation(s_etat_processus, s_objet_argument_1);
   
                           return;
                       }
   
                       if ((chaine_utf8 = transliteration(s_etat_processus,
                               chaine, d_locale, "UTF-8")) == NULL)
                       {
                           free(clef_utf8);
                           free(chaine);
   
                           liberation(s_etat_processus, s_objet_argument_2);
                           liberation(s_etat_processus, s_objet_argument_1);
   
                           return;
                       }
   
                       free(chaine);
   
                       if (alsprintf(&commande, "insert into data "
                               "(data, key_id, sequence) values "
                               "('%s', %lld, %lld)", chaine_utf8, id, ordre) < 0)
                       {
                           (*s_etat_processus).erreur_systeme =
                                   d_es_allocation_memoire;
                           return;
                       }
   
                       if (sqlite3_prepare_v2((*descripteur).descripteur_sqlite,
                               commande, strlen(commande), &ppStmt, &queue)
                               != SQLITE_OK)
                       {
                           (*s_etat_processus).erreur_systeme =
                                   d_es_erreur_fichier;
                           return;
                       }
   
                       if (sqlite3_step(ppStmt) != SQLITE_DONE)
                       {
                           (*s_etat_processus).erreur_systeme =
                                   d_es_erreur_fichier;
                           return;
                       }
   
                       if (sqlite3_finalize(ppStmt) != SQLITE_OK)
                       {
                           (*s_etat_processus).erreur_systeme =
                                   d_es_erreur_fichier;
                           return;
                       }
   
                       free(commande);
                       free(chaine_utf8);
   
                       liberation(s_etat_processus, s_element);
                       liberation(s_etat_processus, s_format);
   
                       l_element_courant = (*l_element_courant).suivant;
                       l_element_courant_format = (*l_element_courant_format)
                               .suivant;
   
                       compteur++;
                       ordre++;
                   }
   
                   free(clef_utf8);
   
                   if ((l_element_courant != NULL) ||
                           (l_element_courant_format != NULL))
                   {
                       liberation(s_etat_processus, s_objet_argument_1);
                       liberation(s_etat_processus, s_objet_argument_2);
   
                       (*s_etat_processus).erreur_execution =
                               d_ex_erreur_format_fichier;
                       return;
                   }
               }
         }          }
         else if ((*((struct_fichier *) (*s_objet_argument_1).objet)).binaire          else if ((*((struct_fichier *) (*s_objet_argument_1).objet)).binaire
                 == 'Y')                  == 'Y')
Line 626  instruction_write(struct_processus *s_et Line 1354  instruction_write(struct_processus *s_et
             /*              /*
              * Fichiers de type FLOW               * Fichiers de type FLOW
              */               */
   
               if ((*((struct_fichier *) (*s_objet_argument_1).objet)).acces
                       == 'S')
               {
                   BUG(((*descripteur).type != 'C'), uprintf("Bad filetype !\n"));
   
                   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 ((*((struct_liste_chainee *) (*s_objet_argument_2).objet))
                           .donnee == 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_type_argument;
                       return;
                   }
   
                   l_element_courant = (*s_objet_argument_2).objet;
                   l_element_courant_format = (struct_liste_chainee *)
                           (*(*((struct_fichier *) (*s_objet_argument_1).objet))
                           .format).objet;
   
                   while((l_element_courant != NULL) &&
                           (l_element_courant_format != NULL))
                   {
                       if ((*(*l_element_courant).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 ((*(*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((unsigned char *)
                               (*(*l_element_courant_format).donnee).objet))
                               == NULL)
                       {
                           (*s_etat_processus).erreur_systeme =
                                   d_es_allocation_memoire;
                           return;
                       }
   
                       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 = 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]), "%ld", &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),
                                   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),
                                   longueur_effective,
                                   (*descripteur).descripteur_c) !=
                                   (size_t) longueur)
                           {
                               (*s_etat_processus).erreur_systeme =
                                       d_es_erreur_fichier;
                               return;
                           }
                       }
   
                       free(chaine);
   
                       l_element_courant = (*l_element_courant).suivant;
                       l_element_courant_format = (*l_element_courant_format)
                               .suivant;
                   }
   
                   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
               {
                   liberation(s_etat_processus, s_objet_argument_1);
                   liberation(s_etat_processus, s_objet_argument_2);
   
                   (*s_etat_processus).erreur_execution =
                           d_ex_erreur_type_fichier;
                   return;
               }
         }          }
     }      }
     else if (((*s_objet_argument_2).type == LST) &&      else if (((*s_objet_argument_2).type == LST) &&
Line 661  instruction_write(struct_processus *s_et Line 1567  instruction_write(struct_processus *s_et
   
                 return;                  return;
             }              }
           }
           else if ((*((struct_socket *) (*s_objet_argument_1).objet)).binaire
                   == 'Y')
           {
               /*
                * Sockets non formatées
                */
   
             if ((strcmp((*((struct_socket *) (*s_objet_argument_1).objet)).type,              chaine = NULL;
                     "STREAM") == 0) || (strcmp((*((struct_socket *)          }
                     (*s_objet_argument_1).objet)).type,          else
                     "SEQUENTIAL DATAGRAM") == 0))          {
             { // Sockets connectées              /*
                *  Sockets de type FLOW
                */
   
                 action.sa_handler = SIG_IGN;              if ((*((*((struct_liste_chainee *) (*s_objet_argument_2).objet))
                 action.sa_flags = SA_ONSTACK;                      .donnee)).type != CHN)
               {
                   liberation(s_etat_processus, s_objet_argument_2);
                   liberation(s_etat_processus, s_objet_argument_1);
   
                 if (sigaction(SIGPIPE, &action, &registre) != 0)                  (*s_etat_processus).erreur_execution =
                           d_ex_erreur_type_argument;
                   return;
               }
   
               if ((chaine = formateur_flux(s_etat_processus, (unsigned char *)
                       (*((*((struct_liste_chainee *) (*s_objet_argument_2)
                       .objet)).donnee)).objet, &longueur_effective)) == NULL)
               {
                   liberation(s_etat_processus, s_objet_argument_2);
                   liberation(s_etat_processus, s_objet_argument_1);
   
                   return;
               }
           }
   
           if ((strcmp((*((struct_socket *) (*s_objet_argument_1).objet)).type,
                   "STREAM") == 0) || (strcmp((*((struct_socket *)
                   (*s_objet_argument_1).objet)).type,
                   "SEQUENTIAL DATAGRAM") == 0))
           { // Sockets connectées
   
               action.sa_handler = SIG_IGN;
               action.sa_flags = SA_ONSTACK;
   
               if (sigaction(SIGPIPE, &action, &registre) != 0)
               {
                   (*s_etat_processus).erreur_systeme = d_es_signal;
                   return;
               }
   
   #           ifndef SEMAPHORES_NOMMES
                   if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0)
   #           else
                   if (sem_post((*s_etat_processus).semaphore_fork) != 0)
   #           endif
               {
                   if (sigaction(SIGPIPE, &registre, NULL) != 0)
                 {                  {
                     (*s_etat_processus).erreur_systeme = d_es_signal;                      (*s_etat_processus).erreur_systeme = d_es_signal;
                     return;                      return;
                 }                  }
   
                 if (sem_post(&((*s_etat_processus).semaphore_fork))                  (*s_etat_processus).erreur_systeme = d_es_processus;
                         != 0)                  return;
               }
   
               if (send((*((struct_socket *) (*s_objet_argument_1).objet))
                       .socket, chaine, longueur_effective, 0) < 0)
               {
                   ios = errno;
   
                   if (sigaction(SIGPIPE, &registre, NULL) != 0)
                 {                  {
                     if (sigaction(SIGPIPE, &registre, NULL) != 0)                      (*s_etat_processus).erreur_systeme = d_es_signal;
                       return;
                   }
   
   #               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_signal;                          (*s_etat_processus).erreur_systeme = d_es_processus;
                         return;                          return;
                     }                      }
                   }
   
                     (*s_etat_processus).erreur_systeme = d_es_processus;                  if ((ios == EPIPE) || (ios == ECONNRESET))
                   {
                       (*s_etat_processus).erreur_execution =
                               d_ex_erreur_acces_fichier;
                     return;                      return;
                 }                  }
   
                 if (send((*((struct_socket *) (*s_objet_argument_1).objet))                  (*s_etat_processus).erreur_systeme = d_es_erreur_fichier;
                         .socket, chaine, strlen(chaine), 0) < 0)                  return;
                 {              }
                     ios = errno;  
   
   #           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)
                   {
                     if (sigaction(SIGPIPE, &registre, NULL) != 0)                      if (sigaction(SIGPIPE, &registre, NULL) != 0)
                     {                      {
                         (*s_etat_processus).erreur_systeme = d_es_signal;                          (*s_etat_processus).erreur_systeme = d_es_signal;
                         return;                          return;
                     }                      }
   
                     while(sem_wait(&((*s_etat_processus).semaphore_fork)) == -1)                      (*s_etat_processus).erreur_systeme = d_es_processus;
                       return;
                   }
               }
   
               if (sigaction(SIGPIPE, &registre, NULL) != 0)
               {
                   (*s_etat_processus).erreur_systeme = d_es_signal;
                   return;
               }
           }
           else
           { // Sockets non connectées
   
               /*
                * Vérification de l'adresse distante
                */
   
               if (strcmp((*((struct_socket *) (*s_objet_argument_1).objet))
                       .adresse_distante, "") == 0)
               {
                   liberation(s_etat_processus, s_objet_argument_1);
                   liberation(s_etat_processus, s_objet_argument_2);
   
                   (*s_etat_processus).erreur_execution =
                           d_ex_erreur_acces_fichier;
                   return;
               }
   
               /*
                * Création de l'adresse logique
                */
   
               if ((*((struct_socket *) (*s_objet_argument_1).objet))
                       .domaine == PF_UNIX)
               {
                   adresse_unix.sun_family = AF_UNIX;
                   strncpy(adresse_unix.sun_path, (*((struct_socket *)
                           (*s_objet_argument_1).objet)).adresse_distante,
                           UNIX_PATH_MAX);
                   adresse_unix.sun_path[UNIX_PATH_MAX - 1] =
                           d_code_fin_chaine;
   
   #               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 (sendto((*((struct_socket *)
                           (*s_objet_argument_1).objet)).socket, chaine,
                           longueur_effective, 0, (struct sockaddr *)
                           &adresse_unix, sizeof(adresse_unix)) < 0)
                   {
                       ios = errno;
   
   #                   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)                          if (errno != EINTR)
                         {                          {
Line 710  instruction_write(struct_processus *s_et Line 1759  instruction_write(struct_processus *s_et
                         }                          }
                     }                      }
   
                     if (ios == EPIPE)                      if ((ios == EPIPE) || (ios == ECONNRESET))
                     {                      {
                         (*s_etat_processus).erreur_execution =                          (*s_etat_processus).erreur_execution =
                                 d_ex_erreur_acces_fichier;                                  d_ex_erreur_acces_fichier;
                         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;
                 }                  }
   
                 while(sem_wait(&((*s_etat_processus).semaphore_fork)) == -1)  #               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)                      if (errno != EINTR)
                     {                      {
                         if (sigaction(SIGPIPE, &registre, NULL) != 0)  
                         {  
                             (*s_etat_processus).erreur_systeme = d_es_signal;  
                             return;  
                         }  
   
                         (*s_etat_processus).erreur_systeme = d_es_processus;                          (*s_etat_processus).erreur_systeme = d_es_processus;
                         return;                          return;
                     }                      }
                 }                  }
   
                 if (sigaction(SIGPIPE, &registre, NULL) != 0)  
                 {  
                     (*s_etat_processus).erreur_systeme = d_es_signal;  
                     return;  
                 }  
             }              }
             else              else if ((*((struct_socket *) (*s_objet_argument_1).objet))
             { // Sockets non connectées                      .domaine == PF_INET)
               {
                 /*                  if (sscanf((*((struct_socket *)
                  * Vérification de l'adresse distante                          (*s_objet_argument_1).objet))
                  */                          .adresse_distante, "%d.%d.%d.%d(%d)",
                           &(adresse[0]), &(adresse[1]), &(adresse[2]),
                 if (strcmp((*((struct_socket *) (*s_objet_argument_1).objet))                          &(adresse[3]), &port) == 5)
                         .adresse_distante, "") == 0)                  { // Adresse IPv4
                 {                      calcul_adresse = 0;
                     liberation(s_etat_processus, s_objet_argument_1);                      for(i = 0; i < 4; calcul_adresse =
                     liberation(s_etat_processus, s_objet_argument_2);                              (256 * calcul_adresse) + adresse[i++]);
   
                     (*s_etat_processus).erreur_execution =                      memset(&adresse_ipv4, 0, sizeof(adresse_ipv4));
                             d_ex_erreur_acces_fichier;                      adresse_ipv4.sin_family = AF_INET;
                     return;                      adresse_ipv4.sin_port = htons(port);
                 }                      adresse_ipv4.sin_addr.s_addr = htonl(calcul_adresse);
   
                 /*  #                   ifndef SEMAPHORES_NOMMES
                  * Création de l'adresse logique                          if (sem_post(&((*s_etat_processus).semaphore_fork))
                  */                                  != 0)
   #                   else
                 if ((*((struct_socket *) (*s_objet_argument_1).objet))                          if (sem_post((*s_etat_processus).semaphore_fork) != 0)
                         .domaine == PF_UNIX)  #                   endif
                 {  
                     adresse_unix.sun_family = AF_UNIX;  
                     strncpy(adresse_unix.sun_path, (*((struct_socket *)  
                             (*s_objet_argument_1).objet)).adresse_distante,  
                             108);  
                     adresse_unix.sun_path[108 - 1] = d_code_fin_chaine;  
   
                     if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0)  
                     {                      {
                         (*s_etat_processus).erreur_systeme = d_es_processus;                          (*s_etat_processus).erreur_systeme = d_es_processus;
                         return;                          return;
Line 781  instruction_write(struct_processus *s_et Line 1821  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,
                             strlen(chaine), 0, (struct sockaddr *)                              longueur_effective, 0, (struct sockaddr *)
                             &adresse_unix, sizeof(adresse_unix)) < 0)                              &adresse_ipv4, sizeof(adresse_ipv4)) < 0)
                     {                      {
                         while(sem_wait(&((*s_etat_processus)                          ios = errno;
                                 .semaphore_fork)) == -1)  
   #                       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)                              if (errno != EINTR)
                             {                              {
Line 795  instruction_write(struct_processus *s_et Line 1842  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;
                     }                      }
   
                     while(sem_wait(&((*s_etat_processus).semaphore_fork)) == -1)  #                   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)                          if (errno != EINTR)
                         {                          {
Line 809  instruction_write(struct_processus *s_et Line 1875  instruction_write(struct_processus *s_et
                         }                          }
                     }                      }
                 }                  }
                 else if ((*((struct_socket *) (*s_objet_argument_1).objet))                  else
                         .domaine == PF_INET)  
                 {                  {
                     if (sscanf((*((struct_socket *)                      liberation(s_etat_processus, s_objet_argument_1);
                             (*s_objet_argument_1).objet))                      liberation(s_etat_processus, s_objet_argument_2);
                             .adresse_distante, "%d.%d.%d.%d(%d)",  
                             &(adresse[0]), &(adresse[1]), &(adresse[2]),  
                             &(adresse[3]), &port) == 5)  
                     { // Adresse IPv4  
                         calcul_adresse = 0;  
                         for(i = 0; i < 4; calcul_adresse =  
                                 (256 * calcul_adresse) + adresse[i++]);  
   
                         memset(&adresse_ipv4, 0, sizeof(adresse_ipv4));  
                         adresse_ipv4.sin_family = AF_INET;  
                         adresse_ipv4.sin_port = htons(port);  
                         adresse_ipv4.sin_addr.s_addr = htonl(calcul_adresse);  
   
                         if (sem_post(&((*s_etat_processus)  
                                 .semaphore_fork)) != 0)  
                         {  
                             (*s_etat_processus).erreur_systeme = d_es_processus;  
                             return;  
                         }  
   
                         if (sendto((*((struct_socket *)                      (*s_etat_processus).erreur_execution =
                                 (*s_objet_argument_1).objet)).socket, chaine,                              d_ex_erreur_parametre_fichier;
                                 strlen(chaine), 0, (struct sockaddr *)                      return;
                                 &adresse_ipv4, sizeof(adresse_ipv4)) < 0)                  }
                         {              }
                             while(sem_wait(&((*s_etat_processus)              else if ((*((struct_socket *) (*s_objet_argument_1).objet))
                                     .semaphore_fork)) == -1)                      .domaine == PF_INET6)
                             {              {
                                 if (errno != EINTR)                  if (sscanf((*((struct_socket *) (*s_objet_argument_1)
                                 {                          .objet)).adresse_distante, "%X:%X:%X:%X:%X:"
                                     (*s_etat_processus).erreur_systeme =                          "%X:%X:%X:%X:%X:%X:%X:%X:%X:%X:%X(%d)",
                                             d_es_processus;                          &(adresse[0]), &(adresse[1]), &(adresse[2]),
                                     return;                          &(adresse[3]), &(adresse[4]), &(adresse[5]),
                                 }                          &(adresse[6]), &(adresse[7]), &(adresse[8]),
                             }                          &(adresse[9]), &(adresse[10]), &(adresse[11]),
                           &(adresse[12]), &(adresse[13]), &(adresse[14]),
                           &(adresse[15]), &port)== 17)
                   { // Adresse IPv6
   #                   ifdef IPV6
                       memset(&adresse_ipv6, 0, sizeof(adresse_ipv6));
                       adresse_ipv6.sin6_family = AF_INET6;
                       adresse_ipv6.sin6_port = htons((uint16_t) port);
   
                       for(i = 0; i < 16;
                               adresse_ipv6.sin6_addr.s6_addr[i] =
                               adresse[i], i++);
   
   #                   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;
                       }
   
                             (*s_etat_processus).erreur_systeme =                      if (sendto((*((struct_socket *)
                                     d_es_erreur_fichier;                              (*s_objet_argument_1).objet)).socket, chaine,
                             return;                              longueur_effective, 0, (struct sockaddr *)
                         }                              &adresse_ipv6, sizeof(adresse_ipv6)) < 0)
                       {
                           ios = errno;
   
                         while(sem_wait(&((*s_etat_processus)  #                       ifndef SEMAPHORES_NOMMES
                                 .semaphore_fork)) == -1)                              while(sem_wait(&((*s_etat_processus)
                                       .semaphore_fork)) != 0)
   #                       else
                               while(sem_wait((*s_etat_processus)
                                       .semaphore_fork) != 0)
   #                       endif
                         {                          {
                             if (errno != EINTR)                              if (errno != EINTR)
                             {                              {
Line 865  instruction_write(struct_processus *s_et Line 1940  instruction_write(struct_processus *s_et
                                 return;                                  return;
                             }                              }
                         }                          }
                     }  
                     else  
                     {  
                         liberation(s_etat_processus, s_objet_argument_1);  
                         liberation(s_etat_processus, s_objet_argument_2);  
   
                         (*s_etat_processus).erreur_execution =                          if ((ios == EPIPE) || (ios == ECONNRESET))
                                 d_ex_erreur_parametre_fichier;  
                         return;  
                     }  
                 }  
                 else if ((*((struct_socket *) (*s_objet_argument_1).objet))  
                         .domaine == PF_INET6)  
                 {  
                     if (sscanf((*((struct_socket *) (*s_objet_argument_1)  
                             .objet)).adresse_distante, "%X:%X:%X:%X:%X:"  
                             "%X:%X:%X:%X:%X:%X:%X:%X:%X:%X:%X(%d)",  
                             &(adresse[0]), &(adresse[1]), &(adresse[2]),  
                             &(adresse[3]), &(adresse[4]), &(adresse[5]),  
                             &(adresse[6]), &(adresse[7]), &(adresse[8]),  
                             &(adresse[9]), &(adresse[10]), &(adresse[11]),  
                             &(adresse[12]), &(adresse[13]), &(adresse[14]),  
                             &(adresse[15]), &port)== 17)  
                     { // Adresse IPv6  
                         memset(&adresse_ipv6, 0, sizeof(adresse_ipv6));  
                         adresse_ipv6.sin6_family = AF_INET6;  
                         adresse_ipv6.sin6_port = htons((uint16_t) port);  
   
                         for(i = 0; i < 16;  
                                 adresse_ipv6.sin6_addr.s6_addr[i] =  
                                 adresse[i], i++);  
   
                         if (sem_post(&((*s_etat_processus)  
                                 .semaphore_fork)) != 0)  
                         {                          {
                             (*s_etat_processus).erreur_systeme = d_es_processus;                              (*s_etat_processus).erreur_execution =
                                       d_ex_erreur_acces_fichier;
                             return;                              return;
                         }                          }
   
                         if (sendto((*((struct_socket *)                          if (ios == EMSGSIZE)
                                 (*s_objet_argument_1).objet)).socket, chaine,  
                                 strlen(chaine), 0, (struct sockaddr *)  
                                 &adresse_ipv6, sizeof(adresse_ipv6)) < 0)  
                         {                          {
                             while(sem_wait(&((*s_etat_processus)                              (*s_etat_processus).erreur_execution =
                                     .semaphore_fork)) == -1)                                      d_ex_taille_message;
                             {  
                                 if (errno != EINTR)  
                                 {  
                                     (*s_etat_processus).erreur_systeme =  
                                             d_es_processus;  
                                     return;  
                                 }  
                             }  
   
                             (*s_etat_processus).erreur_systeme =  
                                     d_es_erreur_fichier;  
                             return;                              return;
                         }                          }
   
                         while(sem_wait(&((*s_etat_processus)                          (*s_etat_processus).erreur_systeme =
                                 .semaphore_fork)) == -1)                                  d_es_erreur_fichier;
                           return;
                       }
   
   #                   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)
                         {                          {
                             if (errno != EINTR)                              (*s_etat_processus).erreur_systeme =
                             {                                      d_es_processus;
                                 (*s_etat_processus).erreur_systeme =                              return;
                                         d_es_processus;  
                                 return;  
                             }  
                         }                          }
                     }                      }
   #                   else
                       if ((*s_etat_processus).langue == 'F')
                       {
                           printf("+++Attention : Support du protocole"
                                   " IPv6 indisponible\n");
                       }
                     else                      else
                     {                      {
                         liberation(s_etat_processus, s_objet_argument_1);                          printf("+++Warning : IPv6 support "
                         liberation(s_etat_processus, s_objet_argument_2);                                  "unavailable\n");
   
                         (*s_etat_processus).erreur_execution =  
                                 d_ex_erreur_parametre_fichier;  
                         return;  
                     }                      }
   #                   endif
                 }                  }
                 else                   else
                 {                  {
                     liberation(s_etat_processus, s_objet_argument_1);                      liberation(s_etat_processus, s_objet_argument_1);
                     liberation(s_etat_processus, s_objet_argument_2);                      liberation(s_etat_processus, s_objet_argument_2);
Line 956  instruction_write(struct_processus *s_et Line 1997  instruction_write(struct_processus *s_et
                     return;                      return;
                 }                  }
             }              }
               else 
               {
                   liberation(s_etat_processus, s_objet_argument_1);
                   liberation(s_etat_processus, s_objet_argument_2);
   
             free(chaine);                  (*s_etat_processus).erreur_execution =
         }                          d_ex_erreur_parametre_fichier;
         else if ((*((struct_socket *) (*s_objet_argument_1).objet)).binaire                  return;
                 == 'Y')              }
         {  
             /*  
              * Sockets non formatées  
              */  
         }  
         else  
         {  
             /*  
              *  Sockets de type FLOW  
              */  
         }          }
   
           free(chaine);
     }      }
     else      else
     {      {
Line 1132  instruction_wflock(struct_processus *s_e Line 2169  instruction_wflock(struct_processus *s_e
                 return;                  return;
             }              }
   
             if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0)  #           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;                  (*s_etat_processus).erreur_systeme = d_es_processus;
                 return;                  return;
             }              }
   
             while(sem_wait(&((*s_etat_processus).semaphore_fork)) == -1)  #           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)                  if (errno != EINTR)
                 {                  {
Line 1361  instruction_wfproc(struct_processus *s_e Line 2406  instruction_wfproc(struct_processus *s_e
                 if ((*(*((struct_processus_fils *) (*(*l_element_courant)                  if ((*(*((struct_processus_fils *) (*(*l_element_courant)
                         .donnee).objet)).thread).processus_detache == d_vrai)                          .donnee).objet)).thread).processus_detache == d_vrai)
                 {                  {
                     if (kill((*(*((struct_processus_fils *)                      if (envoi_signal_processus((*(*((struct_processus_fils *)
                             (*(*l_element_courant).donnee).objet)).thread).pid,                              (*(*l_element_courant).donnee).objet)).thread).pid,
                             0) != 0)                              rpl_signull) != 0)
                     {                      {
                         drapeau_fin = d_vrai;                          drapeau_fin = d_vrai;
                     }                      }
Line 1447  instruction_wfproc(struct_processus *s_e Line 2492  instruction_wfproc(struct_processus *s_e
                                 registre_instruction_valide;                                  registre_instruction_valide;
                     }                      }
   
                     if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0)  #                   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;                          (*s_etat_processus).erreur_systeme = d_es_processus;
                         return;                          return;
Line 1455  instruction_wfproc(struct_processus *s_e Line 2505  instruction_wfproc(struct_processus *s_e
   
                     nanosleep(&attente, NULL);                      nanosleep(&attente, NULL);
   
                     while(sem_wait(&((*s_etat_processus).semaphore_fork)) == -1)  #                   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)                          if (errno != EINTR)
                         {                          {
Line 1706  instruction_wfdata(struct_processus *s_e Line 2761  instruction_wfdata(struct_processus *s_e
                         return;                          return;
                     }                      }
   
                     if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0)  #                   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;                          (*s_etat_processus).erreur_systeme = d_es_processus;
                         return;                          return;
Line 1714  instruction_wfdata(struct_processus *s_e Line 2774  instruction_wfdata(struct_processus *s_e
   
                     nanosleep(&attente, NULL);                      nanosleep(&attente, NULL);
   
                     while(sem_wait(&((*s_etat_processus).semaphore_fork)) == -1)  #                   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)                          if (errno != EINTR)
                         {                          {
Line 1823  instruction_wfsock(struct_processus *s_e Line 2888  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
     struct sockaddr_in6     adresse_ipv6;      struct sockaddr_in6     adresse_ipv6;
   #   endif
   
     unsigned long           i;      unsigned long           i;
   
Line 1874  instruction_wfsock(struct_processus *s_e Line 2943  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;              if ((s_objet_resultat = copie_objet(s_etat_processus,
             return;                      s_objet_argument, 'P')) == NULL)
         }              {
                   (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
         if ((s_objet_resultat = copie_objet(s_etat_processus, s_objet_argument,                  return;
                 'O')) == NULL)              }
         {  
             (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;  
             return;  
         }  
   
         (*((struct_socket *) (*s_objet_resultat).objet)).socket_en_ecoute = 'N';  
         (*((struct_socket *) (*s_objet_resultat).objet)).effacement = 'N';  
   
         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
                 if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0)                  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;                      (*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;
   
                     while(sem_wait(&((*s_etat_processus).semaphore_fork)) == -1)  #                   ifndef SEMAPHORES_NOMMES
                     {                      while(sem_wait(&((*s_etat_processus)
                         if (errno != EINTR)                              .semaphore_fork)) != 0)
                         {  #                   else
                             (*s_etat_processus).erreur_systeme = d_es_processus;                      while(sem_wait((*s_etat_processus).semaphore_fork)
                             return;                              != 0)
                         }  #                   endif
                     }  
   
                     if (erreur != EINTR)                      if (erreur != EINTR)
                     {                      {
Line 1943  instruction_wfsock(struct_processus *s_e Line 3005  instruction_wfsock(struct_processus *s_e
                 }                  }
                 else                  else
                 {                  {
                     while(sem_wait(&((*s_etat_processus).semaphore_fork)) == -1)  #                   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)                          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)  
         {          {
             longueur = sizeof(adresse_ipv6);              // Mode connecté
   
             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;
               }
   
                 if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0)              (*((struct_socket *) (*s_objet_resultat).objet)).effacement = 'N';
                 {              (*((struct_socket *) (*s_objet_resultat).objet)).socket_en_ecoute
                     (*s_etat_processus).erreur_systeme = d_es_processus;                      = 'N';
                     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;
   
                     while(sem_wait(&((*s_etat_processus).semaphore_fork)) == -1)  #               ifndef SEMAPHORES_NOMMES
                           if (sem_post(&((*s_etat_processus).semaphore_fork))
                                   != 0)
   #               else
                           if (sem_post((*s_etat_processus).semaphore_fork) != 0)
   #               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;
                               }
                           }
                     }                      }
                 }                  } while(drapeau == d_faux);
                 else  
                   if (((*((struct_socket *) (*s_objet_resultat).objet))
                           .adresse_distante = malloc(22 *
                           sizeof(unsigned char))) == NULL)
                 {                  {
                     while(sem_wait(&((*s_etat_processus).semaphore_fork)) == -1)                      (*s_etat_processus).erreur_systeme =
                               d_es_allocation_memoire;
                       return;
                   }
   
                   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
                           if (sem_post(&((*s_etat_processus).semaphore_fork))
                                   != 0)
   #               else
                           if (sem_post((*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))
                               .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
                       {
   #                   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;
                               }
                           }
                     }                      }
                   } while(drapeau == d_faux);
   
                   if (((*((struct_socket *) (*s_objet_resultat).objet))
                           .adresse_distante = malloc(55 *
                           sizeof(unsigned char))) == NULL)
                   {
                       (*s_etat_processus).erreur_systeme =
                               d_es_allocation_memoire;
                       return;
                 }                  }
             } while(drapeau == d_faux);  
   
             if (((*((struct_socket *) (*s_objet_resultat).objet))                  (*((struct_socket *) (*s_objet_resultat).objet))
                     .adresse_distante = malloc(55 *                          .adresse_distante = d_code_fin_chaine;
                     sizeof(unsigned char))) == NULL)  
             {  
                 (*s_etat_processus).erreur_systeme =  
                         d_es_allocation_memoire;  
                 return;  
             }  
   
             (*((struct_socket *) (*s_objet_resultat).objet))                  for(i = 0; i < 16; i++)
                     .adresse_distante = d_code_fin_chaine;                  {
                       sprintf((*((struct_socket *) (*s_objet_resultat)
                               .objet)).adresse_distante, (i == 0) ? "%s%X"
                               : "%s:%X", (*((struct_socket *) (*s_objet_resultat)
                               .objet)).adresse_distante,
                               adresse_ipv6.sin6_addr.s6_addr[i]);
                   }
   
             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",                          .objet)).adresse_distante, "%s(%u)",
                         (*((struct_socket *) (*s_objet_resultat)                          (*((struct_socket *) (*s_objet_resultat)
                         .objet)).adresse_distante,                          .objet)).adresse_distante,
                         adresse_ipv6.sin6_addr.s6_addr[i]);                          ntohs(adresse_ipv6.sin6_port));
   #           else
                   if ((*s_etat_processus).langue == 'F')
                   {
                       printf("+++Attention : Support du protocole"
                               " IPv6 indisponible\n");
                   }
                   else
                   {
                       printf("+++Warning : IPv6 support "
                               "unavailable\n");
                   }
   #           endif
             }              }
               else
             sprintf((*((struct_socket *) (*s_objet_resultat)  
                     .objet)).adresse_distante, "%s(%u)",  
                     (*((struct_socket *) (*s_objet_resultat)  
                     .objet)).adresse_distante, ntohs(adresse_ipv6.sin6_port));  
         }  
         else  
         {  
             longueur = 0;  
   
             do  
             {              {
                 drapeau = d_vrai;                  longueur = 0;
   
                 if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0)                  do
                 {                  {
                     (*s_etat_processus).erreur_systeme = d_es_processus;                      drapeau = d_vrai;
                     return;  
                 }  
   
                 if (((*((struct_socket *) (*s_objet_resultat).objet)).socket =  #               ifndef SEMAPHORES_NOMMES
                         accept((*((struct_socket *) (*s_objet_argument).objet))                          if (sem_post(&((*s_etat_processus).semaphore_fork))
                         .socket, NULL, &longueur)) < 0)                                  != 0)
                 {  #               else
                     erreur = errno;                          if (sem_post((*s_etat_processus).semaphore_fork) != 0)
   #               endif
                       {
                           (*s_etat_processus).erreur_systeme = d_es_processus;
                           return;
                       }
   
                     while(sem_wait(&((*s_etat_processus).semaphore_fork)) == -1)                      if (((*((struct_socket *) (*s_objet_resultat).objet))
                               .socket = accept((*((struct_socket *)
                               (*s_objet_argument).objet)).socket, NULL,
                               &longueur)) < 0)
                     {                      {
                         if (errno != EINTR)                          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)
                             return;                              {
                                   (*s_etat_processus).erreur_systeme =
                                           d_es_processus;
                                   return;
                               }
                         }                          }
                     }  
   
                     if (erreur != EINTR)                          if (erreur != EINTR)
                     {                          {
                         liberation(s_etat_processus, s_objet_argument);                              liberation(s_etat_processus, s_objet_argument);
                         liberation(s_etat_processus, s_objet_resultat);                              liberation(s_etat_processus, s_objet_resultat);
   
                         (*s_etat_processus).erreur_execution =                              (*s_etat_processus).erreur_execution =
                                 d_ex_erreur_acces_fichier;                                      d_ex_erreur_acces_fichier;
                         return;                              return;
                     }                          }
   
                     scrutation_injection(s_etat_processus);                          scrutation_injection(s_etat_processus);
   
                     if ((*s_etat_processus).var_volatile_requete_arret != 0)                          if ((*s_etat_processus).var_volatile_requete_arret != 0)
                     {                          {
                         drapeau = d_vrai;                              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)
                     while(sem_wait(&((*s_etat_processus).semaphore_fork)) == -1)                                      != 0)
                     {  #                   endif
                         if (errno != EINTR)  
                         {                          {
                             (*s_etat_processus).erreur_systeme = d_es_processus;                              if (errno != EINTR)
                             return;                              {
                                   (*s_etat_processus).erreur_systeme =
                                           d_es_processus;
                                   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 2400  instruction_wfpoke(struct_processus *s_e Line 3636  instruction_wfpoke(struct_processus *s_e
   
     do      do
     {      {
         if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0)  #       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;              (*s_etat_processus).erreur_systeme = d_es_processus;
             return;              return;
Line 2408  instruction_wfpoke(struct_processus *s_e Line 3648  instruction_wfpoke(struct_processus *s_e
   
         nanosleep(&attente, NULL);          nanosleep(&attente, NULL);
   
         while(sem_wait(&((*s_etat_processus).semaphore_fork)) == -1)  #       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)              if (errno != EINTR)
             {              {
Line 2550  instruction_wfack(struct_processus *s_et Line 3794  instruction_wfack(struct_processus *s_et
             return;              return;
         }          }
   
         if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0)  #       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;              (*s_etat_processus).erreur_systeme = d_es_processus;
             return;              return;
Line 2559  instruction_wfack(struct_processus *s_et Line 3807  instruction_wfack(struct_processus *s_et
         nanosleep(&attente, NULL);          nanosleep(&attente, NULL);
         INCR_GRANULARITE(attente.tv_nsec);          INCR_GRANULARITE(attente.tv_nsec);
   
         while(sem_wait(&((*s_etat_processus).semaphore_fork)) == -1)  #       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)              if (errno != EINTR)
             {              {

Removed from v.1.5  
changed lines
  Added in v.1.74


CVSweb interface <joel.bertrand@systella.fr>