--- rpl/src/chainage.c 2010/03/04 10:17:47 1.4 +++ rpl/src/chainage.c 2010/03/04 17:42:46 1.5 @@ -99,22 +99,48 @@ chainage(struct_processus *s_etat_proces return(d_erreur); } - if ((commande = (unsigned char *) malloc((strlen(ds_preprocesseur) + - (2 * strlen((*s_etat_processus).nom_fichier_source)) + - (4 * strlen(d_exec_path)) + - strlen(nom_fichier_temporaire) + strlen(instructions) - 11) * - sizeof(unsigned char))) == NULL) + if ((*s_etat_processus).rpl_home == NULL) { - (*s_etat_processus).erreur_systeme = d_es_allocation_memoire; + if ((commande = (unsigned char *) malloc((strlen(ds_preprocesseur) + + (2 * strlen((*s_etat_processus).nom_fichier_source)) + + (4 * strlen(d_exec_path)) + + strlen(nom_fichier_temporaire) + strlen(instructions) - 11) + * sizeof(unsigned char))) == NULL) + { + (*s_etat_processus).erreur_systeme = d_es_allocation_memoire; - free(nom_fichier_temporaire); - return(d_erreur); + free(nom_fichier_temporaire); + return(d_erreur); + } + + sprintf(commande, instructions, + (*s_etat_processus).nom_fichier_source, + d_exec_path, ds_preprocesseur, d_exec_path, d_exec_path, + d_exec_path, (*s_etat_processus).nom_fichier_source, + nom_fichier_temporaire); } + else + { + if ((commande = (unsigned char *) malloc((strlen(ds_preprocesseur) + + (2 * strlen((*s_etat_processus).nom_fichier_source)) + + (4 * strlen((*s_etat_processus).rpl_home)) + + strlen(nom_fichier_temporaire) + strlen(instructions) - 11) + * sizeof(unsigned char))) == NULL) + { + (*s_etat_processus).erreur_systeme = d_es_allocation_memoire; - sprintf(commande, instructions, (*s_etat_processus).nom_fichier_source, - d_exec_path, ds_preprocesseur, d_exec_path, d_exec_path, - d_exec_path, (*s_etat_processus).nom_fichier_source, - nom_fichier_temporaire); + free(nom_fichier_temporaire); + return(d_erreur); + } + + sprintf(commande, instructions, + (*s_etat_processus).nom_fichier_source, + (*s_etat_processus).rpl_home, ds_preprocesseur, + (*s_etat_processus).rpl_home, (*s_etat_processus).rpl_home, + (*s_etat_processus).rpl_home, + (*s_etat_processus).nom_fichier_source, + nom_fichier_temporaire); + } if ((f_source = popen(commande, "r")) == NULL) {