Merge pull request #4472 from mbaulch/fix4422

Fix #4422: Reset queue element on pop. Prevent NimVM confusion. Help GC.
This commit is contained in:
Andreas Rumpf
2016-07-11 11:53:43 +02:00
committed by GitHub

View File

@@ -152,11 +152,13 @@ proc add*[T](q: var Queue[T], item: T) =
q.data[q.wr] = item
q.wr = (q.wr + 1) and q.mask
proc default[T](t: typedesc[T]): T {.inline.} = discard
proc pop*[T](q: var Queue[T]): T {.inline, discardable.} =
## Remove and returns the first (oldest) element of the queue `q`.
emptyCheck(q)
dec q.count
result = q.data[q.rd]
q.data[q.rd] = default(type(result))
q.rd = (q.rd + 1) and q.mask
proc enqueue*[T](q: var Queue[T], item: T) =