diff options
author | Araq <rumpf_a@web.de> | 2011-03-03 02:01:22 +0100 |
---|---|---|
committer | Araq <rumpf_a@web.de> | 2011-03-03 02:01:22 +0100 |
commit | e424e13bd9d05ab3fbcbe3572e49c1bc611a1fc9 (patch) | |
tree | e0c60da1e1ddd60d040f02508deb554f687f23aa /tests/reject | |
parent | f93ca8e42a7c987bf03606319d9dfcc0772684f5 (diff) | |
download | Nim-e424e13bd9d05ab3fbcbe3572e49c1bc611a1fc9.tar.gz |
various bugfixes for generics; added generic sort proc
Diffstat (limited to 'tests/reject')
-rw-r--r-- | tests/reject/ttypenoval.nim | 55 |
1 files changed, 55 insertions, 0 deletions
diff --git a/tests/reject/ttypenoval.nim b/tests/reject/ttypenoval.nim new file mode 100644 index 000000000..ed91b05e2 --- /dev/null +++ b/tests/reject/ttypenoval.nim @@ -0,0 +1,55 @@ +discard """ + file: "tambsym.nim" + line: 36 + errormsg: "a type has no value" +""" + +# A min-heap. +type + TNode[T] = tuple[priority: int, data: T] + + TBinHeap[T] = object + heap: seq[TNode[T]] + last: int + + PBinHeap[T] = ref TBinHeap[T] + +proc newBinHeap*[T](heap: var PBinHeap[T], size: int) = + new(heap) + heap.last = 0 + newSeq(heap.heap, size) + #newSeq(heap.seq, size) + +proc parent(elem: int): int {.inline.} = + return (elem-1) div 2 + +proc siftUp[T](heap: PBinHeap[T], elem: int) = + var idx = elem + while idx != 0: + var p = parent(idx) + if heap.heap[idx] < heap.heap[p]: + swap(heap.heap[idx], heap.heap[p]) + idx = p + else: + break + +proc add*[T](heap: PBinHeap[T], priority: int, data: T) = + var node: TNode[T] + node.priority = int + node.data = data + heap.heap[heap.last] = node + siftUp(heap, heap.last) + inc(heap.last) + +proc print*[T](heap: PBinHeap[T]) = + for i in countup(0, heap.last): + echo($heap.heap[i]) + +var + heap: PBinHeap[int] + +newBinHeap(heap, 256) +add(heap, 1, 100) +print(heap) + + |