File: chains.nim

package info (click to toggle)
nim 2.2.0-1
  • links: PTS, VCS
  • area: main
  • in suites: sid
  • size: 1,911,644 kB
  • sloc: sh: 24,603; ansic: 1,761; python: 1,492; makefile: 1,013; sql: 298; asm: 141; xml: 13
file content (44 lines) | stat: -rw-r--r-- 1,199 bytes parent folder | download | duplicates (6)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
#
#
#            Nim's Runtime Library
#        (c) Copyright 2016 Andreas Rumpf
#
#    See the file "copying.txt", included in this
#    distribution, for details about the copyright.
#

## Template based implementation of singly and doubly linked lists.
## The involved types should have 'prev' or 'next' fields and the
## list header should have 'head' or 'tail' fields.

template prepend*(header, node) =
  when compiles(header.head):
    when compiles(node.prev):
      if header.head != nil:
        header.head.prev = node
    node.next = header.head
    header.head = node
  when compiles(header.tail):
    if header.tail == nil:
      header.tail = node

template append*(header, node) =
  when compiles(header.head):
    if header.head == nil:
      header.head = node
  when compiles(header.tail):
    when compiles(node.prev):
      node.prev = header.tail
    if header.tail != nil:
      header.tail.next = node
    header.tail = node

template unlink*(header, node) =
  if node.next != nil:
    node.next.prev = node.prev
  if node.prev != nil:
    node.prev.next = node.next
  if header.head == node:
    header.head = node.prev
  if header.tail == node:
    header.tail = node.next