aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authordrbaggy <js5@sanger.ac.uk>2021-07-03 14:09:40 +0100
committerdrbaggy <js5@sanger.ac.uk>2021-07-03 14:09:40 +0100
commit8db26d825f608ae01ccbc43507ec0e00310abb6b (patch)
tree242f0a109b956699e7b8e9e3cab21187f8313d61
parent489a98656b5502f2bc3551e452142d91a6e12a44 (diff)
parent40a6be70e1e1a6f86920fd0a0c30dbf1aaca8e6d (diff)
downloadperlweeklychallenge-club-8db26d825f608ae01ccbc43507ec0e00310abb6b.tar.gz
perlweeklychallenge-club-8db26d825f608ae01ccbc43507ec0e00310abb6b.tar.bz2
perlweeklychallenge-club-8db26d825f608ae01ccbc43507ec0e00310abb6b.zip
Merge branch 'master' of github.com:drbaggy/perlweeklychallenge-club
-rw-r--r--challenge-119/james-smith/README.md40
1 files changed, 19 insertions, 21 deletions
diff --git a/challenge-119/james-smith/README.md b/challenge-119/james-smith/README.md
index 9937a6296d..8747a9bc7c 100644
--- a/challenge-119/james-smith/README.md
+++ b/challenge-119/james-smith/README.md
@@ -133,7 +133,7 @@ End LINE
```
### Side note... an intepreter for CESIL...
-Didn't like the idea of relying on JAVASCRIPT... so here is a bare bones
+Didn't like the idea of relying on JAVA... so here is a bare bones
interpreter...
```perl
use strict;
@@ -141,31 +141,29 @@ use strict;
$| = 1;
my( $ptr, @in, %mem, @code, %ptrs, $reg ) = 0;
+my %commands = (
+'LINE' ,sub{print "\n"; },
+'IN' ,sub{die 'OUT OF INPUT' unless @in;$reg=shift@in},
+'OUT' ,sub{print $reg},
+'PRINT' ,sub{print $_[0] =~ s{^"}{}r =~ s{"$}{}r; },
+'STORE' ,sub{$mem{$_[0]} = $reg},
+'LOAD' ,sub{$reg = $mem{$_[0]}},
+'HALT' ,sub{exit},
+'JINEG' ,sub{$ptr=$ptrs{$_[0]}-1 if $reg<0},
+'JIZERO' ,sub{$ptr=$ptrs{$_[0]}-1 if $reg==0},
+'JUMP' ,sub{$ptr=$ptrs{$_[0]}-1},
+'ADD' ,sub{$reg+=$_[0]=~m{^-?\d+$}?$_[0]:$mem{$_[0]}},
+'SUBTRACT',sub{$reg-=$_[0]=~m{^-?\d+$}?$_[0]:$mem{$_[0]}},
+'MULTIPLY',sub{$reg*=$_[0]=~m{^-?\d+$}?$_[0]:$mem{$_[0]}},
+'DIVIDE' ,sub{$reg/=$_[0]=~m{^-?\d+$}?$_[0]:$mem{$_[0]};$reg=int$reg},
+);
+
while(<>) {
(@in = map { 0+$_ } <> ) && last if m{^ {8}%};
($ptrs{$1},$_)=(scalar @code,$2) if m{^(\S{1,7})\s+(.*)};
push @code, [ split m{\s+}, s{^\s+}{}r =~ s{\s+$}{}r, 2 ];
}
-
-my %commands = (
- 'LINE' => sub { print "\n"; },
- 'IN' => sub { die "RUN OUT OF INPUT" unless @in; $reg = shift @in; },
- 'OUT' => sub { print $reg },
- 'PRINT' => sub { print $_[0] =~ s{^"}{}r =~ s{"$}{}r; },
- 'STORE' => sub { $mem{$_[0]} = $reg; },
- 'LOAD' => sub { $reg = $mem{$_[0]}; },
- 'HALT' => sub { exit; },
- 'JINEG' => sub { $ptr = $ptrs{$_[0]} - 1 if $reg < 0; },
- 'JIZERO' => sub { $ptr = $ptrs{$_[0]} - 1 if $reg == 0; },
- 'JUMP' => sub { $ptr = $ptrs{$_[0]} - 1; },
- 'ADD' => sub { $reg += ( $_[0]=~m{^-?\d+$} ? $_[0] : $mem{$_[0]} ) },
- 'SUBTRACT' => sub { $reg -= ( $_[0]=~m{^-?\d+$} ? $_[0] : $mem{$_[0]} ) },
- 'MULTIPLY' => sub { $reg *= ( $_[0]=~m{^-?\d+$} ? $_[0] : $mem{$_[0]} ) },
- 'DIVIDE' => sub { $reg /= ( $_[0]=~m{^-?\d+$} ? $_[0] : $mem{$_[0]} ) ; $reg = int $reg; },
-);
-
-## Execution loop...
-(&{ $commands{$code[$ptr][0]} }( $code[$ptr][1] ),$ptr++) foreach 1..1e6;
+($commands{$code[$ptr][0]}($code[$ptr][1]),$ptr++) for 1..1e6;
```
# Task 2 - Sequence without 1-on-1