version 1.175, 2022/09/07 13:40:34
|
version 1.178, 2023/11/22 10:55:15
|
Line 1
|
Line 1
|
/* |
/* |
================================================================================ |
================================================================================ |
RPL/2 (R) version 4.1.34 |
RPL/2 (R) version 4.1.35 |
Copyright (C) 1989-2021 Dr. BERTRAND Joël |
Copyright (C) 1989-2023 Dr. BERTRAND Joël |
|
|
This file is part of RPL/2. |
This file is part of RPL/2. |
|
|
Line 1343 instruction_detach(struct_processus *s_e
|
Line 1343 instruction_detach(struct_processus *s_e
|
(*s_etat_processus).erreur_systeme = d_es_processus; |
(*s_etat_processus).erreur_systeme = d_es_processus; |
} |
} |
|
|
close(pipe_initialisation_segment_signaux[0]); |
|
close(pipe_initialisation_segment_signaux[1]); |
close(pipe_initialisation_segment_signaux[1]); |
|
|
if ((*s_etat_processus).debug == d_vrai) |
if ((*s_etat_processus).debug == d_vrai) |
Line 1823 instruction_detach(struct_processus *s_e
|
Line 1822 instruction_detach(struct_processus *s_e
|
{ |
{ |
l_element_suivant = (*l_element_courant).suivant; |
l_element_suivant = (*l_element_courant).suivant; |
|
|
|
// On ne détruit pas le descripteur sous prétexte |
|
// d'avoir le fichier ou la socket fermée dans le processus père |
|
|
|
/* |
fclose((*((struct_descripteur_fichier *) |
fclose((*((struct_descripteur_fichier *) |
(*l_element_courant).donnee)).descripteur_c); |
(*l_element_courant).donnee)).descripteur_c); |
|
|
Line 1832 instruction_detach(struct_processus *s_e
|
Line 1835 instruction_detach(struct_processus *s_e
|
sqlite3_close((*((struct_descripteur_fichier *) |
sqlite3_close((*((struct_descripteur_fichier *) |
(*l_element_courant).donnee)).descripteur_sqlite); |
(*l_element_courant).donnee)).descripteur_sqlite); |
} |
} |
|
*/ |
|
|
free((*((struct_descripteur_fichier *) (*l_element_courant) |
free((*((struct_descripteur_fichier *) (*l_element_courant) |
.donnee)).nom); |
.donnee)).nom); |
Line 2444 instruction_detach(struct_processus *s_e
|
Line 2448 instruction_detach(struct_processus *s_e
|
{ |
{ |
l_element_suivant = (*l_element_courant).suivant; |
l_element_suivant = (*l_element_courant).suivant; |
|
|
if ((*((struct_socket *) (*(*l_element_courant).donnee) |
|
.objet)).socket_connectee == d_vrai) |
|
{ |
|
shutdown((*((struct_socket *) (*(*l_element_courant).donnee) |
|
.objet)).socket, SHUT_RDWR); |
|
} |
|
|
|
close((*((struct_socket *) (*(*l_element_courant).donnee) |
|
.objet)).socket); |
|
|
|
if (((*((struct_socket *) (*(*l_element_courant).donnee).objet)) |
if (((*((struct_socket *) (*(*l_element_courant).donnee).objet)) |
.pid == getpid()) && (pthread_equal((*((struct_socket *) |
.pid == getpid()) && (pthread_equal((*((struct_socket *) |
(*(*l_element_courant).donnee).objet)).tid, pthread_self()) |
(*(*l_element_courant).donnee).objet)).tid, pthread_self()) |
!= 0)) |
!= 0)) |
{ |
{ |
|
if ((*((struct_socket *) (*(*l_element_courant).donnee) |
|
.objet)).socket_connectee == d_vrai) |
|
{ |
|
shutdown((*((struct_socket *) (*(*l_element_courant).donnee) |
|
.objet)).socket, SHUT_RDWR); |
|
} |
|
|
|
close((*((struct_socket *) (*(*l_element_courant).donnee) |
|
.objet)).socket); |
|
|
if ((*((struct_socket *) (*(*l_element_courant).donnee).objet)) |
if ((*((struct_socket *) (*(*l_element_courant).donnee).objet)) |
.effacement == 'Y') |
.effacement == 'Y') |
{ |
{ |
Line 2926 instruction_detach(struct_processus *s_e
|
Line 2930 instruction_detach(struct_processus *s_e
|
} |
} |
|
|
close(pipe_initialisation_segment_signaux[0]); |
close(pipe_initialisation_segment_signaux[0]); |
close(pipe_initialisation_segment_signaux[1]); |
|
|
|
// Le fils peut être présent sans être en attente du signal de départ. |
// Le fils peut être présent sans être en attente du signal de départ. |
|
|