diff options
author | Daniil Baturin <daniil@baturin.org> | 2019-03-17 21:36:55 +0100 |
---|---|---|
committer | Daniil Baturin <daniil@baturin.org> | 2019-03-17 21:36:55 +0100 |
commit | 592491b377261fe41fc3048ca50ae5829da821c8 (patch) | |
tree | 4092a3b3c4c8d32473031c94c2e5c2f37bf308ba | |
parent | dfe130541ccdd3c8fdedd90b9ef4762f6babd5c6 (diff) | |
download | vyos-1x-592491b377261fe41fc3048ca50ae5829da821c8.tar.gz vyos-1x-592491b377261fe41fc3048ca50ae5829da821c8.zip |
[vyos.configtree] T1305: allow configs to end with leaf nodes.
-rw-r--r-- | python/vyos/configtree.py | 11 | ||||
-rw-r--r-- | tests/data/config.valid | 10 |
2 files changed, 17 insertions, 4 deletions
diff --git a/python/vyos/configtree.py b/python/vyos/configtree.py index 39fe41669..90716baf2 100644 --- a/python/vyos/configtree.py +++ b/python/vyos/configtree.py @@ -41,6 +41,12 @@ def strip_comments(s): else: config_end = 0 break + elif (state == INITIAL) and not re.match(r'(\s|\/)', c): + # Assume there are no (more) trailing comments, + # this is an end of a node: either a brace of the last character + # of a leaf node value + config_end = i + 1 + break elif (state == INITIAL) and (c == '/'): # A comment begins, or it's a stray slash if (s[i-1] == '*'): @@ -48,10 +54,6 @@ def strip_comments(s): i -= 2 else: raise ValueError("Invalid syntax: stray slash at character {0}".format(i + 1)) - elif (state == INITIAL) and (c == '}'): - # We are not inside a comment, that's the end of the last node - config_end = i + 1 - break elif (state == IN_COMMENT) and (c == '*'): # A comment ends here try: @@ -64,6 +66,7 @@ def strip_comments(s): # Ignore everything inside comments, including braces i -= 1 else: + # Shouldn't happen raise ValueError("Invalid syntax at character {0}: invalid character {1}".format(i + 1, c)) return (s[0:config_end], s[config_end+1:]) diff --git a/tests/data/config.valid b/tests/data/config.valid index 353e96df4..a21c6a4d1 100644 --- a/tests/data/config.valid +++ b/tests/data/config.valid @@ -27,3 +27,13 @@ normal-node { } option-with-quoted-value "some-value" } + +trailing-leaf-node-option some-value + +empty-node { +} + +trailing-leaf-node-without-value + +/* Trailing commend */ +/* Another trailing comment */ |