diff options
author | Araq <rumpf_a@web.de> | 2015-01-31 11:31:59 +0100 |
---|---|---|
committer | Araq <rumpf_a@web.de> | 2015-01-31 11:31:59 +0100 |
commit | ee4e95fefeb29f8a1b4b4317a350e02aabf75f2d (patch) | |
tree | fbf435fa66898ecce758ba161e2279198745501b /compiler | |
parent | e9a197e704384409037a9e58cd921a3c22d51ee0 (diff) | |
download | Nim-ee4e95fefeb29f8a1b4b4317a350e02aabf75f2d.tar.gz |
fixes #2039
Diffstat (limited to 'compiler')
-rw-r--r-- | compiler/ccgexprs.nim | 6 | ||||
-rw-r--r-- | compiler/semexprs.nim | 5 |
2 files changed, 6 insertions, 5 deletions
diff --git a/compiler/ccgexprs.nim b/compiler/ccgexprs.nim index 591b6d76f..4372ca524 100644 --- a/compiler/ccgexprs.nim +++ b/compiler/ccgexprs.nim @@ -1120,7 +1120,7 @@ proc genObjConstr(p: BProc, e: PNode, d: var TLoc) = var r = rdLoc(tmp) if isRef: rawGenNew(p, tmp, nil) - t = t.sons[0].skipTypes(abstractInst) + t = t.lastSon.skipTypes(abstractInst) r = ropef("(*$1)", r) gcUsage(e) else: @@ -1201,9 +1201,9 @@ proc genNewFinalize(p: BProc, e: PNode) = appf(p.module.s[cfsTypeInit3], "$1->finalizer = (void*)$2;$n", [ti, rdLoc(f)]) b.r = ropecg(p.module, "($1) #newObj($2, sizeof($3))", [ getTypeDesc(p.module, refType), - ti, getTypeDesc(p.module, skipTypes(refType.sons[0], abstractRange))]) + ti, getTypeDesc(p.module, skipTypes(refType.lastSon, abstractRange))]) genAssignment(p, a, b, {needToKeepAlive}) # set the object type: - bt = skipTypes(refType.sons[0], abstractRange) + bt = skipTypes(refType.lastSon, abstractRange) genObjectInit(p, cpsStmts, bt, a, false) gcUsage(e) diff --git a/compiler/semexprs.nim b/compiler/semexprs.nim index 6638848df..cd27cf15d 100644 --- a/compiler/semexprs.nim +++ b/compiler/semexprs.nim @@ -956,9 +956,10 @@ proc makeDeref(n: PNode): PNode = t = skipTypes(t.sons[0], {tyGenericInst}) while t.kind in {tyPtr, tyRef}: var a = result - result = newNodeIT(nkHiddenDeref, n.info, t.sons[0]) + let baseTyp = t.lastSon + result = newNodeIT(nkHiddenDeref, n.info, baseTyp) addSon(result, a) - t = skipTypes(t.lastSon, {tyGenericInst}) + t = skipTypes(baseTyp, {tyGenericInst}) const tyTypeParamsHolders = {tyGenericInst, tyCompositeTypeClass} |