version 1.57, 2012/10/01 11:05:10
|
version 1.65, 2013/03/04 13:00:26
|
Line 1
|
Line 1
|
/* |
/* |
================================================================================ |
================================================================================ |
RPL/2 (R) version 4.1.11 |
RPL/2 (R) version 4.1.13 |
Copyright (C) 1989-2012 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 90 reencodage(struct_processus *s_etat_proc
|
Line 90 reencodage(struct_processus *s_etat_proc
|
if ((transcodage = iconv_open(codage_sortie, codage_entree)) == |
if ((transcodage = iconv_open(codage_sortie, codage_entree)) == |
(iconv_t) -1) |
(iconv_t) -1) |
{ |
{ |
|
// On affiche une erreur ici car la fonction d'affichage |
|
// de l'erreur utilise la macro printf() donc une |
|
// opération de translitération qui échouera elle aussi. |
|
// Le positionnement de l'erreur permet de sortir du programme. |
|
|
|
if ((*s_etat_processus).langue == 'F') |
|
{ |
|
fprintf(stderr, "+++Erreur : Erreur de transcodage\n"); |
|
} |
|
else |
|
{ |
|
fprintf(stderr, "+++Error : Transcodage error\n"); |
|
} |
|
|
(*s_etat_processus).erreur_execution = d_ex_erreur_transcodage; |
(*s_etat_processus).erreur_execution = d_ex_erreur_transcodage; |
return(NULL); |
return(NULL); |
} |
} |
Line 121 reencodage(struct_processus *s_etat_proc
|
Line 135 reencodage(struct_processus *s_etat_proc
|
&longueur_entree, (char **) &pointeur, &longueur_sortie)) |
&longueur_entree, (char **) &pointeur, &longueur_sortie)) |
== (size_t) -1) |
== (size_t) -1) |
{ |
{ |
// On autorise les erreurs EINVAL et EILSEQ |
// On autorise les erreurs EINVAL si le caractère suivant est non |
if (errno == EILSEQ) |
// nul : la séquence d'entrée est continue sur le bloc suivant. |
|
|
|
if (errno == EINVAL) |
|
{ |
|
if ((*(buffer_entree + 1)) == d_code_fin_chaine) |
|
{ |
|
free(buffer_sortie); |
|
free(chaine_sortie); |
|
|
|
// On affiche une erreur ici car la fonction d'affichage |
|
// de l'erreur utilise la macro printf() donc une |
|
// opération de translitération qui échouera elle aussi. |
|
// Le positionnement de l'erreur permet de sortir du |
|
// programme. |
|
|
|
if ((*s_etat_processus).langue == 'F') |
|
{ |
|
fprintf(stderr, "+++Erreur : Erreur de transcodage\n"); |
|
} |
|
else |
|
{ |
|
fprintf(stderr, "+++Error : Transcodage error\n"); |
|
} |
|
|
|
(*s_etat_processus).erreur_execution = |
|
d_ex_erreur_transcodage; |
|
return(NULL); |
|
} |
|
} |
|
|
|
// Si la séquence d'entrée est invalide, on reçoit une erreur |
|
// EILSEQ. |
|
else if (errno == EILSEQ) |
{ |
{ |
free(buffer_sortie); |
free(buffer_sortie); |
free(chaine_sortie); |
free(chaine_sortie); |
|
|
|
// On affiche une erreur ici car la fonction d'affichage |
|
// de l'erreur utilise la macro printf() donc une |
|
// opération de translitération qui échouera elle aussi. |
|
// Le positionnement de l'erreur permet de sortir du programme. |
|
|
|
if ((*s_etat_processus).langue == 'F') |
|
{ |
|
fprintf(stderr, "+++Erreur : Erreur de transcodage\n"); |
|
} |
|
else |
|
{ |
|
fprintf(stderr, "+++Error : Transcodage error\n"); |
|
} |
|
|
(*s_etat_processus).erreur_execution = d_ex_erreur_transcodage; |
(*s_etat_processus).erreur_execution = d_ex_erreur_transcodage; |
return(NULL); |
return(NULL); |
} |
} |
Line 181 localisation_courante(struct_processus *
|
Line 241 localisation_courante(struct_processus *
|
|
|
pid_t pid; |
pid_t pid; |
|
|
struct sigaction action_passee; |
|
|
|
unsigned char *tampon; |
unsigned char *tampon; |
|
|
unsigned long longueur_lecture; |
unsigned long longueur_lecture; |
Line 554 localisation_courante(struct_processus *
|
Line 612 localisation_courante(struct_processus *
|
strcpy((*s_etat_processus).localisation, d_locale); |
strcpy((*s_etat_processus).localisation, d_locale); |
} |
} |
|
|
if (sigaction(SIGINT, &action_passee, NULL) != 0) |
|
{ |
|
for(i = 0; i < nombre_arguments; i++) |
|
{ |
|
free(arguments[i]); |
|
} |
|
|
|
free(arguments); |
|
(*s_etat_processus).erreur_systeme = d_es_signal; |
|
return; |
|
} |
|
|
|
for(i = 0; i < nombre_arguments; i++) |
for(i = 0; i < nombre_arguments; i++) |
{ |
{ |
free(arguments[i]); |
free(arguments[i]); |