diff options
author | Eelco Dolstra <eelco.dolstra@logicblox.com> | 2016-02-24T12·34+0100 |
---|---|---|
committer | Eelco Dolstra <eelco.dolstra@logicblox.com> | 2016-02-24T12·34+0100 |
commit | b584a0e7dea6fd903f8a285ee3a997ba535b44a7 (patch) | |
tree | 8ec27a4865126929da9ea12bffc9f2cb9f114f9c /src/libexpr/parser.y | |
parent | bf2adf72c4fb4e04afb95ad3b2ad84c19707f246 (diff) | |
parent | 6498adb002bcf7e715afe46c23b8635d4592c156 (diff) |
Merge pull request #816 from tsion/incomplete-parse
Throw a specific error for incomplete parse errors.
Diffstat (limited to 'src/libexpr/parser.y')
-rw-r--r-- | src/libexpr/parser.y | 9 |
1 files changed, 8 insertions, 1 deletions
diff --git a/src/libexpr/parser.y b/src/libexpr/parser.y index f87aa261935b..80ecd44c5981 100644 --- a/src/libexpr/parser.y +++ b/src/libexpr/parser.y @@ -31,10 +31,12 @@ namespace nix { Path basePath; Symbol path; string error; + bool atEnd; Symbol sLetBody; ParseData(EvalState & state) : state(state) , symbols(state.symbols) + , atEnd(false) , sLetBody(symbols.create("<let-body>")) { }; }; @@ -539,7 +541,12 @@ Expr * EvalState::parse(const char * text, int res = yyparse(scanner, &data); yylex_destroy(scanner); - if (res) throw ParseError(data.error); + if (res) { + if (data.atEnd) + throw IncompleteParseError(data.error); + else + throw ParseError(data.error); + } data.result->bindVars(staticEnv); |