#!perl

# Copyright (C) 2006-2007, The Perl Foundation.
# $Id: recursion.t 22352 2007-10-21 14:55:36Z paultcochrane $

use strict;
use warnings;
use lib qw( lib ../lib ../../lib dotnet dotnet/t );

use DotNetTesting;

use Test::More tests => 2;

## Testing class for this file.t';
#
die unless compile_cs( "t.dll", <<'CSHARP');
namespace Testing
{
    public class Test
    {
        public int factorial(int x)
        {
            if (x <= 1)
                return 1;
            else
                return x * factorial(x - 1);
        }
    }
}
CSHARP

## Attempt to translate.
ok( translate( "t.dll", "t.pbc" ), 'translate' );

## Tests.
is( run_pir(<<'PIR'), <<'OUTPUT', 'factorial' );
.sub main
	.local pmc obj
	load_bytecode "t.pbc"
	obj = new [ "Testing" ; "Test" ]
	$I0 = obj.factorial(0)
    print $I0
    print "\n"
    $I0 = obj.factorial(1)
    print $I0
    print "\n"
    $I0 = obj.factorial(2)
    print $I0
    print "\n"
    $I0 = obj.factorial(10)
    print $I0
    print "\n"
.end
PIR
1
1
2
3628800
OUTPUT

## Clean up.
unlink qw(t.dll t.pbc);

# Local Variables:
#   mode: cperl
#   cperl-indent-level: 4
#   fill-column: 100
# End:
# vim: expandtab shiftwidth=4:


syntax highlighted by Code2HTML, v. 0.9.1