/*************************************************************************************************************************************/ /* */ /* E L I M I N A T I O N D E C A R A C T E R E S R E D O N D A NT S : */ /* */ /* */ /* Fonction : */ /* */ /* Cette commande est destinee a assurer */ /* des reecritures du type : */ /* */ /* "XXXX...XXXX" --> "X". */ /* */ /* */ /* Author of '$xcp/redondants$K' : */ /* */ /* Jean-Francois COLONNA (LACTAMME, 1990??????????). */ /* */ /*************************************************************************************************************************************/ /*===================================================================================================================================*/ /*************************************************************************************************************************************/ /* */ /* 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 : */ /* */ /*************************************************************************************************************************************/ #define CARACTERE_REDONDANT \ K_POINT_VIRGULE \ /* Caractere declare comme redondant et devant faire l'objet d'une reecriture. */ /*===================================================================================================================================*/ /*************************************************************************************************************************************/ /* */ /* M A C R O S U T I L E S : */ /* */ /*************************************************************************************************************************************/ /*===================================================================================================================================*/ /*************************************************************************************************************************************/ /* */ /* E L I M I N A T I O N D E C A R A C T E R E S R E D O N D A NT S : */ /* */ /*************************************************************************************************************************************/ BCommande(nombre_d_arguments,arguments) /*-----------------------------------------------------------------------------------------------------------------------------------*/ Bblock DEFV(CHAR,INIT(caractere_redondant,CARACTERE_REDONDANT)); /* Caractere declare comme redondant et devant faire l'objet d'une reecriture. */ 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... */ DEFV(Logical,INIT(on_vient_de_rencontrer_le_caractere_redondant,FAUX)); /* Cet indicateur indique en permanence si l'on vient de rencontrer le caractere */ /* dit "redondant"... */ /*..............................................................................................................................*/ GET_ARGUMENTS_(nombre_d_arguments ,BLOC(GET_ARGUMENT_K("redondant=""r=""caractere=""c=",caractere_redondant); ) ); 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(IFNE(caractere_courant,caractere_redondant)) Bblock CALS(Putchar(caractere_courant)); /* Lorsque le caractere courant n'est pas l'anti-quote "`", on le reemet... */ Test(IFET(IFEQ(caractere_courant,K_QUOTE),EST_FAUX(on_vient_de_rencontrer_une_apostrophe))) 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 Test(IFET(IFNE(caractere_courant,K_BLANC),IFNE(caractere_courant,K_LF))) Bblock EGAL(on_vient_de_rencontrer_le_caractere_redondant,FAUX); /* Pour tout autre caractere que le caractere "redondant", ESPACE et NEW-LINE, on */ /* reinitialise le processus... */ Eblock ATes Bblock /* Les chaines de caracteres "redondants" peuvent contenir des ESPACEs et des NEW-LINEs... */ Eblock ETes Eblock ATes Bblock Test(IFET(EST_FAUX(on_vient_de_rencontrer_une_quote) ,EST_FAUX(on_vient_de_rencontrer_une_apostrophe) ) ) Bblock Test(EST_FAUX(on_vient_de_rencontrer_le_caractere_redondant)) Bblock CALS(Putchar(caractere_courant)); /* Le premier caractere redondant est transmis, */ EGAL(on_vient_de_rencontrer_le_caractere_redondant,VRAI); /* Et on memorise que l'on vient de le rencontrer... */ Eblock ATes Bblock /* Mais pas les suivants (meme si des ESPACEs et des NEW-LINEs viennent s'intercaler). */ Eblock ETes Eblock ATes Bblock CALS(Putchar(caractere_courant)); /* Lorsque le caractere "redondant" est entre quotes ou apostrophes, on l'emet... */ Eblock ETes Eblock ETes Eblock ETan RETU_Commande; Eblock ECommande