diff options
author | awr1 <41453959+awr1@users.noreply.github.com> | 2023-06-07 23:02:57 -0700 |
---|---|---|
committer | GitHub <noreply@github.com> | 2023-06-08 08:02:57 +0200 |
commit | 6514eaa8e00654d5866eff8df764ebde0b251600 (patch) | |
tree | d58c5f8e4272fc7f5a6f2de46414c8492e594c49 /lib/std/private | |
parent | 7ee00d86b1ab2b6745937f524485a2e632f9b0ea (diff) | |
download | Nim-6514eaa8e00654d5866eff8df764ebde0b251600.tar.gz |
Nested `with` blocks (#22042)
* Implemented with-nesting in underscoredCalls() * Add tests for nested with
Diffstat (limited to 'lib/std/private')
-rw-r--r-- | lib/std/private/underscored_calls.nim | 20 |
1 files changed, 14 insertions, 6 deletions
diff --git a/lib/std/private/underscored_calls.nim b/lib/std/private/underscored_calls.nim index f0bcbcc74..8b0392641 100644 --- a/lib/std/private/underscored_calls.nim +++ b/lib/std/private/underscored_calls.nim @@ -12,6 +12,8 @@ import macros +proc underscoredCalls*(result, calls, arg0: NimNode) + proc underscoredCall(n, arg0: NimNode): NimNode = proc underscorePos(n: NimNode): int = for i in 1 ..< n.len: @@ -19,13 +21,19 @@ proc underscoredCall(n, arg0: NimNode): NimNode = return 0 if n.kind in nnkCallKinds: - result = copyNimNode(n) - result.add n[0] + if n[0].kind in {nnkIdent, nnkSym} and n[0].eqIdent("with"): + expectKind n[1], {nnkIdent, nnkSym} - let u = underscorePos(n) - for i in 1..u-1: result.add n[i] - result.add arg0 - for i in u+1..n.len-1: result.add n[i] + result = newStmtList() + underscoredCalls(result, n[2 .. ^1].newStmtList, newDotExpr(arg0, n[1])) + else: + result = copyNimNode(n) + result.add n[0] + + let u = underscorePos(n) + for i in 1..u-1: result.add n[i] + result.add arg0 + for i in u+1..n.len-1: result.add n[i] elif n.kind in {nnkAsgn, nnkExprEqExpr}: var field = n[0] if n[0].kind == nnkDotExpr and n[0][0].eqIdent("_"): |