version 1.86, 2015/11/26 11:44:44
|
version 1.109, 2025/04/15 10:17:58
|
Line 1
|
Line 1
|
/* |
/* |
================================================================================ |
================================================================================ |
RPL/2 (R) version 4.1.24 |
RPL/2 (R) version 4.1.36 |
Copyright (C) 1989-2015 Dr. BERTRAND Joël |
Copyright (C) 1989-2025 Dr. BERTRAND Joël |
|
|
This file is part of RPL/2. |
This file is part of RPL/2. |
|
|
Line 131 reencodage(struct_processus *s_etat_proc
|
Line 131 reencodage(struct_processus *s_etat_proc
|
longueur_sortie = d_LONGUEUR; |
longueur_sortie = d_LONGUEUR; |
pointeur = buffer_sortie; |
pointeur = buffer_sortie; |
|
|
if ((ios = iconv(transcodage, (char **) &buffer_entree, |
if ((ios = iconv(transcodage, |
|
# if defined(Linux) |
|
(char **) |
|
# elif defined(NetBSD) |
|
(const char **) |
|
# else |
|
(char **) |
|
# endif |
|
&buffer_entree, |
&longueur_entree, (char **) &pointeur, &longueur_sortie)) |
&longueur_entree, (char **) &pointeur, &longueur_sortie)) |
== (size_t) -1) |
== (size_t) -1) |
{ |
{ |
Line 291 localisation_courante(struct_processus *
|
Line 299 localisation_courante(struct_processus *
|
|
|
verrouillage_threads_concurrents(s_etat_processus); |
verrouillage_threads_concurrents(s_etat_processus); |
pid = fork(); |
pid = fork(); |
deverrouillage_threads_concurrents(s_etat_processus); |
|
|
|
if (pid < 0) |
if (pid < 0) |
{ |
{ |
Line 419 localisation_courante(struct_processus *
|
Line 426 localisation_courante(struct_processus *
|
} |
} |
else |
else |
{ |
{ |
|
deverrouillage_threads_concurrents(s_etat_processus); |
|
|
if (close(pipes_entree[0]) != 0) |
if (close(pipes_entree[0]) != 0) |
{ |
{ |
(*s_etat_processus).erreur_systeme = d_es_processus; |
(*s_etat_processus).erreur_systeme = d_es_processus; |
Line 464 localisation_courante(struct_processus *
|
Line 473 localisation_courante(struct_processus *
|
return; |
return; |
} |
} |
|
|
if (waitpid(pid, &status, 0) == -1) |
while(waitpid(pid, &status, 0) == -1) |
{ |
{ |
# ifndef SEMAPHORES_NOMMES |
if (errno != EINTR) |
while(sem_wait(&((*s_etat_processus).semaphore_fork)) != 0) |
|
# else |
|
while(sem_wait((*s_etat_processus).semaphore_fork) != 0) |
|
# endif |
|
{ |
{ |
if (errno != EINTR) |
# ifndef SEMAPHORES_NOMMES |
|
while(sem_wait(&((*s_etat_processus).semaphore_fork)) |
|
!= 0) |
|
# else |
|
while(sem_wait((*s_etat_processus).semaphore_fork) != 0) |
|
# endif |
{ |
{ |
(*s_etat_processus).erreur_systeme = d_es_processus; |
if (errno != EINTR) |
return; |
{ |
|
(*s_etat_processus).erreur_systeme = d_es_processus; |
|
return; |
|
} |
} |
} |
} |
|
|
|
(*s_etat_processus).erreur_systeme = d_es_processus; |
(*s_etat_processus).erreur_systeme = d_es_processus; |
return; |
return; |
|
} |
} |
} |
|
|
# ifndef SEMAPHORES_NOMMES |
# ifndef SEMAPHORES_NOMMES |
Line 877 readline_wrapper(struct_processus *s_eta
|
Line 890 readline_wrapper(struct_processus *s_eta
|
return(NULL); |
return(NULL); |
} |
} |
|
|
if ((rpl_chaine = rpl_malloc(s_etat_processus, (strlen(sys_chaine) + 1) * |
if ((rpl_chaine = malloc((strlen(sys_chaine) + 1) * |
sizeof(unsigned char *))) == NULL) |
sizeof(unsigned char))) == NULL) |
{ |
{ |
sys_free(sys_chaine); |
sys_free(sys_chaine); |
(*s_etat_processus).erreur_systeme = d_es_allocation_memoire; |
(*s_etat_processus).erreur_systeme = d_es_allocation_memoire; |