File:  [local] / rpl / src / instructions_r5.c
Revision 1.17: download - view: text, annotated - select for diffs - revision graph
Thu Sep 23 15:27:40 2010 UTC (13 years, 7 months ago) by bertrand
Branches: MAIN
CVS tags: HEAD
En route pour la 4.0.20.

    1: /*
    2: ================================================================================
    3:   RPL/2 (R) version 4.0.20
    4:   Copyright (C) 1989-2010 Dr. BERTRAND Joël
    5: 
    6:   This file is part of RPL/2.
    7: 
    8:   RPL/2 is free software; you can redistribute it and/or modify it
    9:   under the terms of the CeCILL V2 License as published by the french
   10:   CEA, CNRS and INRIA.
   11:  
   12:   RPL/2 is distributed in the hope that it will be useful, but WITHOUT
   13:   ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
   14:   FITNESS FOR A PARTICULAR PURPOSE.  See the CeCILL V2 License
   15:   for more details.
   16:  
   17:   You should have received a copy of the CeCILL License
   18:   along with RPL/2. If not, write to info@cecill.info.
   19: ================================================================================
   20: */
   21: 
   22: 
   23: #include "rpl-conv.h"
   24: 
   25: 
   26: /*
   27: ================================================================================
   28:   Fonction 'rswp'
   29: ================================================================================
   30:   Entrées : pointeur sur une structure struct_processus
   31: --------------------------------------------------------------------------------
   32:   Sorties :
   33: --------------------------------------------------------------------------------
   34:   Effets de bord : néant
   35: ================================================================================
   36: */
   37: 
   38: void
   39: instruction_rswp(struct_processus *s_etat_processus)
   40: {
   41:     struct_objet                *s_copie_argument_3;
   42:     struct_objet                *s_objet_argument_1;
   43:     struct_objet                *s_objet_argument_2;
   44:     struct_objet                *s_objet_argument_3;
   45: 
   46:     signed long                 ligne_1;
   47:     signed long                 ligne_2;
   48: 
   49:     void                        *tampon;
   50: 
   51:     (*s_etat_processus).erreur_execution = d_ex;
   52: 
   53:     if ((*s_etat_processus).affichage_arguments == 'Y')
   54:     {
   55:         printf("\n  RSWP ");
   56: 
   57:         if ((*s_etat_processus).langue == 'F')
   58:         {
   59:             printf("(échange de deux lignes d'une matrice)\n\n");
   60:         }
   61:         else
   62:         {
   63:             printf("(swap two rows of a matrix)\n\n");
   64:         }
   65: 
   66:         printf("    3: %s, %s, %s\n", d_MIN, d_MRL, d_MCX);
   67:         printf("    2: %s\n", d_INT);
   68:         printf("    1: %s\n", d_INT);
   69:         printf("->  1: %s, %s, %s\n", d_MIN, d_MRL, d_MCX);
   70: 
   71:         return;
   72:     }
   73:     else if ((*s_etat_processus).test_instruction == 'Y')
   74:     {
   75:         (*s_etat_processus).nombre_arguments = -1;
   76:         return;
   77:     }
   78: 
   79:     if (test_cfsf(s_etat_processus, 31) == d_vrai)
   80:     {
   81:         if (empilement_pile_last(s_etat_processus, 3) == d_erreur)
   82:         {
   83:             return;
   84:         }
   85:     }
   86: 
   87:     if (depilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
   88:             &s_objet_argument_1) == d_erreur)
   89:     {
   90:         (*s_etat_processus).erreur_execution = d_ex_manque_argument;
   91:         return;
   92:     }
   93: 
   94:     if (depilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
   95:             &s_objet_argument_2) == d_erreur)
   96:     {
   97:         liberation(s_etat_processus, s_objet_argument_1);
   98: 
   99:         (*s_etat_processus).erreur_execution = d_ex_manque_argument;
  100:         return;
  101:     }
  102: 
  103:     if (depilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
  104:             &s_objet_argument_3) == d_erreur)
  105:     {
  106:         liberation(s_etat_processus, s_objet_argument_1);
  107:         liberation(s_etat_processus, s_objet_argument_2);
  108: 
  109:         (*s_etat_processus).erreur_execution = d_ex_manque_argument;
  110:         return;
  111:     }
  112: 
  113:     if (((*s_objet_argument_1).type == INT) &&
  114:             ((*s_objet_argument_2).type == INT))
  115:     {
  116:         if (((*s_objet_argument_3).type == MIN) ||
  117:                 ((*s_objet_argument_3).type == MRL) ||
  118:                 ((*s_objet_argument_3).type == MCX))
  119:         {
  120:             ligne_1 = (*((integer8 *) (*s_objet_argument_1).objet)) - 1;
  121:             ligne_2 = (*((integer8 *) (*s_objet_argument_2).objet)) - 1;
  122: 
  123:             if ((ligne_1 < 0) || (ligne_1 >= (long) (*((struct_matrice *)
  124:                     (*s_objet_argument_3).objet)).nombre_lignes) ||
  125:                     (ligne_2 < 0) || (ligne_2 >= (long) (*((struct_matrice *)
  126:                     (*s_objet_argument_3).objet)).nombre_lignes))
  127:             {
  128:                 liberation(s_etat_processus, s_objet_argument_1);
  129:                 liberation(s_etat_processus, s_objet_argument_2);
  130:                 liberation(s_etat_processus, s_objet_argument_3);
  131: 
  132:                 (*s_etat_processus).erreur_execution =
  133:                         d_ex_dimensions_invalides;
  134:                 return;
  135:             }
  136: 
  137:             if ((s_copie_argument_3 = copie_objet(s_etat_processus,
  138:                     s_objet_argument_3, 'Q')) == NULL)
  139:             {
  140:                 (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
  141:                 return;
  142:             }
  143: 
  144:             liberation(s_etat_processus, s_objet_argument_3);
  145:             s_objet_argument_3 = s_copie_argument_3;
  146: 
  147:             tampon = (*((struct_matrice *) (*s_objet_argument_3).objet))
  148:                     .tableau[ligne_1];
  149:             (*((struct_matrice *) (*s_objet_argument_3).objet)).tableau[ligne_1]
  150:                     = (*((struct_matrice *) (*s_objet_argument_3).objet))
  151:                     .tableau[ligne_2];
  152:             (*((struct_matrice *) (*s_objet_argument_3).objet)).tableau[ligne_2]
  153:                     = tampon;
  154:         }
  155:         else
  156:         {
  157:             liberation(s_etat_processus, s_objet_argument_1);
  158:             liberation(s_etat_processus, s_objet_argument_2);
  159:             liberation(s_etat_processus, s_objet_argument_3);
  160: 
  161:             (*s_etat_processus).erreur_execution = d_ex_erreur_type_argument;
  162:             return;
  163:         }
  164:     }
  165:     else
  166:     {
  167:         liberation(s_etat_processus, s_objet_argument_1);
  168:         liberation(s_etat_processus, s_objet_argument_2);
  169:         liberation(s_etat_processus, s_objet_argument_3);
  170: 
  171:         (*s_etat_processus).erreur_execution = d_ex_erreur_type_argument;
  172:         return;
  173:     }
  174: 
  175:     liberation(s_etat_processus, s_objet_argument_1);
  176:     liberation(s_etat_processus, s_objet_argument_2);
  177: 
  178:     if (empilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
  179:             s_objet_argument_3) == d_erreur)
  180:     {
  181:         return;
  182:     }
  183: 
  184:     return;
  185: }
  186: 
  187: 
  188: /*
  189: ================================================================================
  190:   Fonction 'row+'
  191: ================================================================================
  192:   Entrées :
  193: --------------------------------------------------------------------------------
  194:   Sorties :
  195: --------------------------------------------------------------------------------
  196:   Effets de bord : néant
  197: ================================================================================
  198: */
  199: 
  200: void
  201: instruction_row_plus(struct_processus *s_etat_processus)
  202: {
  203:     integer8                        position;
  204: 
  205:     logical1                        matrice_vide;
  206:     logical1                        presence_nom;
  207:     logical1                        variable_partagee;
  208: 
  209:     struct_objet                    *s_copie_argument_1;
  210:     struct_objet                    *s_copie_argument_3;
  211:     struct_objet                    *s_objet_argument_1;
  212:     struct_objet                    *s_objet_argument_2;
  213:     struct_objet                    *s_objet_argument_3;
  214: 
  215:     unsigned long                   i;
  216:     unsigned long                   j;
  217: 
  218:     void                            **tableau;
  219:     void                            *tampon;
  220: 
  221:     (*s_etat_processus).erreur_execution = d_ex;
  222: 
  223:     if ((*s_etat_processus).affichage_arguments == 'Y')
  224:     {
  225:         printf("\n  ROW+ ");
  226: 
  227:         if ((*s_etat_processus).langue == 'F')
  228:         {
  229:             printf("(ajout d'une ligne dans une matrice)\n\n");
  230:         }
  231:         else
  232:         {
  233:             printf("(add a row in a matrix)\n\n");
  234:         }
  235: 
  236:         printf("    3: %s, %s, %s\n", d_MIN, d_MRL, d_MCX);
  237:         printf("    2: %s\n", d_INT);
  238:         printf("    1: %s, %s, %s\n\n", d_MIN, d_MRL, d_MCX);
  239:         printf("->  1: %s, %s, %s\n\n", d_MIN, d_MRL, d_MCX);
  240: 
  241:         printf("    3: %s\n", d_NOM);
  242:         printf("    2: %s\n", d_INT);
  243:         printf("    1: %s, %s, %s\n", d_MIN, d_MRL, d_MCX);
  244: 
  245:         return;
  246:     }
  247:     else if ((*s_etat_processus).test_instruction == 'Y')
  248:     {
  249:         (*s_etat_processus).nombre_arguments = -1;
  250:         return;
  251:     }
  252: 
  253:     if (test_cfsf(s_etat_processus, 31) == d_vrai)
  254:     {
  255:         if (empilement_pile_last(s_etat_processus, 3) == d_erreur)
  256:         {
  257:             return;
  258:         }
  259:     }
  260: 
  261:     if (depilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
  262:             &s_objet_argument_1) == d_erreur)
  263:     {
  264:         (*s_etat_processus).erreur_execution = d_ex_manque_argument;
  265:         return;
  266:     }
  267: 
  268:     if ((s_copie_argument_1 = copie_objet(s_etat_processus, s_objet_argument_1,
  269:             'O')) == NULL)
  270:     {
  271:         (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
  272:         return;
  273:     }
  274: 
  275:     liberation(s_etat_processus, s_objet_argument_1);
  276:     s_objet_argument_1 = s_copie_argument_1;
  277: 
  278:     if (depilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
  279:             &s_objet_argument_2) == d_erreur)
  280:     {
  281:         liberation(s_etat_processus, s_objet_argument_1);
  282: 
  283:         (*s_etat_processus).erreur_execution = d_ex_manque_argument;
  284:         return;
  285:     }
  286: 
  287:     if (depilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
  288:             &s_objet_argument_3) == d_erreur)
  289:     {
  290:         liberation(s_etat_processus, s_objet_argument_1);
  291:         liberation(s_etat_processus, s_objet_argument_2);
  292: 
  293:         (*s_etat_processus).erreur_execution = d_ex_manque_argument;
  294:         return;
  295:     }
  296: 
  297:     if (((*s_objet_argument_1).type != MIN) &&
  298:             ((*s_objet_argument_1).type != MRL) &&
  299:             ((*s_objet_argument_1).type != MCX))
  300:     {
  301:         liberation(s_etat_processus, s_objet_argument_1);
  302:         liberation(s_etat_processus, s_objet_argument_2);
  303:         liberation(s_etat_processus, s_objet_argument_3);
  304: 
  305:         (*s_etat_processus).erreur_execution = d_ex_erreur_type_argument;
  306:         return;
  307:     }
  308: 
  309:     if ((*((struct_matrice *) (*s_objet_argument_1).objet)).nombre_lignes
  310:             != 1)
  311:     {
  312:         liberation(s_etat_processus, s_objet_argument_1);
  313:         liberation(s_etat_processus, s_objet_argument_2);
  314:         liberation(s_etat_processus, s_objet_argument_3);
  315: 
  316:         (*s_etat_processus).erreur_execution = d_ex_dimensions_invalides;
  317:         return;
  318:     }
  319: 
  320:     if ((*s_objet_argument_2).type != INT)
  321:     {
  322:         liberation(s_etat_processus, s_objet_argument_1);
  323:         liberation(s_etat_processus, s_objet_argument_2);
  324:         liberation(s_etat_processus, s_objet_argument_3);
  325: 
  326:         (*s_etat_processus).erreur_execution = d_ex_erreur_type_argument;
  327:         return;
  328:     }
  329: 
  330:     variable_partagee = d_faux;
  331: 
  332:     if ((*s_objet_argument_3).type == NOM)
  333:     {
  334:         presence_nom = d_vrai;
  335: 
  336:         if (recherche_variable(s_etat_processus, (*((struct_nom *)
  337:                 (*s_objet_argument_3).objet)).nom) == d_faux)
  338:         {
  339:             (*s_etat_processus).erreur_systeme = d_es;
  340:             (*s_etat_processus).erreur_execution = d_ex_variable_non_definie;
  341: 
  342:             liberation(s_etat_processus, s_objet_argument_1);
  343:             liberation(s_etat_processus, s_objet_argument_2);
  344:             liberation(s_etat_processus, s_objet_argument_3);
  345: 
  346:             return;
  347:         }
  348: 
  349:         liberation(s_etat_processus, s_objet_argument_3);
  350: 
  351:         if ((*s_etat_processus).s_liste_variables[(*s_etat_processus)
  352:                 .position_variable_courante].variable_verrouillee == d_vrai)
  353:         {
  354:             (*s_etat_processus).erreur_execution = d_ex_variable_verrouillee;
  355: 
  356:             liberation(s_etat_processus, s_objet_argument_1);
  357:             liberation(s_etat_processus, s_objet_argument_2);
  358: 
  359:             return;
  360:         }
  361: 
  362:         s_objet_argument_3 = (*s_etat_processus).s_liste_variables
  363:                 [(*s_etat_processus).position_variable_courante].objet;
  364: 
  365:         if (s_objet_argument_3 == NULL)
  366:         {
  367:             if (pthread_mutex_lock(&((*(*s_etat_processus)
  368:                     .s_liste_variables_partagees).mutex)) != 0)
  369:             {
  370:                 (*s_etat_processus).erreur_systeme = d_es_processus;
  371:                 return;
  372:             }
  373: 
  374:             if (recherche_variable_partagee(s_etat_processus,
  375:                     (*s_etat_processus).s_liste_variables
  376:                     [(*s_etat_processus).position_variable_courante].nom,
  377:                     (*s_etat_processus).s_liste_variables
  378:                     [(*s_etat_processus).position_variable_courante]
  379:                     .variable_partagee, (*s_etat_processus).s_liste_variables
  380:                     [(*s_etat_processus).position_variable_courante].origine)
  381:                     == d_faux)
  382:             {
  383:                 if (pthread_mutex_unlock(&((*(*s_etat_processus)
  384:                         .s_liste_variables_partagees).mutex)) != 0)
  385:                 {
  386:                     (*s_etat_processus).erreur_systeme = d_es_processus;
  387:                     return;
  388:                 }
  389: 
  390:                 (*s_etat_processus).erreur_systeme = d_es;
  391:                 (*s_etat_processus).erreur_execution =
  392:                         d_ex_variable_non_definie;
  393: 
  394:                 liberation(s_etat_processus, s_objet_argument_1);
  395:                 liberation(s_etat_processus, s_objet_argument_2);
  396: 
  397:                 return;
  398:             }
  399: 
  400:             s_objet_argument_3 = (*(*s_etat_processus)
  401:                     .s_liste_variables_partagees).table
  402:                     [(*(*s_etat_processus).s_liste_variables_partagees)
  403:                     .position_variable].objet;
  404:             variable_partagee = d_vrai;
  405:         }
  406: 
  407:         if ((s_copie_argument_3 = copie_objet(s_etat_processus,
  408:                 s_objet_argument_3, 'Q')) == NULL)
  409:         {
  410:             if (variable_partagee == d_vrai)
  411:             {
  412:                 if (pthread_mutex_unlock(&((*(*s_etat_processus)
  413:                         .s_liste_variables_partagees).mutex)) != 0)
  414:                 {
  415:                     (*s_etat_processus).erreur_systeme = d_es_processus;
  416:                     return;
  417:                 }
  418:             }
  419: 
  420:             (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
  421:             return;
  422:         }
  423: 
  424:         liberation(s_etat_processus, s_objet_argument_3);
  425:         s_objet_argument_3 = s_copie_argument_3;
  426: 
  427:         (*s_etat_processus).s_liste_variables[(*s_etat_processus)
  428:                 .position_variable_courante].objet = s_objet_argument_3;
  429:     }
  430:     else
  431:     {
  432:         presence_nom = d_faux;
  433: 
  434:         if ((s_copie_argument_3 = copie_objet(s_etat_processus,
  435:                 s_objet_argument_3, 'Q')) == NULL)
  436:         {
  437:             (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
  438:             return;
  439:         }
  440: 
  441:         liberation(s_etat_processus, s_objet_argument_3);
  442:         s_objet_argument_3 = s_copie_argument_3;
  443:     }
  444: 
  445:     if (((*((struct_matrice *) (*s_objet_argument_3).objet)).nombre_colonnes
  446:             == 0) && ((*((struct_matrice *) (*s_objet_argument_3).objet))
  447:             .nombre_lignes == 1))
  448:     {
  449:         matrice_vide = d_vrai;
  450:     }
  451:     else
  452:     {
  453:         matrice_vide = d_faux;
  454: 
  455:         if ((*((struct_matrice *) (*s_objet_argument_1).objet)).nombre_colonnes
  456:                 != (*((struct_matrice *) (*s_objet_argument_3).objet))
  457:                 .nombre_colonnes)
  458:         {
  459:             if (variable_partagee == d_vrai)
  460:             {
  461:                 if (pthread_mutex_unlock(&((*(*s_etat_processus)
  462:                         .s_liste_variables_partagees).mutex)) != 0)
  463:                 {
  464:                     (*s_etat_processus).erreur_systeme = d_es_processus;
  465:                     return;
  466:                 }
  467:             }
  468: 
  469:             liberation(s_etat_processus, s_objet_argument_1);
  470:             liberation(s_etat_processus, s_objet_argument_2);
  471: 
  472:             if (presence_nom == d_faux)
  473:             {
  474:                 liberation(s_etat_processus, s_objet_argument_3);
  475:             }
  476: 
  477:             (*s_etat_processus).erreur_execution = d_ex_dimensions_invalides;
  478:             return;
  479:         }
  480:     }
  481: 
  482:     if ((*s_objet_argument_1).type == MRL)
  483:     {
  484:         if ((*s_objet_argument_3).type == MIN)
  485:         {
  486:             // Conversion de la matrice entière en matrice réelle
  487: 
  488:             for(i = 0; i < (*((struct_matrice *) (*s_objet_argument_3).objet))
  489:                     .nombre_lignes; i++)
  490:             {
  491:                 tampon = (*((struct_matrice *) (*s_objet_argument_3).objet))
  492:                         .tableau[i];
  493: 
  494:                 if (((*((struct_matrice *) (*s_objet_argument_3).objet))
  495:                         .tableau[i] = malloc((*((struct_matrice *)
  496:                         (*s_objet_argument_3).objet)).nombre_colonnes *
  497:                         sizeof(real8))) == NULL)
  498:                 {
  499:                     if (variable_partagee == d_vrai)
  500:                     {
  501:                         if (pthread_mutex_unlock(&((*(*s_etat_processus)
  502:                                 .s_liste_variables_partagees).mutex)) != 0)
  503:                         {
  504:                             (*s_etat_processus).erreur_systeme = d_es_processus;
  505:                             return;
  506:                         }
  507:                     }
  508: 
  509:                     (*s_etat_processus).erreur_systeme =
  510:                             d_es_allocation_memoire;
  511:                     return;
  512:                 }
  513: 
  514:                 for(j = 0; j < (*((struct_matrice *) (*s_objet_argument_3)
  515:                         .objet)).nombre_colonnes; j++)
  516:                 {
  517:                     ((real8 **) (*((struct_matrice *) (*s_objet_argument_3)
  518:                             .objet)).tableau)[i][j] = (real8) (((integer8 *)
  519:                             tampon)[j]);
  520:                 }
  521: 
  522:                 free(tampon);
  523:             }
  524: 
  525:             (*((struct_matrice *) (*s_objet_argument_3).objet)).type = 'R';
  526:             (*s_objet_argument_3).type = MRL;
  527:         }
  528:     }
  529:     else if ((*s_objet_argument_1).type == MCX)
  530:     {
  531:         if ((*s_objet_argument_3).type == MIN)
  532:         {
  533:             // Conversion de la matrice entière en matrice complexe
  534: 
  535:             for(i = 0; i < (*((struct_matrice *) (*s_objet_argument_3).objet))
  536:                     .nombre_lignes; i++)
  537:             {
  538:                 tampon = (*((struct_matrice *) (*s_objet_argument_3).objet))
  539:                         .tableau[i];
  540: 
  541:                 if (((*((struct_matrice *) (*s_objet_argument_3).objet))
  542:                         .tableau[i] = malloc((*((struct_matrice *)
  543:                         (*s_objet_argument_3).objet)).nombre_colonnes *
  544:                         sizeof(complex16))) == NULL)
  545:                 {
  546:                     if (variable_partagee == d_vrai)
  547:                     {
  548:                         if (pthread_mutex_unlock(&((*(*s_etat_processus)
  549:                                 .s_liste_variables_partagees).mutex)) != 0)
  550:                         {
  551:                             (*s_etat_processus).erreur_systeme = d_es_processus;
  552:                             return;
  553:                         }
  554:                     }
  555: 
  556:                     (*s_etat_processus).erreur_systeme =
  557:                             d_es_allocation_memoire;
  558:                     return;
  559:                 }
  560: 
  561:                 for(j = 0; j < (*((struct_matrice *) (*s_objet_argument_3)
  562:                         .objet)).nombre_colonnes; j++)
  563:                 {
  564:                     ((complex16 **) (*((struct_matrice *) (*s_objet_argument_3)
  565:                             .objet)).tableau)[i][j].partie_reelle =
  566:                             (real8) (((integer8 *) tampon)[j]);
  567:                     ((complex16 **) (*((struct_matrice *) (*s_objet_argument_3)
  568:                             .objet)).tableau)[i][j].partie_imaginaire = 0;
  569:                 }
  570: 
  571:                 free(tampon);
  572:             }
  573: 
  574:             (*((struct_matrice *) (*s_objet_argument_3).objet)).type = 'C';
  575:             (*s_objet_argument_3).type = MCX;
  576:         }
  577:         else if ((*s_objet_argument_3).type == MRL)
  578:         {
  579:             // Conversion de la matrice réelle en matrice complexe
  580: 
  581:             for(i = 0; i < (*((struct_matrice *) (*s_objet_argument_3).objet))
  582:                     .nombre_lignes; i++)
  583:             {
  584:                 tampon = (*((struct_matrice *) (*s_objet_argument_3).objet))
  585:                         .tableau[i];
  586: 
  587:                 if (((*((struct_matrice *) (*s_objet_argument_3).objet))
  588:                         .tableau[i] = malloc((*((struct_matrice *)
  589:                         (*s_objet_argument_3).objet)).nombre_colonnes *
  590:                         sizeof(complex16))) == NULL)
  591:                 {
  592:                     if (variable_partagee == d_vrai)
  593:                     {
  594:                         if (pthread_mutex_unlock(&((*(*s_etat_processus)
  595:                                 .s_liste_variables_partagees).mutex)) != 0)
  596:                         {
  597:                             (*s_etat_processus).erreur_systeme = d_es_processus;
  598:                             return;
  599:                         }
  600:                     }
  601: 
  602:                     (*s_etat_processus).erreur_systeme =
  603:                             d_es_allocation_memoire;
  604:                     return;
  605:                 }
  606: 
  607:                 for(j = 0; j < (*((struct_matrice *) (*s_objet_argument_3)
  608:                         .objet)).nombre_colonnes; j++)
  609:                 {
  610:                     ((complex16 **) (*((struct_matrice *) (*s_objet_argument_3)
  611:                             .objet)).tableau)[i][j].partie_reelle =
  612:                             ((real8 *) tampon)[j];
  613:                     ((complex16 **) (*((struct_matrice *) (*s_objet_argument_3)
  614:                             .objet)).tableau)[i][j].partie_imaginaire = 0;
  615:                 }
  616: 
  617:                 free(tampon);
  618:             }
  619: 
  620:             (*((struct_matrice *) (*s_objet_argument_3).objet)).type = 'C';
  621:             (*s_objet_argument_3).type = MCX;
  622:         }
  623:     }   
  624: 
  625:     if ((*s_objet_argument_3).type == MRL)
  626:     {
  627:         if ((*s_objet_argument_1).type == MIN)
  628:         {
  629:             // Conversion de la matrice entière en matrice réelle
  630: 
  631:             for(i = 0; i < (*((struct_matrice *) (*s_objet_argument_1).objet))
  632:                     .nombre_lignes; i++)
  633:             {
  634:                 tampon = (*((struct_matrice *) (*s_objet_argument_1).objet))
  635:                         .tableau[i];
  636: 
  637:                 if (((*((struct_matrice *) (*s_objet_argument_1).objet))
  638:                         .tableau[i] = malloc((*((struct_matrice *)
  639:                         (*s_objet_argument_1).objet)).nombre_colonnes *
  640:                         sizeof(real8))) == NULL)
  641:                 {
  642:                     if (variable_partagee == d_vrai)
  643:                     {
  644:                         if (pthread_mutex_unlock(&((*(*s_etat_processus)
  645:                                 .s_liste_variables_partagees).mutex)) != 0)
  646:                         {
  647:                             (*s_etat_processus).erreur_systeme = d_es_processus;
  648:                             return;
  649:                         }
  650:                     }
  651: 
  652:                     (*s_etat_processus).erreur_systeme =
  653:                             d_es_allocation_memoire;
  654:                     return;
  655:                 }
  656: 
  657:                 for(j = 0; j < (*((struct_matrice *) (*s_objet_argument_1)
  658:                         .objet)).nombre_colonnes; j++)
  659:                 {
  660:                     ((real8 **) (*((struct_matrice *) (*s_objet_argument_1)
  661:                             .objet)).tableau)[i][j] = (real8) (((integer8 *)
  662:                             tampon)[j]);
  663:                 }
  664: 
  665:                 free(tampon);
  666:             }
  667: 
  668:             (*((struct_matrice *) (*s_objet_argument_1).objet)).type = 'R';
  669:             (*s_objet_argument_1).type = MRL;
  670:         }
  671:     }
  672:     else if ((*s_objet_argument_3).type == MCX)
  673:     {
  674:         if ((*s_objet_argument_1).type == MIN)
  675:         {
  676:             // Conversion de la matrice entière en matrice complexe
  677: 
  678:             for(i = 0; i < (*((struct_matrice *) (*s_objet_argument_1).objet))
  679:                     .nombre_lignes; i++)
  680:             {
  681:                 tampon = (*((struct_matrice *) (*s_objet_argument_1).objet))
  682:                         .tableau[i];
  683: 
  684:                 if (((*((struct_matrice *) (*s_objet_argument_1).objet))
  685:                         .tableau[i] = malloc((*((struct_matrice *)
  686:                         (*s_objet_argument_1).objet)).nombre_colonnes *
  687:                         sizeof(complex16))) == NULL)
  688:                 {
  689:                     if (variable_partagee == d_vrai)
  690:                     {
  691:                         if (pthread_mutex_unlock(&((*(*s_etat_processus)
  692:                                 .s_liste_variables_partagees).mutex)) != 0)
  693:                         {
  694:                             (*s_etat_processus).erreur_systeme = d_es_processus;
  695:                             return;
  696:                         }
  697:                     }
  698: 
  699:                     (*s_etat_processus).erreur_systeme =
  700:                             d_es_allocation_memoire;
  701:                     return;
  702:                 }
  703: 
  704:                 for(j = 0; j < (*((struct_matrice *) (*s_objet_argument_1)
  705:                         .objet)).nombre_colonnes; j++)
  706:                 {
  707:                     ((complex16 **) (*((struct_matrice *) (*s_objet_argument_1)
  708:                             .objet)).tableau)[i][j].partie_reelle =
  709:                             (real8) (((integer8 *) tampon)[j]);
  710:                     ((complex16 **) (*((struct_matrice *) (*s_objet_argument_1)
  711:                             .objet)).tableau)[i][j].partie_imaginaire = 0;
  712:                 }
  713: 
  714:                 free(tampon);
  715:             }
  716: 
  717:             (*((struct_matrice *) (*s_objet_argument_1).objet)).type = 'C';
  718:             (*s_objet_argument_1).type = MCX;
  719:         }
  720:         else if ((*s_objet_argument_1).type == MRL)
  721:         {
  722:             // Conversion de la matrice réelle en matrice complexe
  723: 
  724:             for(i = 0; i < (*((struct_matrice *) (*s_objet_argument_1).objet))
  725:                     .nombre_lignes; i++)
  726:             {
  727:                 tampon = (*((struct_matrice *) (*s_objet_argument_1).objet))
  728:                         .tableau[i];
  729: 
  730:                 if (((*((struct_matrice *) (*s_objet_argument_1).objet))
  731:                         .tableau[i] = malloc((*((struct_matrice *)
  732:                         (*s_objet_argument_1).objet)).nombre_colonnes *
  733:                         sizeof(complex16))) == NULL)
  734:                 {
  735:                     if (variable_partagee == d_vrai)
  736:                     {
  737:                         if (pthread_mutex_unlock(&((*(*s_etat_processus)
  738:                                 .s_liste_variables_partagees).mutex)) != 0)
  739:                         {
  740:                             (*s_etat_processus).erreur_systeme = d_es_processus;
  741:                             return;
  742:                         }
  743:                     }
  744: 
  745:                     (*s_etat_processus).erreur_systeme =
  746:                             d_es_allocation_memoire;
  747:                     return;
  748:                 }
  749: 
  750:                 for(j = 0; j < (*((struct_matrice *) (*s_objet_argument_1)
  751:                         .objet)).nombre_colonnes; j++)
  752:                 {
  753:                     ((complex16 **) (*((struct_matrice *) (*s_objet_argument_1)
  754:                             .objet)).tableau)[i][j].partie_reelle =
  755:                             ((real8 *) tampon)[j];
  756:                     ((complex16 **) (*((struct_matrice *) (*s_objet_argument_1)
  757:                             .objet)).tableau)[i][j].partie_imaginaire = 0;
  758:                 }
  759: 
  760:                 free(tampon);
  761:             }
  762: 
  763:             (*((struct_matrice *) (*s_objet_argument_1).objet)).type = 'C';
  764:             (*s_objet_argument_1).type = MCX;
  765:         }
  766:     }
  767: 
  768:     position = (*((integer8 *) (*s_objet_argument_2).objet));
  769: 
  770:     if (((position < 1) || (position > (integer8) ((*((struct_matrice *)
  771:             (*s_objet_argument_3).objet)).nombre_lignes + 1))) ||
  772:             ((position != 1) && (matrice_vide == d_vrai)))
  773:     {
  774:         if (variable_partagee == d_vrai)
  775:         {
  776:             if (pthread_mutex_unlock(&((*(*s_etat_processus)
  777:                     .s_liste_variables_partagees).mutex)) != 0)
  778:             {
  779:                 (*s_etat_processus).erreur_systeme = d_es_processus;
  780:                 return;
  781:             }
  782:         }
  783: 
  784:         liberation(s_etat_processus, s_objet_argument_1);
  785:         liberation(s_etat_processus, s_objet_argument_2);
  786: 
  787:         if (presence_nom == d_faux)
  788:         {
  789:             liberation(s_etat_processus, s_objet_argument_3);
  790:         }
  791: 
  792:         (*s_etat_processus).erreur_execution =
  793:                 d_ex_argument_invalide;
  794:         return;
  795:     }
  796: 
  797:     tableau = (*((struct_matrice *) (*s_objet_argument_3).objet)).tableau;
  798: 
  799:     if (matrice_vide == d_faux)
  800:     {
  801:         if (((*((struct_matrice *) (*s_objet_argument_3).objet)).tableau
  802:                 = malloc(((*((struct_matrice *) (*s_objet_argument_3).objet))
  803:                 .nombre_lignes + 1) * sizeof(void *))) == NULL)
  804:         {
  805:             if (variable_partagee == d_vrai)
  806:             {
  807:                 if (pthread_mutex_unlock(&((*(*s_etat_processus)
  808:                         .s_liste_variables_partagees).mutex)) != 0)
  809:                 {
  810:                     (*s_etat_processus).erreur_systeme = d_es_processus;
  811:                     return;
  812:                 }
  813:             }
  814: 
  815:             (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
  816:             return;
  817:         }
  818: 
  819:         if (position != ((integer8) (*((struct_matrice *)
  820:                 (*s_objet_argument_3).objet)).nombre_lignes + 1))
  821:         {
  822:             for(j = i = 0; i < (*((struct_matrice *)
  823:                     (*s_objet_argument_3).objet)).nombre_lignes; i++)
  824:             {
  825:                 if (i == (unsigned long) (position - 1))
  826:                 {
  827:                     (*((struct_matrice *) (*s_objet_argument_3).objet))
  828:                             .tableau[i] = (*((struct_matrice *)
  829:                             (*s_objet_argument_1).objet)).tableau[0];
  830:                     j = 1;
  831:                 }
  832: 
  833:                 (*((struct_matrice *) (*s_objet_argument_3).objet))
  834:                         .tableau[i + j] = tableau[i];
  835:             }
  836:         }
  837:         else
  838:         {
  839:             for(i = 0; i < (*((struct_matrice *) (*s_objet_argument_3).objet))
  840:                     .nombre_lignes; i++)
  841:             {
  842:                 (*((struct_matrice *) (*s_objet_argument_3).objet)).tableau[i]
  843:                         = tableau[i];
  844:             }
  845: 
  846:             (*((struct_matrice *) (*s_objet_argument_3).objet)).tableau
  847:                     [(*((struct_matrice *) (*s_objet_argument_3).objet))
  848:                     .nombre_lignes] = (*((struct_matrice *)
  849:                     (*s_objet_argument_1).objet)).tableau[0];
  850:         }
  851: 
  852:         (*((struct_matrice *) (*s_objet_argument_3).objet)).nombre_lignes++;
  853:     }
  854:     else
  855:     {
  856:         free((*((struct_matrice *) (*s_objet_argument_3).objet)).tableau[0]);
  857: 
  858:         if (((*((struct_matrice *) (*s_objet_argument_3).objet)).tableau
  859:                 = malloc(sizeof(void *))) == NULL)
  860:         {
  861:             if (variable_partagee == d_vrai)
  862:             {
  863:                 if (pthread_mutex_unlock(&((*(*s_etat_processus)
  864:                         .s_liste_variables_partagees).mutex)) != 0)
  865:                 {
  866:                     (*s_etat_processus).erreur_systeme = d_es_processus;
  867:                     return;
  868:                 }
  869:             }
  870: 
  871:             (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
  872:             return;
  873:         }
  874: 
  875:         (*((struct_matrice *) (*s_objet_argument_3).objet)).tableau[0] =
  876:                 (*((struct_matrice *) (*s_objet_argument_1).objet)).tableau[0];
  877:         (*((struct_matrice *) (*s_objet_argument_3).objet)).nombre_lignes =
  878:                 (*((struct_matrice *) (*s_objet_argument_1).objet))
  879:                 .nombre_lignes;
  880:         (*((struct_matrice *) (*s_objet_argument_3).objet)).nombre_colonnes =
  881:                 (*((struct_matrice *) (*s_objet_argument_1).objet))
  882:                 .nombre_colonnes;
  883:     }
  884: 
  885:     free(tableau);
  886: 
  887:     if (presence_nom == d_faux)
  888:     {
  889:         if (empilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
  890:                 s_objet_argument_3) == d_erreur)
  891:         {
  892:             return;
  893:         }
  894:     }
  895:     else
  896:     {
  897:         if (variable_partagee == d_vrai)
  898:         {
  899:             (*(*s_etat_processus).s_liste_variables_partagees).table
  900:                     [(*(*s_etat_processus).s_liste_variables_partagees)
  901:                     .position_variable].objet = s_objet_argument_3;
  902: 
  903:             if (pthread_mutex_unlock(&((*(*s_etat_processus)
  904:                     .s_liste_variables_partagees).mutex)) != 0)
  905:             {
  906:                 (*s_etat_processus).erreur_systeme = d_es_processus;
  907:                 return;
  908:             }
  909:         }
  910:     }
  911: 
  912:     free((*((struct_matrice *) (*s_objet_argument_1).objet)).tableau);
  913:     free((*s_objet_argument_1).objet);
  914:     free(s_objet_argument_1);
  915: 
  916:     liberation(s_etat_processus, s_objet_argument_2);
  917: 
  918:     return;
  919: }
  920: 
  921: 
  922: /*
  923: ================================================================================
  924:   Fonction 'row-'
  925: ================================================================================
  926:   Entrées : pointeur sur une structure struct_processus
  927: --------------------------------------------------------------------------------
  928:   Sorties :
  929: --------------------------------------------------------------------------------
  930:   Effets de bord : néant
  931: ================================================================================
  932: */
  933: 
  934: void
  935: instruction_row_moins(struct_processus *s_etat_processus)
  936: {
  937:     integer8                    position;
  938: 
  939:     logical1                    presence_variable;
  940:     logical1                    variable_partagee;
  941: 
  942:     struct_objet                *s_copie_argument_2;
  943:     struct_objet                *s_objet_argument_1;
  944:     struct_objet                *s_objet_argument_2;
  945:     struct_objet                *s_objet_resultat;
  946: 
  947:     unsigned long               i;
  948:     unsigned long               j;
  949:     unsigned long               colonne;
  950: 
  951:     void                        **tableau;
  952: 
  953:     (*s_etat_processus).erreur_execution = d_ex;
  954: 
  955:     if ((*s_etat_processus).affichage_arguments == 'Y')
  956:     {
  957:         printf("\n  ROW- ");
  958: 
  959:         if ((*s_etat_processus).langue == 'F')
  960:         {
  961:             printf("(retrait d'une ligne dans une matrice)\n\n");
  962:         }
  963:         else
  964:         {
  965:             printf("(remove a row from a matrix)\n\n");
  966:         }
  967: 
  968:         printf("    2: %s, %s, %s\n", d_MIN, d_MRL, d_MCX);
  969:         printf("    1: %s\n", d_INT);
  970:         printf("->  2: %s, %s, %s\n\n", d_MIN, d_MRL, d_MCX);
  971:         printf("    1: %s, %s, %s\n\n", d_MIN, d_MRL, d_MCX);
  972: 
  973:         printf("    2: %s\n", d_NOM);
  974:         printf("    1: %s\n", d_INT);
  975:         printf("->  1: %s, %s, %s\n", d_MIN, d_MRL, d_MCX);
  976: 
  977:         return;
  978:     }
  979:     else if ((*s_etat_processus).test_instruction == 'Y')
  980:     {
  981:         (*s_etat_processus).nombre_arguments = -1;
  982:         return;
  983:     }
  984: 
  985:     if (test_cfsf(s_etat_processus, 31) == d_vrai)
  986:     {
  987:         if (empilement_pile_last(s_etat_processus, 2) == d_erreur)
  988:         {
  989:             return;
  990:         }
  991:     }
  992: 
  993:     if (depilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
  994:             &s_objet_argument_1) == d_erreur)
  995:     {
  996:         (*s_etat_processus).erreur_execution = d_ex_manque_argument;
  997:         return;
  998:     }
  999: 
 1000:     if (depilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
 1001:             &s_objet_argument_2) == d_erreur)
 1002:     {
 1003:         liberation(s_etat_processus, s_objet_argument_1);
 1004: 
 1005:         (*s_etat_processus).erreur_execution = d_ex_manque_argument;
 1006:         return;
 1007:     }
 1008: 
 1009:     variable_partagee = d_faux;
 1010: 
 1011:     if ((*s_objet_argument_2).type == NOM)
 1012:     {
 1013:         presence_variable = d_vrai;
 1014: 
 1015:         if (recherche_variable(s_etat_processus, (*((struct_nom *)
 1016:                 (*s_objet_argument_2).objet)).nom) == d_faux)
 1017:         {
 1018:             liberation(s_etat_processus, s_objet_argument_1);
 1019:             liberation(s_etat_processus, s_objet_argument_2);
 1020: 
 1021:             (*s_etat_processus).erreur_systeme = d_es;
 1022:             (*s_etat_processus).erreur_execution = d_ex_variable_non_definie;
 1023: 
 1024:             return;
 1025:         }
 1026: 
 1027:         liberation(s_etat_processus, s_objet_argument_2);
 1028: 
 1029:         if ((*s_etat_processus).s_liste_variables[(*s_etat_processus)
 1030:                 .position_variable_courante].variable_verrouillee == d_vrai)
 1031:         {
 1032:             liberation(s_etat_processus, s_objet_argument_1);
 1033: 
 1034:             (*s_etat_processus).erreur_execution = d_ex_variable_verrouillee;
 1035:             return;
 1036:         }
 1037: 
 1038:         s_objet_argument_2 = (*s_etat_processus).s_liste_variables
 1039:                 [(*s_etat_processus).position_variable_courante].objet;
 1040: 
 1041:         if (s_objet_argument_2 == NULL)
 1042:         {
 1043:             if (pthread_mutex_lock(&((*(*s_etat_processus)
 1044:                     .s_liste_variables_partagees).mutex)) != 0)
 1045:             {
 1046:                 (*s_etat_processus).erreur_systeme = d_es_processus;
 1047:                 return;
 1048:             }
 1049: 
 1050:             if (recherche_variable_partagee(s_etat_processus,
 1051:                     (*s_etat_processus).s_liste_variables
 1052:                     [(*s_etat_processus).position_variable_courante].nom,
 1053:                     (*s_etat_processus).s_liste_variables
 1054:                     [(*s_etat_processus).position_variable_courante]
 1055:                     .variable_partagee, (*s_etat_processus).s_liste_variables
 1056:                     [(*s_etat_processus).position_variable_courante].origine)
 1057:                     == d_faux)
 1058:             {
 1059:                 if (pthread_mutex_unlock(&((*(*s_etat_processus)
 1060:                         .s_liste_variables_partagees).mutex)) != 0)
 1061:                 {
 1062:                     (*s_etat_processus).erreur_systeme = d_es_processus;
 1063:                     return;
 1064:                 }
 1065: 
 1066:                 (*s_etat_processus).erreur_systeme = d_es;
 1067:                 (*s_etat_processus).erreur_execution =
 1068:                         d_ex_variable_non_definie;
 1069: 
 1070:                 liberation(s_etat_processus, s_objet_argument_1);
 1071: 
 1072:                 return;
 1073:             }
 1074: 
 1075:             s_objet_argument_2 = (*(*s_etat_processus)
 1076:                     .s_liste_variables_partagees).table
 1077:                     [(*(*s_etat_processus).s_liste_variables_partagees)
 1078:                     .position_variable].objet;
 1079:             variable_partagee = d_vrai;
 1080:         }
 1081: 
 1082:         if ((s_copie_argument_2 = copie_objet(s_etat_processus,
 1083:                 s_objet_argument_2, 'Q')) == NULL)
 1084:         {
 1085:             if (variable_partagee == d_vrai)
 1086:             {
 1087:                 if (pthread_mutex_unlock(&((*(*s_etat_processus)
 1088:                         .s_liste_variables_partagees).mutex)) != 0)
 1089:                 {
 1090:                     (*s_etat_processus).erreur_systeme = d_es_processus;
 1091:                     return;
 1092:                 }
 1093:             }
 1094: 
 1095:             (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
 1096:             return;
 1097:         }
 1098: 
 1099:         liberation(s_etat_processus, s_objet_argument_2);
 1100:         s_objet_argument_2 = s_copie_argument_2;
 1101: 
 1102:         (*s_etat_processus).s_liste_variables[(*s_etat_processus)
 1103:                 .position_variable_courante].objet = s_objet_argument_2;
 1104:     }
 1105:     else
 1106:     {
 1107:         presence_variable = d_faux;
 1108: 
 1109:         if ((s_copie_argument_2 = copie_objet(s_etat_processus,
 1110:                 s_objet_argument_2, 'Q')) == NULL)
 1111:         {
 1112:             (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
 1113:             return;
 1114:         }
 1115: 
 1116:         liberation(s_etat_processus, s_objet_argument_2);
 1117:         s_objet_argument_2 = s_copie_argument_2;
 1118:     }
 1119: 
 1120:     if (((*s_objet_argument_2).type == MIN) ||
 1121:             ((*s_objet_argument_2).type == MRL) ||
 1122:             ((*s_objet_argument_2).type == MCX))
 1123:     {
 1124:         if ((*s_objet_argument_1).type == INT)
 1125:         {
 1126:             position = (*((integer8 *) (*s_objet_argument_1).objet));
 1127: 
 1128:             if ((position <= 0) || (position > (integer8) (*((struct_matrice *)
 1129:                     (*s_objet_argument_2).objet)).nombre_lignes))
 1130:             {
 1131:                 if (variable_partagee == d_vrai)
 1132:                 {
 1133:                     if (pthread_mutex_unlock(&((*(*s_etat_processus)
 1134:                             .s_liste_variables_partagees).mutex)) != 0)
 1135:                     {
 1136:                         (*s_etat_processus).erreur_systeme = d_es_processus;
 1137:                         return;
 1138:                     }
 1139:                 }
 1140: 
 1141:                 liberation(s_etat_processus, s_objet_argument_1);
 1142: 
 1143:                 if (presence_variable == d_faux)
 1144:                 {
 1145:                     liberation(s_etat_processus, s_objet_argument_2);
 1146:                 }
 1147: 
 1148:                 (*s_etat_processus).erreur_execution =
 1149:                         d_ex_argument_invalide;
 1150:                 return;
 1151:             }
 1152: 
 1153:             if ((s_objet_resultat = allocation(s_etat_processus,
 1154:                     (*s_objet_argument_2).type)) == NULL)
 1155:             {
 1156:                 if (variable_partagee == d_vrai)
 1157:                 {
 1158:                     if (pthread_mutex_unlock(&((*(*s_etat_processus)
 1159:                             .s_liste_variables_partagees).mutex)) != 0)
 1160:                     {
 1161:                         (*s_etat_processus).erreur_systeme = d_es_processus;
 1162:                         return;
 1163:                     }
 1164:                 }
 1165: 
 1166:                 (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
 1167:                 return;
 1168:             }
 1169: 
 1170:             (*((struct_matrice *) (*s_objet_resultat).objet)).nombre_lignes =
 1171:                     1;
 1172:             (*((struct_matrice *) (*s_objet_resultat).objet)).nombre_colonnes =
 1173:                     (*((struct_matrice *) (*s_objet_argument_2).objet))
 1174:                     .nombre_colonnes;
 1175: 
 1176:             if (((*((struct_matrice *) (*s_objet_resultat).objet)).tableau =
 1177:                     malloc(sizeof(void *))) == NULL)
 1178:             {
 1179:                 if (variable_partagee == d_vrai)
 1180:                 {
 1181:                     if (pthread_mutex_unlock(&((*(*s_etat_processus)
 1182:                             .s_liste_variables_partagees).mutex)) != 0)
 1183:                     {
 1184:                         (*s_etat_processus).erreur_systeme = d_es_processus;
 1185:                         return;
 1186:                     }
 1187:                 }
 1188: 
 1189:                 (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
 1190:                 return;
 1191:             }
 1192: 
 1193:             (*((struct_matrice *) (*s_objet_resultat).objet)).tableau[0] =
 1194:                     (*((struct_matrice *) (*s_objet_argument_2).objet)).tableau
 1195:                     [colonne = position - 1];
 1196: 
 1197:             if ((*((struct_matrice *) (*s_objet_argument_2).objet))
 1198:                     .nombre_lignes > 1)
 1199:             {
 1200:                 tableau = (*((struct_matrice *) (*s_objet_argument_2).objet))
 1201:                         .tableau;
 1202: 
 1203:                 if (((*((struct_matrice *) (*s_objet_argument_2).objet)).tableau
 1204:                         = malloc(((*((struct_matrice *) (*s_objet_argument_2)
 1205:                         .objet)).nombre_lignes - 1) * sizeof(void *))) == NULL)
 1206:                 {
 1207:                     if (variable_partagee == d_vrai)
 1208:                     {
 1209:                         if (pthread_mutex_unlock(&((*(*s_etat_processus)
 1210:                                 .s_liste_variables_partagees).mutex)) != 0)
 1211:                         {
 1212:                             (*s_etat_processus).erreur_systeme = d_es_processus;
 1213:                             return;
 1214:                         }
 1215:                     }
 1216: 
 1217:                     (*s_etat_processus).erreur_systeme =
 1218:                             d_es_allocation_memoire;
 1219:                     return;
 1220:                 }
 1221: 
 1222:                 (*((struct_matrice *) (*s_objet_argument_2).objet))
 1223:                         .nombre_lignes--;
 1224: 
 1225:                 for(i = j = 0; i < (*((struct_matrice *) (*s_objet_argument_2)
 1226:                         .objet)).nombre_lignes; i++)
 1227:                 {
 1228:                     if (i == colonne)
 1229:                     {
 1230:                         j = 1;
 1231:                     }
 1232: 
 1233:                     (*((struct_matrice *) (*s_objet_argument_2).objet))
 1234:                             .tableau[i] = tableau[i + j];
 1235:                 }
 1236: 
 1237:                 free(tableau);
 1238:             }
 1239:             else
 1240:             {
 1241:                 if (((*((struct_matrice *) (*s_objet_argument_2).objet))
 1242:                         .tableau[0] = malloc(0)) == NULL)
 1243:                 {
 1244:                     if (variable_partagee == d_vrai)
 1245:                     {
 1246:                         if (pthread_mutex_unlock(&((*(*s_etat_processus)
 1247:                                 .s_liste_variables_partagees).mutex)) != 0)
 1248:                         {
 1249:                             (*s_etat_processus).erreur_systeme = d_es_processus;
 1250:                             return;
 1251:                         }
 1252:                     }
 1253: 
 1254:                     (*s_etat_processus).erreur_systeme =
 1255:                             d_es_allocation_memoire;
 1256:                     return;
 1257:                 }
 1258: 
 1259:                 (*((struct_matrice *) (*s_objet_argument_2).objet))
 1260:                         .nombre_colonnes = 0;
 1261:             }
 1262:         }
 1263:         else
 1264:         {
 1265:             if (variable_partagee == d_vrai)
 1266:             {
 1267:                 if (pthread_mutex_unlock(&((*(*s_etat_processus)
 1268:                         .s_liste_variables_partagees).mutex)) != 0)
 1269:                 {
 1270:                     (*s_etat_processus).erreur_systeme = d_es_processus;
 1271:                     return;
 1272:                 }
 1273:             }
 1274: 
 1275:             liberation(s_etat_processus, s_objet_argument_1);
 1276: 
 1277:             if (presence_variable == d_faux)
 1278:             {
 1279:                 liberation(s_etat_processus, s_objet_argument_2);
 1280:             }
 1281: 
 1282:             (*s_etat_processus).erreur_execution = d_ex_erreur_type_argument;
 1283:             return;
 1284:         }
 1285:     }
 1286:     else
 1287:     {
 1288:         if (variable_partagee == d_vrai)
 1289:         {
 1290:             if (pthread_mutex_unlock(&((*(*s_etat_processus)
 1291:                     .s_liste_variables_partagees).mutex)) != 0)
 1292:             {
 1293:                 (*s_etat_processus).erreur_systeme = d_es_processus;
 1294:                 return;
 1295:             }
 1296:         }
 1297: 
 1298:         liberation(s_etat_processus, s_objet_argument_1);
 1299: 
 1300:         if (presence_variable == d_faux)
 1301:         {
 1302:             liberation(s_etat_processus, s_objet_argument_2);
 1303:         }
 1304: 
 1305:         (*s_etat_processus).erreur_execution = d_ex_erreur_type_argument;
 1306:         return;
 1307:     }
 1308: 
 1309:     liberation(s_etat_processus, s_objet_argument_1);
 1310: 
 1311:     if (presence_variable == d_faux)
 1312:     {
 1313:         if (empilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
 1314:                 s_objet_argument_2) == d_erreur)
 1315:         {
 1316:             return;
 1317:         }
 1318:     }
 1319:     else if (variable_partagee == d_vrai)
 1320:     {
 1321:         (*(*s_etat_processus).s_liste_variables_partagees).table
 1322:                 [(*(*s_etat_processus).s_liste_variables_partagees)
 1323:                 .position_variable].objet = s_objet_argument_2;
 1324: 
 1325:         if (pthread_mutex_unlock(&((*(*s_etat_processus)
 1326:                 .s_liste_variables_partagees).mutex)) != 0)
 1327:         {
 1328:             (*s_etat_processus).erreur_systeme = d_es_processus;
 1329:             return;
 1330:         }
 1331:     }
 1332: 
 1333:     if (empilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
 1334:             s_objet_resultat) == d_erreur)
 1335:     {
 1336:         return;
 1337:     }
 1338: 
 1339:     return;
 1340: }
 1341: 
 1342: 
 1343: /*
 1344: ================================================================================
 1345:   Fonction 'rci'
 1346: ================================================================================
 1347:   Entrées : pointeur sur une structure struct_processus
 1348: --------------------------------------------------------------------------------
 1349:   Sorties :
 1350: --------------------------------------------------------------------------------
 1351:   Effets de bord : néant
 1352: ================================================================================
 1353: */
 1354: 
 1355: void
 1356: instruction_rci(struct_processus *s_etat_processus)
 1357: {
 1358:     logical1                    last_valide;
 1359: 
 1360:     struct_objet                *s_objet_argument_1;
 1361:     struct_objet                *s_objet_argument_2;
 1362:     struct_objet                *s_objet_argument_3;
 1363:     struct_objet                *tampon;
 1364: 
 1365:     (*s_etat_processus).erreur_execution = d_ex;
 1366: 
 1367:     if ((*s_etat_processus).affichage_arguments == 'Y')
 1368:     {
 1369:         printf("\n  RCI ");
 1370: 
 1371:         if ((*s_etat_processus).langue == 'F')
 1372:         {
 1373:             printf("(multiplication d'une ligne d'une matrice)\n\n");
 1374:         }
 1375:         else
 1376:         {
 1377:             printf("(multiply a row in a matrix)\n\n");
 1378:         }
 1379: 
 1380:         printf("    3: %s, %s, %s\n", d_MIN, d_MRL, d_MCX);
 1381:         printf("    2: %s, %s, %s\n", d_INT, d_REL, d_CPL);
 1382:         printf("    1: %s\n", d_INT);
 1383:         printf("->  1: %s, %s, %s\n", d_MIN, d_MRL, d_MCX);
 1384: 
 1385:         return;
 1386:     }
 1387:     else if ((*s_etat_processus).test_instruction == 'Y')
 1388:     {
 1389:         (*s_etat_processus).nombre_arguments = -1;
 1390:         return;
 1391:     }
 1392: 
 1393:     if ((last_valide = test_cfsf(s_etat_processus, 31)) == d_vrai)
 1394:     {
 1395:         if (empilement_pile_last(s_etat_processus, 3) == d_erreur)
 1396:         {
 1397:             return;
 1398:         }
 1399: 
 1400:         cf(s_etat_processus, 31);
 1401:     }
 1402: 
 1403:     if (depilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
 1404:             &s_objet_argument_1) == d_erreur)
 1405:     {
 1406:         if (last_valide == d_vrai)
 1407:         {
 1408:             sf(s_etat_processus, 31);
 1409:         }
 1410: 
 1411:         (*s_etat_processus).erreur_execution = d_ex_manque_argument;
 1412:         return;
 1413:     }
 1414: 
 1415:     if (depilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
 1416:             &s_objet_argument_2) == d_erreur)
 1417:     {
 1418:         if (last_valide == d_vrai)
 1419:         {
 1420:             sf(s_etat_processus, 31);
 1421:         }
 1422: 
 1423:         liberation(s_etat_processus, s_objet_argument_1);
 1424: 
 1425:         (*s_etat_processus).erreur_execution = d_ex_manque_argument;
 1426:         return;
 1427:     }
 1428: 
 1429:     if (depilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
 1430:             &s_objet_argument_3) == d_erreur)
 1431:     {
 1432:         if (last_valide == d_vrai)
 1433:         {
 1434:             sf(s_etat_processus, 31);
 1435:         }
 1436: 
 1437:         liberation(s_etat_processus, s_objet_argument_1);
 1438:         liberation(s_etat_processus, s_objet_argument_2);
 1439: 
 1440:         (*s_etat_processus).erreur_execution = d_ex_manque_argument;
 1441:         return;
 1442:     }
 1443: 
 1444:     if ((((*s_objet_argument_3).type == MIN) ||
 1445:             ((*s_objet_argument_3).type == MRL) ||
 1446:             ((*s_objet_argument_3).type == MCX)) &&
 1447:             (((*s_objet_argument_2).type == INT) ||
 1448:             ((*s_objet_argument_2).type == REL) ||
 1449:             ((*s_objet_argument_2).type == CPL)) &&
 1450:             ((*s_objet_argument_1).type == INT))
 1451:     {
 1452:         if (empilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
 1453:                 s_objet_argument_3) == d_erreur)
 1454:         {
 1455:             if (last_valide == d_vrai)
 1456:             {
 1457:                 sf(s_etat_processus, 31);
 1458:             }
 1459: 
 1460:             return;
 1461:         }
 1462: 
 1463:         tampon = s_objet_argument_1;
 1464: 
 1465:         if ((s_objet_argument_1 = allocation(s_etat_processus, LST)) == NULL)
 1466:         {
 1467:             (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
 1468:             return;
 1469:         }
 1470: 
 1471:         if (((*s_objet_argument_1).objet =
 1472:                 allocation_maillon(s_etat_processus)) == NULL)
 1473:         {
 1474:             (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
 1475:             return;
 1476:         }
 1477: 
 1478:         (*((struct_liste_chainee *) (*s_objet_argument_1).objet)).donnee =
 1479:                 tampon;
 1480:         (*((struct_liste_chainee *) (*s_objet_argument_1).objet)).suivant =
 1481:                 NULL;
 1482: 
 1483:         if (empilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
 1484:                 s_objet_argument_1) == d_erreur)
 1485:         {
 1486:             if (last_valide == d_vrai)
 1487:             {
 1488:                 sf(s_etat_processus, 31);
 1489:             }
 1490: 
 1491:             return;
 1492:         }
 1493: 
 1494:         instruction_dup2(s_etat_processus);
 1495: 
 1496:         if (((*s_etat_processus).erreur_systeme != d_es) ||
 1497:                 ((*s_etat_processus).erreur_execution != d_ex) ||
 1498:                 ((*s_etat_processus).exception != d_ep))
 1499:         {
 1500:             liberation(s_etat_processus, s_objet_argument_1);
 1501:             liberation(s_etat_processus, s_objet_argument_2);
 1502:             liberation(s_etat_processus, s_objet_argument_3);
 1503: 
 1504:             if (last_valide == d_vrai)
 1505:             {
 1506:                 sf(s_etat_processus, 31);
 1507:             }
 1508: 
 1509:             return;
 1510:         }
 1511: 
 1512:         instruction_getr(s_etat_processus);
 1513: 
 1514:         if (((*s_etat_processus).erreur_systeme != d_es) ||
 1515:                 ((*s_etat_processus).erreur_execution != d_ex) ||
 1516:                 ((*s_etat_processus).exception != d_ep))
 1517:         {
 1518:             liberation(s_etat_processus, s_objet_argument_1);
 1519:             liberation(s_etat_processus, s_objet_argument_2);
 1520:             liberation(s_etat_processus, s_objet_argument_3);
 1521: 
 1522:             if (last_valide == d_vrai)
 1523:             {
 1524:                 sf(s_etat_processus, 31);
 1525:             }
 1526: 
 1527:             return;
 1528:         }
 1529: 
 1530:         if (empilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
 1531:                 s_objet_argument_2) == d_erreur)
 1532:         {
 1533:             return;
 1534:         }
 1535: 
 1536:         instruction_multiplication(s_etat_processus);
 1537: 
 1538:         if (((*s_etat_processus).erreur_systeme != d_es) ||
 1539:                 ((*s_etat_processus).erreur_execution != d_ex) ||
 1540:                 ((*s_etat_processus).exception != d_ep))
 1541:         {
 1542:             liberation(s_etat_processus, s_objet_argument_1);
 1543:             liberation(s_etat_processus, s_objet_argument_2);
 1544:             liberation(s_etat_processus, s_objet_argument_3);
 1545: 
 1546:             if (last_valide == d_vrai)
 1547:             {
 1548:                 sf(s_etat_processus, 31);
 1549:             }
 1550: 
 1551:             return;
 1552:         }
 1553: 
 1554:         instruction_putr(s_etat_processus);
 1555: 
 1556:         if (((*s_etat_processus).erreur_systeme != d_es) ||
 1557:                 ((*s_etat_processus).erreur_execution != d_ex) ||
 1558:                 ((*s_etat_processus).exception != d_ep))
 1559:         {
 1560:             liberation(s_etat_processus, s_objet_argument_1);
 1561:             liberation(s_etat_processus, s_objet_argument_2);
 1562:             liberation(s_etat_processus, s_objet_argument_3);
 1563: 
 1564:             if (last_valide == d_vrai)
 1565:             {
 1566:                 sf(s_etat_processus, 31);
 1567:             }
 1568: 
 1569:             return;
 1570:         }
 1571:     }
 1572:     else
 1573:     {
 1574:         liberation(s_etat_processus, s_objet_argument_1);
 1575:         liberation(s_etat_processus, s_objet_argument_2);
 1576:         liberation(s_etat_processus, s_objet_argument_3);
 1577: 
 1578:         if (last_valide == d_vrai)
 1579:         {
 1580:             sf(s_etat_processus, 31);
 1581:         }
 1582: 
 1583:         (*s_etat_processus).erreur_execution = d_ex_erreur_type_argument;
 1584:         return;
 1585:     }
 1586: 
 1587:     if (last_valide == d_vrai)
 1588:     {
 1589:         sf(s_etat_processus, 31);
 1590:     }
 1591: 
 1592:     return;
 1593: }
 1594: 
 1595: 
 1596: /*
 1597: ================================================================================
 1598:   Fonction 'rcij'
 1599: ================================================================================
 1600:   Entrées : pointeur sur une structure struct_processus
 1601: --------------------------------------------------------------------------------
 1602:   Sorties :
 1603: --------------------------------------------------------------------------------
 1604:   Effets de bord : néant
 1605: ================================================================================
 1606: */
 1607: 
 1608: void
 1609: instruction_rcij(struct_processus *s_etat_processus)
 1610: {
 1611:     logical1                    last_valide;
 1612: 
 1613:     struct_objet                *s_objet_argument_1;
 1614:     struct_objet                *s_objet_argument_2;
 1615:     struct_objet                *s_objet_argument_3;
 1616:     struct_objet                *s_objet_argument_4;
 1617:     struct_objet                *tampon;
 1618: 
 1619:     (*s_etat_processus).erreur_execution = d_ex;
 1620: 
 1621:     if ((*s_etat_processus).affichage_arguments == 'Y')
 1622:     {
 1623:         printf("\n  RCIJ ");
 1624: 
 1625:         if ((*s_etat_processus).langue == 'F')
 1626:         {
 1627:             printf("(multiplication puis ajout d'une ligne d'une matrice)\n\n");
 1628:         }
 1629:         else
 1630:         {
 1631:             printf("(multiply and add a row in a matrix)\n\n");
 1632:         }
 1633: 
 1634:         printf("    4: %s, %s, %s\n", d_MIN, d_MRL, d_MCX);
 1635:         printf("    3: %s, %s, %s\n", d_INT, d_REL, d_CPL);
 1636:         printf("    2: %s\n", d_INT);
 1637:         printf("    1: %s\n", d_INT);
 1638:         printf("->  1: %s, %s, %s\n", d_MIN, d_MRL, d_MCX);
 1639: 
 1640:         return;
 1641:     }
 1642:     else if ((*s_etat_processus).test_instruction == 'Y')
 1643:     {
 1644:         (*s_etat_processus).nombre_arguments = -1;
 1645:         return;
 1646:     }
 1647: 
 1648:     if ((last_valide = test_cfsf(s_etat_processus, 31)) == d_vrai)
 1649:     {
 1650:         if (empilement_pile_last(s_etat_processus, 4) == d_erreur)
 1651:         {
 1652:             return;
 1653:         }
 1654: 
 1655:         cf(s_etat_processus, 31);
 1656:     }
 1657: 
 1658:     if (depilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
 1659:             &s_objet_argument_1) == d_erreur)
 1660:     {
 1661:         (*s_etat_processus).erreur_execution = d_ex_manque_argument;
 1662:         return;
 1663:     }
 1664: 
 1665:     if (depilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
 1666:             &s_objet_argument_2) == d_erreur)
 1667:     {
 1668:         liberation(s_etat_processus, s_objet_argument_1);
 1669: 
 1670:         (*s_etat_processus).erreur_execution = d_ex_manque_argument;
 1671:         return;
 1672:     }
 1673: 
 1674:     if (depilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
 1675:             &s_objet_argument_3) == d_erreur)
 1676:     {
 1677:         liberation(s_etat_processus, s_objet_argument_1);
 1678:         liberation(s_etat_processus, s_objet_argument_2);
 1679: 
 1680:         (*s_etat_processus).erreur_execution = d_ex_manque_argument;
 1681:         return;
 1682:     }
 1683: 
 1684:     if (depilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
 1685:             &s_objet_argument_4) == d_erreur)
 1686:     {
 1687:         liberation(s_etat_processus, s_objet_argument_1);
 1688:         liberation(s_etat_processus, s_objet_argument_2);
 1689:         liberation(s_etat_processus, s_objet_argument_3);
 1690: 
 1691:         (*s_etat_processus).erreur_execution = d_ex_manque_argument;
 1692:         return;
 1693:     }
 1694: 
 1695:     if ((((*s_objet_argument_4).type == MIN) ||
 1696:             ((*s_objet_argument_4).type == MRL) ||
 1697:             ((*s_objet_argument_4).type == MCX)) &&
 1698:             (((*s_objet_argument_3).type == INT) ||
 1699:             ((*s_objet_argument_3).type == REL) ||
 1700:             ((*s_objet_argument_3).type == CPL)) &&
 1701:             ((*s_objet_argument_2).type == INT) &&
 1702:             ((*s_objet_argument_1).type == INT))
 1703:     {
 1704:         if (empilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
 1705:                 s_objet_argument_4) == d_erreur)
 1706:         {
 1707:             return;
 1708:         }
 1709: 
 1710:         tampon = s_objet_argument_1;
 1711: 
 1712:         if ((s_objet_argument_1 = allocation(s_etat_processus, LST)) == NULL)
 1713:         {
 1714:             (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
 1715:             return;
 1716:         }
 1717: 
 1718:         if (((*s_objet_argument_1).objet =
 1719:                 allocation_maillon(s_etat_processus)) == NULL)
 1720:         {
 1721:             (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
 1722:             return;
 1723:         }
 1724: 
 1725:         (*((struct_liste_chainee *) (*s_objet_argument_1).objet)).donnee =
 1726:                 tampon;
 1727:         (*((struct_liste_chainee *) (*s_objet_argument_1).objet)).suivant =
 1728:                 NULL;
 1729: 
 1730:         tampon = s_objet_argument_2;
 1731: 
 1732:         if ((s_objet_argument_2 = allocation(s_etat_processus, LST)) == NULL)
 1733:         {
 1734:             (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
 1735:             return;
 1736:         }
 1737: 
 1738:         if (((*s_objet_argument_2).objet =
 1739:                 allocation_maillon(s_etat_processus)) == NULL)
 1740:         {
 1741:             (*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
 1742:             return;
 1743:         }
 1744: 
 1745:         (*((struct_liste_chainee *) (*s_objet_argument_2).objet)).donnee =
 1746:                 tampon;
 1747:         (*((struct_liste_chainee *) (*s_objet_argument_2).objet)).suivant =
 1748:                 NULL;
 1749: 
 1750:         instruction_dup(s_etat_processus);
 1751: 
 1752:         if (((*s_etat_processus).erreur_systeme != d_es) ||
 1753:                 ((*s_etat_processus).erreur_execution != d_ex) ||
 1754:                 ((*s_etat_processus).exception != d_ep))
 1755:         {
 1756:             liberation(s_etat_processus, s_objet_argument_1);
 1757:             liberation(s_etat_processus, s_objet_argument_2);
 1758:             liberation(s_etat_processus, s_objet_argument_3);
 1759:             liberation(s_etat_processus, s_objet_argument_4);
 1760: 
 1761:             if (last_valide == d_vrai)
 1762:             {
 1763:                 sf(s_etat_processus, 31);
 1764:             }
 1765: 
 1766:             return;
 1767:         }
 1768: 
 1769:         if (empilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
 1770:                 s_objet_argument_2) == d_erreur)
 1771:         {
 1772:             return;
 1773:         }
 1774: 
 1775:         instruction_getr(s_etat_processus);
 1776: 
 1777:         if (((*s_etat_processus).erreur_systeme != d_es) ||
 1778:                 ((*s_etat_processus).erreur_execution != d_ex) ||
 1779:                 ((*s_etat_processus).exception != d_ep))
 1780:         {
 1781:             liberation(s_etat_processus, s_objet_argument_1);
 1782:             liberation(s_etat_processus, s_objet_argument_2);
 1783:             liberation(s_etat_processus, s_objet_argument_3);
 1784:             liberation(s_etat_processus, s_objet_argument_4);
 1785: 
 1786:             if (last_valide == d_vrai)
 1787:             {
 1788:                 sf(s_etat_processus, 31);
 1789:             }
 1790: 
 1791:             return;
 1792:         }
 1793: 
 1794:         if (empilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
 1795:                 s_objet_argument_3) == d_erreur)
 1796:         {
 1797:             return;
 1798:         }
 1799: 
 1800:         instruction_multiplication(s_etat_processus);
 1801: 
 1802:         if (((*s_etat_processus).erreur_systeme != d_es) ||
 1803:                 ((*s_etat_processus).erreur_execution != d_ex) ||
 1804:                 ((*s_etat_processus).exception != d_ep))
 1805:         {
 1806:             liberation(s_etat_processus, s_objet_argument_1);
 1807:             liberation(s_etat_processus, s_objet_argument_2);
 1808:             liberation(s_etat_processus, s_objet_argument_3);
 1809:             liberation(s_etat_processus, s_objet_argument_4);
 1810: 
 1811:             if (last_valide == d_vrai)
 1812:             {
 1813:                 sf(s_etat_processus, 31);
 1814:             }
 1815: 
 1816:             return;
 1817:         }
 1818: 
 1819:         instruction_over(s_etat_processus);
 1820: 
 1821:         if (((*s_etat_processus).erreur_systeme != d_es) ||
 1822:                 ((*s_etat_processus).erreur_execution != d_ex) ||
 1823:                 ((*s_etat_processus).exception != d_ep))
 1824:         {
 1825:             liberation(s_etat_processus, s_objet_argument_1);
 1826:             liberation(s_etat_processus, s_objet_argument_2);
 1827:             liberation(s_etat_processus, s_objet_argument_3);
 1828:             liberation(s_etat_processus, s_objet_argument_4);
 1829: 
 1830:             if (last_valide == d_vrai)
 1831:             {
 1832:                 sf(s_etat_processus, 31);
 1833:             }
 1834: 
 1835:             return;
 1836:         }
 1837: 
 1838:         if (empilement(s_etat_processus, &((*s_etat_processus).l_base_pile),
 1839:                 s_objet_argument_1) == d_erreur)
 1840:         {
 1841:             return;
 1842:         }
 1843: 
 1844:         instruction_swap(s_etat_processus);
 1845: 
 1846:         if (((*s_etat_processus).erreur_systeme != d_es) ||
 1847:                 ((*s_etat_processus).erreur_execution != d_ex) ||
 1848:                 ((*s_etat_processus).exception != d_ep))
 1849:         {
 1850:             liberation(s_etat_processus, s_objet_argument_1);
 1851:             liberation(s_etat_processus, s_objet_argument_2);
 1852:             liberation(s_etat_processus, s_objet_argument_3);
 1853:             liberation(s_etat_processus, s_objet_argument_4);
 1854: 
 1855:             if (last_valide == d_vrai)
 1856:             {
 1857:                 sf(s_etat_processus, 31);
 1858:             }
 1859: 
 1860:             return;
 1861:         }
 1862: 
 1863:         if (((*s_etat_processus).erreur_systeme != d_es) ||
 1864:                 ((*s_etat_processus).erreur_execution != d_ex) ||
 1865:                 ((*s_etat_processus).exception != d_ep))
 1866:         {
 1867:             liberation(s_etat_processus, s_objet_argument_1);
 1868:             liberation(s_etat_processus, s_objet_argument_2);
 1869:             liberation(s_etat_processus, s_objet_argument_3);
 1870:             liberation(s_etat_processus, s_objet_argument_4);
 1871: 
 1872:             if (last_valide == d_vrai)
 1873:             {
 1874:                 sf(s_etat_processus, 31);
 1875:             }
 1876: 
 1877:             return;
 1878:         }
 1879: 
 1880:         instruction_over(s_etat_processus);
 1881: 
 1882:         if (((*s_etat_processus).erreur_systeme != d_es) ||
 1883:                 ((*s_etat_processus).erreur_execution != d_ex) ||
 1884:                 ((*s_etat_processus).exception != d_ep))
 1885:         {
 1886:             liberation(s_etat_processus, s_objet_argument_1);
 1887:             liberation(s_etat_processus, s_objet_argument_2);
 1888:             liberation(s_etat_processus, s_objet_argument_3);
 1889:             liberation(s_etat_processus, s_objet_argument_4);
 1890: 
 1891:             if (last_valide == d_vrai)
 1892:             {
 1893:                 sf(s_etat_processus, 31);
 1894:             }
 1895: 
 1896:             return;
 1897:         }
 1898: 
 1899:         if (((*s_etat_processus).erreur_systeme != d_es) ||
 1900:                 ((*s_etat_processus).erreur_execution != d_ex) ||
 1901:                 ((*s_etat_processus).exception != d_ep))
 1902:         {
 1903:             liberation(s_etat_processus, s_objet_argument_1);
 1904:             liberation(s_etat_processus, s_objet_argument_2);
 1905:             liberation(s_etat_processus, s_objet_argument_3);
 1906:             liberation(s_etat_processus, s_objet_argument_4);
 1907: 
 1908:             if (last_valide == d_vrai)
 1909:             {
 1910:                 sf(s_etat_processus, 31);
 1911:             }
 1912: 
 1913:             return;
 1914:         }
 1915: 
 1916:         instruction_getr(s_etat_processus);
 1917: 
 1918:         if (((*s_etat_processus).erreur_systeme != d_es) ||
 1919:                 ((*s_etat_processus).erreur_execution != d_ex) ||
 1920:                 ((*s_etat_processus).exception != d_ep))
 1921:         {
 1922:             liberation(s_etat_processus, s_objet_argument_1);
 1923:             liberation(s_etat_processus, s_objet_argument_2);
 1924:             liberation(s_etat_processus, s_objet_argument_3);
 1925:             liberation(s_etat_processus, s_objet_argument_4);
 1926: 
 1927:             if (last_valide == d_vrai)
 1928:             {
 1929:                 sf(s_etat_processus, 31);
 1930:             }
 1931: 
 1932:             return;
 1933:         }
 1934: 
 1935:         if (((*s_etat_processus).erreur_systeme != d_es) ||
 1936:                 ((*s_etat_processus).erreur_execution != d_ex) ||
 1937:                 ((*s_etat_processus).exception != d_ep))
 1938:         {
 1939:             liberation(s_etat_processus, s_objet_argument_1);
 1940:             liberation(s_etat_processus, s_objet_argument_2);
 1941:             liberation(s_etat_processus, s_objet_argument_3);
 1942:             liberation(s_etat_processus, s_objet_argument_4);
 1943: 
 1944:             if (last_valide == d_vrai)
 1945:             {
 1946:                 sf(s_etat_processus, 31);
 1947:             }
 1948: 
 1949:             return;
 1950:         }
 1951: 
 1952:         instruction_rot(s_etat_processus);
 1953: 
 1954:         if (((*s_etat_processus).erreur_systeme != d_es) ||
 1955:                 ((*s_etat_processus).erreur_execution != d_ex) ||
 1956:                 ((*s_etat_processus).exception != d_ep))
 1957:         {
 1958:             liberation(s_etat_processus, s_objet_argument_1);
 1959:             liberation(s_etat_processus, s_objet_argument_2);
 1960:             liberation(s_etat_processus, s_objet_argument_3);
 1961:             liberation(s_etat_processus, s_objet_argument_4);
 1962: 
 1963:             if (last_valide == d_vrai)
 1964:             {
 1965:                 sf(s_etat_processus, 31);
 1966:             }
 1967: 
 1968:             return;
 1969:         }
 1970: 
 1971:         if (((*s_etat_processus).erreur_systeme != d_es) ||
 1972:                 ((*s_etat_processus).erreur_execution != d_ex) ||
 1973:                 ((*s_etat_processus).exception != d_ep))
 1974:         {
 1975:             liberation(s_etat_processus, s_objet_argument_1);
 1976:             liberation(s_etat_processus, s_objet_argument_2);
 1977:             liberation(s_etat_processus, s_objet_argument_3);
 1978:             liberation(s_etat_processus, s_objet_argument_4);
 1979: 
 1980:             if (last_valide == d_vrai)
 1981:             {
 1982:                 sf(s_etat_processus, 31);
 1983:             }
 1984: 
 1985:             return;
 1986:         }
 1987: 
 1988:         instruction_plus(s_etat_processus);
 1989: 
 1990:         if (((*s_etat_processus).erreur_systeme != d_es) ||
 1991:                 ((*s_etat_processus).erreur_execution != d_ex) ||
 1992:                 ((*s_etat_processus).exception != d_ep))
 1993:         {
 1994:             liberation(s_etat_processus, s_objet_argument_1);
 1995:             liberation(s_etat_processus, s_objet_argument_2);
 1996:             liberation(s_etat_processus, s_objet_argument_3);
 1997:             liberation(s_etat_processus, s_objet_argument_4);
 1998: 
 1999:             if (last_valide == d_vrai)
 2000:             {
 2001:                 sf(s_etat_processus, 31);
 2002:             }
 2003: 
 2004:             return;
 2005:         }
 2006: 
 2007:         instruction_putr(s_etat_processus);
 2008: 
 2009:         if (((*s_etat_processus).erreur_systeme != d_es) ||
 2010:                 ((*s_etat_processus).erreur_execution != d_ex) ||
 2011:                 ((*s_etat_processus).exception != d_ep))
 2012:         {
 2013:             liberation(s_etat_processus, s_objet_argument_1);
 2014:             liberation(s_etat_processus, s_objet_argument_2);
 2015:             liberation(s_etat_processus, s_objet_argument_3);
 2016:             liberation(s_etat_processus, s_objet_argument_4);
 2017: 
 2018:             if (last_valide == d_vrai)
 2019:             {
 2020:                 sf(s_etat_processus, 31);
 2021:             }
 2022: 
 2023:             return;
 2024:         }
 2025:     }
 2026:     else
 2027:     {
 2028:         liberation(s_etat_processus, s_objet_argument_1);
 2029:         liberation(s_etat_processus, s_objet_argument_2);
 2030:         liberation(s_etat_processus, s_objet_argument_3);
 2031:         liberation(s_etat_processus, s_objet_argument_4);
 2032: 
 2033:         if (last_valide == d_vrai)
 2034:         {
 2035:             sf(s_etat_processus, 31);
 2036:         }
 2037: 
 2038:         (*s_etat_processus).erreur_execution = d_ex_erreur_type_argument;
 2039:         return;
 2040:     }
 2041: 
 2042:     if (last_valide == d_vrai)
 2043:     {
 2044:         sf(s_etat_processus, 31);
 2045:     }
 2046: 
 2047:     return;
 2048: }
 2049: 
 2050: // vim: ts=4

CVSweb interface <joel.bertrand@systella.fr>