Skip to content

Commit

Permalink
Browse files Browse the repository at this point in the history
  • Loading branch information
cooldome committed Dec 13, 2019
1 parent 22b2684 commit c17b6bf
Show file tree
Hide file tree
Showing 2 changed files with 46 additions and 1 deletion.
12 changes: 12 additions & 0 deletions compiler/sempass2.nim
Original file line number Diff line number Diff line change
Expand Up @@ -758,6 +758,18 @@ proc track(tracked: PEffects, n: PNode) =
if n[1].typ.len > 0:
createTypeBoundOps(tracked, n[1].typ.lastSon, n.info)
createTypeBoundOps(tracked, n[1].typ, n.info)

if a.kind == nkSym and a.sym.name.s.len > 0 and a.sym.name.s[0] == '=' and
tracked.owner.kind != skMacro:
let opKind = find(AttachedOpToStr, a.sym.name.s)
if opKind != -1:
# rebind type bounds operations after createTypeBoundOps call
let t = n[1].typ.skipTypes({tyAlias, tyVar})
createTypeBoundOps(tracked, t, n.info)
let op = t.attachedOps[TTypeAttachedOp(opKind)]
if op != nil:
n[0].sym = op

for i in 0..<n.safeLen:
track(tracked, n[i])
of nkDotExpr:
Expand Down
35 changes: 34 additions & 1 deletion tests/destructor/tdestructor3.nim
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,13 @@ destroy
destroy Foo: 123
destroy Foo: 5
(x1: (val: ...))
destroy'''
destroy
---------------
app begin
(val: ...)
destroy
app end
'''
joinable: false
"""

Expand Down Expand Up @@ -93,3 +99,30 @@ proc test =
echo obj2

test()


#------------------------------------------------------------
# Issue #12883

type
TopObject = object
internal: UniquePtr[int]

proc deleteTop(p: ptr TopObject) =
if p != nil:
`=destroy`(p[]) # !!! this operation leak the integer
deallocshared(p)

proc createTop(): ptr TopObject =
result = cast[ptr TopObject](allocShared0(sizeof(TopObject)))
result.internal = newUniquePtr(1)

proc test2() =
let x = createTop()
echo $x.internal
deleteTop(x)

echo "---------------"
echo "app begin"
test2()
echo "app end"

0 comments on commit c17b6bf

Please sign in to comment.