From d933fde40d1232004c9eaa260dc6bd3dc376c272 Mon Sep 17 00:00:00 2001 From: Araq Date: Sat, 7 Feb 2015 02:15:50 +0100 Subject: [PATCH] yet another C++ bugfix --- compiler/semexprs.nim | 7 ++++--- 1 file changed, 4 insertions(+), 3 deletions(-) diff --git a/compiler/semexprs.nim b/compiler/semexprs.nim index 26ca542391..eeada00063 100644 --- a/compiler/semexprs.nim +++ b/compiler/semexprs.nim @@ -578,11 +578,12 @@ proc skipObjConv(n: PNode): PNode = proc isAssignable(c: PContext, n: PNode): TAssignableResult = result = parampatterns.isAssignable(c.p.owner, n) -proc newHiddenAddrTaken(c: PContext, n: PNode): PNode = - if n.kind == nkHiddenDeref: +proc newHiddenAddrTaken(c: PContext, n: PNode): PNode = + if n.kind == nkHiddenDeref and not (gCmd == cmdCompileToCpp or + sfCompileToCpp in c.module.flags): checkSonsLen(n, 1) result = n.sons[0] - else: + else: result = newNodeIT(nkHiddenAddr, n.info, makeVarType(c, n.typ)) addSon(result, n) if isAssignable(c, n) notin {arLValue, arLocalLValue}: