Ce projet a pour but la création d'un compilateur et d'une machine virtuelle pour le langage CPYRR, un langage procédural à structure de blocs.
Une première phase de compilation va permettre la construction de tables et d'un arbre binaire tout en effectuant une analyse lexicale, synthaxique et sémantique.
Ces tables et cet arbre seront ensuite stockés dans un fichier : c'est le texte intermédiaire
L'interpreteur est chargé d'executer le programme après récupération des tables et de l'arbre dans le texte intermédiaire. L'exécution se fait par un parcours de l'arbre, chaque noeud parcouru est analysé et une pile d'exécution est générée pour stocker les données.
make
./compilateur.exe -r fichier
./compilateur.exe -h
./interpreteur.exe -h
PROG
var a : float;
var b : float;
DEBUT
a := 1;
b := 1,2;
ecrit ("Le resultat de \f + \f caste en entier est \d", a, b, a + b);
FIN
./compilateur.exe -r ./exemples/representatifs/r-5.txt
Debut de la compilation
Compilation terminee
Debut de l'interpretation
Le resultat de 1.000000 + 1.200000 caste en entier est 2
Interpretation terminee
PROG
var entier : int;
fonction demande_entier() retourne int
var a : int;
DEBUT
ecrit("Saisissez un entier: ");
lire(a);
retourne a;
FIN;
DEBUT
entier := demande_entier();
ecrit("Affichage de l'entier: \d", entier);
FIN
./compilateur.exe -r ./exemples/representatifs/r-14.txt
Debut de la compilation
Compilation terminee
Debut de l'interpretation
Saisissez un entier: 4
Affichage de l'entier: 4
Interpretation terminee
Votre navigateur ne supporte pas la lecture de PDFs: Télécharger la présentation.