]>
iEval git - app-scheme79asm.git/blob - t/Compiler.t
5 use Test
::More tests
=> 11;
6 BEGIN { use_ok
('App::Scheme79asm::Compiler', qw
/pretty_print/) };
9 my ($expr, $expected, $name) = @_;
10 is pretty_print
($expr), $expected, $name;
15 scalar Data
::SExpression
->new({fold_lists
=> 0, use_symbol_class
=> 1})->read($string)
19 App
::Scheme79asm
::Compiler
->new;
23 my ($string, $expected) = @_;
24 is_sexp new
->process_toplevel(to_sexp
$string), $expected, "process_toplevel $string";
27 is_sexp new
->process_quoted(to_sexp
'5'), '(symbol 3)', 'process_quoted 5';
28 is_sexp new
->process_quoted(to_sexp
'()'), '(list 0)', 'process_quoted ()';
29 is_sexp new
->process_quoted(to_sexp
'(5 foo)'), '(list (list (list 0) (symbol 3)) (symbol 4))', 'process_quoted (5 foo)';
30 is_sexp new
->process_quoted(to_sexp
'(((5)))'), '(list (list 0) (list (list 0) (list (list 0) (symbol 3))))', 'process_quoted (((5)))';
32 is_toplevel
'(quote 5)', '(symbol 3)';
33 is_toplevel
'(if t \'(2 3) \'x)', '(if (list (symbol 5) (list (list (list 0) (symbol 3)) (symbol 4))) (symbol 2))';
34 is_toplevel
'(car \'(1 2))', '(call (car 0) (list (list (list 0) (symbol 3)) (symbol 4)))';
35 is_toplevel
'(lambda id (x) x)', '(proc (var -2))';
36 is_toplevel
'((lambda id (x) x) 5)', '(call (more (funcall 0) (proc (var -2))) (symbol 3))';
37 is_toplevel
'(lambda append (x y) (if (atom x) y (cons (car x) (append (cdr x) y))))', '(proc (if (list (call (more (cons 0) (call (more (more (funcall 0) (var -1)) (var -2)) (call (cdr 0) (var -3)))) (call (car 0) (var -3))) (var -2)) (call (atom 0) (var -3))))';
This page took 0.051652 seconds and 5 git commands to generate.