Commit 580d2bc6 authored by Bruce Momjian's avatar Bruce Momjian

Syslog Facility Patch

Here is one with a stray character removed.

Larry Rosenman
parent d8071295
...@@ -4,7 +4,7 @@ ...@@ -4,7 +4,7 @@
* *
* Copyright 2000 by PostgreSQL Global Development Group * Copyright 2000 by PostgreSQL Global Development Group
* *
* $Header: /cvsroot/pgsql/src/backend/utils/misc/guc-file.l,v 1.4 2000/07/27 19:49:18 momjian Exp $ * $Header: /cvsroot/pgsql/src/backend/utils/misc/guc-file.l,v 1.5 2000/11/16 05:50:01 momjian Exp $
*/ */
%{ %{
...@@ -16,6 +16,7 @@ ...@@ -16,6 +16,7 @@
#include <sys/stat.h> #include <sys/stat.h>
#include <unistd.h> #include <unistd.h>
#include <errno.h> #include <errno.h>
#include <ctype.h>
#include "miscadmin.h" #include "miscadmin.h"
#include "storage/fd.h" #include "storage/fd.h"
...@@ -32,6 +33,7 @@ enum { ...@@ -32,6 +33,7 @@ enum {
GUC_INTEGER = 3, GUC_INTEGER = 3,
GUC_REAL = 4, GUC_REAL = 4,
GUC_EQUALS = 5, GUC_EQUALS = 5,
GUC_UNQUOTED_STRING = 6,
GUC_EOL = 99, GUC_EOL = 99,
GUC_ERROR = 100 GUC_ERROR = 100
}; };
...@@ -45,7 +47,7 @@ enum { ...@@ -45,7 +47,7 @@ enum {
/* prototype, so compiler is happy with our high warnings setting */ /* prototype, so compiler is happy with our high warnings setting */
int GUC_yylex(void); int GUC_yylex(void);
char *GUC_scanstr(char *);
%} %}
SIGN ("-"|"+") SIGN ("-"|"+")
...@@ -61,16 +63,9 @@ LETTER [A-Za-z_\200-\377] ...@@ -61,16 +63,9 @@ LETTER [A-Za-z_\200-\377]
LETTER_OR_DIGIT [A-Za-z_0-9\200-\377] LETTER_OR_DIGIT [A-Za-z_0-9\200-\377]
ID {LETTER}{LETTER_OR_DIGIT}* ID {LETTER}{LETTER_OR_DIGIT}*
/*
* FIXME: This string syntax is nice and all but of course the quotes UNQUOTED_STRING {LETTER}({LETTER_OR_DIGIT}|[-._:/])*
* need to be stripped before we can make any use of the string value. STRING \'([^'"\n]|\\.)*\'
* There is a function in parser/scansup.c that does this but it uses
* palloc and there might be a little more magic needed to get it to
* work right. Now there are no string options, and if there were then
* the unquoted (`ID') tokens should still work. Of course this only
* affects the configuration file.
*/
STRING \'([^'\n]|\\.)*'
%% %%
...@@ -80,6 +75,7 @@ STRING \'([^'\n]|\\.)*' ...@@ -80,6 +75,7 @@ STRING \'([^'\n]|\\.)*'
{ID} return GUC_ID; {ID} return GUC_ID;
{STRING} return GUC_STRING; {STRING} return GUC_STRING;
{UNQUOTED_STRING} return GUC_UNQUOTED_STRING;
{INTEGER} return GUC_INTEGER; {INTEGER} return GUC_INTEGER;
{REAL} return GUC_REAL; {REAL} return GUC_REAL;
= return GUC_EQUALS; = return GUC_EQUALS;
...@@ -139,7 +135,8 @@ ProcessConfigFile(GucContext context) ...@@ -139,7 +135,8 @@ ProcessConfigFile(GucContext context)
int elevel; int elevel;
FILE * fp; FILE * fp;
Assert(context == PGC_POSTMASTER || context == PGC_BACKEND || context == PGC_SIGHUP); Assert(context == PGC_POSTMASTER || context == PGC_BACKEND
|| context == PGC_SIGHUP);
Assert(DataDir); Assert(DataDir);
elevel = (context == PGC_SIGHUP) ? DEBUG : ERROR; elevel = (context == PGC_SIGHUP) ? DEBUG : ERROR;
...@@ -210,11 +207,24 @@ ProcessConfigFile(GucContext context) ...@@ -210,11 +207,24 @@ ProcessConfigFile(GucContext context)
if (token == GUC_EQUALS) if (token == GUC_EQUALS)
token = yylex(); token = yylex();
if (token != GUC_ID && token != GUC_STRING && token != GUC_INTEGER && token != GUC_REAL) if (token != GUC_ID && token != GUC_STRING &&
token != GUC_INTEGER && token != GUC_REAL &&
token != GUC_UNQUOTED_STRING)
goto parse_error; goto parse_error;
opt_value = strdup(yytext); opt_value = strdup(yytext);
if (opt_value == NULL) if (opt_value == NULL)
goto out_of_memory; goto out_of_memory;
if (token == GUC_STRING)
{
/* remove the beginning and ending quote/apostrophe */
/* first: shift the whole shooting match down one
character */
memmove(opt_value,opt_value+1,strlen(opt_value)-1);
/* second: null out the 2 characters we shifted */
opt_value[strlen(opt_value)-2]='\0';
/* do the escape thing. free()'s the strdup above */
opt_value=GUC_scanstr(opt_value);
}
parse_state = 2; parse_state = 2;
break; break;
...@@ -266,7 +276,8 @@ ProcessConfigFile(GucContext context) ...@@ -266,7 +276,8 @@ ProcessConfigFile(GucContext context)
FreeFile(fp); FreeFile(fp);
free(filename); free(filename);
free_name_value_list(head); free_name_value_list(head);
elog(elevel, CONFIG_FILENAME ":%u: syntax error", ConfigFileLineno); elog(elevel, CONFIG_FILENAME ":%u: syntax error, token=\"%s\"",
ConfigFileLineno,yytext);
return; return;
out_of_memory: out_of_memory:
...@@ -284,3 +295,88 @@ yywrap(void) ...@@ -284,3 +295,88 @@ yywrap(void)
{ {
return 1; return 1;
} }
/* ----------------
* scanstr
*
* if the string passed in has escaped codes, map the escape codes to actual
* chars
*
* the string returned is malloc'd and should eventually be free'd by the
* caller!
* ----------------
*/
char *
GUC_scanstr(char *s)
{
char *newStr;
int len,
i,
j;
if (s == NULL || s[0] == '\0')
{
if (s != NULL) free (s);
return strdup("");
}
len = strlen(s);
newStr = malloc(len + 1); /* string cannot get longer */
for (i = 0, j = 0; i < len; i++)
{
if (s[i] == '\\')
{
i++;
switch (s[i])
{
case 'b':
newStr[j] = '\b';
break;
case 'f':
newStr[j] = '\f';
break;
case 'n':
newStr[j] = '\n';
break;
case 'r':
newStr[j] = '\r';
break;
case 't':
newStr[j] = '\t';
break;
case '0':
case '1':
case '2':
case '3':
case '4':
case '5':
case '6':
case '7':
{
int k;
long octVal = 0;
for (k = 0;
s[i + k] >= '0' && s[i + k] <= '7' && k < 3;
k++)
octVal = (octVal << 3) + (s[i + k] - '0');
i += k - 1;
newStr[j] = ((char) octVal);
}
break;
default:
newStr[j] = s[i];
break;
}
} /* switch */
else
newStr[j] = s[i];
j++;
}
newStr[j] = '\0';
free(s);
return newStr;
}
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