Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in
Toggle navigation
P
Postgres FD Implementation
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Abuhujair Javed
Postgres FD Implementation
Commits
33c2da97
Commit
33c2da97
authored
Feb 12, 1998
by
Marc G. Fournier
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
From: Michael Meskes <meskes@topsystem.de>
Here's the ecpg patch for the local variables bug I reported earlier:
parent
7d55b1c7
Changes
4
Show whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
51 additions
and
19 deletions
+51
-19
src/interfaces/ecpg/TODO
src/interfaces/ecpg/TODO
+0
-3
src/interfaces/ecpg/doc/ecpg.texinfo
src/interfaces/ecpg/doc/ecpg.texinfo
+1
-1
src/interfaces/ecpg/preproc/pgc.l
src/interfaces/ecpg/preproc/pgc.l
+5
-2
src/interfaces/ecpg/preproc/preproc.y
src/interfaces/ecpg/preproc/preproc.y
+45
-13
No files found.
src/interfaces/ecpg/TODO
View file @
33c2da97
...
...
@@ -44,8 +44,5 @@ could be realised in a script.
Now comes my list (MM):
Ecpg should remove variables from its list as soon as they are undefined and
not rely on cc to report an error.
Variable definitions containing static/volatile have to be possible.
src/interfaces/ecpg/doc/ecpg.texinfo
View file @
33c2da97
...
...
@@ -356,7 +356,7 @@ you are not interested in how it really works, skip this chapter.
@comment node-name, next, previous, up
@section To do list
In the alpha version the preprocessor has a lot of
flaws:
This version the preprocessor has some
flaws:
@table @asis
@item Preprocessor output
...
...
src/interfaces/ecpg/preproc/pgc.l
View file @
33c2da97
...
...
@@ -3,7 +3,7 @@
#include "type.h"
#include "y.tab.h"
extern int debugging;
#include "extern.h"
#define dbg(arg) if (debugging) fprintf(stderr, "DEBUG, %d: %s\n", yylineno, #arg);
%}
...
...
@@ -97,6 +97,8 @@ bool { dbg(S_BOOL); return S_BOOL; }
"]" { dbg(]); return ']'; }
";" { dbg(;); return ';'; }
"," { dbg(komma); return ','; }
\{ { dbg(blockstart); return '{'; }
\} { dbg(blockend); return'}'; }
<SQL>":" { dbg(:); return ':'; }
...
...
@@ -106,6 +108,7 @@ bool { dbg(S_BOOL); return S_BOOL; }
void
lex_init(void)
{
braces_open = 0;
BEGIN C;
}
...
...
src/interfaces/ecpg/preproc/preproc.y
View file @
33c2da97
...
...
@@ -29,27 +29,24 @@ output_line_number()
/*
* Handling of the variables.
*/
/* Since we don't want to keep track of where the functions end we just
* have a list of functions that we search in, most reasently defined
* function. This won't work if we use block scope for variables with the
* same name but different types but in all other cases the c-compiler will
* signal an error (hopefully).
*
* This list is leaked on program exit. This is because I don't think it is
* important enough to spend the extra ten minutes to write the function that
* deletes it. It would be another thing if I would have written in C++.
/*
* brace level counter
*/
int braces_open;
/* This is a linked list of the variable names and types. */
struct variable
{
char * name;
struct ECPGtype * type;
int brace_level;
struct variable * next;
};
static struct variable * allvariables = NULL;
struct variable *
st
atic st
ruct variable *
find_variable(char * name)
{
struct variable * p;
...
...
@@ -71,18 +68,42 @@ find_variable(char * name)
}
void
static
void
new_variable(const char * name, struct ECPGtype * type)
{
struct variable * p = (struct variable*) malloc(sizeof(struct variable));
p->name = strdup(name);
p->type = type;
p->brace_level = braces_open;
p->next = allvariables;
allvariables = p;
}
static void
remove_variables(int brace_level)
{
struct variable * p, *prev;
for (p = prev = allvariables; p; p = p->next)
{
if (p->brace_level >= brace_level)
{
/* remove it */
if (p == allvariables)
prev = allvariables = p->next;
else
prev->next = p->next;
free(p);
p = prev;
}
else
prev = p;
}
}
/*
* Here are the variables that need to be handled on every request.
...
...
@@ -161,7 +182,7 @@ dump_variables(struct arguments * list)
%token <tagname> S_EXTERN S_STATIC
%token <tagname> S_UNSIGNED S_SIGNED
%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
%type <symbolname> symbol
...
...
@@ -184,7 +205,9 @@ statement : sqldeclaration
| sqlcommit
| sqlrollback
| sqlstatement
| cthing;
| cthing
| blockstart
| blockend;
sqldeclaration : sql_startdeclare
variable_declarations
...
...
@@ -356,6 +379,15 @@ both_anything : S_LENGTH | S_VARCHAR | S_VARCHAR2
| '[' | ']' | ','
| S_ANYTHING;
blockstart : '{' {
braces_open++;
fwrite(yytext, yyleng, 1, yyout);
}
blockend : '}' {
remove_variables(braces_open--);
fwrite(yytext, yyleng, 1, yyout);
}
%%
static void yyerror(char * error)
{
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment