Commit 74e01591 authored by Marc G. Fournier's avatar Marc G. Fournier

Update the preprocessor code

From: Michael Meskes <meskes@topsystem.de>
parent 922ea913
...@@ -8,18 +8,24 @@ Wed Feb 11 10:58:13 CET 1998 ...@@ -8,18 +8,24 @@ Wed Feb 11 10:58:13 CET 1998
Thu Feb 12 14:45:07 CET 1998 Thu Feb 12 14:45:07 CET 1998
- Changed parser to correctly handle local variables. - changed parser to correctly handle local variables.
- Allow static and extern variable definitions.
- free() variable structure completely. Thu Feb 12 15:55:37 CET 1998
- allow static and extern variable definitions.
- free() variable structure completely.
Fri Feb 13 12:35:58 CET 1998 Fri Feb 13 12:35:58 CET 1998
- ecpg can use structs to store data, but only if the complete - ecpg can use structs to store data, but only if the complete
definition of the struct lies inside the sql declare section definition of the struct lies inside the sql declare section
and only simple types used. and only simple types used.
Fre Feb 13 14:12:41 CET 1998 Fre Feb 13 14:12:41 CET 1998
- Structure now work completely. - struct definitions now work completely.
Mon Feb 16 16:17:21 CET 1998
- enable initialisation in declare section.
- connect call accepts a variable as well.
...@@ -2,16 +2,16 @@ ...@@ -2,16 +2,16 @@
SRCDIR= ../../.. SRCDIR= ../../..
include $(SRCDIR)/Makefile.global include $(SRCDIR)/Makefile.global
MAJOR_VERSION=0 MAJOR_VERSION=1
MINOR_VERSION=5 MINOR_VERSION=0
PATCHLEVEL=1 PATCHLEVEL=0
CFLAGS=-I../include -O2 -g -Wall -DMAJOR_VERSION=$(MAJOR_VERSION) -DMINOR_VERSION=$(MINOR_VERSION) -DPATCHLEVEL=$(PATCHLEVEL) CFLAGS=-I../include -O2 -g -Wall -DMAJOR_VERSION=$(MAJOR_VERSION) -DMINOR_VERSION=$(MINOR_VERSION) -DPATCHLEVEL=$(PATCHLEVEL)
all:: ecpg all:: ecpg
clean: clean:
rm -f *.o core a.out ecpg preproc.tab.h y.tab.c *~ rm -f *.o core a.out ecpg y.tab.h y.tab.c *~
install: all install: all
install -c -m 755 ecpg $(DESTDIR)$(BINDIR) install -c -m 755 ecpg $(DESTDIR)$(BINDIR)
......
...@@ -18,6 +18,7 @@ symbol {letter}({letter}|{digit})* ...@@ -18,6 +18,7 @@ symbol {letter}({letter}|{digit})*
string '[^']*' string '[^']*'
exec [eE][xX][eE][cC] exec [eE][xX][eE][cC]
execute [eE][xX][eE][cC][uU][tT][eE]
sql [sS][qQ][lL] sql [sS][qQ][lL]
varchar [vV][aA][rR][cC][hH][aA][rR] varchar [vV][aA][rR][cC][hH][aA][rR]
varchar2 [vV][aA][rR][cC][hH][aA][rR]2 varchar2 [vV][aA][rR][cC][hH][aA][rR]2
...@@ -30,18 +31,25 @@ include [iI][nN][cC][lL][uU][dD][eE] ...@@ -30,18 +31,25 @@ include [iI][nN][cC][lL][uU][dD][eE]
connect [cC][oO][nN][nN][eE][cC][tT] connect [cC][oO][nN][nN][eE][cC][tT]
open [oO][pP][eE][nN] open [oO][pP][eE][nN]
commit [cC][oO][mM][mM][iI][tT] commit [cC][oO][mM][mM][iI][tT]
immediate [iI][mM][mM][eE][dD][iI][aA][tT][eE]
release [rR][eE][lL][eE][aA][sS][eE]
rollback [rR][oO][lL][lL][bB][aA][cC][kK] rollback [rR][oO][lL][lL][bB][aA][cC][kK]
work [wW][oO][rR][kK]
%% %%
<C>{exec}{ws}{sql} { BEGIN SQL; dbg(SQL_START); return SQL_START; } <C>{exec}{ws}{sql} { BEGIN SQL; dbg(SQL_START); return SQL_START; }
<SQL>";" { BEGIN C; dbg(SQL_SEMI); return SQL_SEMI; } <SQL>";" { BEGIN C; dbg(SQL_SEMI); return SQL_SEMI; }
<SQL>{begin} { dbg(SQL_BEGIN); return SQL_BEGIN; } <SQL>{begin} { dbg(SQL_BEGIN); return SQL_BEGIN; }
<SQL>{end} { dbg(SQL_END); return SQL_END; } <SQL>{end} { dbg(SQL_END); return SQL_END; }
<SQL>{declare} { dbg(SQL_DECLARE); return SQL_DECLARE; } <SQL>{declare} { dbg(SQL_DECLARE); return SQL_DECLARE; }
<SQL>{execute} { dbg(SQL_EXECUTE); return SQL_EXECUTE; }
<SQL>{immediate} { dbg(SQL_IMMEDIATE); return SQL_IMMEDIATE; }
<SQL>{section} { dbg(SQL_SECTION); return SQL_SECTION; } <SQL>{section} { dbg(SQL_SECTION); return SQL_SECTION; }
<SQL>{include} { dbg(SQL_INCLUDE); return SQL_INCLUDE; } <SQL>{include} { dbg(SQL_INCLUDE); return SQL_INCLUDE; }
<SQL>{connect} { dbg(SQL_CONNECT); return SQL_CONNECT; } <SQL>{connect} { dbg(SQL_CONNECT); return SQL_CONNECT; }
<SQL>{open} { dbg(SQL_OPEN); return SQL_OPEN; } <SQL>{open} { dbg(SQL_OPEN); return SQL_OPEN; }
<SQL>{commit} { dbg(SQL_COMMIT); return SQL_COMMIT; } <SQL>{commit} { dbg(SQL_COMMIT); return SQL_COMMIT; }
<SQL>{release} { dbg(SQL_RELEASE); return SQL_RELEASE; }
<SQL>{work} { dbg(SQL_WORK); return SQL_WORK; }
<SQL>{rollback} { dbg(SQL_ROLLBACK); return SQL_ROLLBACK; } <SQL>{rollback} { dbg(SQL_ROLLBACK); return SQL_ROLLBACK; }
<SQL>{into} { dbg(SQL_INTO); return SQL_INTO; } <SQL>{into} { dbg(SQL_INTO); return SQL_INTO; }
...@@ -104,9 +112,11 @@ struct { dbg(S_STRUCT); return S_STRUCT; } ...@@ -104,9 +112,11 @@ struct { dbg(S_STRUCT); return S_STRUCT; }
"[" { dbg([); return '['; } "[" { dbg([); return '['; }
"]" { dbg(]); return ']'; } "]" { dbg(]); return ']'; }
";" { dbg(;); return ';'; } ";" { dbg(;); return ';'; }
"=" { dbg(=); return '='; }
"," { dbg(komma); return ','; } "," { dbg(komma); return ','; }
\{ { dbg(blockstart); return '{'; } \{ { dbg(blockstart); return '{'; }
\} { dbg(blockend); return'}'; } \} { dbg(blockend); return'}'; }
\* { dbg(*); return('*'); }
<SQL>":" { dbg(:); return ':'; } <SQL>":" { dbg(:); return ':'; }
......
...@@ -180,22 +180,22 @@ dump_variables(struct arguments * list) ...@@ -180,22 +180,22 @@ dump_variables(struct arguments * list)
%token <tagname> SQL_START SQL_SEMI SQL_STRING SQL_INTO %token <tagname> SQL_START SQL_SEMI SQL_STRING SQL_INTO
%token <tagname> SQL_BEGIN SQL_END SQL_DECLARE SQL_SECTION SQL_INCLUDE %token <tagname> SQL_BEGIN SQL_END SQL_DECLARE SQL_SECTION SQL_INCLUDE
%token <tagname> SQL_CONNECT SQL_OPEN %token <tagname> SQL_CONNECT SQL_OPEN SQL_EXECUTE SQL_IMMEDIATE
%token <tagname> SQL_COMMIT SQL_ROLLBACK %token <tagname> SQL_COMMIT SQL_ROLLBACK SQL_RELEASE SQL_WORK
%token <tagname> S_SYMBOL S_LENGTH S_ANYTHING %token <tagname> S_SYMBOL S_LENGTH S_ANYTHING
%token <tagname> S_VARCHAR S_VARCHAR2 %token <tagname> S_VARCHAR S_VARCHAR2
%token <tagname> S_EXTERN S_STATIC S_AUTO S_CONST S_REGISTER S_STRUCT %token <tagname> S_EXTERN S_STATIC S_AUTO S_CONST S_REGISTER S_STRUCT
%token <tagname> S_UNSIGNED S_SIGNED %token <tagname> S_UNSIGNED S_SIGNED
%token <tagname> S_LONG S_SHORT S_INT S_CHAR S_FLOAT S_DOUBLE S_BOOL %token <tagname> S_LONG S_SHORT S_INT S_CHAR S_FLOAT S_DOUBLE S_BOOL
%token <tagname> '[' ']' ';' ',' '{' '}' %token <tagname> '[' ']' ';' ',' '{' '}' '=' '*'
%type <type> type type_detailed varchar_type simple_type array_type struct_type %type <type> type type_detailed varchar_type simple_type array_type struct_type
%type <symbolname> symbol %type <symbolname> symbol
%type <tagname> maybe_storage_clause varchar_tag %type <tagname> maybe_storage_clause varchar_tag db_name
%type <type_enum> simple_tag %type <type_enum> simple_tag
%type <indexsize> index length %type <indexsize> index length
%type <tagname> canything sqlanything both_anything %type <tagname> canything sqlanything both_anything vartext commit_release
%% %%
...@@ -210,6 +210,7 @@ statement : sqldeclaration ...@@ -210,6 +210,7 @@ statement : sqldeclaration
| sqlopen | sqlopen
| sqlcommit | sqlcommit
| sqlrollback | sqlrollback
| sqlexecute
| sqlstatement | sqlstatement
| cthing | cthing
| blockstart | blockstart
...@@ -222,17 +223,18 @@ sqldeclaration : sql_startdeclare ...@@ -222,17 +223,18 @@ sqldeclaration : sql_startdeclare
sql_startdeclare : SQL_START SQL_BEGIN SQL_DECLARE SQL_SECTION SQL_SEMI { sql_startdeclare : SQL_START SQL_BEGIN SQL_DECLARE SQL_SECTION SQL_SEMI {
fprintf(yyout, "/* exec sql begin declare section */\n"); fprintf(yyout, "/* exec sql begin declare section */\n");
output_line_number(); output_line_number();
}; }
sql_enddeclare : SQL_START SQL_END SQL_DECLARE SQL_SECTION SQL_SEMI { sql_enddeclare : SQL_START SQL_END SQL_DECLARE SQL_SECTION SQL_SEMI {
fprintf(yyout,"/* exec sql end declare section */\n"); fprintf(yyout,"/* exec sql end declare section */\n");
output_line_number(); output_line_number();
}; }
variable_declarations : /* empty */ variable_declarations : /* empty */
| variable_declarations variable_declaration ; | variable_declarations variable_declaration;
/* Here is where we can enter support for typedef. */ /* Here is where we can enter support for typedef. */
variable_declaration : type ';' { variable_declaration : type initializer ';' {
/* don't worry about our list when we're working on a struct */ /* don't worry about our list when we're working on a struct */
if (struct_level == 0) if (struct_level == 0)
{ {
...@@ -242,6 +244,12 @@ variable_declaration : type ';' { ...@@ -242,6 +244,12 @@ variable_declaration : type ';' {
fprintf(yyout, ";"); fprintf(yyout, ";");
} }
initializer : /*empty */
| '=' {fwrite(yytext, yyleng, 1, yyout);} vartext;
vartext : both_anything {fwrite(yytext, yyleng, 1, yyout);}
| vartext both_anything {fwrite(yytext, yyleng, 1, yyout);}
symbol : S_SYMBOL { symbol : S_SYMBOL {
char * name = (char *)malloc(yyleng + 1); char * name = (char *)malloc(yyleng + 1);
...@@ -255,10 +263,14 @@ type : maybe_storage_clause type_detailed { $<type>$ = $<type>2; }; ...@@ -255,10 +263,14 @@ type : maybe_storage_clause type_detailed { $<type>$ = $<type>2; };
type_detailed : varchar_type { $<type>$ = $<type>1; } type_detailed : varchar_type { $<type>$ = $<type>1; }
| simple_type { $<type>$ = $<type>1; } | simple_type { $<type>$ = $<type>1; }
| array_type {$<type>$ = $<type>1; } | array_type {$<type>$ = $<type>1; }
| pointer_type {$<type>$ = $<type>1; }
| struct_type {$<type>$ = $<type>1; }; | struct_type {$<type>$ = $<type>1; };
varchar_type : varchar_tag symbol index { varchar_type : varchar_tag symbol index {
fprintf(yyout, "struct varchar_%s { int len; char arr[%d]; } %s", $<symbolname>2, $<indexsize>3, $<symbolname>2); if ($<indexsize>3 > 0)
fprintf(yyout, "struct varchar_%s { int len; char arr[%d]; } %s", $<symbolname>2, $<indexsize>3, $<symbolname>2);
else
fprintf(yyout, "struct varchar_%s { int len; char arr[%d]; } %s", $<symbolname>2, $<indexsize>3, $<symbolname>2);
if (struct_level == 0) if (struct_level == 0)
{ {
$<type>$.name = $<symbolname>2; $<type>$.name = $<symbolname>2;
...@@ -283,7 +295,10 @@ simple_type : simple_tag symbol { ...@@ -283,7 +295,10 @@ simple_type : simple_tag symbol {
} }
array_type : simple_tag symbol index { array_type : simple_tag symbol index {
fprintf(yyout, "%s %s [%d]", ECPGtype_name($<type_enum>1), $<symbolname>2, $<indexsize>3); if ($<indexsize>3 > 0)
fprintf(yyout, "%s %s [%d]", ECPGtype_name($<type_enum>1), $<symbolname>2, $<indexsize>3);
else
fprintf(yyout, "%s %s []", ECPGtype_name($<type_enum>1), $<symbolname>2);
if (struct_level == 0) if (struct_level == 0)
{ {
$<type>$.name = $<symbolname>2; $<type>$.name = $<symbolname>2;
...@@ -293,6 +308,17 @@ array_type : simple_tag symbol index { ...@@ -293,6 +308,17 @@ array_type : simple_tag symbol index {
ECPGmake_record_member($<symbolname>2, ECPGmake_array_type(ECPGmake_simple_type($<type_enum>1), $<indexsize>3), &(record_member_list[struct_level-1])); ECPGmake_record_member($<symbolname>2, ECPGmake_array_type(ECPGmake_simple_type($<type_enum>1), $<indexsize>3), &(record_member_list[struct_level-1]));
} }
pointer_type : simple_tag '*' symbol {
fprintf(yyout, "%s * %s", ECPGtype_name($<type_enum>1), $<symbolname>3);
if (struct_level == 0)
{
$<type>$.name = $<symbolname>3;
$<type>$.typ = ECPGmake_array_type(ECPGmake_simple_type($<type_enum>1), 0);
}
else
ECPGmake_record_member($<symbolname>3, ECPGmake_array_type(ECPGmake_simple_type($<type_enum>1), 0), &(record_member_list[struct_level-1]));
}
s_struct : S_STRUCT symbol { s_struct : S_STRUCT symbol {
struct_level++; struct_level++;
fprintf(yyout, "struct %s {", $<symbolname>2); fprintf(yyout, "struct %s {", $<symbolname>2);
...@@ -330,9 +356,8 @@ maybe_storage_clause : S_EXTERN { fwrite(yytext, yyleng, 1, yyout); } ...@@ -330,9 +356,8 @@ maybe_storage_clause : S_EXTERN { fwrite(yytext, yyleng, 1, yyout); }
| S_AUTO { fwrite(yytext, yyleng, 1, yyout); } | S_AUTO { fwrite(yytext, yyleng, 1, yyout); }
| /* empty */ { }; | /* empty */ { };
index : '[' length ']' { index : '[' length ']' { $<indexsize>$ = $<indexsize>2; }
$<indexsize>$ = $<indexsize>2; | '[' ']' { $<indexsize>$ = 0; }
};
length : S_LENGTH { $<indexsize>$ = atoi(yytext); } length : S_LENGTH { $<indexsize>$ = atoi(yytext); }
...@@ -342,9 +367,24 @@ sqlinclude : SQL_START SQL_INCLUDE { fprintf(yyout, "#include \""); } ...@@ -342,9 +367,24 @@ sqlinclude : SQL_START SQL_INCLUDE { fprintf(yyout, "#include \""); }
filename : cthing filename : cthing
| filename cthing; | filename cthing;
sqlconnect : SQL_START SQL_CONNECT { fprintf(yyout, "ECPGconnect(\""); } sqlconnect : SQL_START SQL_CONNECT { fprintf(yyout, "ECPGconnect("); }
SQL_STRING { fwrite(yytext + 1, yyleng - 2, 1, yyout); } db_name
SQL_SEMI { fprintf(yyout, "\");"); output_line_number(); }; SQL_SEMI { fprintf(yyout, ");"); output_line_number();}
db_name : SQL_STRING { fprintf(yyout, "\""); fwrite(yytext + 1, yyleng - 2, 1, yyout); fprintf(yyout, "\""); }
| ':' symbol { /* check if we have a char variabnle */
struct variable *p = find_variable($<symbolname>2);
enum ECPGttype typ = p->type->typ;
/* if array see what's inside */
if (typ == ECPGt_array)
typ = p->type->u.element->typ;
if (typ != ECPGt_char && typ != ECPGt_unsigned_char)
yyerror("invalid datatype");
fprintf(yyout, "%s", $<symbolname>2);
}
/* Open is an open cursor. Removed. */ /* Open is an open cursor. Removed. */
sqlopen : SQL_START SQL_OPEN sqlgarbage SQL_SEMI { output_line_number(); }; sqlopen : SQL_START SQL_OPEN sqlgarbage SQL_SEMI { output_line_number(); };
...@@ -353,21 +393,37 @@ sqlgarbage : /* Empty */ ...@@ -353,21 +393,37 @@ sqlgarbage : /* Empty */
| sqlgarbage sqlanything; | sqlgarbage sqlanything;
sqlcommit : SQL_START SQL_COMMIT SQL_SEMI { sqlcommit : SQL_START commit_release SQL_SEMI {
fprintf(yyout, "ECPGcommit(__LINE__);"); fprintf(yyout, "ECPGcommit(__LINE__);");
output_line_number(); output_line_number();
}; }
commit_release : SQL_COMMIT
| SQL_COMMIT SQL_RELEASE
| SQL_COMMIT SQL_WORK SQL_RELEASE;
sqlrollback : SQL_START SQL_ROLLBACK SQL_SEMI { sqlrollback : SQL_START SQL_ROLLBACK SQL_SEMI {
fprintf(yyout, "ECPGrollback(__LINE__);"); fprintf(yyout, "ECPGrollback(__LINE__);");
output_line_number(); output_line_number();
}; };
sqlexecute : SQL_START { /* Reset stack */
reset_variables();
fprintf(yyout, "ECPGdo(__LINE__, \"");
} SQL_EXECUTE SQL_IMMEDIATE sqlstatement_words SQL_SEMI {
/* Dump */
fprintf(yyout, "\", ");
dump_variables(argsinsert);
fprintf(yyout, "ECPGt_EOIT, ");
dump_variables(argsresult);
fprintf(yyout, "ECPGt_EORT );");
output_line_number();
};
sqlstatement : SQL_START { /* Reset stack */ sqlstatement : SQL_START { /* Reset stack */
reset_variables(); reset_variables();
fprintf(yyout, "ECPGdo(__LINE__, \""); fprintf(yyout, "ECPGdo(__LINE__, \"");
} } sqlstatement_words SQL_SEMI {
sqlstatement_words
SQL_SEMI {
/* Dump */ /* Dump */
fprintf(yyout, "\", "); fprintf(yyout, "\", ");
dump_variables(argsinsert); dump_variables(argsinsert);
...@@ -416,7 +472,7 @@ canything : both_anything ...@@ -416,7 +472,7 @@ canything : both_anything
sqlanything : both_anything; sqlanything : both_anything;
both_anything : S_LENGTH | S_VARCHAR | S_VARCHAR2 both_anything : S_LENGTH | S_VARCHAR | S_VARCHAR2
| S_LONG | S_SHORT | S_INT | S_CHAR | S_FLOAT | S_DOUBLE | S_BOOL | S_LONG | S_SHORT | S_INT | S_CHAR | S_FLOAT | S_DOUBLE | S_BOOL
| SQL_OPEN | SQL_CONNECT | SQL_OPEN | SQL_CONNECT
| SQL_STRING | SQL_STRING
| SQL_BEGIN | SQL_END | SQL_BEGIN | SQL_END
...@@ -424,7 +480,7 @@ both_anything : S_LENGTH | S_VARCHAR | S_VARCHAR2 ...@@ -424,7 +480,7 @@ both_anything : S_LENGTH | S_VARCHAR | S_VARCHAR2
| SQL_INCLUDE | SQL_INCLUDE
| S_SYMBOL | S_SYMBOL
| S_STATIC | S_EXTERN | S_AUTO | S_CONST | S_REGISTER | S_STRUCT | S_STATIC | S_EXTERN | S_AUTO | S_CONST | S_REGISTER | S_STRUCT
| '[' | ']' | ',' | '[' | ']' | ',' | '=' | '*'
| S_ANYTHING; | S_ANYTHING;
blockstart : '{' { blockstart : '{' {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment