Diff for /rpl/src/instructions_w1.c between versions 1.56 and 1.71

version 1.56, 2011/12/06 13:27:14 version 1.71, 2013/02/26 19:56:16
Line 1 Line 1
 /*  /*
 ================================================================================  ================================================================================
   RPL/2 (R) version 4.1.5    RPL/2 (R) version 4.1.12
   Copyright (C) 1989-2011 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 385  instruction_write(struct_processus *s_et Line 385  instruction_write(struct_processus *s_et
   
     int                                 adresse[16];      int                                 adresse[16];
     int                                 port;      int                                 port;
       int                                 sqlite_status;
   
     integer8                            clef;      integer8                            clef;
     integer8                            compteur;      integer8                            compteur;
     integer8                            id;      integer8                            id;
     integer8                            ordre;      integer8                            ordre;
   
       logical1                            format_degenere;
     logical1                            mise_a_jour;      logical1                            mise_a_jour;
   
       long                                longueur;
     long                                longueur_effective;      long                                longueur_effective;
     long                                recursivite;      long                                recursivite;
   
Line 422  instruction_write(struct_processus *s_et Line 425  instruction_write(struct_processus *s_et
   
     struct flock                        lock;      struct flock                        lock;
   
       struct timespec                     attente;
   
     uint32_t                            calcul_adresse;      uint32_t                            calcul_adresse;
   
     unsigned char                       *chaine;      unsigned char                       *chaine;
     unsigned char                       *chaine_utf8;      unsigned char                       *chaine_utf8;
     unsigned char                       *clef_utf8;      unsigned char                       *clef_utf8;
     unsigned char                       *commande;      unsigned char                       *commande;
       unsigned char                       *format_chaine;
   
     unsigned long                       i;      unsigned long                       i;
   
Line 757  instruction_write(struct_processus *s_et Line 763  instruction_write(struct_processus *s_et
                     return;                      return;
                 }                  }
   
                 if (sqlite3_step(ppStmt) != SQLITE_ROW)                  attente.tv_sec = 0;
                   attente.tv_nsec = GRANULARITE_us * 1000;
   
                   do
                 {                  {
                     (*s_etat_processus).erreur_systeme = d_es_erreur_fichier;                      sqlite_status = sqlite3_step(ppStmt);
                     return;  
                 }                      if (sqlite_status == SQLITE_ROW)
                       {
                           break;
                       }
                       else if ((sqlite_status == SQLITE_BUSY) ||
                               (sqlite_status == SQLITE_LOCKED))
                       {
                           nanosleep(&attente, NULL);
                           INCR_GRANULARITE(attente.tv_nsec);
                       }
                       else
                       {
                           (*s_etat_processus).erreur_systeme =
                                   d_es_erreur_fichier;
                           return;
                       }
                   } while(sqlite_status != SQLITE_ROW);
   
                 if (sqlite3_column_type(ppStmt, 0) != SQLITE_INTEGER)                  if (sqlite3_column_type(ppStmt, 0) != SQLITE_INTEGER)
                 {                  {
Line 914  instruction_write(struct_processus *s_et Line 939  instruction_write(struct_processus *s_et
                     return;                      return;
                 }                  }
   
                 switch(sqlite3_step(ppStmt))                  attente.tv_sec = 0;
                 {                  attente.tv_nsec = GRANULARITE_us * 1000;
                     case SQLITE_ROW:  
                     {  
                         // Une clef existe.  
   
                         mise_a_jour = d_vrai;  
                         break;  
                     }  
   
                     case SQLITE_DONE:                  do
                   {
                       switch(sqlite_status = sqlite3_step(ppStmt))
                     {                      {
                         // Aucune clef n'existe.                          case SQLITE_ROW:
   
                         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 =                              // Une clef existe.
                                     d_es_allocation_memoire;  
                             return;  
                         }  
   
                         if (sqlite3_prepare_v2((*descripteur)                              mise_a_jour = d_vrai;
                                 .descripteur_sqlite,                              break;
                                 commande, strlen(commande), &ppStmt, &queue)  
                                 != SQLITE_OK)  
                         {  
                             (*s_etat_processus).erreur_systeme =  
                                     d_es_erreur_fichier;  
                             return;  
                         }                          }
   
                         if (sqlite3_step(ppStmt) != SQLITE_DONE)                          case SQLITE_DONE:
                         {                          {
                             (*s_etat_processus).erreur_systeme =                              // Aucune clef n'existe.
                                     d_es_erreur_fichier;  
                             return;  
                         }  
   
                         if (sqlite3_finalize(ppStmt) != SQLITE_OK)                              mise_a_jour = d_faux;
                         {  
                             (*s_etat_processus).erreur_systeme =  
                                     d_es_erreur_fichier;  
                             return;  
                         }  
   
                         free(commande);                              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;
                               }
   
                         if (alsprintf(&commande, "select id from key "                              break;
                                 "where key = '%s'", clef_utf8) < 0)  
                         {  
                             (*s_etat_processus).erreur_systeme =  
                                     d_es_allocation_memoire;  
                             return;  
                         }                          }
   
                         if (sqlite3_prepare_v2((*descripteur)                          case SQLITE_BUSY:
                                 .descripteur_sqlite,                          case SQLITE_LOCKED:
                                 commande, strlen(commande), &ppStmt, &queue)  
                                 != SQLITE_OK)  
                         {                          {
                             (*s_etat_processus).erreur_systeme =                              nanosleep(&attente, NULL);
                                     d_es_erreur_fichier;                              INCR_GRANULARITE(attente.tv_nsec);
                             return;                              break;
                         }                          }
   
                         if (sqlite3_step(ppStmt) != SQLITE_ROW)                          default:
                         {                          {
                             (*s_etat_processus).erreur_systeme =                              (*s_etat_processus).erreur_systeme =
                                     d_es_erreur_fichier;                                      d_es_erreur_fichier;
                             return;                              return;
                         }                          }
   
                         break;  
                     }  
   
                     default:  
                     {  
                         (*s_etat_processus).erreur_systeme =  
                                 d_es_erreur_fichier;  
                         return;  
                     }                      }
                 }                  } while(sqlite_status != SQLITE_ROW);
   
                 if (sqlite3_column_type(ppStmt, 0) != SQLITE_INTEGER)                  if (sqlite3_column_type(ppStmt, 0) != SQLITE_INTEGER)
                 {                  {
Line 1349  instruction_write(struct_processus *s_et Line 1381  instruction_write(struct_processus *s_et
                     return;                      return;
                 }                  }
   
                 if ((*((*((struct_liste_chainee *) (*s_objet_argument_2).objet))                  l_element_courant = (*s_objet_argument_2).objet;
                         .donnee)).type != CHN)                  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))
                 {                  {
                     liberation(s_etat_processus, s_objet_argument_2);                      if ((*(*l_element_courant).donnee).type != CHN)
                     liberation(s_etat_processus, s_objet_argument_1);                      {
                           liberation(s_etat_processus, s_objet_argument_2);
                           liberation(s_etat_processus, s_objet_argument_1);
   
                     (*s_etat_processus).erreur_execution =                          (*s_etat_processus).erreur_execution =
                             d_ex_erreur_type_argument;                                  d_ex_erreur_type_argument;
                     return;                          return;
                 }                      }
   
                 if ((chaine = formateur_flux(s_etat_processus, (unsigned char *)                      if ((*(*l_element_courant_format).donnee).type != CHN)
                         (*((*((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);
                     (*s_etat_processus).erreur_systeme =  
                             d_es_allocation_memoire;                          (*s_etat_processus).erreur_execution =
                     return;                                  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 (fwrite(chaine, sizeof(unsigned char), longueur_effective,                  if ((l_element_courant_format != NULL) ||
                         (*descripteur).descripteur_c) !=                          (l_element_courant != NULL))
                         (size_t) longueur_effective)  
                 {                  {
                     (*s_etat_processus).erreur_systeme = d_es_erreur_fichier;                      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;                      return;
                 }                  }
   
                 free(chaine);  
             }              }
             else              else
             {              {

Removed from v.1.56  
changed lines
  Added in v.1.71


CVSweb interface <joel.bertrand@systella.fr>