1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111
| #include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <limits.h>
#include <float.h>
#include <ctype.h>
int EstDouble(char *ligne, double *val)
{
double v;
char *endptr = NULL;
v = strtod(ligne,&endptr);
/* la chaine ne contient pas que des chiffres */
if(*endptr != '\0')
{
fprintf(stderr,"le chiffre n'est pas correctement ecrit\n");
return 1;
}
/* verification si debordements */
if(v<=(-DBL_MAX) || v>=DBL_MAX)
{
fprintf(stderr,"debordement\n");
return 1;
}
/* on recupere la valeur */
*val = v;
return 0;
}
int EstVariable(char *ligne)
{
while(isalpha(*ligne))
ligne++;
if(*ligne == '\0')
return 0;
return 1;
}
int EstFonction(char *ligne, char *nom, int *nb)
{
int val;
char *blanc = NULL;
char *sep = NULL;
/*il ne doit pas y avoir d'espae entre le nom,'@' et le nombre de parametres */
blanc = strchr(ligne,' ');
if(blanc != NULL)
return 1;
/*recherche de '@' pour avoir le nom de la fonction et le nombre de parametres */
sep = strchr(ligne,'@');
if(sep == NULL)
return 1;
*sep = '\0';
/*sep pointe sur le nombre de parametre*/
sep++;
/*on verifie qu'on a un chiffre*/
if(!isdigit(*sep))
return 1;
val = atoi(sep);
if(val<=INT_MIN || val >=INT_MAX)
return 1;
*nb = val;
nom = malloc(strlen(ligne)+1);
if(nom == NULL)
return 1;
strcpy(nom,ligne);
return 0;
}
int main(int argc, char *argv[])
{
char *nom;
double val;
int nb;
int i;
for(i=1;i<argc;i++)
{
/*if(!EstDouble(argv[i],&val))
printf("%lf ",val);*/
/*if(!EstVariable(argv[i]))
printf("%s ",argv[i]);*/
if(!EstFonction(argv[i],nom,&nb))
printf("%s=%d ",nom,nb);
else
printf("erreur ");
}
printf("\n");
return 0;
} |
Partager