Execute Brain****/Raku: Difference between revisions
Content added Content deleted
(prefer comb over split; fix private method call syntax) |
No edit summary |
||
Line 42: | Line 42: | ||
$!c++; |
$!c++; |
||
die "unbalanced code" if $!c >= @!code.elems; |
die "unbalanced code" if $!c >= @!code.elems; |
||
$ |
$depth++ if @!code[$!c] eq '['; |
||
$ |
$depth-- if @!code[$!c] eq ']'; |
||
} |
} |
||
} |
} |
||
Line 49: | Line 49: | ||
Test: "Hello World" program: |
Test: "Hello World" program: |
||
<lang perl6> |
<lang perl6>my $code = "++++++++++ |
||
my $code = "++++++++++ |
|||
[>+++++++>++++++++++>+++>+<<<<-] |
[>+++++++>++++++++++>+++>+<<<<-] |
||
>++.>+.+++++++..+++.>++.<<+++++++++++++++.>. |
>++.>+.+++++++..+++.>++.<<+++++++++++++++.>. |
Revision as of 17:08, 6 January 2013
<lang perl6>class BFInterpreter {
has @!code; has @!mem; has @!loop_stack; has @!input_buffer; has $!m; has $!c;
method new (Str $code) { BFInterpreter.bless(*,code => $code.lines.comb); }
method run { $!c = 0; $!m = 0; while $!c < @!code { given @!code[$!c] { when '>' { $!m++ } when '<' { $!m-- } when '+' { @!mem[$!m]++ } when '-' { @!mem[$!m]-- } when '.' { @!mem[$!m].chr.print } when ',' { @!input_buffer = $*IN.get.comb unless @!input_buffer.elems > 0; @!mem[$!m] = @!input_buffer.shift; } when '[' { @!mem[$!m] == 0 ?? self!jump !! @!loop_stack.push($!c); } when ']' { my $b = @!loop_stack.pop - 1; $!c = $b if @!mem[$!m] > 0; } }
$!c++;
} }
method !jump { my $depth = 1; while $depth { $!c++; die "unbalanced code" if $!c >= @!code.elems; $depth++ if @!code[$!c] eq '['; $depth-- if @!code[$!c] eq ']'; } }
}</lang>
Test: "Hello World" program: <lang perl6>my $code = "++++++++++
[>+++++++>++++++++++>+++>+<<<<-] >++.>+.+++++++..+++.>++.<<+++++++++++++++.>. +++.------.--------.>+.>.";
my $bfi = BFInterpreter.new($code); $bfi.run; </lang>