version 1.13, 2010/08/06 15:32:57
|
version 1.44, 2013/03/21 16:31:58
|
Line 1
|
Line 1
|
/*
|
/* |
================================================================================
|
================================================================================ |
RPL/2 (R) version 4.0.18
|
RPL/2 (R) version 4.1.13 |
Copyright (C) 1989-2010 Dr. BERTRAND Joël
|
Copyright (C) 1989-2013 Dr. BERTRAND Joël |
|
|
This file is part of RPL/2.
|
This file is part of RPL/2. |
|
|
RPL/2 is free software; you can redistribute it and/or modify it
|
RPL/2 is free software; you can redistribute it and/or modify it |
under the terms of the CeCILL V2 License as published by the french
|
under the terms of the CeCILL V2 License as published by the french |
CEA, CNRS and INRIA.
|
CEA, CNRS and INRIA. |
|
|
RPL/2 is distributed in the hope that it will be useful, but WITHOUT
|
RPL/2 is distributed in the hope that it will be useful, but WITHOUT |
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
|
ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
FITNESS FOR A PARTICULAR PURPOSE. See the CeCILL V2 License
|
FITNESS FOR A PARTICULAR PURPOSE. See the CeCILL V2 License |
for more details.
|
for more details. |
|
|
You should have received a copy of the CeCILL License
|
You should have received a copy of the CeCILL License |
along with RPL/2. If not, write to info@cecill.info.
|
along with RPL/2. If not, write to info@cecill.info. |
================================================================================
|
================================================================================ |
*/
|
*/ |
|
|
|
|
#include "rpl-conv.h"
|
#include "rpl-conv.h" |
|
|
|
|
/*
|
/* |
================================================================================
|
================================================================================ |
Analyseur syntaxique d'une expression algébrique
|
Analyseur syntaxique d'une expression algébrique |
================================================================================
|
================================================================================ |
Entrées : chaîne de caractères comprenant l'expression algébrique
|
Entrées : chaîne de caractères comprenant l'expression algébrique |
--------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------- |
Sorties : chaîne de caractères contenant l'expression convertie en
|
Sorties : chaîne de caractères contenant l'expression convertie en |
notation polonaise inverse et liste chaînée contenant les diverses
|
notation polonaise inverse et liste chaînée contenant les diverses |
fonctions.
|
fonctions. |
--------------------------------------------------------------------------------
|
-------------------------------------------------------------------------------- |
Effets de bord : néant
|
Effets de bord : néant |
================================================================================
|
================================================================================ |
*/
|
*/ |
|
|
unsigned char *
|
unsigned char * |
analyse_algebrique(struct_processus *s_etat_processus,
|
analyse_algebrique(struct_processus *s_etat_processus, |
unsigned char *chaine_algebrique, struct_liste_chainee **l_base_liste)
|
unsigned char *chaine_algebrique, struct_liste_chainee **l_base_liste) |
{
|
{ |
struct_fonction *s_fonction;
|
struct_fonction *s_fonction; |
|
|
struct_liste_chainee *l_element_courant;
|
struct_liste_chainee *l_element_courant; |
|
|
logical1 chaine_invalide;
|
logical1 chaine_invalide; |
logical1 drapeau_debut_zone_valide;
|
logical1 drapeau_debut_zone_valide; |
logical1 drapeau_elimination_parentheses;
|
logical1 drapeau_elimination_parentheses; |
logical1 drapeau_fin_boucle;
|
logical1 drapeau_fin_boucle; |
logical1 drapeau_fin_zone_valide;
|
logical1 drapeau_fin_zone_valide; |
logical1 drapeau_modification;
|
logical1 drapeau_modification; |
logical1 drapeau_priorite_entierement_traitee;
|
logical1 drapeau_priorite_entierement_traitee; |
logical1 fin_boucle_extraction;
|
logical1 fin_boucle_extraction; |
logical1 presence_chaine;
|
logical1 presence_chaine; |
logical1 presence_fonction;
|
logical1 presence_fonction; |
logical1 presence_liste;
|
logical1 presence_liste; |
|
|
long k;
|
unsigned char *chaine_arguments; |
|
unsigned char *chaine_centrale; |
unsigned char *chaine_arguments;
|
unsigned char *chaine_droite; |
unsigned char *chaine_centrale;
|
unsigned char *chaine_fonction; |
unsigned char *chaine_droite;
|
unsigned char *chaine_gauche; |
unsigned char *chaine_fonction;
|
unsigned char *chaine_travail; |
unsigned char *chaine_gauche;
|
unsigned char *epilogue; |
unsigned char *chaine_travail;
|
unsigned char instruction_test[6]; |
unsigned char *epilogue;
|
unsigned char *instruction_majuscule; |
unsigned char instruction_test[6];
|
unsigned char *prologue; |
unsigned char *instruction_majuscule;
|
unsigned char *ptr1; |
unsigned char *prologue;
|
unsigned char *ptr2; |
unsigned char *ptr1;
|
unsigned char *registre_instruction_courante; |
unsigned char *ptr2;
|
unsigned char registre_instruction_valide; |
unsigned char *registre_instruction_courante;
|
unsigned char registre_test; |
unsigned char registre_instruction_valide;
|
unsigned char *sous_chaine_droite; |
unsigned char registre_test;
|
unsigned char *sous_chaine_gauche; |
unsigned char *sous_chaine_droite;
|
unsigned char *tampon; |
unsigned char *sous_chaine_gauche;
|
|
unsigned char t0;
|
int t0; |
unsigned char t1;
|
int t1; |
unsigned char t2;
|
int t2; |
unsigned char t3;
|
int t3; |
unsigned char t4;
|
int t4; |
unsigned char *tampon;
|
|
|
integer8 debut_zone_algebrique; |
unsigned long debut_zone_algebrique;
|
integer8 fin_zone_algebrique; |
unsigned long fin_zone_algebrique;
|
integer8 i; |
unsigned long i;
|
integer8 j; |
unsigned long j;
|
integer8 k; |
unsigned long longueur_chaine;
|
integer8 longueur_chaine; |
unsigned long longueur_tampon;
|
integer8 longueur_tampon; |
unsigned long niveau;
|
integer8 niveau; |
unsigned long niveau_liste;
|
integer8 niveau_liste; |
unsigned long nombre_apostrophes;
|
integer8 nombre_apostrophes; |
unsigned long nombre_arguments;
|
integer8 nombre_arguments; |
unsigned long priorite;
|
integer8 priorite; |
|
|
(*l_base_liste) = NULL;
|
(*l_base_liste) = NULL; |
|
|
/*
|
/* |
* Vérification de la chaîne. Celle-ci doit comporter au moins un
|
* Vérification de la chaîne. Celle-ci doit comporter au moins un |
* caractère entre les délimiteurs ''.
|
* caractère entre les délimiteurs ''. |
*/
|
*/ |
|
|
presence_chaine = d_faux;
|
presence_chaine = d_faux; |
presence_liste = d_faux;
|
presence_liste = d_faux; |
niveau_liste = 0;
|
niveau_liste = 0; |
|
|
for(i = 1, chaine_invalide = d_vrai; i < strlen(chaine_algebrique) - 1; i++)
|
for(i = 1, chaine_invalide = d_vrai; i < ((integer8) |
{
|
strlen(chaine_algebrique)) - 1; i++) |
if (chaine_algebrique[i] != ' ')
|
{ |
{
|
if (chaine_algebrique[i] != ' ') |
chaine_invalide = d_faux;
|
{ |
}
|
chaine_invalide = d_faux; |
|
} |
if (chaine_algebrique[i] == '"')
|
|
{
|
if (chaine_algebrique[i] == '"') |
presence_chaine = (presence_chaine == d_faux) ? d_vrai : d_faux;
|
{ |
}
|
presence_chaine = (presence_chaine == d_faux) ? d_vrai : d_faux; |
else if (presence_chaine == d_faux)
|
} |
{
|
else if (presence_chaine == d_faux) |
if (chaine_algebrique[i] == '{')
|
{ |
{
|
if (chaine_algebrique[i] == '{') |
presence_liste = d_vrai;
|
{ |
niveau_liste++;
|
presence_liste = d_vrai; |
}
|
niveau_liste++; |
else if (chaine_algebrique[i] == '}')
|
} |
{
|
else if (chaine_algebrique[i] == '}') |
presence_liste = d_vrai;
|
{ |
niveau_liste--;
|
presence_liste = d_vrai; |
}
|
niveau_liste--; |
}
|
} |
}
|
} |
|
} |
if ((chaine_invalide == d_vrai) || (presence_chaine == d_vrai) ||
|
|
(niveau_liste != 0) || (presence_liste == d_vrai))
|
if ((chaine_invalide == d_vrai) || (presence_chaine == d_vrai) || |
{
|
(niveau_liste != 0) || (presence_liste == d_vrai)) |
(*s_etat_processus).erreur_execution = d_ex_expression_invalide;
|
{ |
return(NULL);
|
(*s_etat_processus).erreur_execution = d_ex_expression_invalide; |
}
|
return(NULL); |
|
} |
/*
|
|
* Transformation des "**" en "^ "
|
/* |
*/
|
* Transformation des "**" en "^ " |
|
*/ |
for(i = 1; i < strlen(chaine_algebrique) - 1; i++)
|
|
{
|
for(i = 1; i < ((integer8) strlen(chaine_algebrique)) - 1; i++) |
if (chaine_algebrique[i] == '*')
|
{ |
{
|
if (chaine_algebrique[i] == '*') |
if (chaine_algebrique[i + 1] == '*')
|
{ |
{
|
if (chaine_algebrique[i + 1] == '*') |
chaine_algebrique[i++] = '^';
|
{ |
chaine_algebrique[i] = ' ';
|
chaine_algebrique[i++] = '^'; |
}
|
chaine_algebrique[i] = ' '; |
}
|
} |
}
|
} |
|
} |
if ((chaine_travail = (unsigned char *) malloc((strlen(chaine_algebrique) +
|
|
1) * sizeof(unsigned char))) == NULL)
|
if ((chaine_travail = (unsigned char *) malloc((strlen(chaine_algebrique) + |
{
|
1) * sizeof(unsigned char))) == NULL) |
(*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
|
{ |
return(NULL);
|
(*s_etat_processus).erreur_systeme = d_es_allocation_memoire; |
}
|
return(NULL); |
|
} |
strcpy(chaine_travail, chaine_algebrique);
|
|
|
strcpy(chaine_travail, chaine_algebrique); |
/*
|
|
* Retrait des espaces dans l'expression algébrique
|
/* |
*/
|
* Retrait des espaces dans l'expression algébrique |
|
*/ |
ptr1 = chaine_travail;
|
|
ptr2 = chaine_travail;
|
ptr1 = chaine_travail; |
presence_chaine = d_faux;
|
ptr2 = chaine_travail; |
|
presence_chaine = d_faux; |
while((*ptr1) != d_code_fin_chaine)
|
|
{
|
while((*ptr1) != d_code_fin_chaine) |
if ((*ptr1) == '"')
|
{ |
{
|
if ((*ptr1) == '"') |
if (presence_chaine == d_faux)
|
{ |
{
|
if (presence_chaine == d_faux) |
presence_chaine = d_vrai;
|
{ |
}
|
presence_chaine = d_vrai; |
else
|
} |
{
|
else |
presence_chaine = d_faux;
|
{ |
}
|
presence_chaine = d_faux; |
}
|
} |
|
} |
if (presence_chaine == d_faux)
|
|
{
|
if (presence_chaine == d_faux) |
if ((*ptr1) != ' ')
|
{ |
{
|
if ((*ptr1) != ' ') |
(*(ptr2++)) = (*ptr1);
|
{ |
}
|
(*(ptr2++)) = (*ptr1); |
else
|
} |
{
|
else |
instruction_test[5] = d_code_fin_chaine;
|
{ |
|
instruction_test[5] = d_code_fin_chaine; |
instruction_majuscule = conversion_majuscule(strncpy(
|
|
instruction_test, ptr1, 5));
|
instruction_majuscule = conversion_majuscule(strncpy( |
|
instruction_test, ptr1, 5)); |
if (instruction_majuscule == NULL)
|
|
{
|
if (instruction_majuscule == NULL) |
(*s_etat_processus).erreur_systeme =
|
{ |
d_es_allocation_memoire;
|
(*s_etat_processus).erreur_systeme = |
return(NULL);
|
d_es_allocation_memoire; |
}
|
return(NULL); |
|
} |
/*
|
|
* Repérer le premier espace ou la fin de la chaîne.
|
/* |
*/
|
* Repérer le premier espace ou la fin de la chaîne. |
|
*/ |
if (strcmp(instruction_majuscule, " AND ") == 0)
|
|
{
|
if (strcmp(instruction_majuscule, " AND ") == 0) |
for(i = 0; i < 4; (*(ptr2++)) = (*(ptr1++)), i++);
|
{ |
(*(ptr2++)) = (*ptr1);
|
for(i = 0; i < 4; (*(ptr2++)) = (*(ptr1++)), i++); |
}
|
(*(ptr2++)) = (*ptr1); |
else if (strcmp(instruction_majuscule, " XOR ") == 0)
|
} |
{
|
else if (strcmp(instruction_majuscule, " XOR ") == 0) |
for(i = 0; i < 4; (*(ptr2++)) = (*(ptr1++)), i++);
|
{ |
(*(ptr2++)) = (*ptr1);
|
for(i = 0; i < 4; (*(ptr2++)) = (*(ptr1++)), i++); |
}
|
(*(ptr2++)) = (*ptr1); |
else if ((strncmp(instruction_majuscule, " OR ", 4) == 0) &&
|
} |
(strlen(instruction_majuscule) == 4))
|
else if ((strncmp(instruction_majuscule, " OR ", 4) == 0) && |
{
|
(strlen(instruction_majuscule) == 4)) |
for(i = 0; i < 3; (*(ptr2++)) = (*(ptr1++)), i++);
|
{ |
(*(ptr2++)) = (*ptr1);
|
for(i = 0; i < 3; (*(ptr2++)) = (*(ptr1++)), i++); |
}
|
(*(ptr2++)) = (*ptr1); |
|
} |
free(instruction_majuscule);
|
|
}
|
free(instruction_majuscule); |
|
} |
ptr1++;
|
|
}
|
ptr1++; |
else
|
} |
{
|
else |
(*(ptr2++)) = (*(ptr1++));
|
{ |
}
|
(*(ptr2++)) = (*(ptr1++)); |
}
|
} |
|
} |
(*ptr2) = d_code_fin_chaine;
|
|
|
(*ptr2) = d_code_fin_chaine; |
do
|
|
{
|
do |
i = 0;
|
{ |
drapeau_modification = d_faux;
|
i = 0; |
|
drapeau_modification = d_faux; |
do
|
|
{
|
do |
presence_chaine = d_faux;
|
{ |
drapeau_debut_zone_valide = d_faux;
|
presence_chaine = d_faux; |
debut_zone_algebrique = 0;
|
drapeau_debut_zone_valide = d_faux; |
drapeau_fin_boucle = d_faux;
|
debut_zone_algebrique = 0; |
|
drapeau_fin_boucle = d_faux; |
do
|
|
{
|
do |
if (chaine_travail[i] == d_code_fin_chaine)
|
{ |
{
|
if (chaine_travail[i] == d_code_fin_chaine) |
drapeau_fin_boucle = d_vrai;
|
{ |
}
|
drapeau_fin_boucle = d_vrai; |
else if ((chaine_travail[i] == '\'') &&
|
} |
(presence_chaine == d_faux))
|
else if ((chaine_travail[i] == '\'') && |
{
|
(presence_chaine == d_faux)) |
drapeau_fin_boucle = d_vrai;
|
{ |
debut_zone_algebrique = i;
|
drapeau_fin_boucle = d_vrai; |
drapeau_debut_zone_valide = d_vrai;
|
debut_zone_algebrique = i; |
}
|
drapeau_debut_zone_valide = d_vrai; |
else if (chaine_travail[i] == '"')
|
} |
{
|
else if (chaine_travail[i] == '"') |
presence_chaine = (presence_chaine == d_vrai)
|
{ |
? d_faux : d_vrai;
|
presence_chaine = (presence_chaine == d_vrai) |
}
|
? d_faux : d_vrai; |
|
} |
i++;
|
|
} while(drapeau_fin_boucle == d_faux);
|
i++; |
|
} while(drapeau_fin_boucle == d_faux); |
presence_chaine = 0;
|
|
drapeau_fin_zone_valide = d_faux;
|
presence_chaine = 0; |
|
drapeau_fin_zone_valide = d_faux; |
if (drapeau_debut_zone_valide == d_vrai)
|
|
{
|
if (drapeau_debut_zone_valide == d_vrai) |
j = debut_zone_algebrique + 1;
|
{ |
}
|
j = debut_zone_algebrique + 1; |
else
|
} |
{
|
else |
j = 0;
|
{ |
}
|
j = 0; |
|
} |
fin_zone_algebrique = 0;
|
|
drapeau_fin_boucle = d_faux;
|
fin_zone_algebrique = 0; |
|
drapeau_fin_boucle = d_faux; |
do
|
|
{
|
do |
if (chaine_travail[j] == 0)
|
{ |
{
|
if (chaine_travail[j] == 0) |
drapeau_fin_boucle = d_vrai;
|
{ |
}
|
drapeau_fin_boucle = d_vrai; |
|
} |
if ((chaine_travail[j] == '\'') && (presence_chaine == d_faux))
|
|
{
|
if ((chaine_travail[j] == '\'') && (presence_chaine == d_faux)) |
drapeau_fin_boucle = d_vrai;
|
{ |
fin_zone_algebrique = j;
|
drapeau_fin_boucle = d_vrai; |
drapeau_fin_zone_valide = d_vrai;
|
fin_zone_algebrique = j; |
}
|
drapeau_fin_zone_valide = d_vrai; |
|
} |
if (chaine_travail[j] == '"')
|
|
{
|
if (chaine_travail[j] == '"') |
presence_chaine = (presence_chaine == d_vrai)
|
{ |
? d_faux : d_vrai;
|
presence_chaine = (presence_chaine == d_vrai) |
}
|
? d_faux : d_vrai; |
|
} |
j++;
|
|
} while(drapeau_fin_boucle == d_faux);
|
j++; |
|
} while(drapeau_fin_boucle == d_faux); |
if ((drapeau_debut_zone_valide == d_vrai) &&
|
|
(drapeau_fin_zone_valide == d_vrai))
|
if ((drapeau_debut_zone_valide == d_vrai) && |
{
|
(drapeau_fin_zone_valide == d_vrai)) |
chaine_gauche = purification_chaine(
|
{ |
extraction_chaine(chaine_travail,
|
chaine_gauche = purification_chaine( |
1, debut_zone_algebrique));
|
extraction_chaine(chaine_travail, |
chaine_centrale = purification_chaine(
|
1, debut_zone_algebrique)); |
extraction_chaine(chaine_travail,
|
chaine_centrale = purification_chaine( |
debut_zone_algebrique + 1, fin_zone_algebrique + 1));
|
extraction_chaine(chaine_travail, |
chaine_droite = purification_chaine(
|
debut_zone_algebrique + 1, fin_zone_algebrique + 1)); |
extraction_chaine(chaine_travail,
|
chaine_droite = purification_chaine( |
fin_zone_algebrique + 2, strlen(chaine_travail)));
|
extraction_chaine(chaine_travail, |
|
fin_zone_algebrique + 2, |
free(chaine_travail);
|
(integer8) strlen(chaine_travail))); |
|
|
if ((chaine_gauche == NULL) || (chaine_centrale == NULL) ||
|
free(chaine_travail); |
(chaine_droite == NULL))
|
|
{
|
if ((chaine_gauche == NULL) || (chaine_centrale == NULL) || |
(*s_etat_processus).erreur_systeme =
|
(chaine_droite == NULL)) |
d_es_allocation_memoire;
|
{ |
return(NULL);
|
(*s_etat_processus).erreur_systeme = |
}
|
d_es_allocation_memoire; |
|
return(NULL); |
if ((strcmp(chaine_centrale, "''") == 0) ||
|
} |
(strcmp(chaine_centrale, "'()'") == 0))
|
|
{
|
if ((strcmp(chaine_centrale, "''") == 0) || |
free(chaine_gauche);
|
(strcmp(chaine_centrale, "'()'") == 0)) |
free(chaine_centrale);
|
{ |
free(chaine_droite);
|
free(chaine_gauche); |
|
free(chaine_centrale); |
(*s_etat_processus).erreur_execution =
|
free(chaine_droite); |
d_ex_expression_invalide;
|
|
return(NULL);
|
(*s_etat_processus).erreur_execution = |
}
|
d_ex_expression_invalide; |
|
return(NULL); |
i = 1;
|
} |
niveau = 0;
|
|
drapeau_elimination_parentheses = d_vrai;
|
i = 1; |
presence_chaine = d_faux;
|
niveau = 0; |
|
drapeau_elimination_parentheses = d_vrai; |
while(i < (strlen(chaine_centrale) - 1))
|
presence_chaine = d_faux; |
{
|
|
if (chaine_centrale[i] == '"')
|
while(i < ((integer8) strlen(chaine_centrale)) - 1) |
{
|
{ |
presence_chaine = (presence_chaine == d_faux)
|
if (chaine_centrale[i] == '"') |
? d_vrai : d_faux;
|
{ |
|
presence_chaine = (presence_chaine == d_faux) |
if (i == 1)
|
? d_vrai : d_faux; |
{
|
|
drapeau_elimination_parentheses = d_faux;
|
if (i == 1) |
}
|
{ |
}
|
drapeau_elimination_parentheses = d_faux; |
else if (presence_chaine == d_faux)
|
} |
{
|
} |
if (chaine_centrale[i] == '(')
|
else if (presence_chaine == d_faux) |
{
|
{ |
niveau++;
|
if (chaine_centrale[i] == '(') |
}
|
{ |
|
niveau++; |
if ((niveau == 0) || ((((test_cfsf(s_etat_processus,
|
} |
48) == d_vrai) && (chaine_centrale[i] ==
|
|
'.')) || ((test_cfsf(s_etat_processus, 48)
|
if ((niveau == 0) || ((((test_cfsf(s_etat_processus, |
== d_faux) && (chaine_centrale[i] == ',')))
|
48) == d_vrai) && (chaine_centrale[i] == |
&& (niveau == 1)))
|
'.')) || ((test_cfsf(s_etat_processus, 48) |
{
|
== d_faux) && (chaine_centrale[i] == ','))) |
drapeau_elimination_parentheses = d_faux;
|
&& (niveau == 1))) |
}
|
{ |
|
drapeau_elimination_parentheses = d_faux; |
if (chaine_centrale[i] == ')')
|
} |
{
|
|
niveau--;
|
if (chaine_centrale[i] == ')') |
}
|
{ |
}
|
niveau--; |
|
} |
i++;
|
} |
}
|
|
|
i++; |
if (drapeau_elimination_parentheses == d_vrai)
|
} |
{
|
|
tampon = chaine_centrale;
|
if (drapeau_elimination_parentheses == d_vrai) |
|
{ |
if ((chaine_centrale = (unsigned char *) malloc(
|
tampon = chaine_centrale; |
(strlen(tampon) - 1) * sizeof(unsigned char)))
|
|
== NULL)
|
if ((chaine_centrale = (unsigned char *) malloc( |
{
|
(strlen(tampon) - 1) * sizeof(unsigned char))) |
(*s_etat_processus).erreur_systeme =
|
== NULL) |
d_es_allocation_memoire;
|
{ |
return(NULL);
|
(*s_etat_processus).erreur_systeme = |
}
|
d_es_allocation_memoire; |
|
return(NULL); |
tampon[strlen(tampon) - 2] = d_code_fin_chaine;
|
} |
|
|
sprintf(chaine_centrale, "'%s'", &(tampon[2]));
|
tampon[strlen(tampon) - 2] = d_code_fin_chaine; |
free(tampon);
|
|
|
sprintf(chaine_centrale, "'%s'", &(tampon[2])); |
fin_zone_algebrique -= 2;
|
free(tampon); |
drapeau_modification = d_vrai;
|
|
}
|
fin_zone_algebrique -= 2; |
|
drapeau_modification = d_vrai; |
if ((test_expression_rpn(chaine_centrale) == d_vrai) &&
|
} |
(fin_zone_algebrique - debut_zone_algebrique > 0))
|
|
{
|
if ((test_expression_rpn(chaine_centrale) == d_vrai) && |
if ((tampon = purification_chaine(
|
(fin_zone_algebrique - debut_zone_algebrique > 0)) |
extraction_chaine(chaine_centrale, 2,
|
{ |
strlen(chaine_centrale) - 1))) == NULL)
|
if ((tampon = purification_chaine( |
{
|
extraction_chaine(chaine_centrale, 2, |
(*s_etat_processus).erreur_systeme =
|
((integer8) strlen(chaine_centrale)) - 1))) == NULL) |
d_es_allocation_memoire;
|
{ |
return(NULL);
|
(*s_etat_processus).erreur_systeme = |
}
|
d_es_allocation_memoire; |
|
return(NULL); |
/*
|
} |
* Si on tombe sur une fonction intrinsèque ou
|
|
* extrinsèque, il doit y avoir des arguments passés
|
/* |
* entre parenthèses et on ne doit pas passer par ici !
|
* Si on tombe sur une fonction intrinsèque ou |
*/
|
* extrinsèque, il doit y avoir des arguments passés |
|
* entre parenthèses et on ne doit pas passer par ici ! |
registre_instruction_courante = (*s_etat_processus)
|
*/ |
.instruction_courante;
|
|
registre_test = (*s_etat_processus).test_instruction;
|
registre_instruction_courante = (*s_etat_processus) |
registre_instruction_valide = (*s_etat_processus)
|
.instruction_courante; |
.instruction_valide;
|
registre_test = (*s_etat_processus).test_instruction; |
|
registre_instruction_valide = (*s_etat_processus) |
(*s_etat_processus).test_instruction = 'Y';
|
.instruction_valide; |
(*s_etat_processus).instruction_courante = tampon;
|
|
|
(*s_etat_processus).test_instruction = 'Y'; |
analyse(s_etat_processus, NULL);
|
(*s_etat_processus).instruction_courante = tampon; |
|
|
(*s_etat_processus).test_instruction = registre_test;
|
analyse(s_etat_processus, NULL); |
(*s_etat_processus).instruction_courante =
|
|
registre_instruction_courante;
|
(*s_etat_processus).test_instruction = registre_test; |
|
(*s_etat_processus).instruction_courante = |
if (((*s_etat_processus).instruction_valide == 'Y') &&
|
registre_instruction_courante; |
((*s_etat_processus).constante_symbolique == 'N'))
|
|
{
|
if (((*s_etat_processus).instruction_valide == 'Y') && |
free(chaine_gauche);
|
((*s_etat_processus).constante_symbolique == 'N')) |
free(chaine_centrale);
|
{ |
free(chaine_droite);
|
free(chaine_gauche); |
free(tampon);
|
free(chaine_centrale); |
|
free(chaine_droite); |
(*s_etat_processus).instruction_valide =
|
free(tampon); |
registre_instruction_valide;
|
|
|
(*s_etat_processus).instruction_valide = |
(*s_etat_processus).erreur_execution =
|
registre_instruction_valide; |
d_ex_expression_invalide;
|
|
return(NULL);
|
(*s_etat_processus).erreur_execution = |
}
|
d_ex_expression_invalide; |
|
return(NULL); |
(*s_etat_processus).instruction_valide =
|
} |
registre_instruction_valide;
|
|
|
(*s_etat_processus).instruction_valide = |
free(chaine_centrale);
|
registre_instruction_valide; |
chaine_centrale = tampon;
|
|
|
free(chaine_centrale); |
fin_zone_algebrique--;
|
chaine_centrale = tampon; |
drapeau_modification = d_vrai;
|
|
}
|
fin_zone_algebrique--; |
else if ((test_fonction(chaine_centrale) == d_vrai) &&
|
drapeau_modification = d_vrai; |
(fin_zone_algebrique - debut_zone_algebrique > 0))
|
} |
{
|
else if ((test_fonction(chaine_centrale) == d_vrai) && |
i = 1;
|
(fin_zone_algebrique - debut_zone_algebrique > 0)) |
while((i < (strlen(chaine_centrale) - 1)) &&
|
{ |
(chaine_centrale[i] != '('))
|
i = 1; |
{
|
while((i < ((integer8) strlen(chaine_centrale)) - 1) && |
i++;
|
(chaine_centrale[i] != '(')) |
}
|
{ |
|
i++; |
j = strlen(chaine_centrale) - 1;
|
} |
while(chaine_centrale[j] != ')')
|
|
{
|
j = ((integer8) strlen(chaine_centrale)) - 1; |
j--;
|
while(chaine_centrale[j] != ')') |
}
|
{ |
|
j--; |
chaine_fonction = purification_chaine(
|
} |
extraction_chaine(chaine_centrale, 2, i));
|
|
chaine_arguments = purification_chaine(
|
chaine_fonction = purification_chaine( |
extraction_chaine(chaine_centrale, i + 2, j));
|
extraction_chaine(chaine_centrale, 2, i)); |
|
chaine_arguments = purification_chaine( |
i = 0;
|
extraction_chaine(chaine_centrale, i + 2, j)); |
niveau = 0;
|
|
nombre_arguments = 1;
|
i = 0; |
|
niveau = 0; |
while(chaine_arguments[i] != d_code_fin_chaine)
|
nombre_arguments = 1; |
{
|
|
if (chaine_arguments[i] == '(')
|
while(chaine_arguments[i] != d_code_fin_chaine) |
{
|
{ |
niveau++;
|
if (chaine_arguments[i] == '(') |
}
|
{ |
|
niveau++; |
if (chaine_arguments[i] == ')')
|
} |
{
|
|
niveau--;
|
if (chaine_arguments[i] == ')') |
}
|
{ |
|
niveau--; |
if ((chaine_arguments[i] == ',') && (niveau == 0))
|
} |
{
|
|
sous_chaine_gauche = purification_chaine(
|
if ((chaine_arguments[i] == ',') && (niveau == 0)) |
extraction_chaine(chaine_arguments, 1, i));
|
{ |
sous_chaine_droite = purification_chaine(
|
sous_chaine_gauche = purification_chaine( |
extraction_chaine(chaine_arguments, i + 2,
|
extraction_chaine(chaine_arguments, 1, i)); |
strlen(chaine_arguments)));
|
sous_chaine_droite = purification_chaine( |
|
extraction_chaine(chaine_arguments, i + 2, |
free(chaine_arguments);
|
((integer8) strlen(chaine_arguments)))); |
|
|
if ((chaine_arguments = (unsigned char *) malloc(
|
free(chaine_arguments); |
(strlen(sous_chaine_gauche) + strlen(
|
|
sous_chaine_droite) + 3 + 1) * sizeof(
|
if ((chaine_arguments = (unsigned char *) malloc( |
unsigned char))) == NULL)
|
(strlen(sous_chaine_gauche) + strlen( |
{
|
sous_chaine_droite) + 3 + 1) * sizeof( |
(*s_etat_processus).erreur_systeme =
|
unsigned char))) == NULL) |
d_es_allocation_memoire;
|
{ |
return(NULL);
|
(*s_etat_processus).erreur_systeme = |
}
|
d_es_allocation_memoire; |
|
return(NULL); |
sprintf(chaine_arguments, "%s' '%s",
|
} |
sous_chaine_gauche, sous_chaine_droite);
|
|
i += 2;
|
sprintf(chaine_arguments, "%s' '%s", |
|
sous_chaine_gauche, sous_chaine_droite); |
free(sous_chaine_gauche);
|
i += 2; |
free(sous_chaine_droite);
|
|
|
free(sous_chaine_gauche); |
nombre_arguments++;
|
free(sous_chaine_droite); |
}
|
|
|
nombre_arguments++; |
i++;
|
} |
}
|
|
|
i++; |
free(chaine_centrale);
|
} |
|
|
l_element_courant = (*l_base_liste);
|
free(chaine_centrale); |
presence_fonction = d_faux;
|
|
|
l_element_courant = (*l_base_liste); |
while((l_element_courant != NULL) &&
|
presence_fonction = d_faux; |
(presence_fonction == d_faux))
|
|
{
|
while((l_element_courant != NULL) && |
if (strcmp((*((struct_fonction *) ((*l_element_courant)
|
(presence_fonction == d_faux)) |
.donnee))).nom_fonction, chaine_fonction) == 0)
|
{ |
{
|
if (strcmp((*((struct_fonction *) ((*l_element_courant) |
presence_fonction = d_vrai;
|
.donnee))).nom_fonction, chaine_fonction) == 0) |
}
|
{ |
else
|
presence_fonction = d_vrai; |
{
|
} |
l_element_courant = (*l_element_courant).suivant;
|
else |
}
|
{ |
}
|
l_element_courant = (*l_element_courant).suivant; |
|
} |
if (presence_fonction == d_vrai)
|
} |
{
|
|
if ((*((struct_fonction *)
|
if (presence_fonction == d_vrai) |
((*l_element_courant).donnee)))
|
{ |
.nombre_arguments != nombre_arguments)
|
if ((*((struct_fonction *) |
{
|
((*l_element_courant).donnee))) |
(*s_etat_processus).erreur_execution =
|
.nombre_arguments != nombre_arguments) |
d_ex_nombre_arguments;
|
{ |
|
(*s_etat_processus).erreur_execution = |
free(chaine_arguments);
|
d_ex_nombre_arguments; |
free(chaine_fonction);
|
|
free(chaine_gauche);
|
free(chaine_arguments); |
free(chaine_droite);
|
free(chaine_fonction); |
|
free(chaine_gauche); |
return(NULL);
|
free(chaine_droite); |
}
|
|
}
|
return(NULL); |
else
|
} |
{
|
} |
registre_instruction_courante = (*s_etat_processus)
|
else |
.instruction_courante;
|
{ |
registre_test = (*s_etat_processus).test_instruction;
|
registre_instruction_courante = (*s_etat_processus) |
registre_instruction_valide = (*s_etat_processus)
|
.instruction_courante; |
.instruction_valide;
|
registre_test = (*s_etat_processus).test_instruction; |
|
registre_instruction_valide = (*s_etat_processus) |
(*s_etat_processus).test_instruction = 'Y';
|
.instruction_valide; |
(*s_etat_processus).instruction_courante =
|
|
chaine_fonction;
|
(*s_etat_processus).test_instruction = 'Y'; |
|
(*s_etat_processus).instruction_courante = |
analyse(s_etat_processus, NULL);
|
chaine_fonction; |
|
|
(*s_etat_processus).test_instruction = registre_test;
|
analyse(s_etat_processus, NULL); |
(*s_etat_processus).instruction_courante =
|
|
registre_instruction_courante;
|
(*s_etat_processus).test_instruction = registre_test; |
(*s_etat_processus).instruction_valide =
|
(*s_etat_processus).instruction_courante = |
registre_instruction_valide;
|
registre_instruction_courante; |
|
(*s_etat_processus).instruction_valide = |
if (((unsigned long) (*s_etat_processus)
|
registre_instruction_valide; |
.nombre_arguments != nombre_arguments) &&
|
|
((*s_etat_processus).nombre_arguments != -2))
|
if (((*s_etat_processus).nombre_arguments != |
{
|
nombre_arguments) && |
(*s_etat_processus).erreur_execution =
|
((*s_etat_processus).nombre_arguments != -2)) |
d_ex_nombre_arguments_fonction;
|
{ |
|
(*s_etat_processus).erreur_execution = |
free(chaine_arguments);
|
d_ex_nombre_arguments_fonction; |
free(chaine_fonction);
|
|
free(chaine_gauche);
|
free(chaine_arguments); |
free(chaine_droite);
|
free(chaine_fonction); |
|
free(chaine_gauche); |
return(NULL);
|
free(chaine_droite); |
}
|
|
|
return(NULL); |
if ((l_element_courant = (struct_liste_chainee *)
|
} |
malloc(sizeof(struct_liste_chainee))) == NULL)
|
|
{
|
if ((l_element_courant = (struct_liste_chainee *) |
(*s_etat_processus).erreur_systeme =
|
malloc(sizeof(struct_liste_chainee))) == NULL) |
d_es_allocation_memoire;
|
{ |
return(NULL);
|
(*s_etat_processus).erreur_systeme = |
}
|
d_es_allocation_memoire; |
|
return(NULL); |
(*l_element_courant).suivant = (*l_base_liste);
|
} |
(*l_base_liste) = l_element_courant;
|
|
|
(*l_element_courant).suivant = (*l_base_liste); |
if ((s_fonction = malloc(sizeof(struct_fonction)))
|
(*l_base_liste) = l_element_courant; |
== NULL)
|
|
{
|
if ((s_fonction = malloc(sizeof(struct_fonction))) |
(*s_etat_processus).erreur_systeme =
|
== NULL) |
d_es_allocation_memoire;
|
{ |
return(NULL);
|
(*s_etat_processus).erreur_systeme = |
}
|
d_es_allocation_memoire; |
|
return(NULL); |
if (((*s_fonction).nom_fonction = (unsigned char *)
|
} |
malloc((strlen(chaine_fonction) + 1) *
|
|
sizeof(unsigned char))) == NULL)
|
if (((*s_fonction).nom_fonction = (unsigned char *) |
{
|
malloc((strlen(chaine_fonction) + 1) * |
(*s_etat_processus).erreur_systeme =
|
sizeof(unsigned char))) == NULL) |
d_es_allocation_memoire;
|
{ |
return(NULL);
|
(*s_etat_processus).erreur_systeme = |
}
|
d_es_allocation_memoire; |
|
return(NULL); |
strcpy((*s_fonction).nom_fonction, chaine_fonction);
|
} |
(*s_fonction).nombre_arguments = nombre_arguments;
|
|
|
strcpy((*s_fonction).nom_fonction, chaine_fonction); |
(*(*l_base_liste)).donnee = (void *) s_fonction;
|
(*s_fonction).nombre_arguments = nombre_arguments; |
}
|
|
|
(*(*l_base_liste)).donnee = (void *) s_fonction; |
if ((chaine_centrale = (unsigned char *) malloc((strlen(
|
} |
chaine_arguments) + 1 + strlen(chaine_fonction)
|
|
+ 1 + 2) * sizeof(unsigned char))) == NULL)
|
if ((chaine_centrale = (unsigned char *) malloc((strlen( |
{
|
chaine_arguments) + 1 + strlen(chaine_fonction) |
(*s_etat_processus).erreur_systeme =
|
+ 1 + 2) * sizeof(unsigned char))) == NULL) |
d_es_allocation_memoire;
|
{ |
return(NULL);
|
(*s_etat_processus).erreur_systeme = |
}
|
d_es_allocation_memoire; |
|
return(NULL); |
sprintf(chaine_centrale, "'%s' %s", chaine_arguments,
|
} |
chaine_fonction);
|
|
drapeau_modification = d_vrai;
|
sprintf(chaine_centrale, "'%s' %s", chaine_arguments, |
|
chaine_fonction); |
free(chaine_arguments);
|
drapeau_modification = d_vrai; |
free(chaine_fonction);
|
|
}
|
free(chaine_arguments); |
else if ((chaine_centrale[1] == '+') ||
|
free(chaine_fonction); |
(chaine_centrale[1] == '-'))
|
} |
{
|
else if ((chaine_centrale[1] == '+') || |
if (chaine_centrale[1] == '-')
|
(chaine_centrale[1] == '-')) |
{
|
{ |
tampon = chaine_centrale;
|
if (chaine_centrale[1] == '-') |
|
{ |
if ((chaine_centrale = (unsigned char *) malloc(
|
tampon = chaine_centrale; |
(strlen(tampon) + 5) * sizeof(unsigned char)))
|
|
== NULL)
|
if ((chaine_centrale = (unsigned char *) malloc( |
{
|
(strlen(tampon) + 5) * sizeof(unsigned char))) |
(*s_etat_processus).erreur_systeme =
|
== NULL) |
d_es_allocation_memoire;
|
{ |
return(NULL);
|
(*s_etat_processus).erreur_systeme = |
}
|
d_es_allocation_memoire; |
|
return(NULL); |
tampon[strlen(tampon) - 1] = d_code_fin_chaine;
|
} |
sprintf(chaine_centrale, "'NEG(%s)'", &(tampon[2]));
|
|
fin_zone_algebrique += 5;
|
tampon[strlen(tampon) - 1] = d_code_fin_chaine; |
drapeau_modification = d_vrai;
|
sprintf(chaine_centrale, "'NEG(%s)'", &(tampon[2])); |
|
fin_zone_algebrique += 5; |
free(tampon);
|
drapeau_modification = d_vrai; |
}
|
|
else
|
free(tampon); |
{
|
} |
tampon = chaine_centrale;
|
else |
|
{ |
if ((chaine_centrale = (unsigned char *) malloc(
|
tampon = chaine_centrale; |
(strlen(tampon) + 7) * sizeof(unsigned char)))
|
|
== NULL)
|
if ((chaine_centrale = (unsigned char *) malloc( |
{
|
(strlen(tampon) + 7) * sizeof(unsigned char))) |
(*s_etat_processus).erreur_systeme =
|
== NULL) |
d_es_allocation_memoire;
|
{ |
return(NULL);
|
(*s_etat_processus).erreur_systeme = |
}
|
d_es_allocation_memoire; |
|
return(NULL); |
tampon[strlen(tampon) - 1] = d_code_fin_chaine;
|
} |
sprintf(chaine_centrale, "'RELAX(%s)'", &(tampon[2]));
|
|
fin_zone_algebrique += 7;
|
tampon[strlen(tampon) - 1] = d_code_fin_chaine; |
drapeau_modification = d_vrai;
|
sprintf(chaine_centrale, "'RELAX(%s)'", &(tampon[2])); |
|
fin_zone_algebrique += 7; |
free(tampon);
|
drapeau_modification = d_vrai; |
}
|
|
}
|
free(tampon); |
|
} |
if ((chaine_travail = (unsigned char *) malloc(
|
} |
(strlen(chaine_gauche) + strlen(chaine_centrale) +
|
|
strlen(chaine_droite) + 1 + 2) * sizeof(unsigned char)))
|
if ((chaine_travail = (unsigned char *) malloc( |
== NULL)
|
(strlen(chaine_gauche) + strlen(chaine_centrale) + |
{
|
strlen(chaine_droite) + 1 + 2) * sizeof(unsigned char))) |
(*s_etat_processus).erreur_systeme =
|
== NULL) |
d_es_allocation_memoire;
|
{ |
return(NULL);
|
(*s_etat_processus).erreur_systeme = |
}
|
d_es_allocation_memoire; |
|
return(NULL); |
sprintf(chaine_travail, "%s %s %s", chaine_gauche,
|
} |
chaine_centrale, chaine_droite);
|
|
|
sprintf(chaine_travail, "%s %s %s", chaine_gauche, |
free(chaine_gauche);
|
chaine_centrale, chaine_droite); |
free(chaine_centrale);
|
|
free(chaine_droite);
|
free(chaine_gauche); |
}
|
free(chaine_centrale); |
|
free(chaine_droite); |
i = fin_zone_algebrique + 1;
|
} |
} while((drapeau_debut_zone_valide == d_vrai)
|
|
&& (drapeau_fin_zone_valide == d_vrai));
|
i = fin_zone_algebrique + 1; |
|
} while((drapeau_debut_zone_valide == d_vrai) |
for(longueur_chaine = strlen(chaine_travail),
|
&& (drapeau_fin_zone_valide == d_vrai)); |
i = nombre_apostrophes = 0; i < longueur_chaine;
|
|
nombre_apostrophes += (chaine_travail[i++] == '\'') ? 1 : 0);
|
for(longueur_chaine = (integer8) strlen(chaine_travail), |
|
i = nombre_apostrophes = 0; i < longueur_chaine; |
if (nombre_apostrophes != 0)
|
nombre_apostrophes += (chaine_travail[i++] == '\'') ? 1 : 0); |
{
|
|
priorite = 1;
|
if (nombre_apostrophes != 0) |
|
{ |
do
|
priorite = 1; |
{
|
|
drapeau_priorite_entierement_traitee = d_vrai;
|
do |
|
{ |
i = 0;
|
drapeau_priorite_entierement_traitee = d_vrai; |
while((chaine_travail[i] != '\'') && (chaine_travail[i] != 0))
|
|
{
|
i = 0; |
i++;
|
while((chaine_travail[i] != '\'') && (chaine_travail[i] != 0)) |
}
|
{ |
|
i++; |
if (chaine_travail[i] == 0)
|
} |
{
|
|
i = 0;
|
if (chaine_travail[i] == 0) |
}
|
{ |
|
i = 0; |
j = i + 1;
|
} |
while((chaine_travail[j] != '\'') && (chaine_travail[j] != 0))
|
|
{
|
j = i + 1; |
j++;
|
while((chaine_travail[j] != '\'') && (chaine_travail[j] != 0)) |
}
|
{ |
|
j++; |
if (chaine_travail[j] == 0)
|
} |
{
|
|
j = 0;
|
if (chaine_travail[j] == 0) |
}
|
{ |
|
j = 0; |
if ((chaine_travail[i] != 0) && (j != 0))
|
} |
{
|
|
chaine_gauche = purification_chaine(
|
if ((chaine_travail[i] != 0) && (j != 0)) |
extraction_chaine(chaine_travail, 1, i));
|
{ |
chaine_centrale = purification_chaine(
|
chaine_gauche = purification_chaine( |
extraction_chaine(chaine_travail,
|
extraction_chaine(chaine_travail, 1, i)); |
i + 1, j + 1));
|
chaine_centrale = purification_chaine( |
chaine_droite = purification_chaine(
|
extraction_chaine(chaine_travail, |
extraction_chaine(chaine_travail, j + 2,
|
i + 1, j + 1)); |
strlen(chaine_travail)));
|
chaine_droite = purification_chaine( |
|
extraction_chaine(chaine_travail, j + 2, |
if ((chaine_gauche == NULL) || (chaine_centrale == NULL) ||
|
((integer8) strlen(chaine_travail)))); |
(chaine_droite == NULL))
|
|
{
|
if ((chaine_gauche == NULL) || (chaine_centrale == NULL) || |
(*s_etat_processus).erreur_systeme =
|
(chaine_droite == NULL)) |
d_es_allocation_memoire;
|
{ |
return(NULL);
|
(*s_etat_processus).erreur_systeme = |
}
|
d_es_allocation_memoire; |
|
return(NULL); |
drapeau_elimination_parentheses = d_vrai;
|
} |
|
|
if ((longueur_tampon = strlen(chaine_centrale)) != 0)
|
drapeau_elimination_parentheses = d_vrai; |
{
|
|
niveau = 0;
|
if ((longueur_tampon = ((integer8) strlen(chaine_centrale))) |
|
!= 0) |
for(i = 1; i < longueur_tampon - 1; i++)
|
{ |
{
|
niveau = 0; |
if (chaine_centrale[i] == '(')
|
|
{
|
for(i = 1; i < longueur_tampon - 1; i++) |
niveau++;
|
{ |
}
|
if (chaine_centrale[i] == '(') |
|
{ |
if ((niveau == 0) || ((((test_cfsf(s_etat_processus,
|
niveau++; |
48) == d_vrai) && (chaine_centrale[i] ==
|
} |
'.')) || ((test_cfsf(s_etat_processus, 48)
|
|
== d_faux) && (chaine_centrale[i] == ',')))
|
if ((niveau == 0) || ((((test_cfsf(s_etat_processus, |
&& (niveau == 1)))
|
48) == d_vrai) && (chaine_centrale[i] == |
{
|
'.')) || ((test_cfsf(s_etat_processus, 48) |
drapeau_elimination_parentheses = d_faux;
|
== d_faux) && (chaine_centrale[i] == ','))) |
}
|
&& (niveau == 1))) |
|
{ |
if (chaine_centrale[i] == ')')
|
drapeau_elimination_parentheses = d_faux; |
{
|
} |
niveau--;
|
|
}
|
if (chaine_centrale[i] == ')') |
}
|
{ |
|
niveau--; |
if (drapeau_elimination_parentheses == d_vrai)
|
} |
{
|
} |
if ((tampon = (unsigned char *) malloc(
|
|
((longueur_tampon = strlen(
|
if (drapeau_elimination_parentheses == d_vrai) |
chaine_centrale)) + 1) * sizeof(
|
{ |
unsigned char))) == NULL)
|
if ((tampon = (unsigned char *) malloc(((size_t) |
{
|
((longueur_tampon = (integer8) strlen( |
(*s_etat_processus).erreur_systeme =
|
chaine_centrale)) + 1)) * sizeof( |
d_es_allocation_memoire;
|
unsigned char))) == NULL) |
return(NULL);
|
{ |
}
|
(*s_etat_processus).erreur_systeme = |
|
d_es_allocation_memoire; |
chaine_centrale[longueur_tampon - 2] =
|
return(NULL); |
d_code_fin_chaine;
|
} |
sprintf(tampon, "'%s'", &(chaine_centrale[2]));
|
|
free(chaine_centrale);
|
chaine_centrale[longueur_tampon - 2] = |
chaine_centrale = tampon;
|
d_code_fin_chaine; |
drapeau_modification = d_vrai;
|
sprintf(tampon, "'%s'", &(chaine_centrale[2])); |
}
|
free(chaine_centrale); |
}
|
chaine_centrale = tampon; |
|
drapeau_modification = d_vrai; |
if ((tampon = (unsigned char *) malloc(sizeof(
|
} |
unsigned char))) == NULL)
|
} |
{
|
|
(*s_etat_processus).erreur_systeme =
|
if ((tampon = (unsigned char *) malloc(sizeof( |
d_es_allocation_memoire;
|
unsigned char))) == NULL) |
return(NULL);
|
{ |
}
|
(*s_etat_processus).erreur_systeme = |
|
d_es_allocation_memoire; |
tampon[0] = d_code_fin_chaine;
|
return(NULL); |
longueur_chaine = strlen(chaine_centrale);
|
} |
niveau = 0;
|
|
k = strlen(chaine_centrale) - 1;
|
tampon[0] = d_code_fin_chaine; |
fin_boucle_extraction = d_faux;
|
longueur_chaine = (integer8) strlen(chaine_centrale); |
|
k = ((integer8) strlen(chaine_centrale)) - 1; |
while((k >= 0) && (fin_boucle_extraction ==
|
niveau = 0; |
d_faux))
|
fin_boucle_extraction = d_faux; |
{
|
|
t0 = ((size_t) k < strlen(chaine_centrale))
|
while((k >= 0) && (fin_boucle_extraction == d_faux)) |
? chaine_centrale[k + 1] : ' ';
|
{ |
t1 = chaine_centrale[k];
|
t0 = (k < ((integer8) strlen(chaine_centrale))) |
t2 = (k < 1) ? ' ' : chaine_centrale[k - 1];
|
? chaine_centrale[k + 1] : ' '; |
t3 = (k < 2) ? ' ' : chaine_centrale[k - 2];
|
t1 = chaine_centrale[k]; |
t4 = (k < 3) ? ' ' : chaine_centrale[k - 3];
|
t2 = (k < 1) ? ' ' : chaine_centrale[k - 1]; |
|
t3 = (k < 2) ? ' ' : chaine_centrale[k - 2]; |
if ((t0 >= 'a') && (t0 <= 'z'))
|
t4 = (k < 3) ? ' ' : chaine_centrale[k - 3]; |
{
|
|
t0 = t0 + ('A' - 'a');
|
if ((t0 >= 'a') && (t0 <= 'z')) |
}
|
{ |
|
t0 = t0 + ('A' - 'a'); |
if ((t1 >= 'a') && (t1 <= 'z'))
|
} |
{
|
|
t1 = t1 + ('A' - 'a');
|
if ((t1 >= 'a') && (t1 <= 'z')) |
}
|
{ |
|
t1 = t1 + ('A' - 'a'); |
if ((t2 >= 'a') && (t2 <= 'z'))
|
} |
{
|
|
t2 = t2 + ('A' - 'a');
|
if ((t2 >= 'a') && (t2 <= 'z')) |
}
|
{ |
|
t2 = t2 + ('A' - 'a'); |
if ((t3 >= 'a') && (t3 <= 'z'))
|
} |
{
|
|
t3 = t3 + ('A' - 'a');
|
if ((t3 >= 'a') && (t3 <= 'z')) |
}
|
{ |
|
t3 = t3 + ('A' - 'a'); |
if ((t4 >= 'a') && (t4 <= 'z'))
|
} |
{
|
|
t4 = t4 + ('A' - 'a');
|
if ((t4 >= 'a') && (t4 <= 'z')) |
}
|
{ |
|
t4 = t4 + ('A' - 'a'); |
if (t1 == '(')
|
} |
{
|
|
niveau++;
|
if (t1 == '(') |
}
|
{ |
|
niveau++; |
if (niveau == 0)
|
} |
{
|
|
prologue = purification_chaine(
|
if (niveau == 0) |
extraction_chaine(chaine_centrale, 1, k));
|
{ |
epilogue = purification_chaine(
|
prologue = purification_chaine( |
extraction_chaine(chaine_centrale,
|
extraction_chaine(chaine_centrale, 1, k)); |
k + 2, longueur_chaine));
|
epilogue = purification_chaine( |
|
extraction_chaine(chaine_centrale, |
if ((prologue == NULL) || (epilogue == NULL))
|
k + 2, longueur_chaine)); |
{
|
|
(*s_etat_processus).erreur_systeme =
|
if ((prologue == NULL) || (epilogue == NULL)) |
d_es_allocation_memoire;
|
{ |
return(NULL);
|
(*s_etat_processus).erreur_systeme = |
}
|
d_es_allocation_memoire; |
|
return(NULL); |
/*
|
} |
* Priorité = 1 : traitement des fonctions les plus prioritaires
|
|
*/
|
/* |
|
* Priorité = 1 : traitement des fonctions les plus prioritaires |
if (((priorite == 4) && (((t1 == '<') && (t0 != '=')
|
*/ |
&& (t2 != '=')) || ((t1 == '>') &&
|
|
(t0 != '=') && (t2 != '=')) ||
|
if (((priorite == 4) && (((t1 == '<') && (t0 != '=') |
((t1 == '=') && (t0 != '=') && (t0 != '<')
|
&& (t2 != '=')) || ((t1 == '>') && |
&& (t0 != '>') && (t2 != '<') && (t2 != '>')
|
(t0 != '=') && (t2 != '=')) || |
&& (t2 != '=')))) ||
|
((t1 == '=') && (t0 != '=') && (t0 != '<') |
((t1 == '+') && (priorite == 5) &&
|
&& (t0 != '>') && (t2 != '<') && (t2 != '>') |
(t2 != '\'') && (!(((t2 == '(')
|
&& (t2 != '=')))) || |
|| (t2 == '\'') || (t2 == 'e')
|
((t1 == '+') && (priorite == 5) && |
|| (t2 == 'E')) && (((t3 >= '0')
|
(t2 != '\'') && (!(((t2 == '(') |
&& (t3 <= '9')) || (t3 == '.'))))) ||
|
|| (t2 == '\'') || (t2 == 'e') |
((t1 == '-') && (priorite == 6) &&
|
|| (t2 == 'E')) && (((t3 >= '0') |
(t2 != '\'') && (!(((t2 == '(')
|
&& (t3 <= '9')) || (t3 == '.'))))) || |
|| (t2 == '\'') || (t2 == 'e')
|
((t1 == '-') && (priorite == 6) && |
|| (t2 == 'E')) && (((t3 >= '0')
|
(t2 != '\'') && (!(((t2 == '(') |
&& (t3 <= '9')) || (t3 == '.')))))
|
|| (t2 == '\'') || (t2 == 'e') |
|| ((t1 == '*') && (priorite == 7))
|
|| (t2 == 'E')) && (((t3 >= '0') |
|| ((t1 == '/') && (priorite == 8)) ||
|
&& (t3 <= '9')) || (t3 == '.'))))) |
((t1 == '^') && (priorite == 9)))
|
|| ((t1 == '*') && (priorite == 7)) |
{
|
|| ((t1 == '/') && (priorite == 8)) || |
drapeau_priorite_entierement_traitee = d_faux;
|
((t1 == '^') && (priorite == 9))) |
fin_boucle_extraction = d_vrai;
|
{ |
|
drapeau_priorite_entierement_traitee = d_faux; |
free(tampon);
|
fin_boucle_extraction = d_vrai; |
|
|
if ((tampon = (unsigned char *)
|
free(tampon); |
malloc((strlen(prologue) +
|
|
strlen(epilogue) + 6) *
|
if ((tampon = (unsigned char *) |
sizeof(unsigned char))) == NULL)
|
malloc((strlen(prologue) + |
{
|
strlen(epilogue) + 6) * |
(*s_etat_processus).erreur_systeme =
|
sizeof(unsigned char))) == NULL) |
d_es_allocation_memoire;
|
{ |
return(NULL);
|
(*s_etat_processus).erreur_systeme = |
}
|
d_es_allocation_memoire; |
|
return(NULL); |
sprintf(tampon, "%s' '%s %c",
|
} |
prologue, epilogue, t1);
|
|
drapeau_modification = d_vrai;
|
sprintf(tampon, "%s' '%s %c", |
}
|
prologue, epilogue, t1); |
else if (((priorite == 4) && (((t1 == '<') &&
|
drapeau_modification = d_vrai; |
(t2 == '=')) || ((t1 == '=') &&
|
} |
(t2 == '<')) || ((t1 == '>') &&
|
else if (((priorite == 4) && (((t1 == '<') && |
(t2 == '<')) || (((t1 == '>') &&
|
(t2 == '=')) || ((t1 == '=') && |
(t2 == '=')) || ((t1 == '=') &&
|
(t2 == '<')) || ((t1 == '>') && |
(t2 == '>')) || ((t1 == '=') &&
|
(t2 == '<')) || (((t1 == '>') && |
(t2 == '='))))) || ((priorite == 1) &&
|
(t2 == '=')) || ((t1 == '=') && |
(t1 == 'R') && (t2 == 'O') && (t3 == ' ')
|
(t2 == '>')) || ((t1 == '=') && |
&& (t0 == ' ')))
|
(t2 == '='))))) || ((priorite == 1) && |
{
|
(t1 == 'R') && (t2 == 'O') && (t3 == ' ') |
drapeau_priorite_entierement_traitee = d_faux;
|
&& (t0 == ' '))) |
fin_boucle_extraction = d_vrai;
|
{ |
|
drapeau_priorite_entierement_traitee = d_faux; |
free(tampon);
|
fin_boucle_extraction = d_vrai; |
|
|
if ((tampon = (unsigned char *)
|
free(tampon); |
malloc((strlen(prologue) +
|
|
strlen(epilogue) + 6) *
|
if ((tampon = (unsigned char *) |
sizeof(unsigned char))) == NULL)
|
malloc((strlen(prologue) + |
{
|
strlen(epilogue) + 6) * |
(*s_etat_processus).erreur_systeme =
|
sizeof(unsigned char))) == NULL) |
d_es_allocation_memoire;
|
{ |
return(NULL);
|
(*s_etat_processus).erreur_systeme = |
}
|
d_es_allocation_memoire; |
|
return(NULL); |
prologue[strlen(prologue) - 1] =
|
} |
d_code_fin_chaine;
|
|
|
prologue[strlen(prologue) - 1] = |
sprintf(tampon, "%s' '%s %c%c", prologue,
|
d_code_fin_chaine; |
epilogue, t2, t1);
|
|
drapeau_modification = d_vrai;
|
sprintf(tampon, "%s' '%s %c%c", prologue, |
}
|
epilogue, t2, t1); |
else if (((priorite == 1) && (t4 == ' ') &&
|
drapeau_modification = d_vrai; |
(t3 == 'X') && (t2 == 'O') && (t1 == 'R')
|
} |
&& (t0 == ' ')) || ((priorite == 2) &&
|
else if (((priorite == 1) && (t4 == ' ') && |
(t4 == ' ') && (t3 == 'A') && (t2 == 'N')
|
(t3 == 'X') && (t2 == 'O') && (t1 == 'R') |
&& (t1 == 'D') && (t0 == ' ')))
|
&& (t0 == ' ')) || ((priorite == 2) && |
{
|
(t4 == ' ') && (t3 == 'A') && (t2 == 'N') |
drapeau_priorite_entierement_traitee = d_faux;
|
&& (t1 == 'D') && (t0 == ' '))) |
fin_boucle_extraction = d_vrai;
|
{ |
|
drapeau_priorite_entierement_traitee = d_faux; |
free(tampon);
|
fin_boucle_extraction = d_vrai; |
|
|
if ((tampon = (unsigned char *)
|
free(tampon); |
malloc((strlen(prologue) +
|
|
strlen(epilogue) + 5) *
|
if ((tampon = (unsigned char *) |
sizeof(unsigned char))) == NULL)
|
malloc((strlen(prologue) + |
{
|
strlen(epilogue) + 5) * |
(*s_etat_processus).erreur_systeme =
|
sizeof(unsigned char))) == NULL) |
d_es_allocation_memoire;
|
{ |
return(NULL);
|
(*s_etat_processus).erreur_systeme = |
}
|
d_es_allocation_memoire; |
|
return(NULL); |
prologue[strlen(prologue) - 3] =
|
} |
d_code_fin_chaine;
|
|
|
prologue[strlen(prologue) - 3] = |
sprintf(tampon, "%s' '%s %c%c%c", prologue,
|
d_code_fin_chaine; |
epilogue, t3, t2, t1);
|
|
drapeau_modification = d_vrai;
|
sprintf(tampon, "%s' '%s %c%c%c", prologue, |
}
|
epilogue, t3, t2, t1); |
|
drapeau_modification = d_vrai; |
free(prologue);
|
} |
free(epilogue);
|
|
}
|
free(prologue); |
|
free(epilogue); |
if (t1 == ')')
|
} |
{
|
|
niveau--;
|
if (t1 == ')') |
}
|
{ |
|
niveau--; |
k--;
|
} |
}
|
|
|
k--; |
if (drapeau_priorite_entierement_traitee == d_vrai)
|
} |
{
|
|
free(tampon);
|
if (drapeau_priorite_entierement_traitee == d_vrai) |
|
{ |
if ((tampon = (unsigned char *) malloc(
|
free(tampon); |
(strlen(chaine_centrale) + 1) *
|
|
sizeof(unsigned char))) == NULL)
|
if ((tampon = (unsigned char *) malloc( |
{
|
(strlen(chaine_centrale) + 1) * |
(*s_etat_processus).erreur_systeme =
|
sizeof(unsigned char))) == NULL) |
d_es_allocation_memoire;
|
{ |
return(NULL);
|
(*s_etat_processus).erreur_systeme = |
}
|
d_es_allocation_memoire; |
|
return(NULL); |
strcpy(tampon, chaine_centrale);
|
} |
}
|
|
|
strcpy(tampon, chaine_centrale); |
free(chaine_centrale);
|
} |
free(chaine_travail);
|
|
|
free(chaine_centrale); |
if ((chaine_travail = (unsigned char *) malloc(
|
free(chaine_travail); |
(strlen(chaine_gauche) + strlen(tampon)
|
|
+ strlen(chaine_droite) + 1 + 2)
|
if ((chaine_travail = (unsigned char *) malloc( |
* sizeof(unsigned char))) == NULL)
|
(strlen(chaine_gauche) + strlen(tampon) |
{
|
+ strlen(chaine_droite) + 1 + 2) |
(*s_etat_processus).erreur_systeme =
|
* sizeof(unsigned char))) == NULL) |
d_es_allocation_memoire;
|
{ |
return(NULL);
|
(*s_etat_processus).erreur_systeme = |
}
|
d_es_allocation_memoire; |
|
return(NULL); |
sprintf(chaine_travail, "%s %s %s", chaine_gauche,
|
} |
tampon, chaine_droite);
|
|
|
sprintf(chaine_travail, "%s %s %s", chaine_gauche, |
free(chaine_gauche);
|
tampon, chaine_droite); |
free(tampon);
|
|
free(chaine_droite);
|
free(chaine_gauche); |
}
|
free(tampon); |
|
free(chaine_droite); |
if (drapeau_priorite_entierement_traitee == d_vrai)
|
} |
{
|
|
priorite++;
|
if (drapeau_priorite_entierement_traitee == d_vrai) |
}
|
{ |
else
|
priorite++; |
{
|
} |
priorite = 1;
|
else |
}
|
{ |
} while(priorite < 10);
|
priorite = 1; |
|
} |
/*
|
} while(priorite < 10); |
* Aucune modification n'a pu être faite sur l'expression
|
|
* algébrique.
|
/* |
*/
|
* Aucune modification n'a pu être faite sur l'expression |
|
* algébrique. |
if (drapeau_modification == d_faux)
|
*/ |
{
|
|
free(chaine_travail);
|
if (drapeau_modification == d_faux) |
|
{ |
(*s_etat_processus).erreur_execution = d_ex_syntaxe;
|
free(chaine_travail); |
return(NULL);
|
|
}
|
(*s_etat_processus).erreur_execution = d_ex_syntaxe; |
}
|
return(NULL); |
} while(nombre_apostrophes != 0);
|
} |
|
} |
tampon = chaine_travail;
|
} while(nombre_apostrophes != 0); |
|
|
if ((chaine_travail = (unsigned char *) malloc((strlen(tampon) + 1 + 6) *
|
tampon = chaine_travail; |
sizeof(unsigned char))) == NULL)
|
|
{
|
if ((chaine_travail = (unsigned char *) malloc((strlen(tampon) + 1 + 6) * |
(*s_etat_processus).erreur_systeme = d_es_allocation_memoire;
|
sizeof(unsigned char))) == NULL) |
return(NULL);
|
{ |
}
|
(*s_etat_processus).erreur_systeme = d_es_allocation_memoire; |
|
return(NULL); |
sprintf(chaine_travail, "<< %s >>", tampon);
|
} |
free(tampon);
|
|
|
sprintf(chaine_travail, "<< %s >>", tampon); |
return(chaine_travail);
|
free(tampon); |
}
|
|
|
return(chaine_travail); |
|
} |
unsigned char *
|
|
purification_chaine(unsigned char *chaine)
|
|
{
|
unsigned char * |
long i;
|
purification_chaine(unsigned char *chaine) |
long j;
|
{ |
|
integer8 i; |
unsigned char *chaine_purifiee;
|
integer8 j; |
|
|
i = 0;
|
unsigned char *chaine_purifiee; |
j = strlen(chaine) - 1;
|
|
|
i = 0; |
while(chaine[i] == ' ')
|
j = ((integer8) strlen(chaine)) - 1; |
{
|
|
if ((i++) > j)
|
while(chaine[i] == ' ') |
{
|
{ |
i = j;
|
if ((i++) > j) |
break;
|
{ |
}
|
i = j; |
}
|
break; |
|
} |
if (j >= 0)
|
} |
{
|
|
while(chaine[j] == ' ')
|
if (j >= 0) |
{
|
{ |
if ((--j) < 0)
|
while(chaine[j] == ' ') |
{
|
{ |
j = 0;
|
if ((--j) < 0) |
break;
|
{ |
}
|
j = 0; |
}
|
break; |
}
|
} |
|
} |
chaine_purifiee = extraction_chaine(chaine, i + 1, j + 1);
|
} |
free(chaine);
|
|
|
chaine_purifiee = extraction_chaine(chaine, i + 1, j + 1); |
return(chaine_purifiee);
|
free(chaine); |
}
|
|
|
return(chaine_purifiee); |
|
} |
logical1
|
|
test_expression_rpn(unsigned char *chaine)
|
|
{
|
logical1 |
long j;
|
test_expression_rpn(unsigned char *chaine) |
|
{ |
unsigned char t;
|
int t; |
unsigned char t0;
|
int t0; |
unsigned char t1;
|
int t1; |
unsigned char t2;
|
int t2; |
unsigned char t3;
|
int t3; |
unsigned char t4;
|
int t4; |
|
|
unsigned long compteur;
|
integer8 compteur; |
unsigned long longueur_chaine;
|
integer8 longueur_chaine; |
unsigned long i;
|
integer8 i; |
unsigned long niveau;
|
integer8 j; |
|
integer8 niveau; |
/*
|
|
* On teste d'abord la chaîne pour vérifier qu'il n'y a pas de fonction
|
/* |
* utilisant la notation infixe.
|
* On teste d'abord la chaîne pour vérifier qu'il n'y a pas de fonction |
*/
|
* utilisant la notation infixe. |
|
*/ |
compteur = 0;
|
|
|
compteur = 0; |
for(longueur_chaine = strlen(chaine), i = 1; i < longueur_chaine; i++)
|
|
{
|
for(longueur_chaine = ((integer8) strlen(chaine)), i = 1; |
/*
|
i < longueur_chaine; i++) |
* On saute les chaînes de caractères
|
{ |
*/
|
/* |
|
* On saute les chaînes de caractères |
if (chaine[i - 1] == '"')
|
*/ |
{
|
|
i++;
|
if (chaine[i - 1] == '"') |
while(chaine[i - 1] != '"')
|
{ |
{
|
i++; |
i++;
|
while(chaine[i - 1] != '"') |
}
|
{ |
}
|
i++; |
|
} |
j = ((long) i) - 2;
|
} |
t0 = (i >= 2) ? chaine[i - 2] : '?';
|
|
t1 = chaine[i - 1];
|
j = i - 2; |
t2 = chaine[i];
|
t0 = (i >= 2) ? chaine[i - 2] : '?'; |
t3 = ((i + 1) < strlen(chaine)) ? chaine[i + 1] : '?';
|
t1 = chaine[i - 1]; |
t4 = ((i + 2) < strlen(chaine)) ? chaine[i + 2] : '?';
|
t2 = chaine[i]; |
|
t3 = ((i + 1) < ((integer8) strlen(chaine))) ? chaine[i + 1] : '?'; |
/*
|
t4 = ((i + 2) < ((integer8) strlen(chaine))) ? chaine[i + 2] : '?'; |
* Ouverture d'une parenthèse signalant une fonction
|
|
*/
|
/* |
|
* Ouverture d'une parenthèse signalant une fonction |
if ((t1 != '+') && (t1 != '-') && (t1 != '*') && (t1 != '/')
|
*/ |
&& (t1 != '\'') && (t2 == '('))
|
|
{
|
if ((t1 != '+') && (t1 != '-') && (t1 != '*') && (t1 != '/') |
niveau = 0;
|
&& (t1 != '\'') && (t2 == '(')) |
|
{ |
do
|
niveau = 0; |
{
|
|
if ((t = chaine[i++]) == '(')
|
do |
{
|
{ |
niveau++;
|
if ((t = chaine[i++]) == '(') |
}
|
{ |
else if (t == ')')
|
niveau++; |
{
|
} |
niveau--;
|
else if (t == ')') |
}
|
{ |
} while(((niveau != 0) || (t != ')')) && (i < longueur_chaine));
|
niveau--; |
|
} |
if (i < longueur_chaine)
|
} while(((niveau != 0) || (t != ')')) && (i < longueur_chaine)); |
{
|
|
t2 = chaine[i];
|
if (i < longueur_chaine) |
}
|
{ |
else
|
t2 = chaine[i]; |
{
|
} |
t2 = ' ';
|
else |
}
|
{ |
}
|
t2 = ' '; |
|
} |
/*
|
} |
* Signalement de l'une des quatre opérations et des fonctions
|
|
* infixes traditionnelles
|
/* |
*/
|
* Signalement de l'une des quatre opérations et des fonctions |
|
* infixes traditionnelles |
if ((t2 == '+') || (t2 == '-') || (t2 == '*') || (t2 == '/')
|
*/ |
|| (t2 == '^') || (t2 == '<') || (t2 == '>') || (t2 == '=')
|
|
|| ((t0 == ' ') && ((t1 == 'A') || (t1 == 'a')) &&
|
if ((t2 == '+') || (t2 == '-') || (t2 == '*') || (t2 == '/') |
((t2 == 'N') || (t2 == 'n')) && ((t3 == 'D') || (t3 == 'd'))
|
|| (t2 == '^') || (t2 == '<') || (t2 == '>') || (t2 == '=') |
&& (t4 == ' ')) ||
|
|| ((t0 == ' ') && ((t1 == 'A') || (t1 == 'a')) && |
((t0 == ' ') && ((t1 == 'O') || (t1 == 'o')) &&
|
((t2 == 'N') || (t2 == 'n')) && ((t3 == 'D') || (t3 == 'd')) |
((t2 == 'R') || (t2 == 'r')) && (t3 == ' ')) ||
|
&& (t4 == ' ')) || |
((t0 == ' ') && ((t1 == 'X') || (t1 == 'x')) &&
|
((t0 == ' ') && ((t1 == 'O') || (t1 == 'o')) && |
((t2 == 'O') || (t2 == 'o')) && ((t3 == 'R') || (t3 == 'r'))
|
((t2 == 'R') || (t2 == 'r')) && (t3 == ' ')) || |
&& (t4 == ' ')))
|
((t0 == ' ') && ((t1 == 'X') || (t1 == 'x')) && |
{
|
((t2 == 'O') || (t2 == 'o')) && ((t3 == 'R') || (t3 == 'r')) |
compteur++;
|
&& (t4 == ' '))) |
}
|
{ |
|
compteur++; |
/*
|
} |
* Signalement d'un nombre
|
|
*/
|
/* |
|
* Signalement d'un nombre |
if (((t2 == '+') || (t2 == '-')) && ((t1 == '(')
|
*/ |
|| ((t1 == 'e') || (t1 == 'E') || (t1 == '\'')))
|
|
&& (((t0 >= '0') && (t0 <= '9')) || (t0 == '.')))
|
if (((t2 == '+') || (t2 == '-')) && ((t1 == '(') |
{
|
|| ((t1 == 'e') || (t1 == 'E') || (t1 == '\''))) |
compteur--;
|
&& (((t0 >= '0') && (t0 <= '9')) || (t0 == '.'))) |
}
|
{ |
else if (((t2 == '+') || (t2 == '-')) && (t1 == '\'') && (j < 0)
|
compteur--; |
&& (((t3 >= '0') && (t3 <= '9')) || (t3 == '.')))
|
} |
{
|
else if (((t2 == '+') || (t2 == '-')) && (t1 == '\'') && (j < 0) |
compteur--;
|
&& (((t3 >= '0') && (t3 <= '9')) || (t3 == '.'))) |
}
|
{ |
}
|
compteur--; |
|
} |
return(((compteur == 0) && (test_fonction(chaine) == d_faux))
|
} |
? d_vrai : d_faux);
|
|
}
|
return(((compteur == 0) && (test_fonction(chaine) == d_faux)) |
|
? d_vrai : d_faux); |
|
} |
logical1
|
|
test_fonction(unsigned char *chaine)
|
|
{
|
logical1 |
logical1 drapeau_fonction;
|
test_fonction(unsigned char *chaine) |
|
{ |
unsigned char t;
|
logical1 drapeau_fonction; |
|
|
unsigned long compteur;
|
int t; |
unsigned long i;
|
|
unsigned long longueur_chaine;
|
integer8 compteur; |
|
integer8 i; |
longueur_chaine = strlen(chaine);
|
integer8 longueur_chaine; |
i = 1;
|
|
|
longueur_chaine = (integer8) strlen(chaine); |
while(((t = chaine[i]) != '(') && (i < (longueur_chaine - 1)))
|
i = 1; |
{
|
|
if ((t == '+') || (t == '-') || (t == '*') ||
|
while(((t = chaine[i]) != '(') && (i < (longueur_chaine - 1))) |
(t == '/') || (t == '^') || (t == '>') || (t == '<') ||
|
{ |
(t == '='))
|
if ((t == '+') || (t == '-') || (t == '*') || |
{
|
(t == '/') || (t == '^') || (t == '>') || (t == '<') || |
i = longueur_chaine - 1;
|
(t == '=')) |
}
|
{ |
else
|
i = longueur_chaine - 1; |
{
|
} |
i++;
|
else |
}
|
{ |
}
|
i++; |
|
} |
compteur = 1;
|
} |
drapeau_fonction = ((i < (longueur_chaine - 1)) && (i != 1))
|
|
? d_vrai : d_faux;
|
compteur = 1; |
|
drapeau_fonction = ((i < (longueur_chaine - 1)) && (i != 1)) |
for(i++; i < (longueur_chaine - 2); i++)
|
? d_vrai : d_faux; |
{
|
|
if ((t = chaine[i]) == '(')
|
for(i++; i < (longueur_chaine - 2); i++) |
{
|
{ |
compteur++;
|
if ((t = chaine[i]) == '(') |
}
|
{ |
else if (t == ')')
|
compteur++; |
{
|
} |
compteur--;
|
else if (t == ')') |
}
|
{ |
|
compteur--; |
if (compteur == 0)
|
} |
{
|
|
drapeau_fonction = d_faux;
|
if (compteur == 0) |
}
|
{ |
}
|
drapeau_fonction = d_faux; |
|
} |
return drapeau_fonction;
|
} |
}
|
|
|
return drapeau_fonction; |
|
} |
unsigned char *
|
|
extraction_chaine(unsigned char *chaine, unsigned long position_1,
|
|
unsigned long position_2)
|
unsigned char * |
{
|
extraction_chaine(unsigned char *chaine, integer8 position_1, |
long i;
|
integer8 position_2) |
|
{ |
unsigned char *pointeur_ecriture;
|
integer8 i; |
unsigned char *pointeur_lecture;
|
|
unsigned char *sous_chaine;
|
unsigned char *pointeur_ecriture; |
|
unsigned char *pointeur_lecture; |
if ((position_1 < 1) || (position_2 < position_1) ||
|
unsigned char *sous_chaine; |
(position_2 > strlen(chaine)))
|
|
{
|
if ((position_1 < 1) || (position_2 < position_1) || |
if ((sous_chaine = (unsigned char *) malloc(sizeof(unsigned char)))
|
(position_1 > ((integer8) strlen(chaine)))) |
== NULL)
|
{ |
{
|
if ((sous_chaine = (unsigned char *) malloc(sizeof(unsigned char))) |
return(NULL);
|
== NULL) |
}
|
{ |
|
return(NULL); |
(*sous_chaine) = d_code_fin_chaine;
|
} |
return(sous_chaine);
|
|
}
|
(*sous_chaine) = d_code_fin_chaine; |
|
return(sous_chaine); |
if ((sous_chaine = (unsigned char *)
|
} |
malloc((position_2 - position_1 + 2) * sizeof(unsigned char)))
|
|
== NULL)
|
if (position_2 > ((integer8) strlen(chaine))) |
{
|
{ |
return(NULL);
|
if ((sous_chaine = (unsigned char *) malloc(sizeof(unsigned char))) |
}
|
== NULL) |
|
{ |
pointeur_lecture = &(chaine[position_1 - 1]);
|
return(NULL); |
pointeur_ecriture = sous_chaine;
|
} |
|
|
for(sous_chaine[i = position_2 - position_1 + 1] = 0; (--i) >= 0;
|
(*sous_chaine) = d_code_fin_chaine; |
*(pointeur_ecriture++) = *(pointeur_lecture++));
|
return(sous_chaine); |
|
} |
return(sous_chaine);
|
|
}
|
if ((sous_chaine = (unsigned char *) |
|
malloc(((size_t) (position_2 - position_1 + 2)) * |
// vim: ts=4
|
sizeof(unsigned char))) == NULL) |
|
{ |
|
return(NULL); |
|
} |
|
|
|
pointeur_lecture = &(chaine[position_1 - 1]); |
|
pointeur_ecriture = sous_chaine; |
|
|
|
for(sous_chaine[i = position_2 - position_1 + 1] = 0; (--i) >= 0; |
|
*(pointeur_ecriture++) = *(pointeur_lecture++)); |
|
|
|
return(sous_chaine); |
|
} |
|
|
|
// vim: ts=4 |