version 1.47, 2013/03/20 22:24:36
|
version 1.48, 2013/03/23 16:14:39
|
Line 471 void
|
Line 471 void
|
instruction_prusr(struct_processus *s_etat_processus) |
instruction_prusr(struct_processus *s_etat_processus) |
{ |
{ |
integer8 i; |
integer8 i; |
|
integer8 j; |
integer8 nb_variables; |
integer8 nb_variables; |
|
|
struct_objet s_objet; |
struct_objet s_objet; |
Line 510 instruction_prusr(struct_processus *s_et
|
Line 511 instruction_prusr(struct_processus *s_et
|
} |
} |
} |
} |
|
|
|
if (pthread_mutex_lock(&mutex_liste_variables_partagees) != 0) |
|
{ |
|
(*s_etat_processus).erreur_systeme = d_es_processus; |
|
return; |
|
} |
|
|
nb_variables = nombre_variables(s_etat_processus); |
nb_variables = nombre_variables(s_etat_processus); |
|
|
if ((tableau = malloc(((size_t) nb_variables) * |
if ((tableau = malloc(((size_t) nb_variables) * |
Line 517 instruction_prusr(struct_processus *s_et
|
Line 524 instruction_prusr(struct_processus *s_et
|
{ |
{ |
liberation_mutexes_arbre_variables_partagees(s_etat_processus, |
liberation_mutexes_arbre_variables_partagees(s_etat_processus, |
(*(*s_etat_processus).s_arbre_variables_partagees)); |
(*(*s_etat_processus).s_arbre_variables_partagees)); |
|
pthread_mutex_unlock(&mutex_liste_variables_partagees); |
(*s_etat_processus).erreur_systeme = d_es_allocation_memoire; |
(*s_etat_processus).erreur_systeme = d_es_allocation_memoire; |
return; |
return; |
} |
} |
|
|
liste_variables(s_etat_processus, tableau); |
nb_variables = liste_variables(s_etat_processus, tableau); |
|
|
|
if (pthread_mutex_unlock(&mutex_liste_variables_partagees) != 0) |
|
{ |
|
(*s_etat_processus).erreur_systeme = d_es_processus; |
|
return; |
|
} |
|
|
s_objet.type = CHN; |
s_objet.type = CHN; |
|
|
Line 530 instruction_prusr(struct_processus *s_et
|
Line 544 instruction_prusr(struct_processus *s_et
|
if ((s_objet.objet = malloc((strlen(tableau[i].nom) + 64) |
if ((s_objet.objet = malloc((strlen(tableau[i].nom) + 64) |
* sizeof(unsigned char))) == NULL) |
* sizeof(unsigned char))) == NULL) |
{ |
{ |
|
for(j = i; j < nb_variables; j++) |
|
{ |
|
if (tableau[j].mutex != NULL) |
|
{ |
|
pthread_mutex_unlock(tableau[i].mutex); |
|
} |
|
} |
|
|
free(tableau); |
free(tableau); |
|
|
(*s_etat_processus).erreur_systeme = d_es_allocation_memoire; |
(*s_etat_processus).erreur_systeme = d_es_allocation_memoire; |
Line 539 instruction_prusr(struct_processus *s_et
|
Line 561 instruction_prusr(struct_processus *s_et
|
sprintf((unsigned char *) s_objet.objet, "\\\\noindent %s [%lld]\n", |
sprintf((unsigned char *) s_objet.objet, "\\\\noindent %s [%lld]\n", |
tableau[i].nom, tableau[i].niveau); |
tableau[i].nom, tableau[i].niveau); |
|
|
|
if (tableau[i].mutex != NULL) |
|
{ |
|
pthread_mutex_unlock(tableau[i].mutex); |
|
} |
|
|
formateur_tex(s_etat_processus, &s_objet, 'N'); |
formateur_tex(s_etat_processus, &s_objet, 'N'); |
free(s_objet.objet); |
free(s_objet.objet); |
} |
} |