2008-05-08 18:12:15 -06:00
|
|
|
// $G $F.go && $L $F.$A && ./$A.out
|
|
|
|
|
|
|
|
// Copyright 2009 The Go Authors. All rights reserved.
|
|
|
|
// Use of this source code is governed by a BSD-style
|
|
|
|
// license that can be found in the LICENSE file.
|
|
|
|
|
|
|
|
package main
|
|
|
|
|
|
|
|
// brainfuck
|
|
|
|
|
|
|
|
func main() {
|
2008-05-15 16:20:59 -06:00
|
|
|
var a [30000]byte;
|
2008-06-06 14:28:03 -06:00
|
|
|
prog := "++++++++++[>+++++++>++++++++++>+++>+<<<<-]>++.>+.+++++++..+++.>++.<<+++++++++++++++.>.+++.------.--------.>+.>.!";
|
2008-05-15 16:20:59 -06:00
|
|
|
p := 0;
|
|
|
|
pc := 0;
|
|
|
|
for {
|
|
|
|
switch prog[pc] {
|
|
|
|
case '>':
|
|
|
|
p++;
|
|
|
|
case '<':
|
|
|
|
p--;
|
|
|
|
case '+':
|
|
|
|
a[p]++;
|
|
|
|
case '-':
|
|
|
|
a[p]--;
|
|
|
|
case '.':
|
2008-08-11 23:07:49 -06:00
|
|
|
print(string(a[p]));
|
2008-05-15 16:20:59 -06:00
|
|
|
case '[':
|
|
|
|
if a[p] == 0 {
|
|
|
|
for nest := 1; nest > 0; pc++ {
|
|
|
|
switch prog[pc+1] {
|
|
|
|
case ']':
|
|
|
|
nest--;
|
|
|
|
case '[':
|
|
|
|
nest++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
case ']':
|
|
|
|
if a[p] != 0 {
|
|
|
|
for nest := -1; nest < 0; pc-- {
|
|
|
|
switch prog[pc-1] {
|
|
|
|
case ']':
|
|
|
|
nest--;
|
|
|
|
case '[':
|
|
|
|
nest++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
default:
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
pc++;
|
|
|
|
}
|
2008-05-08 18:12:15 -06:00
|
|
|
}
|