/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        C O N C A T E N A T I O N   D E S   C H A I N E S   D E   C A R A C T E R E S   A D J A C E N T E S  :                     */
/*                                                                                                                                   */
/*                                                                                                                                   */
/*        Fonction :                                                                                                                 */
/*                                                                                                                                   */
/*                    Cette commande est destinee a assurer                                                                          */
/*                  des reecritures du type :                                                                                        */
/*                                                                                                                                   */
/*                  "XX...XX""YY...YY" --> "XX...XXYY...YY"                                                                          */
/*                                                                                                                                   */
/*                                                                                                                                   */
/*        Author of '$xcp/concatene$K' :                                                                                             */
/*                                                                                                                                   */
/*                    Jean-Francois COLONNA (LACTAMME, 1991??????????).                                                              */
/*                                                                                                                                   */
/*************************************************************************************************************************************/

/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        I N T E R F A C E   ' listG '  :                                                                                           */
/*                                                                                                                                   */
/*                                                                                                                                   */
/*        :Debut_listG:                                                                                                              */
/*        :Fin_listG:                                                                                                                */
/*                                                                                                                                   */
/*************************************************************************************************************************************/

/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        D I R E C T I V E S   S P E C I F I Q U E S   D E   C O M P I L A T I O N  :                                               */
/*                                                                                                                                   */
/*************************************************************************************************************************************/
@define   PRAGMA_CL_____PAS_DE_LIBRAIRIES_DYNAMIQUES

/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        F I C H I E R S   D ' I N C L U D E S  :                                                                                   */
/*                                                                                                                                   */
/*************************************************************************************************************************************/
#include  INCLUDES_MINI

/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        P A R A M E T R E S  :                                                                                                     */
/*                                                                                                                                   */
/*************************************************************************************************************************************/

/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        M A C R O S   U T I L E S  :                                                                                               */
/*                                                                                                                                   */
/*************************************************************************************************************************************/

