Salut à tous,
j'ai un projet à réaliser sur les compilateurs et pour parvenir à réaliser mon projet je dois entre autres réaliser un arbre syntaxique abstrait. Donc je bosse avec antlr4 sous java, et pas mal des tutos sur le net ne fonctionnent qu'avec les versions antérieures à antlr4 en utliisant l'option output = AST..
Le but de cet arbre est le suivant, considérons l'expression suivante : i =3*( 4+2), alors je dois générer cet arbre:
.............. i
........... / ... \
...... + .......... *
... / .... \ ....... 3
...4 .... 2
Je fais du mieux que je peux, mais c'est censé être assez clair là 
(L'arbre doit évidemment respecter les priorités d'opérations.)
Pour se faire j'utilise la grammaire suivante:
http://pastebin.com/bTF819jK
Vous constaterez que cette grammaire contient bien plus que les opérations, en réalité je suis censé récupérer une boucle dans un fichier .c et réaliser un arbre, mais avant de m'intéresser à ça je veux comprendre la base.. donc si jamais vous avez une grammaire plus simple je suis preneur.
Et voici le code test qui m'a été fourni:
http://pastebin.com/QapuBvQw
Je ne suis pas censé utiliser la sortie qui est écrit dans ce code, c'est juste censer m'aider dans la compréhension du compilateur.
J'en reviens à mon problème, je dois donc extraire les nombres et les opérateurs et les mettre dans des noeuds. Pour ça on m'a dit d'utiliser la méthode getChild(), sauf que je n'arrive pas à l'utiliser... Et quand j'applique la méthode getChildCount() j'obtiens 2, sauf que je ne pense pas avoir 2 enfants au total...
Merci à ceux qui pourront m'aider car je dois admettre que je suis un peu perdu dans tout ça..