Fin TP1
This commit is contained in:
parent
64dad0dfef
commit
62ec7ad082
12 changed files with 3589 additions and 0 deletions
BIN
Analyse_Lexicale/a.out
Executable file
BIN
Analyse_Lexicale/a.out
Executable file
Binary file not shown.
38
Analyse_Lexicale/al.lex
Normal file
38
Analyse_Lexicale/al.lex
Normal file
|
@ -0,0 +1,38 @@
|
||||||
|
%{
|
||||||
|
#include "as.tab.h"
|
||||||
|
#include <stdio.h>
|
||||||
|
%}
|
||||||
|
|
||||||
|
%%
|
||||||
|
|
||||||
|
"main" { printf("tMAIN\n");}
|
||||||
|
"{" { printf("tOBRACKET\n"); }
|
||||||
|
"}" { printf("tCBRACKET\n"); }
|
||||||
|
"(" { printf("tOBRACE\n"); }
|
||||||
|
")" { printf("tCBRACE\n"); }
|
||||||
|
"const" { printf("tCONST\n"); }
|
||||||
|
"int" { printf("tINT\n"); }
|
||||||
|
"printf" { printf("tPRINTF\n"); } //Degeu mais à degager
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
[0-9]+ { printf("tNB\n"); }
|
||||||
|
[0-9]+e[0-9]+ { printf("tNBEXP\n"); } //Renvoyer le token tNB et pas tNBEXP
|
||||||
|
"+" { printf("tADD\n"); }
|
||||||
|
"-" { printf("tSUB\n"); }
|
||||||
|
"*" { printf("tMUL\n"); }
|
||||||
|
"/" { printf("tDIV\n"); }
|
||||||
|
"=" { printf("tEQ\n"); }
|
||||||
|
";" { printf("tPV\n"); }
|
||||||
|
" " { printf("tSPACE\n"); } //Ne pas les retourner à Yacc
|
||||||
|
" " { printf("tTAB\n"); } //Ne pas les retourner à Yacc
|
||||||
|
"," { printf("tCOMA\n"); }
|
||||||
|
"\n" { printf("tRC\n") ; } //Ne pas les retourner à Yacc
|
||||||
|
[a-zA-Z][a-zA-Z0-9_]* { printf("tID\n"); }
|
||||||
|
. { return tERROR; }
|
||||||
|
|
||||||
|
%%
|
||||||
|
|
||||||
|
|
||||||
|
int yywrap(void){return 1;}
|
1479
Analyse_Lexicale/as.tab.c
Normal file
1479
Analyse_Lexicale/as.tab.c
Normal file
File diff suppressed because it is too large
Load diff
81
Analyse_Lexicale/as.tab.h
Normal file
81
Analyse_Lexicale/as.tab.h
Normal file
|
@ -0,0 +1,81 @@
|
||||||
|
/* A Bison parser, made by GNU Bison 3.0.4. */
|
||||||
|
|
||||||
|
/* Bison interface for Yacc-like parsers in C
|
||||||
|
|
||||||
|
Copyright (C) 1984, 1989-1990, 2000-2015 Free Software Foundation, Inc.
|
||||||
|
|
||||||
|
This program is free software: you can redistribute it and/or modify
|
||||||
|
it under the terms of the GNU General Public License as published by
|
||||||
|
the Free Software Foundation, either version 3 of the License, or
|
||||||
|
(at your option) any later version.
|
||||||
|
|
||||||
|
This program is distributed in the hope that it will be useful,
|
||||||
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
GNU General Public License for more details.
|
||||||
|
|
||||||
|
You should have received a copy of the GNU General Public License
|
||||||
|
along with this program. If not, see <http://www.gnu.org/licenses/>. */
|
||||||
|
|
||||||
|
/* As a special exception, you may create a larger work that contains
|
||||||
|
part or all of the Bison parser skeleton and distribute that work
|
||||||
|
under terms of your choice, so long as that work isn't itself a
|
||||||
|
parser generator using the skeleton or a modified version thereof
|
||||||
|
as a parser skeleton. Alternatively, if you modify or redistribute
|
||||||
|
the parser skeleton itself, you may (at your option) remove this
|
||||||
|
special exception, which will cause the skeleton and the resulting
|
||||||
|
Bison output files to be licensed under the GNU General Public
|
||||||
|
License without this special exception.
|
||||||
|
|
||||||
|
This special exception was added by the Free Software Foundation in
|
||||||
|
version 2.2 of Bison. */
|
||||||
|
|
||||||
|
#ifndef YY_YY_AS_TAB_H_INCLUDED
|
||||||
|
# define YY_YY_AS_TAB_H_INCLUDED
|
||||||
|
/* Debug traces. */
|
||||||
|
#ifndef YYDEBUG
|
||||||
|
# define YYDEBUG 0
|
||||||
|
#endif
|
||||||
|
#if YYDEBUG
|
||||||
|
extern int yydebug;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Token type. */
|
||||||
|
#ifndef YYTOKENTYPE
|
||||||
|
# define YYTOKENTYPE
|
||||||
|
enum yytokentype
|
||||||
|
{
|
||||||
|
tNB = 258,
|
||||||
|
tADD = 259,
|
||||||
|
tSUB = 260,
|
||||||
|
tOB = 261,
|
||||||
|
tCB = 262,
|
||||||
|
tPV = 263,
|
||||||
|
tERROR = 264,
|
||||||
|
tMAIN = 265
|
||||||
|
};
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/* Value type. */
|
||||||
|
#if ! defined YYSTYPE && ! defined YYSTYPE_IS_DECLARED
|
||||||
|
|
||||||
|
union YYSTYPE
|
||||||
|
{
|
||||||
|
#line 1 "as.y" /* yacc.c:1909 */
|
||||||
|
|
||||||
|
int nombre;
|
||||||
|
|
||||||
|
#line 69 "as.tab.h" /* yacc.c:1909 */
|
||||||
|
};
|
||||||
|
|
||||||
|
typedef union YYSTYPE YYSTYPE;
|
||||||
|
# define YYSTYPE_IS_TRIVIAL 1
|
||||||
|
# define YYSTYPE_IS_DECLARED 1
|
||||||
|
#endif
|
||||||
|
|
||||||
|
|
||||||
|
extern YYSTYPE yylval;
|
||||||
|
|
||||||
|
int yyparse (void);
|
||||||
|
|
||||||
|
#endif /* !YY_YY_AS_TAB_H_INCLUDED */
|
44
Analyse_Lexicale/as.y
Normal file
44
Analyse_Lexicale/as.y
Normal file
|
@ -0,0 +1,44 @@
|
||||||
|
%union {
|
||||||
|
int nombre;
|
||||||
|
}
|
||||||
|
|
||||||
|
%token tMAIN
|
||||||
|
%token tOBRACKET tCBRACKET
|
||||||
|
%token tOBRACE tCBRACE
|
||||||
|
%token tINT
|
||||||
|
%token tCONST
|
||||||
|
%token tPV tCOMA
|
||||||
|
%token tMUL tDIV tADD tSUB tEQ
|
||||||
|
%token<nombre> tNB tNBEXP
|
||||||
|
%token tPRINTF
|
||||||
|
%token tERROR
|
||||||
|
|
||||||
|
//%type<nombre> E
|
||||||
|
|
||||||
|
/* 1 + 2 + 3 + 4 */
|
||||||
|
|
||||||
|
/* E => E + E => 1 + E => 1 + E + E ... */
|
||||||
|
/* E => E + E => E + 4 => E + E + 4 ... */
|
||||||
|
|
||||||
|
%%
|
||||||
|
|
||||||
|
/* S -> E ; S
|
||||||
|
* S ->
|
||||||
|
*/
|
||||||
|
S : E tPV
|
||||||
|
{ printf("RES: %d\n", $1); }
|
||||||
|
S
|
||||||
|
| { printf("END\n"); }
|
||||||
|
;
|
||||||
|
|
||||||
|
E : E tADD E { $$ = $1 + $3; }
|
||||||
|
| E tSUB E { $$ = $1 - $3; }
|
||||||
|
| tOB E tCB { $$ = $2; }
|
||||||
|
| tNB { $$ = $1; }
|
||||||
|
;
|
||||||
|
|
||||||
|
%%
|
||||||
|
|
||||||
|
void main(void) {
|
||||||
|
yyparse();
|
||||||
|
}
|
5
Analyse_Lexicale/comp.sh
Executable file
5
Analyse_Lexicale/comp.sh
Executable file
|
@ -0,0 +1,5 @@
|
||||||
|
bison -d as.y
|
||||||
|
flex al.lex
|
||||||
|
gcc *.c -ly
|
||||||
|
cat progC | ./a.out
|
||||||
|
|
52
Analyse_Lexicale/grammaire_c_minimaliste
Normal file
52
Analyse_Lexicale/grammaire_c_minimaliste
Normal file
|
@ -0,0 +1,52 @@
|
||||||
|
les fonctions (avec parametres)
|
||||||
|
le if
|
||||||
|
le while
|
||||||
|
les declarations
|
||||||
|
les affectations
|
||||||
|
les operations arith.
|
||||||
|
le retour de fonction
|
||||||
|
l'invocation de fonctions
|
||||||
|
|
||||||
|
|
||||||
|
C : Fonctions ;
|
||||||
|
Fonctions : Fonction Fonctions | Fonction ;
|
||||||
|
|
||||||
|
Fonction : tInt tID tPO Params tPF Body ;
|
||||||
|
|
||||||
|
Params : | Param SuiteParams ;
|
||||||
|
Param : tInt tID ;
|
||||||
|
|
||||||
|
SuiteParams : tVirgule Param SuiteParams | ;
|
||||||
|
|
||||||
|
// Ps : P Ps | ;
|
||||||
|
// P : tInt tID tVirgule
|
||||||
|
// Ps =>* tInt tID tVirgule tInt tID tVirgule
|
||||||
|
// Ps => P Ps => P P Ps ...
|
||||||
|
|
||||||
|
Body : tAO Instructions tAF ;
|
||||||
|
|
||||||
|
Instructions : Instruction Instructions | ;
|
||||||
|
|
||||||
|
Instruction : Aff | If | While | Return | Decl | Invocation tPV ;
|
||||||
|
|
||||||
|
Aff : tID tEQ E tPV ;
|
||||||
|
|
||||||
|
E : tNB | tID | E tADD E | E tMUL E | E tMINUS E | E tDIV E | Invocation | tPO E tPF | tMINUS E ;
|
||||||
|
|
||||||
|
// E : tID tADD tID | ...
|
||||||
|
|
||||||
|
If : tIF tPO Cond tPF Body ;
|
||||||
|
|
||||||
|
Cond : Cond tAND Cond | Cond tOR Cond | E tEQ2 E | E tINF E | tNOT Cond ;
|
||||||
|
|
||||||
|
Invocation : tID tPO Args tPF ;
|
||||||
|
|
||||||
|
Args : .... cf params
|
||||||
|
|
||||||
|
Return : tRET E tPV ;
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
1876
Analyse_Lexicale/lex.yy.c
Normal file
1876
Analyse_Lexicale/lex.yy.c
Normal file
File diff suppressed because it is too large
Load diff
7
Analyse_Lexicale/progC
Normal file
7
Analyse_Lexicale/progC
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
int main(int x, int i){
|
||||||
|
int azertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbn; printf("%d\n", azertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbn);
|
||||||
|
int y = 2;
|
||||||
|
int res_2 = x + y;
|
||||||
|
}
|
7
Analyse_Lexicale/progC.c
Normal file
7
Analyse_Lexicale/progC.c
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
#include <stdio.h>
|
||||||
|
|
||||||
|
int main(int x, int i){
|
||||||
|
int azertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbn; printf("%d\n", azertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbnazertyuiopqsdfghjklmwxcvbn);
|
||||||
|
int y = 2;
|
||||||
|
int res_2 = x + y;
|
||||||
|
}
|
BIN
Analyse_Lexicale/test
Executable file
BIN
Analyse_Lexicale/test
Executable file
Binary file not shown.
0
Analyse_Lexicale/truc
Normal file
0
Analyse_Lexicale/truc
Normal file
Loading…
Reference in a new issue