/*===================================================================================================================================*/
/*************************************************************************************************************************************/
/*                                                                                                                                   */
/*        C O N C A T E N A T I O N   D E S   C H A I N E S   D E   C A R A C T E R E S   A D J A C E N T E S  :                     */
/*                                                                                                                                   */
/*************************************************************************************************************************************/
BCommande(nombre_d_arguments,arguments)
/*-----------------------------------------------------------------------------------------------------------------------------------*/
     Bblock
     DEFV(Char,INIT(caractere_precedent,K_UNDEF));
                                        /* Caractere precedent.                                                                      */
     DEFV(Char,INIT(caractere_courant,K_UNDEF));
                                        /* Caractere courant.                                                                        */
     DEFV(Logical,INIT(on_vient_de_rencontrer_une_apostrophe,FAUX));
                                        /* Cet indicateur indique en permanence si l'on vient de rencontrer                          */
                                        /* immediatement une apostrophe (') :                                                        */
                                        /*                                                                                           */
                                        /*                  VRAI    : apres la premiere rencontree,                                  */
                                        /*                  FAUX    : apres la seconde,                                              */
                                        /*                                                                                           */
                                        /* cet indicateur fonctionnant en bascule, puisque les apostrophes forment                   */
                                        /* des couples de parentheses...                                                             */
     DEFV(Logical,INIT(on_vient_de_rencontrer_une_quote,FAUX));
                                        /* Cet indicateur indique en permanence si l'on vient de rencontrer                          */
                                        /* immediatement une quote (") :                                                             */
                                        /*                                                                                           */
                                        /*                  VRAI    : apres la premiere rencontree,                                  */
                                        /*                  FAUX    : apres la seconde,                                              */
                                        /*                                                                                           */
                                        /* cet indicateur fonctionnant en bascule, puisque les quotes forment                        */
                                        /* des couples de parentheses...                                                             */
     /*..............................................................................................................................*/
     GET_ARGUMENTS_(nombre_d_arguments
                   ,BLOC(VIDE;
                         )
                    );

     Tant(GetcharT(caractere_courant))
          Bblock
                                        /* Le caractere courant de l'entree courante est recupere ; et on boucle                     */
                                        /* sur cette recuperation tant que l'on n'est pas au bout du fichier.                        */
          Test(I3ET(IFEQ(caractere_precedent,K_QUOTE)
                   ,IFNE(caractere_courant,K_QUOTE)
                   ,IFET(EST_FAUX(on_vient_de_rencontrer_une_quote),EST_FAUX(on_vient_de_rencontrer_une_apostrophe))
                    )
               )
               Bblock
               CALS(Putchar(caractere_precedent));
                                        /* Emission de la quote precedente en attente lorsqu'il n'y a pas de concatenation...        */
               Eblock
          ATes
               Bblock
               Eblock
          ETes

          Test(I4OU(IFNE(caractere_courant,K_QUOTE)
                   ,I3ET(IFEQ(caractere_courant,K_QUOTE)
                        ,IFNE(caractere_precedent,K_QUOTE)
                        ,EST_FAUX(on_vient_de_rencontrer_une_quote)
                         )
                   ,I3ET(IFEQ(caractere_courant,K_QUOTE)
                        ,IFEQ(caractere_precedent,K_ANTI_SLASH)
                        ,EST_VRAI(on_vient_de_rencontrer_une_quote)
                         )
                   ,IFET(IFEQ(caractere_courant,K_QUOTE)
                        ,EST_VRAI(on_vient_de_rencontrer_une_apostrophe)
                         )
                    )
               )
                                        /* Le 20120115100037 fut introduit le test relatif a 'K_ANTI_SLASH' et ce a cause de la      */
                                        /* chaine 'v $xil/defi_c1$vv$DEF C_QUOTE'...                                                 */
               Bblock
               CALS(Putchar(caractere_courant));
                                        /* Tout caractere different de la quote (sauf la premiere d'une chaine a condition qu'il     */
                                        /* n'y ait pas concatenation) est transmis...                                                */
               Eblock
          ATes
               Bblock
               Eblock
          ETes

          Test(IFET(IFET(IFEQ(caractere_courant,K_QUOTE)
                        ,IFNE(caractere_precedent,K_ANTI_SLASH)
                         )
                   ,EST_FAUX(on_vient_de_rencontrer_une_apostrophe)
                    )
               )
                                        /* Le 20120115100037 fut introduit le test relatif a 'K_ANTI_SLASH' et ce a cause de la      */
                                        /* chaine 'v $xil/defi_c1$vv$DEF C_QUOTE'...                                                 */
               Bblock
               EGAL(on_vient_de_rencontrer_une_quote,NOTL(on_vient_de_rencontrer_une_quote));
                                        /* On gere les quotes comme des parentheses...                                               */
               Eblock
          ATes
               Bblock
               Eblock
          ETes

          Test(IFET(IFEQ(caractere_courant,K_APOSTROPHE)
                   ,EST_FAUX(on_vient_de_rencontrer_une_quote)
                    )
               )
               Bblock
               EGAL(on_vient_de_rencontrer_une_apostrophe,NOTL(on_vient_de_rencontrer_une_apostrophe));
                                        /* On gere les apostrophes comme des parentheses...                                          */
               Eblock
          ATes
               Bblock
               Eblock
          ETes

          Test(IFEQ(caractere_courant,K_LF))
               Bblock
               EGAL(on_vient_de_rencontrer_une_apostrophe,FAUX);
               EGAL(on_vient_de_rencontrer_une_quote,FAUX);
                                        /* Au changement de ligne, on reinitialise la gestion des quotes et apostrophes...           */
               Eblock
          ATes
               Bblock
               Eblock
          ETes

          EGAL(caractere_precedent,caractere_courant);
                                        /* Changement de caractere precedent...                                                      */
          Eblock
     ETan

     RETU_Commande;
     Eblock
ECommande



Copyright © Jean-François COLONNA, 2019-2024.
Copyright © CMAP (Centre de Mathématiques APpliquées) UMR CNRS 7641 / École polytechnique, Institut Polytechnique de Paris, 2019-2024.