summaryrefslogtreecommitdiff
path: root/usr.sbin/relayd
diff options
context:
space:
mode:
authorPierre-Yves Ritschard <pyr@cvs.openbsd.org>2007-10-02 21:04:14 +0000
committerPierre-Yves Ritschard <pyr@cvs.openbsd.org>2007-10-02 21:04:14 +0000
commita86c5bc9bd4af827a0028e48843b2799471dd027 (patch)
tree9b76e922ccf0cd29e2a1170a74621bc51bb4e294 /usr.sbin/relayd
parent961d9e3f56705e98393e7bb848303dbb69074fbd (diff)
stop messing with lgetc to please hoststated's check/expect.
instead move some of the logic in yylex and do hoststated specific translations into hoststated.c ok gilles@
Diffstat (limited to 'usr.sbin/relayd')
-rw-r--r--usr.sbin/relayd/parse.y57
-rw-r--r--usr.sbin/relayd/relayd.c30
-rw-r--r--usr.sbin/relayd/relayd.h3
3 files changed, 59 insertions, 31 deletions
diff --git a/usr.sbin/relayd/parse.y b/usr.sbin/relayd/parse.y
index 2b66240b3dc..6135aa6cbce 100644
--- a/usr.sbin/relayd/parse.y
+++ b/usr.sbin/relayd/parse.y
@@ -1,4 +1,4 @@
-/* $OpenBSD: parse.y,v 1.58 2007/10/02 07:21:04 pyr Exp $ */
+/* $OpenBSD: parse.y,v 1.59 2007/10/02 21:04:13 pyr Exp $ */
/*
* Copyright (c) 2006 Pierre-Yves Ritschard <pyr@openbsd.org>
@@ -67,7 +67,7 @@ int yyerror(const char *, ...);
int yyparse(void);
int kw_cmp(const void *, const void *);
int lookup(char *);
-int lgetc(FILE *, int *);
+int lgetc(FILE *, int);
int lungetc(int);
int findeol(void);
int yylex(void);
@@ -517,6 +517,7 @@ tableoptsl : host {
free($5);
YYERROR;
}
+ translate_string(table->conf.exbuf);
free($5);
}
| CHECK SCRIPT STRING {
@@ -1257,11 +1258,10 @@ char pushback_buffer[MAXPUSHBACK];
int pushback_index = 0;
int
-lgetc(FILE *f, int *keep)
+lgetc(FILE *f, int inquot)
{
int c, next;
- *keep = 0;
if (parsebuf) {
/* Read character from the parsebuffer instead of input. */
if (parseindex >= 0) {
@@ -1276,17 +1276,14 @@ lgetc(FILE *f, int *keep)
if (pushback_index)
return (pushback_buffer[--pushback_index]);
+ if (inquot) {
+ c = getc(f);
+ return (c);
+ }
+
while ((c = getc(f)) == '\\') {
next = getc(f);
- if (next == 'n') {
- *keep = 1;
- c = '\n';
- break;
- } else if (next == 'r') {
- *keep = 1;
- c = '\r';
- break;
- } else if (next != '\n') {
+ if (next != '\n') {
c = next;
break;
}
@@ -1325,15 +1322,14 @@ int
findeol(void)
{
int c;
- int k;
parsebuf = NULL;
pushback_index = 0;
/* skip to either EOF or the first real EOL */
while (1) {
- c = lgetc(fin, &k);
- if (c == '\n' && k == 0) {
+ c = lgetc(fin, 0);
+ if (c == '\n') {
lineno++;
break;
}
@@ -1348,24 +1344,21 @@ yylex(void)
{
char buf[8096];
char *p, *val;
- int endc, c;
+ int endc, next, c;
int token;
- int keep;
top:
p = buf;
- while ((c = lgetc(fin, &keep)) == ' ')
+ while ((c = lgetc(fin, 0)) == ' ')
; /* nothing */
yylval.lineno = lineno;
if (c == '#')
- do {
- while ((c = lgetc(fin, &keep)) != '\n' && c != EOF)
- ; /* nothing */
- } while (keep == 1);
+ while ((c = lgetc(fin, 0)) != '\n' && c != EOF)
+ ; /* nothing */
if (c == '$' && parsebuf == NULL) {
while (1) {
- if ((c = lgetc(fin, &keep)) == EOF)
+ if ((c = lgetc(fin, 0)) == EOF)
return (0);
if (p + 1 >= buf + sizeof(buf) - 1) {
@@ -1395,13 +1388,19 @@ top:
case '"':
endc = c;
while (1) {
- if ((c = lgetc(fin, &keep)) == EOF)
+ if ((c = lgetc(fin, 1)) == EOF)
return (0);
- if (c == endc) {
+ if (c == '\\') {
+ next = lgetc(fin, 1);
+ if (next == endc)
+ c = next;
+ else
+ lungetc(next);
+ } else if (c == endc) {
*p = '\0';
break;
}
- if (c == '\n' && keep == 0) {
+ if (c == '\n') {
lineno++;
continue;
}
@@ -1427,7 +1426,7 @@ top:
yyerror("string too long");
return (findeol());
}
- } while ((c = lgetc(fin, &keep)) != EOF && isdigit(c));
+ } while ((c = lgetc(fin, 0)) != EOF && isdigit(c));
lungetc(c);
if (p == buf + 1 && buf[0] == '-')
goto nodigits;
@@ -1466,7 +1465,7 @@ nodigits:
yyerror("string too long");
return (findeol());
}
- } while ((c = lgetc(fin, &keep)) != EOF &&
+ } while ((c = lgetc(fin, 0)) != EOF &&
(allowed_in_string(c)));
lungetc(c);
*p = '\0';
diff --git a/usr.sbin/relayd/relayd.c b/usr.sbin/relayd/relayd.c
index 15c0d3b948b..766654c1fcb 100644
--- a/usr.sbin/relayd/relayd.c
+++ b/usr.sbin/relayd/relayd.c
@@ -1,4 +1,4 @@
-/* $OpenBSD: relayd.c,v 1.41 2007/09/28 20:23:38 pyr Exp $ */
+/* $OpenBSD: relayd.c,v 1.42 2007/10/02 21:04:13 pyr Exp $ */
/*
* Copyright (c) 2006 Pierre-Yves Ritschard <pyr@openbsd.org>
@@ -849,3 +849,31 @@ expand_string(char *label, size_t len, const char *srch, const char *repl)
return (0);
}
+
+void
+translate_string(char *str)
+{
+ char *reader;
+ char *writer;
+
+ reader = writer = str;
+
+ while (*reader) {
+ if (*reader == '\\') {
+ reader++;
+ switch (*reader) {
+ case 'n':
+ *writer++ = '\n';
+ break;
+ case 'r':
+ *writer++ = '\r';
+ break;
+ default:
+ *writer++ = *reader;
+ }
+ } else
+ *writer++ = *reader;
+ reader++;
+ }
+ *writer = '\0';
+}
diff --git a/usr.sbin/relayd/relayd.h b/usr.sbin/relayd/relayd.h
index 920ee1379d8..603014b6838 100644
--- a/usr.sbin/relayd/relayd.h
+++ b/usr.sbin/relayd/relayd.h
@@ -1,4 +1,4 @@
-/* $OpenBSD: relayd.h,v 1.64 2007/09/28 13:29:56 pyr Exp $ */
+/* $OpenBSD: relayd.h,v 1.65 2007/10/02 21:04:13 pyr Exp $ */
/*
* Copyright (c) 2006, 2007 Pierre-Yves Ritschard <pyr@openbsd.org>
@@ -758,6 +758,7 @@ struct relay *relay_find(struct hoststated *, objid_t);
struct session *session_find(struct hoststated *, objid_t);
struct relay *relay_findbyname(struct hoststated *, const char *);
int expand_string(char *, size_t, const char *, const char *);
+void translate_string(char *);
void purge_config(struct hoststated *, u_int8_t);
void merge_config(struct hoststated *, struct hoststated *);