File: hanoi.m4

package info (click to toggle)
m4 1.4.16-3
  • links: PTS
  • area: main
  • in suites: wheezy
  • size: 10,204 kB
  • sloc: ansic: 69,401; sh: 7,576; cpp: 1,030; lisp: 243; makefile: 161
file content (15 lines) | stat: -rw-r--r-- 363 bytes parent folder | download | duplicates (9)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
divert(-1)

# move(from, to)
define(`move', `Move one disk from `$1' to `$2'.
')

# _hanoi (cnt, from, to, aux)
define(`_hanoi', `ifelse(eval(`$1'<=1), 1, `move($2, $3)',
`$0(decr($1), $2, $4, $3)move($2, $3)$0(decr($1), $4, $3, $2)')')

# hanoi (cnt)
define(`hanoi', `_$0(`$1', source, destination, auxilliary)')

# traceon(`move', `_hanoi', `decr')
divert`'dnl