Fix for newer versions of compiler.

61720e0df9475af647de171f6b2964c36234961a in the Nim compiler introduced the bug
in this project. In brief, the upstream change flattens `nnkStmtList`s of one
item. Thus, `quote do:` followed by one statement is no longer a nnkStmtList
but whatever that one statement is. This breaks several macro implementations
where a `quote do:` form is initialized and then appended to. Based on Araq's
feedback (https://irclogs.nim-lang.org/02-10-2017.html#21:01:26), these
single-statement quotes are now converted into one-element statement lists as
necessary (behavior on old versions of the compiler is maintained).
This commit is contained in:
Jacob MacDonald 2017-10-02 19:27:27 -05:00 committed by flyx
parent e7e532ccb8
commit 4933194dd6
2 changed files with 6 additions and 0 deletions

View File

@ -414,6 +414,8 @@ macro parserState(name: untyped, impl: untyped): typed =
nameId = newIdentNode("state" & capitalize(nameStr)) nameId = newIdentNode("state" & capitalize(nameStr))
var procImpl = quote do: var procImpl = quote do:
debug("state: " & `nameStr`) debug("state: " & `nameStr`)
if procImpl.kind == nnkStmtList and procImpl.len == 1: procImpl = procImpl[0]
procImpl = newStmtList(procImpl)
procImpl.add(newLetStmt(ident("c"), newCall("ParserContext", ident("s")))) procImpl.add(newLetStmt(ident("c"), newCall("ParserContext", ident("s"))))
procImpl.add(newAssignment(newIdentNode("result"), newLit(false))) procImpl.add(newAssignment(newIdentNode("result"), newLit(false)))
assert impl.kind == nnkStmtList assert impl.kind == nnkStmtList

View File

@ -678,6 +678,8 @@ proc ifNotTransient(tSym: NimNode, fieldIndex: int, content: openarray[NimNode],
result = quote do: result = quote do:
when `tSym` == -1 or `fieldIndex` notin transientVectors[`tSym`]: when `tSym` == -1 or `fieldIndex` notin transientVectors[`tSym`]:
`stmts` `stmts`
if result.kind == nnkStmtList and result.len == 1: result = result[0]
result = newStmtList(result)
if elseError: if elseError:
result[0].add(newNimNode(nnkElse).add(quote do: result[0].add(newNimNode(nnkElse).add(quote do:
raise constructionError(`s`, "While constructing " & `tName` & raise constructionError(`s`, "While constructing " & `tName` &
@ -692,6 +694,8 @@ macro ensureAllFieldsPresent(s: YamlStream, t: typedesc, tIndex: int, o: typed,
result = quote do: result = quote do:
when compiles(`dbp`(`t`)): when compiles(`dbp`(`t`)):
const `defaultValues` = `defaultValueGetter`(`t`) const `defaultValues` = `defaultValueGetter`(`t`)
if result.kind == nnkStmtList and result.len == 1: result = result[0]
result = newStmtList(result)
let let
tDecl = getType(t) tDecl = getType(t)
tName = $tDecl[1] tName = $tDecl[1]