--- rpl/src/gestion_threads.c 2012/10/05 13:12:38 1.68 +++ rpl/src/gestion_threads.c 2012/10/07 08:18:35 1.69 @@ -38,35 +38,38 @@ void * lancement_thread(void *argument) { - int status; + int status; - pid_t ppid; + pid_t ppid; - pthread_t tid_final; + pthread_t tid_final; - sig_atomic_t registre_stop; + sig_atomic_t registre_stop; - ssize_t longueur_ecriture; + ssize_t longueur_ecriture; - struct_descripteur_thread *s_argument_thread; + struct_descripteur_thread *s_argument_thread; - struct_liste_chainee *l_element_courant; - struct_liste_chainee *l_element_suivant; + struct_liste_chainee *l_element_courant; + struct_liste_chainee *l_element_suivant; - struct_objet *s_objet_temporaire; + struct_liste_variables_statiques *l_element_statique_courant; + struct_liste_variables_statiques *l_element_statique_suivant; - struct_processus *s_etat_processus; + struct_objet *s_objet_temporaire; - struct sigaction action; - struct sigaction registre; + struct_processus *s_etat_processus; - struct timespec attente; + struct sigaction action; + struct sigaction registre; - unsigned char *message; + struct timespec attente; - unsigned int erreur; + unsigned char *message; - unsigned long i; + unsigned int erreur; + + unsigned long i; attente.tv_sec = 0; attente.tv_nsec = GRANULARITE_us * 1000; @@ -813,6 +816,16 @@ lancement_thread(void *argument) liberation_arbre_variables(s_etat_processus, (*s_etat_processus).s_arbre_variables, d_faux); + l_element_statique_courant = (*s_etat_processus) + .l_liste_variables_statiques; + + while(l_element_statique_courant != NULL) + { + l_element_statique_suivant = (*l_element_statique_courant).suivant; + free(l_element_statique_courant); + l_element_statique_courant = l_element_statique_suivant; + } + l_element_courant = (*s_etat_processus).l_base_pile; while(l_element_courant != NULL) {