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

version 1.52, 2011/09/26 15:57:16 version 1.63, 2012/06/21 16:07:25
Line 1 Line 1
 /*  /*
 ================================================================================  ================================================================================
   RPL/2 (R) version 4.1.4    RPL/2 (R) version 4.1.9
   Copyright (C) 1989-2011 Dr. BERTRAND Joël    Copyright (C) 1989-2012 Dr. BERTRAND Joël
   
   This file is part of RPL/2.    This file is part of RPL/2.
   
Line 428  instruction_write(struct_processus *s_et Line 428  instruction_write(struct_processus *s_et
     unsigned char                       *chaine_utf8;      unsigned char                       *chaine_utf8;
     unsigned char                       *clef_utf8;      unsigned char                       *clef_utf8;
     unsigned char                       *commande;      unsigned char                       *commande;
       unsigned char                       retour;
   
     unsigned long                       i;      unsigned long                       i;
   
Line 1328  instruction_write(struct_processus *s_et Line 1329  instruction_write(struct_processus *s_et
             {              {
                 BUG(((*descripteur).type != 'C'), uprintf("Bad filetype !\n"));                  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;
                   }
   
                 if ((*((*((struct_liste_chainee *) (*s_objet_argument_2).objet))                  if ((*((*((struct_liste_chainee *) (*s_objet_argument_2).objet))
                         .donnee)).type != CHN)                          .donnee)).type != CHN)
                 {                  {
Line 1357  instruction_write(struct_processus *s_et Line 1379  instruction_write(struct_processus *s_et
                 }                  }
   
                 free(chaine);                  free(chaine);
   
                   // Le fichier de type FLOW est à accès séquentiel. Il
                   // convient d'ajouter un retour à la ligne pour l'opération
                   // de lecture.
   
                   retour = d_code_retour_chariot;
   
                   if (fwrite(&retour, sizeof(unsigned char), 1,
                           (*descripteur).descripteur_c) != 1)
                   {
                       (*s_etat_processus).erreur_systeme = d_es_erreur_fichier;
                       return;
                   }
             }              }
             else              else
             {              {
Line 2685  instruction_wfsock(struct_processus *s_e Line 2720  instruction_wfsock(struct_processus *s_e
     struct_objet            *s_objet_argument;      struct_objet            *s_objet_argument;
     struct_objet            *s_objet_resultat;      struct_objet            *s_objet_resultat;
   
       struct pollfd           s_poll;
   
     struct sockaddr_in      adresse_ipv4;      struct sockaddr_in      adresse_ipv4;
 #   ifdef IPV6  #   ifdef IPV6
     struct sockaddr_in6     adresse_ipv6;      struct sockaddr_in6     adresse_ipv6;
Line 2738  instruction_wfsock(struct_processus *s_e Line 2775  instruction_wfsock(struct_processus *s_e
                 "STREAM") != 0) && (strcmp((*((struct_socket *)                  "STREAM") != 0) && (strcmp((*((struct_socket *)
                 (*s_objet_argument).objet)).type, "SEQUENTIAL DATAGRAM") != 0))                  (*s_objet_argument).objet)).type, "SEQUENTIAL DATAGRAM") != 0))
         {          {
             liberation(s_etat_processus, s_objet_argument);              // Mode non connecté : l'attente se fait sur un poll()
   
             (*s_etat_processus).erreur_execution = d_ex_erreur_acces_fichier;  
             return;  
         }  
   
         if ((s_objet_resultat = copie_objet(s_etat_processus, s_objet_argument,  
                 'O')) == NULL)  
         {  
             (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;  
             return;  
         }  
   
         (*((struct_socket *) (*s_objet_resultat).objet)).socket_en_ecoute = 'N';              if ((s_objet_resultat = copie_objet(s_etat_processus,
         (*((struct_socket *) (*s_objet_resultat).objet)).effacement = 'N';                      s_objet_argument, 'P')) == NULL)
               {
                   (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
                   return;
               }
   
         if ((*((struct_socket *) (*s_objet_resultat).objet)).domaine == PF_INET)              s_poll.fd = (*((struct_socket *) (*s_objet_argument).objet)).socket;
         {              s_poll.events = POLLIN;
             longueur = sizeof(adresse_ipv4);              s_poll.revents = 0;
   
             do              do
             {              {
                 drapeau = d_vrai;                  drapeau = d_vrai;
   
 #               ifndef SEMAPHORES_NOMMES  #               ifndef SEMAPHORES_NOMMES
                     if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0)                  if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0)
 #               else  #               else
                     if (sem_post((*s_etat_processus).semaphore_fork) != 0)                  if (sem_post((*s_etat_processus).semaphore_fork) != 0)
 #               endif  #               endif
                 {                  {
                     (*s_etat_processus).erreur_systeme = d_es_processus;                      (*s_etat_processus).erreur_systeme = d_es_processus;
                     return;                      return;
                 }                  }
   
                 if (((*((struct_socket *) (*s_objet_resultat).objet)).socket =                  if (poll(&s_poll, 1, -1) < 0)
                         accept((*((struct_socket *) (*s_objet_argument).objet))  
                         .socket, (struct sockaddr *) &adresse_ipv4, &longueur))  
                         < 0)  
                 {                  {
                     erreur = errno;                      erreur = errno;
   
 #                   ifndef SEMAPHORES_NOMMES  #                   ifndef SEMAPHORES_NOMMES
                         while(sem_wait(&((*s_etat_processus).semaphore_fork))                      while(sem_wait(&((*s_etat_processus)
                                 != 0)                              .semaphore_fork)) != 0)
 #                   else  #                   else
                         while(sem_wait((*s_etat_processus).semaphore_fork) != 0)                      while(sem_wait((*s_etat_processus).semaphore_fork)
                               != 0)
 #                   endif  #                   endif
                     {  
                         if (errno != EINTR)  
                         {  
                             (*s_etat_processus).erreur_systeme = d_es_processus;  
                             return;  
                         }  
                     }  
   
                     if (erreur != EINTR)                      if (erreur != EINTR)
                     {                      {
Line 2817  instruction_wfsock(struct_processus *s_e Line 2838  instruction_wfsock(struct_processus *s_e
                 else                  else
                 {                  {
 #                   ifndef SEMAPHORES_NOMMES  #                   ifndef SEMAPHORES_NOMMES
                         while(sem_wait(&((*s_etat_processus).semaphore_fork))                          while(sem_wait(&((*s_etat_processus)
                                 != 0)                                  .semaphore_fork)) != 0)
 #                   else  #                   else
                         while(sem_wait((*s_etat_processus).semaphore_fork) != 0)                          while(sem_wait((*s_etat_processus).semaphore_fork)
                                   != 0)
 #                   endif  #                   endif
                     {                      {
                         if (errno != EINTR)                          if (errno != EINTR)
                         {                          {
                             (*s_etat_processus).erreur_systeme = d_es_processus;                              (*s_etat_processus).erreur_systeme =
                                       d_es_processus;
                             return;                              return;
                         }                          }
                     }                      }
                 }                  }
             } while(drapeau == d_faux);              } while(drapeau == d_faux);
   
             if (((*((struct_socket *) (*s_objet_resultat).objet))              if (empilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
                     .adresse_distante = malloc(22 *                      s_objet_argument) == d_erreur)
                     sizeof(unsigned char))) == NULL)  
             {              {
                 (*s_etat_processus).erreur_systeme =  
                         d_es_allocation_memoire;  
                 return;                  return;
             }              }
   
             sprintf((*((struct_socket *) (*s_objet_resultat).objet))              if (empilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
                     .adresse_distante, "%d.%d.%d.%d(%d)",                      s_objet_resultat) == d_erreur)
                     (ntohl(adresse_ipv4.sin_addr.s_addr) >> 24) & 0xFF,              {
                     (ntohl(adresse_ipv4.sin_addr.s_addr) >> 16) & 0xFF,                  return;
                     (ntohl(adresse_ipv4.sin_addr.s_addr) >> 8) & 0xFF,              }
                     ntohl(adresse_ipv4.sin_addr.s_addr) & 0xFF,  
                     ntohs(adresse_ipv4.sin_port));  
         }          }
         else if ((*((struct_socket *) (*s_objet_resultat).objet)).domaine ==          else
                 PF_INET6)  
         {          {
 #           ifdef IPV6              // Mode connecté
             longueur = sizeof(adresse_ipv6);  
   
             do              if ((s_objet_resultat = copie_objet(s_etat_processus,
                       s_objet_argument, 'O')) == NULL)
             {              {
                 drapeau = d_vrai;                  (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
                   return;
               }
   
               (*((struct_socket *) (*s_objet_resultat).objet)).effacement = 'N';
               (*((struct_socket *) (*s_objet_resultat).objet)).socket_en_ecoute
                       = 'N';
   
               if ((*((struct_socket *) (*s_objet_resultat).objet)).domaine ==
                       PF_INET)
               {
                   longueur = sizeof(adresse_ipv4);
   
                   do
                   {
                       drapeau = d_vrai;
   
 #               ifndef SEMAPHORES_NOMMES  #               ifndef SEMAPHORES_NOMMES
                     if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0)                          if (sem_post(&((*s_etat_processus).semaphore_fork))
                                   != 0)
 #               else  #               else
                     if (sem_post((*s_etat_processus).semaphore_fork) != 0)                          if (sem_post((*s_etat_processus).semaphore_fork) != 0)
 #               endif  #               endif
                       {
                           (*s_etat_processus).erreur_systeme = d_es_processus;
                           return;
                       }
   
                       if (((*((struct_socket *) (*s_objet_resultat).objet))
                               .socket = accept((*((struct_socket *)
                               (*s_objet_argument).objet)).socket,
                               (struct sockaddr *) &adresse_ipv4, &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
                           {
                               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;
                           }
   
                           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(22 *
                           sizeof(unsigned char))) == NULL)
                 {                  {
                     (*s_etat_processus).erreur_systeme = d_es_processus;                      (*s_etat_processus).erreur_systeme =
                               d_es_allocation_memoire;
                     return;                      return;
                 }                  }
   
                 if (((*((struct_socket *) (*s_objet_resultat).objet)).socket =                  sprintf((*((struct_socket *) (*s_objet_resultat).objet))
                         accept((*((struct_socket *) (*s_objet_argument).objet))                          .adresse_distante, "%d.%d.%d.%d(%d)",
                         .socket, (struct sockaddr *) &adresse_ipv6, &longueur))                          (ntohl(adresse_ipv4.sin_addr.s_addr) >> 24) & 0xFF,
                         < 0)                          (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
                 {                  {
                     erreur = errno;                      drapeau = d_vrai;
   
 #                   ifndef SEMAPHORES_NOMMES  #               ifndef SEMAPHORES_NOMMES
                         while(sem_wait(&((*s_etat_processus).semaphore_fork))                          if (sem_post(&((*s_etat_processus).semaphore_fork))
                                 != 0)                                  != 0)
   #               else
                           if (sem_post((*s_etat_processus).semaphore_fork) != 0)
   #               endif
                       {
                           (*s_etat_processus).erreur_systeme = d_es_processus;
                           return;
                       }
   
                       if (((*((struct_socket *) (*s_objet_resultat).objet))
                               .socket = 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  #                   else
                         while(sem_wait((*s_etat_processus).semaphore_fork) != 0)                              while(sem_wait((*s_etat_processus).semaphore_fork)
                                       != 0)
 #                   endif  #                   endif
                     {  
                         if (errno != EINTR)  
                         {                          {
                             (*s_etat_processus).erreur_systeme = d_es_processus;                              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;  
                     }  
                 }  
                 else  
                 {  
 #                   ifndef SEMAPHORES_NOMMES  #                   ifndef SEMAPHORES_NOMMES
                         while(sem_wait(&((*s_etat_processus).semaphore_fork))                              while(sem_wait(&((*s_etat_processus)
                                 != 0)                                      .semaphore_fork)) != 0)
 #                   else  #                   else
                         while(sem_wait((*s_etat_processus).semaphore_fork) != 0)                              while(sem_wait((*s_etat_processus).semaphore_fork)
                                       != 0)
 #                   endif  #                   endif
                     {  
                         if (errno != EINTR)  
                         {                          {
                             (*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);
   
                   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));
             }  
   
             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  #           else
             if ((*s_etat_processus).langue == 'F')                  if ((*s_etat_processus).langue == 'F')
             {                  {
                 printf("+++Attention : Support du protocole"                      printf("+++Attention : Support du protocole"
                         " IPv6 indisponible\n");                              " IPv6 indisponible\n");
                   }
                   else
                   {
                       printf("+++Warning : IPv6 support "
                               "unavailable\n");
                   }
   #           endif
             }              }
             else              else
             {              {
                 printf("+++Warning : IPv6 support "                  longueur = 0;
                         "unavailable\n");  
             }  
 #           endif  
         }  
         else  
         {  
             longueur = 0;  
   
             do                  do
             {                  {
                 drapeau = d_vrai;                      drapeau = d_vrai;
   
 #               ifndef SEMAPHORES_NOMMES  #               ifndef SEMAPHORES_NOMMES
                     if (sem_post(&((*s_etat_processus).semaphore_fork)) != 0)                          if (sem_post(&((*s_etat_processus).semaphore_fork))
                                   != 0)
 #               else  #               else
                     if (sem_post((*s_etat_processus).semaphore_fork) != 0)                          if (sem_post((*s_etat_processus).semaphore_fork) != 0)
 #               endif  #               endif
                 {                      {
                     (*s_etat_processus).erreur_systeme = d_es_processus;                          (*s_etat_processus).erreur_systeme = d_es_processus;
                     return;                          return;
                 }                      }
   
                 if (((*((struct_socket *) (*s_objet_resultat).objet)).socket =                      if (((*((struct_socket *) (*s_objet_resultat).objet))
                         accept((*((struct_socket *) (*s_objet_argument).objet))                              .socket = accept((*((struct_socket *)
                         .socket, NULL, &longueur)) < 0)                              (*s_objet_argument).objet)).socket, NULL,
                 {                              &longueur)) < 0)
                     erreur = errno;                      {
                           erreur = errno;
   
 #                   ifndef SEMAPHORES_NOMMES  #                   ifndef SEMAPHORES_NOMMES
                         while(sem_wait(&((*s_etat_processus).semaphore_fork))                              while(sem_wait(&((*s_etat_processus)
                                 != 0)                                      .semaphore_fork)) != 0)
 #                   else  #                   else
                         while(sem_wait((*s_etat_processus).semaphore_fork) != 0)                              while(sem_wait((*s_etat_processus).semaphore_fork)
                                       != 0)
 #                   endif  #                   endif
                     {  
                         if (errno != EINTR)  
                         {                          {
                             (*s_etat_processus).erreur_systeme = d_es_processus;                              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;  
                     }  
                 }  
                 else  
                 {  
 #                   ifndef SEMAPHORES_NOMMES  #                   ifndef SEMAPHORES_NOMMES
                         while(sem_wait(&((*s_etat_processus).semaphore_fork))                              while(sem_wait(&((*s_etat_processus)
                                 != 0)                                      .semaphore_fork)) != 0)
 #                   else  #                   else
                         while(sem_wait((*s_etat_processus).semaphore_fork) != 0)                              while(sem_wait((*s_etat_processus).semaphore_fork)
                                       != 0)
 #                   endif  #                   endif
                     {  
                         if (errno != EINTR)  
                         {                          {
                             (*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),  
                 s_objet_argument) == d_erreur)  
         {  
             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_resultat) == d_erreur)                      s_objet_resultat) == d_erreur)
         {              {
             return;                  return;
               }
         }          }
     }      }
     else      else

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


CVSweb interface <joel.bertrand@systella.fr>