Diff for /rpl/src/chainage.c between versions 1.7 and 1.19

version 1.7, 2010/03/09 10:18:42 version 1.19, 2010/09/07 08:58:04
Line 1 Line 1
 /*  /*
 ================================================================================  ================================================================================
   RPL/2 (R) version 4.0.13    RPL/2 (R) version 4.0.19
   Copyright (C) 1989-2010 Dr. BERTRAND Joël    Copyright (C) 1989-2010 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"
   
   
 /*  /*
 ================================================================================  ================================================================================
   Routine de chainage du programme (lecture du fichier puis constitution    Routine de chaînage du programme (lecture du fichier puis constitution
   de la chaine executable)    de la chaîne exécutable)
 ================================================================================  ================================================================================
   Entrées: structure processus    Entrées: structure processus
 --------------------------------------------------------------------------------  --------------------------------------------------------------------------------
Line 49  chainage(struct_processus *s_etat_proces Line 49  chainage(struct_processus *s_etat_proces
   
     logical1                drapeau_fin;      logical1                drapeau_fin;
     logical1                existence;      logical1                existence;
       logical1                initialisation;
     logical1                ouverture;      logical1                ouverture;
     logical1                presence_chaine;      logical1                presence_chaine;
   
Line 57  chainage(struct_processus *s_etat_proces Line 58  chainage(struct_processus *s_etat_proces
   
     unsigned char           *commande;      unsigned char           *commande;
     unsigned char           *executable_candidat;      unsigned char           *executable_candidat;
     unsigned char           *instructions = "sed -e '1,1s/^#!/\\/\\//g' %s | "  
                                     "%s/bin/%s | "  #   ifndef OS2
       unsigned char           *instructions = "%s/bin/%s %s | "
                                     "%s/bin/rpliconv `%s/bin/rplfile "                                      "%s/bin/rpliconv `%s/bin/rplfile "
                                     "-m %s/share/rplfiles -i %s | awk "                                      "-m %s/share/rplfiles -i %s | awk "
                                     "'{ print $3; }' | awk -F= "                                      "'{ print $3; }' | awk -F= "
                                     "'{ if ($2 != \"\") printf(\"-f %%s\", "                                      "'{ if ($2 != \"\") printf(\"-f %%s\", "
                                     "$2); }'` -t `locale charmap`//IGNORE > %s";                                      "$2); }'` -t %s//IGNORE > %s";
   #   else
       unsigned char           *instructions = "sh -c \""
                                       "%s/bin/%s %s | "
                                       "%s/bin/rpliconv `%s/bin/rplfile "
                                       "-m %s/share/rplfiles -i %s | awk "
                                       "'{ print $3; }' | awk -F= "
                                       "'{ if ($2 != \\\"\\\") "
                                       "printf(\\\"-f %%s\\\", "
                                       "$2); }'` -t %s//IGNORE\" > %s";
   #   endif
   
     unsigned long           unite_fichier;      unsigned long           unite_fichier;
   
Line 107  chainage(struct_processus *s_etat_proces Line 119  chainage(struct_processus *s_etat_proces
         {          {
             if ((commande = (unsigned char *) malloc((strlen(ds_preprocesseur) +              if ((commande = (unsigned char *) malloc((strlen(ds_preprocesseur) +
                     (2 * strlen((*s_etat_processus).nom_fichier_source)) +                      (2 * strlen((*s_etat_processus).nom_fichier_source)) +
                     (4 * strlen(d_exec_path)) +                      (4 * strlen(d_exec_path)) + strlen(d_locale) +
                     strlen(nom_fichier_temporaire) + strlen(instructions) - 11)                      strlen(nom_fichier_temporaire) + strlen(instructions) - 13)
                     * sizeof(unsigned char))) == NULL)                      * sizeof(unsigned char))) == NULL)
             {              {
                 (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;                  (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
Line 118  chainage(struct_processus *s_etat_proces Line 130  chainage(struct_processus *s_etat_proces
             }              }
   
             sprintf(commande, instructions,              sprintf(commande, instructions,
                       d_exec_path, ds_preprocesseur,
                     (*s_etat_processus).nom_fichier_source,                      (*s_etat_processus).nom_fichier_source,
                     d_exec_path, ds_preprocesseur, d_exec_path, d_exec_path,                      d_exec_path, d_exec_path,
                     d_exec_path, (*s_etat_processus).nom_fichier_source,                      d_exec_path, (*s_etat_processus).nom_fichier_source,
                     nom_fichier_temporaire);                      d_locale, nom_fichier_temporaire);
   
             if (alsprintf(&executable_candidat, "%s/bin/rpliconv",              if (alsprintf(&executable_candidat, "%s/bin/rpliconv",
                     d_exec_path) < 0)                      d_exec_path) < 0)
Line 345  chainage(struct_processus *s_etat_proces Line 358  chainage(struct_processus *s_etat_proces
   
             i = 0;              i = 0;
             drapeau_fin = d_faux;              drapeau_fin = d_faux;
               initialisation = d_vrai;
   
               /*
                * Élimination du sharp-bang si nécessaire et des caractères
                * inutiles. Conversion de caractères.
                */
   
             while(drapeau_fin == d_faux)              while(drapeau_fin == d_faux)
             {              {
                 if ((caractere = getc(f_source)) != EOF)                  if ((caractere = getc(f_source)) != EOF)
                 {                  {
                       if (initialisation == d_vrai)
                       {
                           if (caractere == '#')
                           {
                               if ((caractere = getc(f_source)) != EOF)
                               {
                                   if (caractere == '!')
                                   {
                                       do
                                       {
                                           caractere = getc(f_source);
                                       } while((caractere != EOF) &&
                                               (caractere !=
                                               d_code_retour_chariot));
                                   }
                                   else
                                   {
                                       rewind(f_source);
                                       caractere = getc(f_source);
                                   }
                               }
                           }
   
                           initialisation = d_faux;
                       }
   
                     if ((caractere == d_code_retour_chariot) ||                      if ((caractere == d_code_retour_chariot) ||
                             (caractere == d_code_tabulation) ||                              (caractere == d_code_tabulation) ||
                             ((caractere == d_code_espace) &&                              ((caractere == d_code_espace) &&

Removed from v.1.7  
changed lines
  Added in v.1.19


CVSweb interface <joel.bertrand@systella.fr>