--- rpl/src/instructions_d4.c 2011/04/11 12:10:07 1.19 +++ rpl/src/instructions_d4.c 2011/09/26 15:57:12 1.32 @@ -1,6 +1,6 @@ /* ================================================================================ - RPL/2 (R) version 4.1.0.prerelease.0 + RPL/2 (R) version 4.1.4 Copyright (C) 1989-2011 Dr. BERTRAND Joël This file is part of RPL/2. @@ -666,11 +666,8 @@ instruction_drws(struct_processus *s_eta int dimensions; - logical1 presence_variable; logical1 matrice_entiere; - long i; - struct_objet *s_objet_statistique; unsigned char *nom_fichier; @@ -717,44 +714,19 @@ instruction_drws(struct_processus *s_eta * Vérification de la présence de la matrice statistique */ - if (recherche_variable(s_etat_processus, ds_sdat) == d_faux) + if (recherche_variable_globale(s_etat_processus, ds_sdat) == d_faux) { /* * Aucune variable ds_sdat n'existe. */ - (*s_etat_processus).erreur_execution = d_ex_absence_observations; - (*s_etat_processus).erreur_systeme = d_es; - - return; - } - - i = (*s_etat_processus).position_variable_courante; - presence_variable = d_faux; - - while(i >= 0) - { - if ((strcmp((*s_etat_processus).s_liste_variables[i].nom, - ds_sdat) == 0) && ((*s_etat_processus) - .s_liste_variables[i].niveau == 1)) + if ((*s_etat_processus).erreur_execution == d_ex) { - presence_variable = d_vrai; - break; + (*s_etat_processus).erreur_execution = d_ex_absence_observations; } - i--; - } - - if (presence_variable == d_faux) - { - (*s_etat_processus).erreur_execution = d_ex_absence_observations; - return; - } + (*s_etat_processus).erreur_systeme = d_es; - if ((s_objet_statistique = (*s_etat_processus).s_liste_variables[i].objet) - == NULL) - { - (*s_etat_processus).erreur_execution = d_ex_variable_partagee; return; } @@ -1083,8 +1055,7 @@ instruction_decr(struct_processus *s_eta liberation(s_etat_processus, s_objet_argument); - if ((*s_etat_processus).s_liste_variables - [(*s_etat_processus).position_variable_courante] + if ((*(*s_etat_processus).pointeur_variable_courante) .variable_verrouillee == d_vrai) { (*s_etat_processus).erreur_execution = @@ -1092,8 +1063,7 @@ instruction_decr(struct_processus *s_eta return; } - if ((*s_etat_processus).s_liste_variables - [(*s_etat_processus).position_variable_courante].objet + if ((*(*s_etat_processus).pointeur_variable_courante).objet == NULL) { if (pthread_mutex_lock(&((*(*s_etat_processus) @@ -1104,13 +1074,10 @@ instruction_decr(struct_processus *s_eta } if (recherche_variable_partagee(s_etat_processus, - (*s_etat_processus).s_liste_variables - [(*s_etat_processus).position_variable_courante].nom, - (*s_etat_processus).s_liste_variables - [(*s_etat_processus).position_variable_courante] - .variable_partagee, (*s_etat_processus).s_liste_variables - [(*s_etat_processus).position_variable_courante] - .origine) == d_faux) + (*(*s_etat_processus).pointeur_variable_courante).nom, + (*(*s_etat_processus).pointeur_variable_courante) + .variable_partagee, (*(*s_etat_processus) + .pointeur_variable_courante).origine) == d_faux) { (*s_etat_processus).erreur_systeme = d_es; (*s_etat_processus).erreur_execution = @@ -1127,8 +1094,8 @@ instruction_decr(struct_processus *s_eta } else { - s_objet_argument = (*s_etat_processus).s_liste_variables - [(*s_etat_processus).position_variable_courante].objet; + s_objet_argument = (*(*s_etat_processus).pointeur_variable_courante) + .objet; variable_partagee = d_faux; } @@ -1153,8 +1120,7 @@ instruction_decr(struct_processus *s_eta if (variable_partagee == d_vrai) { - (*s_etat_processus).s_liste_variables[(*s_etat_processus) - .position_variable_courante].objet = NULL; + (*(*s_etat_processus).pointeur_variable_courante).objet = NULL; (*(*s_etat_processus) .s_liste_variables_partagees).table [(*(*s_etat_processus).s_liste_variables_partagees) @@ -1162,8 +1128,8 @@ instruction_decr(struct_processus *s_eta } else { - (*s_etat_processus).s_liste_variables[(*s_etat_processus) - .position_variable_courante].objet = s_copie_argument; + (*(*s_etat_processus).pointeur_variable_courante).objet = + s_copie_argument; } if ((*s_copie_argument).type == INT)