IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Générateurs de compilateur Discussion :

[Lex & Yacc] Gestion des ensembles d'entiers


Sujet :

Générateurs de compilateur

  1. #1
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    189
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 189
    Points : 60
    Points
    60
    Par défaut [Lex & Yacc] Gestion des ensembles d'entiers
    Bonjour, j'aimerais faire un analyseur syntaxique qui gère les ensembles d'entiers. Un identificateur est composé d'une seule lettre et pour gérer les identificateurs et les associer à leur valeur, j'utilise un tableau : tab[0] correspond a l'identificateur a ou A, tab[1] correspond a l'identificateur b ou B et ainsi de suite. J'ai déja bien avancé mais j'ai des erreurs pas très normales. Par exemple, lorsque je tappe a:={3} donc pour définir l'emsemble "a" et que ensuite je veux afficher la valeur de a (pas de tab[a]) il m'affiche 3. alors que normalement a devrait être égal à 0. J'ai l'impression que les valeurs des ensembles interagissent avec les indices de mon tableau. Je vous laisse le code. SI vous avez un petite idée on sait jamais.

    mon .y :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    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
    112
    113
    114
    115
    116
    117
    118
    119
    120
    121
    122
    123
    124
    125
    126
    127
    128
    129
    130
    131
    132
    133
    134
    %{
    #include <stdio.h>
    long tab[26] ;
     
     
     
    %}
     
     
     
    %token UNION
    %token INTER
    %token DIFF
    %token COMP
    %token ident
    %token elem
     
    %token AFFECT
    %token DEBUT_E
    %token FIN_E
    %token SEP
     
    %start liste
    %right ':='
    %left COMP
     
    %%
     
    liste		:								{;}
    		| liste instruction '\n'					{;}		
    		;
     
    instruction	: ident AFFECT expression					{tab[$1] = tab[$1]|$3; }
    	 	| ident								{affiche(tab[$1]);}
    		;
     
     
    expression	: operande							{$$=$1;}
    		| operande UNION operande					{$$ = $1 | $2; }
    		| operande INTER  						{$$ = $1 & $2 ; }
    		| operande DIFF operande					{$$ = $1 & ~$2;}
    		| COMP operande							{$$ = ~$1 ;}
    		;
     
     
    operande	: ident								{$$=tab[$1]; }
    		| ensemble							{$$=$1;}
    		;
     
    ensemble	: DEBUT_E FIN_E							{;}
    		| DEBUT_E liste_element FIN_E					{$$=$2;}
    		;
     
    liste_element	: elem								{$$=p($1);}
    		| elem SEP liste_element					{$$=p($1)| $3;}
    		;
     
     
    %%
     
    long puiss(long n)
    {
    	long res = 1 ;
    	int k ;
    	for (k=0 ; k<n ; k++)
    	res = res * 2 ;
     
    	return res ;
     
     
    }
     
     
    int yyerror(char *s)
    {
    	printf("%s\n",s);
    }
     
    int p(int p)
    {
     
     
    	return 1<<(p-1);
     
    }
     
     
    void affiche(long n)
    {
     
     
    	int i ;
    	int virgule=0 ;
    	printf("{") ;	
     
    	for(i=0; i<32 ; i++)
    	{
    		long et = n&puiss(i) ;
    		if (et != 0)
    		{
    			if (virgule==0)
    			{
    				printf("%d", i+1) ; 
    				virgule = 1 ;
    			}	
    			else
    			printf(",%d", i+1) ;
    		}
     
     
    	}
     
    	printf("}\n") ;
     
    }
     
    int main()
    {
    	int k ;
    	for(k=0 ; k<26 ; k++)
    	tab[k]=0 ;	
     
    	yyparse() ;
    	//affiche(p(23)) ;
     
    }
     
    void afficheTab()
    {
    	int k ;
     
    	for(k=0 ; k<32 ; k++)
    	affiche(tab[k]) ;
    }
    et mon .l
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    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
     
    %{
    	#include <stdio.h>
    	#include "y.tab.h"
    	extern int yylval;
    %}
     
    %%
    [a-zA-Z]			{	if(yytext[0]>'a' && yytext[0]<'z')
    					yylval=yytext[0] -'a' ; 
    					if(yytext[0]>'A' && yytext[0]<'Z')
    					yylval=yytext[0] - 'A' ;
     
    					return ident;
    				}
     
    [0-9]				{yylval=atol(yytext); return elem;}
    "UNION" | "union"		{return UNION;}
    "INTER" | "inter"		{return INTER;}
    "DIFF" | "diff"			{return DIFF;}
    "COMP" | "comp"			{return COMP;}
    ":=" 				{return AFFECT;}
    "{"				{return DEBUT_E;}
    "}"				{return FIN_E;}
    "," 				{return SEP;}
    "\n"				{return *yytext;} 
     
    %%

  2. #2
    Rédacteur/Modérateur
    Avatar de Trap D
    Profil pro
    Inscrit en
    Septembre 2003
    Messages
    4 942
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Septembre 2003
    Messages : 4 942
    Points : 6 498
    Points
    6 498
    Par défaut
    Ce n'est pas un problème de C mais je pense un problème de définition de grammare pour Yacc/Lex. Ta question a plus lieu d'être dans le forum Algo ou peut-être "Autre Langages"
    "La haine seule fait des choix" - Koan Zen
    "Il ne faut pas être meilleur que les autres, il faut être meilleur que soi." Albert Jacquard
    "Ceux qui savent où ils ont posé leur parapluie ne sont pas alcooliques." - pgibonne.
    Faites du Prolog, ça vous changera les idées !
    Ma page Prolog
    Mes codes sources commentés

    Mon avatar : La Madeleine à la veilleuse de Georges de La Tour

  3. #3
    Rédacteur
    Avatar de Franck.H
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Janvier 2004
    Messages
    6 951
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Haut Rhin (Alsace)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Service public

    Informations forums :
    Inscription : Janvier 2004
    Messages : 6 951
    Points : 12 462
    Points
    12 462
    Par défaut
    Dit innosang, est-ce que tu as de bons cours et/ou tutorials sur lex et yacc ou voir même flex et bison ? J'en cherche depuis long sans trouver quelque chose de correcte !
    Mon Site
    Ma bibliothèque de gestion des chaînes de caractères en C

    L'imagination est plus importante que le savoir. A. Einstein

    Je ne répond à aucune question technique par MP, merci d'avance !

  4. #4
    Expert éminent sénior
    Avatar de Médinoc
    Homme Profil pro
    Développeur informatique
    Inscrit en
    Septembre 2005
    Messages
    27 369
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 40
    Localisation : France

    Informations professionnelles :
    Activité : Développeur informatique
    Secteur : High Tech - Éditeur de logiciels

    Informations forums :
    Inscription : Septembre 2005
    Messages : 27 369
    Points : 41 519
    Points
    41 519
    Par défaut
    Déjà, tu devrais définir le type de tous des non-terminaux: Tu va avoir besoin d'un type "groupe d'entiers" Et là, je ne vois ni bloc %union, ni types de token, ni directives %type...
    SVP, pas de questions techniques par MP. Surtout si je ne vous ai jamais parlé avant.

    "Aw, come on, who would be so stupid as to insert a cast to make an error go away without actually fixing the error?"
    Apparently everyone.
    -- Raymond Chen.
    Traduction obligatoire: "Oh, voyons, qui serait assez stupide pour mettre un cast pour faire disparaitre un message d'erreur sans vraiment corriger l'erreur?" - Apparemment, tout le monde. -- Raymond Chen.

  5. #5
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    92
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Janvier 2004
    Messages : 92
    Points : 101
    Points
    101
    Par défaut
    Citation Envoyé par CSoldier
    Dit innosang, est-ce que tu as de bons cours et/ou tutorials sur lex et yacc ou voir même flex et bison ? J'en cherche depuis long sans trouver quelque chose de correcte !
    http://www.google.fr/search?q=tutorial+lex+yacc&start=0&start=0&ie=utf-8&oe=utf-8&client=firefox-a&rls=org.mozilla:fr:official

    ==> premier lien : http://epaperpress.com/lexandyacc/ j'ai lu celui là et je l'ai trouvé très bien pour commencer!

  6. #6
    Membre du Club
    Profil pro
    Inscrit en
    Avril 2004
    Messages
    189
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Avril 2004
    Messages : 189
    Points : 60
    Points
    60
    Par défaut
    Citation Envoyé par Médinoc
    Déjà, tu devrais définir le type de tous des non-terminaux: Tu va avoir besoin d'un type "groupe d'entiers" Et là, je ne vois ni bloc %union, ni types de token, ni directives %type...
    en fait nos listes d'entiers sont des long .. c'est a dire que si la liste vaut 00..101 ça signifie qu'il y a le 1 et le 3 dans la liste.

  7. #7
    Rédacteur
    Avatar de Franck.H
    Homme Profil pro
    Développeur .NET
    Inscrit en
    Janvier 2004
    Messages
    6 951
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 46
    Localisation : France, Haut Rhin (Alsace)

    Informations professionnelles :
    Activité : Développeur .NET
    Secteur : Service public

    Informations forums :
    Inscription : Janvier 2004
    Messages : 6 951
    Points : 12 462
    Points
    12 462
    Par défaut
    Citation Envoyé par @drien
    Citation Envoyé par CSoldier
    Dit innosang, est-ce que tu as de bons cours et/ou tutorials sur lex et yacc ou voir même flex et bison ? J'en cherche depuis long sans trouver quelque chose de correcte !
    http://www.google.fr/search?q=tutorial+lex+yacc&start=0&start=0&ie=utf-8&oe=utf-8&client=firefox-a&rls=org.mozilla:fr:official

    ==> premier lien : http://epaperpress.com/lexandyacc/ j'ai lu celui là et je l'ai trouvé très bien pour commencer!
    Merci
    Mon Site
    Ma bibliothèque de gestion des chaînes de caractères en C

    L'imagination est plus importante que le savoir. A. Einstein

    Je ne répond à aucune question technique par MP, merci d'avance !

  8. #8
    Membre régulier
    Profil pro
    Inscrit en
    Janvier 2004
    Messages
    92
    Détails du profil
    Informations personnelles :
    Âge : 36
    Localisation : France, Paris (Île de France)

    Informations forums :
    Inscription : Janvier 2004
    Messages : 92
    Points : 101
    Points
    101
    Par défaut
    de rien, je me rappelais ustement du mot clé pour le trouver, c'est cool, il y a même un petit exemple gèrant quelques mots clés et les expressions

Discussions similaires

  1. Réponses: 3
    Dernier message: 12/08/2007, 16h49
  2. makefile pour des fichiers lex et yacc
    Par samarensi dans le forum Linux
    Réponses: 1
    Dernier message: 25/12/2006, 09h27
  3. Problème sur la gestion des ensembles
    Par stardeus dans le forum Langage
    Réponses: 4
    Dernier message: 19/11/2006, 10h56
  4. [MCD] Gestion d'une nomenclature et des ensembles
    Par Corben dans le forum Schéma
    Réponses: 6
    Dernier message: 06/10/2006, 18h04

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo