Diff for /rpl/src/interface_cas.cpp between versions 1.62 and 1.70

version 1.62, 2019/10/31 15:40:22 version 1.70, 2023/11/27 12:51:19
Line 1 Line 1
 /*  /*
 ================================================================================  ================================================================================
   RPL/2 (R) version 4.1.32    RPL/2 (R) version 4.1.35
   Copyright (C) 1989-2019 Dr. BERTRAND Joël    Copyright (C) 1989-2023 Dr. BERTRAND Joël
   
   This file is part of RPL/2.    This file is part of RPL/2.
   
Line 21 Line 21
   
   
 #ifdef RPLCAS  #ifdef RPLCAS
   #   define RPLCXX
   
 // Giac inclut <semaphore.h> et définit sem_t. Or l'émulation  // Giac inclut <semaphore.h> et définit sem_t. Or l'émulation
 // des IPCS POSIX requiert une redéfinition de sem_t.  // des IPCS POSIX requiert une redéfinition de sem_t.
Line 54  extern "C" Line 55  extern "C"
 #   include "rpl-conv.h"  #   include "rpl-conv.h"
 }  }
   
 #include <iostream>  #ifdef RPLCAS
   #   include <iostream>
   #endif
   
 using namespace std;  using namespace std;
   
Line 132  conversion_rpl_vers_cas(struct_processus Line 135  conversion_rpl_vers_cas(struct_processus
   
             liberation(s_etat_processus, *s_objet);              liberation(s_etat_processus, *s_objet);
   
             if (depilement(s_etat_processus, &(s_etat_processus              if (depilement(s_etat_processus, &(s_etat_processus->l_base_pile),
                     ->l_base_pile), s_objet) == d_erreur)                      s_objet) == d_erreur)
             {              {
                 return(NULL);                  return(NULL);
             }              }
Line 463  interface_cas(struct_processus *s_etat_p Line 466  interface_cas(struct_processus *s_etat_p
     contexte = reinterpret_cast<giac::context *>(      contexte = reinterpret_cast<giac::context *>(
             s_etat_processus->contexte_cas);              s_etat_processus->contexte_cas);
   
       giac::angle_radian((test_cfsf(s_etat_processus, 60) == d_vrai) ? 1 : 0,
               contexte);
   
     if ((s_etat_processus->erreur_execution != d_ex) ||      if ((s_etat_processus->erreur_execution != d_ex) ||
             (s_etat_processus->erreur_systeme != d_es))              (s_etat_processus->erreur_systeme != d_es))
     {      {
Line 703  interface_cas(struct_processus *s_etat_p Line 709  interface_cas(struct_processus *s_etat_p
   
             break;              break;
         }          }
   
           case RPLCAS_SIMPLIFICATION:
           {
               if (depilement(s_etat_processus, &(s_etat_processus->l_base_pile),
                       &s_objet_argument_1) == d_erreur)
               {
                   s_etat_processus->erreur_execution = d_ex_manque_argument;
                   return;
               }
   
               if ((argument_1 = conversion_rpl_vers_cas(s_etat_processus,
                       &s_objet_argument_1)) == NULL)
               {
                   s_etat_processus->erreur_systeme = d_es_allocation_memoire;
                   return;
               }
   
               liberation(s_etat_processus, s_objet_argument_1);
   
               try
               {
                   gen expression(
                           string(reinterpret_cast<const char *>(argument_1)),
                           contexte);
   
                   gen resultat = simplify(expression, contexte);
                   string chaine = "'" + resultat.print() + "'";
   
                   conversion_cas_vers_rpl(s_etat_processus,
                           reinterpret_cast<unsigned char *>(const_cast<char *>(
                           chaine.c_str())));
               }
               catch(bad_alloc &exception)
               {
                   s_etat_processus->erreur_systeme = d_es_allocation_memoire;
               }
               catch(...)
               {
                   s_etat_processus->erreur_execution = d_ex_erreur_interne_rplcas;
               }
   
               free(argument_1);
   
               break;
           }
     }      }
   
     return;      return;

Removed from v.1.62  
changed lines
  Added in v.1.70


CVSweb interface <joel.bertrand@systella.fr>