X-Git-Url: http://git.pk910.de/?a=blobdiff_plain;f=src%2Frecdb.c;h=9b8ac1455e67c1df3e9bff0d6764aa4caef0c9f6;hb=80d9ed728be4b02ac483f3339cbb184f6602d15b;hp=262de7fb39ba37777a8ba6183a0a75bf333b0027;hpb=dd42b21b5942e1aa570ccefe458bc159271aa7be;p=srvx.git diff --git a/src/recdb.c b/src/recdb.c index 262de7f..9b8ac14 100644 --- a/src/recdb.c +++ b/src/recdb.c @@ -109,6 +109,7 @@ ABORT(RECDB *recdb, int code, unsigned char ch) { enum fail_codes { UNTERMINATED_STRING, + UNTERMINATED_COMMENT, EXPECTED_OPEN_QUOTE, EXPECTED_OPEN_BRACE, EXPECTED_OPEN_PAREN, @@ -345,8 +346,10 @@ parse_skip_ws(RECDB *recdb) do { do { c = dbgetc(recdb); - } while (c != '*' && c != EOF); + if (c == EOF) ABORT(recdb, UNTERMINATED_COMMENT, c); + } while (c != '*'); if ((c = dbgetc(recdb)) == '/') in_comment = 0; + if (c == EOF) ABORT(recdb, UNTERMINATED_COMMENT, c); } while (in_comment); } else if (d == '/') { /* C++ style comment, with slash slash comment newline */ @@ -552,6 +555,7 @@ failure_reason(int code) const char *reason; switch (code >> 8) { case UNTERMINATED_STRING: reason = "Unterminated string"; break; + case UNTERMINATED_COMMENT: reason = "Unterminated comment"; break; case EXPECTED_OPEN_QUOTE: reason = "Expected '\"'"; break; case EXPECTED_OPEN_BRACE: reason = "Expected '{'"; break; case EXPECTED_OPEN_PAREN: reason = "Expected '('"; break; @@ -568,9 +572,16 @@ failure_reason(int code) void explain_failure(RECDB *recdb, int code) { - log_module(MAIN_LOG, LOG_ERROR, "%s (got '%c') at %s line %d column %d.", - failure_reason(code), code & 255, - recdb->source, recdb->ctx.line, recdb->ctx.col); + static char msg[1024]; + snprintf(msg, sizeof(msg), "%s (got '%c') at %s line %d column %d.", + failure_reason(code), code & 255, + recdb->source, recdb->ctx.line, recdb->ctx.col); + if (MAIN_LOG == NULL) { + fputs(msg, stderr); + fputc('\n', stderr); + fflush(stderr); + } else + log_module(MAIN_LOG, LOG_ERROR, "%s", msg); } const char *