diff --git a/lib/pure/json.nim b/lib/pure/json.nim index ed560d7e49..2c2b6500f3 100644 --- a/lib/pure/json.nim +++ b/lib/pure/json.nim @@ -1111,11 +1111,11 @@ proc processObjField(field, jsonNode: NimNode): seq[NimNode] = exprColonExpr.add(createConstructor(typeNode, indexedJsonNode)) of nnkRecCase: # A "case" field that introduces a variant. - let exprColonExpr = newNimNode(nnkExprColonExpr) - result.add(exprColonExpr) + let exprEqExpr = newNimNode(nnkExprEqExpr) + result.add(exprEqExpr) # Add the "case" field name (usually "kind"). - exprColonExpr.add(toIdentNode(field[0])) + exprEqExpr.add(toIdentNode(field[0])) # -> jsonNode["`field[0]`"] let kindJsonNode = createJsonIndexer(jsonNode, $field[0]) @@ -1125,7 +1125,7 @@ proc processObjField(field, jsonNode: NimNode): seq[NimNode] = let getEnumSym = bindSym("getEnum") let astStrLit = toStrLit(kindJsonNode) let getEnumCall = newCall(getEnumSym, kindJsonNode, astStrLit, kindType) - exprColonExpr.add(getEnumCall) + exprEqExpr.add(getEnumCall) # Iterate through each `of` branch. for i in 1 ..< field.len: @@ -1475,20 +1475,18 @@ proc postProcess(node: NimNode): NimNode = # TODO: Placing `node[0]` inside quote is buggy var resType = toIdentNode(node[0]) - result.add( - quote do: - var `resIdent` = `resType`(); - ) + var objConstr = newTree(nnkObjConstr, resType) + result.add newVarStmt(resIdent, objConstr) # Process each ExprColonExpr. for i in 1..