diff --git a/lib/pure/sugar.nim b/lib/pure/sugar.nim index 5719e8dd77f1c..fa28ffcf47cfd 100644 --- a/lib/pure/sugar.nim +++ b/lib/pure/sugar.nim @@ -184,7 +184,7 @@ macro capture*(locals: openArray[typed], body: untyped): untyped {.since: (1, 1) ## echo r[0] & ", or " & r[1] # output: to be, or not to be var params = @[newIdentNode("auto")] for arg in locals: - params.add(newIdentDefs(ident(arg.strVal), freshIdentNodes getTypeImpl arg)) + params.add(newIdentDefs(ident(arg.strVal), freshIdentNodes getTypeInst arg)) result = newNimNode(nnkCall) result.add(newProc(newEmptyNode(), params, body, nnkProcDef)) for arg in locals: result.add(arg) diff --git a/tests/closure/tcapture.nim b/tests/closure/tcapture.nim index 304a76285fb68..ff3490f07eb1a 100644 --- a/tests/closure/tcapture.nim +++ b/tests/closure/tcapture.nim @@ -1,6 +1,9 @@ discard """ output: ''' -to be, or not to be''' +to be, or not to be +(v: 1) +(v: 1) +''' joinable: false """ @@ -9,4 +12,15 @@ import sequtils, sugar let m = @[proc (s: string): string = "to " & s, proc (s: string): string = "not to " & s] var l = m.mapIt(capture([it], proc (s: string): string = it(s))) let r = l.mapIt(it("be")) -echo r[0] & ", or " & r[1] \ No newline at end of file +echo r[0] & ", or " & r[1] + +type O = object + v: int +var o = O(v: 1) +var execute: proc() +capture [o]: + execute = proc() = + echo o +execute() +o.v = -1 +execute()