summaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
authorVsevolod Stakhov <vsevolod@highsecure.ru>2013-12-14 14:54:25 +0400
committerVsevolod Stakhov <vsevolod@highsecure.ru>2013-12-14 14:54:25 +0400
commitcc9d5fc4f4f14a2833d65d1928114eb2a67550da (patch)
tree096a50649b21d5e34f4bd17a69402e7dd21f5490 /src
parenteb1ac2e1505ac344963fc9f9aa5651929f89f170 (diff)
downloadrspamd-cc9d5fc4f4f14a2833d65d1928114eb2a67550da.tar.gz
rspamd-cc9d5fc4f4f14a2833d65d1928114eb2a67550da.zip
Sync with libucl.
Diffstat (limited to 'src')
-rw-r--r--src/ucl/src/ucl_parser.c14
1 files changed, 7 insertions, 7 deletions
diff --git a/src/ucl/src/ucl_parser.c b/src/ucl/src/ucl_parser.c
index ffcd58902..a22389ae9 100644
--- a/src/ucl/src/ucl_parser.c
+++ b/src/ucl/src/ucl_parser.c
@@ -899,7 +899,7 @@ ucl_parse_key (struct ucl_parser *parser, struct ucl_chunk *chunk, bool *next_ke
* A key must start with alpha, number, '/' or '_' and end with space character
*/
if (c == NULL) {
- if (ucl_lex_is_comment (p[0], p[1])) {
+ if (chunk->remain >= 2 && ucl_lex_is_comment (p[0], p[1])) {
if (!ucl_skip_comments (parser)) {
return false;
}
@@ -994,7 +994,7 @@ ucl_parse_key (struct ucl_parser *parser, struct ucl_chunk *chunk, bool *next_ke
return false;
}
}
- else if (ucl_lex_is_comment (p[0], p[1])) {
+ else if (chunk->remain >= 2 && ucl_lex_is_comment (p[0], p[1])) {
/* Check for comment */
if (!ucl_skip_comments (parser)) {
return false;
@@ -1127,7 +1127,7 @@ ucl_parse_string_value (struct ucl_parser *parser,
*var_expand = true;
}
- if (ucl_lex_is_atom_end (*p) || ucl_lex_is_comment (p[0], p[1])) {
+ if (ucl_lex_is_atom_end (*p) || (chunk->remain >= 2 && ucl_lex_is_comment (p[0], p[1]))) {
break;
}
ucl_chunk_skipc (chunk, p);
@@ -1292,7 +1292,7 @@ ucl_parse_value (struct ucl_parser *parser, struct ucl_chunk *chunk)
default:
/* Skip any spaces and comments */
if (ucl_test_character (*p, UCL_CHARACTER_WHITESPACE_UNSAFE) ||
- ucl_lex_is_comment (p[0], p[1])) {
+ (chunk->remain >= 2 && ucl_lex_is_comment (p[0], p[1]))) {
while (p < chunk->end && ucl_test_character (*p, UCL_CHARACTER_WHITESPACE_UNSAFE)) {
ucl_chunk_skipc (chunk, p);
}
@@ -1374,7 +1374,7 @@ ucl_parse_after_value (struct ucl_parser *parser, struct ucl_chunk *chunk)
/* Skip whitespaces */
ucl_chunk_skipc (chunk, p);
}
- else if (ucl_lex_is_comment (p[0], p[1])) {
+ else if (chunk->remain >= 2 && ucl_lex_is_comment (p[0], p[1])) {
/* Skip comment */
if (!ucl_skip_comments (parser)) {
return false;
@@ -1653,7 +1653,7 @@ ucl_state_machine (struct ucl_parser *parser)
/* Now we need to skip all spaces */
while (p < chunk->end) {
if (!ucl_test_character (*p, UCL_CHARACTER_WHITESPACE_UNSAFE)) {
- if (ucl_lex_is_comment (p[0], p[1])) {
+ if (chunk->remain >= 2 && ucl_lex_is_comment (p[0], p[1])) {
/* Skip comment */
if (!ucl_skip_comments (parser)) {
return false;
@@ -1675,7 +1675,7 @@ ucl_state_machine (struct ucl_parser *parser)
return false;
}
macro_len = ucl_expand_variable (parser, &macro_escaped, macro_start, macro_len);
- parser->state = UCL_STATE_AFTER_VALUE;
+ parser->state = UCL_STATE_KEY;
if (macro_escaped == NULL) {
if (!macro->handler (macro_start, macro_len, macro->ud)) {
return false;