From f5e096b13fba839967a80825dfe7d20902ad1672 Mon Sep 17 00:00:00 2001 From: Araq Date: Tue, 29 Oct 2019 15:07:04 +0100 Subject: [PATCH] fixes #12547 [backport] (cherry picked from commit 1214960a1bde9b45c76caaff0cdea7d2d753b205) --- compiler/vmgen.nim | 7 +++++++ 1 file changed, 7 insertions(+) diff --git a/compiler/vmgen.nim b/compiler/vmgen.nim index eae600f76f..0dc55862c0 100644 --- a/compiler/vmgen.nim +++ b/compiler/vmgen.nim @@ -231,6 +231,12 @@ proc getTemp(cc: PCtx; tt: PType): TRegister = # for e.g. mNAdd[Multiple]: let k = if typ.isNil: slotTempComplex else: typ.getSlotKind result = getFreeRegister(cc, k, start = 0) + when false: + # enable this to find "register" leaks: + if result == 4: + echo "begin ---------------" + writeStackTrace() + echo "end ----------------" proc freeTemp(c: PCtx; r: TRegister) = let c = c.prc @@ -1703,6 +1709,7 @@ proc genCheckedObjAccessAux(c: PCtx; n: PNode; dest: var TDest; flags: TGenFlags let setLit = c.genx(checkExpr[1]) var rs = c.getTemp(getSysType(c.graph, n.info, tyBool)) c.gABC(n, opcContainsSet, rs, setLit, discVal) + c.freeTemp(discVal) c.freeTemp(setLit) # If the check fails let the user know let lab1 = c.xjmp(n, if negCheck: opcFJmp else: opcTJmp, rs)