diff options
author | Pierre-Yves Ritschard <pyr@cvs.openbsd.org> | 2007-10-02 21:04:14 +0000 |
---|---|---|
committer | Pierre-Yves Ritschard <pyr@cvs.openbsd.org> | 2007-10-02 21:04:14 +0000 |
commit | a86c5bc9bd4af827a0028e48843b2799471dd027 (patch) | |
tree | 9b76e922ccf0cd29e2a1170a74621bc51bb4e294 /usr.sbin/relayd | |
parent | 961d9e3f56705e98393e7bb848303dbb69074fbd (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.y | 57 | ||||
-rw-r--r-- | usr.sbin/relayd/relayd.c | 30 | ||||
-rw-r--r-- | usr.sbin/relayd/relayd.h | 3 |
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 *); |