Tested perl4caml on Mac OS X. Basically works fine, but had to
[perl4caml.git] / examples / test.ml
1 (* Simple test of the API.
2  * Copyright (C) 2003 Merjis Ltd.
3  * $Id: test.ml,v 1.7 2004-11-25 22:16:17 rich Exp $
4  *)
5
6 open Printf
7
8 let () =
9   (* Perform a full collection - good way to find bugs in initialization code*)
10   Gc.full_major ();
11
12   (* Load "test.pl". *)
13   Perl.eval "require 'examples/test.pl'";
14
15   (* Call some subroutines in [test.pl]. *)
16   let sv = Perl.call ~fn:"return_one" [] in
17   printf "return_one returned %d\n" (Perl.int_of_sv sv); flush stdout;
18
19   let sv = Perl.call ~fn:"adder" [Perl.sv_of_int 3; Perl.sv_of_int 4] in
20   printf "adder (3, 4) = %d\n" (Perl.int_of_sv sv); flush stdout;
21
22   let svlist = Perl.call_array ~fn:"return_array" [] in
23   print_string "array returned:";
24   List.iter (
25     fun sv ->
26       printf " %d" (Perl.int_of_sv sv);
27   ) svlist;
28   printf "\n"; flush stdout;
29
30   let sv = Perl.sv_of_string "return_one" in
31   let sv = Perl.call ~sv [] in
32   printf "return_one returned %d\n" (Perl.int_of_sv sv); flush stdout;
33
34   (* Call a Perl closure. *)
35   let sv = Perl.call ~fn:"return_closure" [] in
36   let sv = Perl.call ~sv [Perl.sv_of_int 3; Perl.sv_of_int 4] in
37   printf "closure returned %d\n" (Perl.int_of_sv sv); flush stdout;
38
39   (* Evaluate a simple expression. *)
40   Perl.eval "$a = 3";
41   printf "$a contains %d\n" (Perl.int_of_sv (Perl.get_sv "a")); flush stdout;
42
43   (* Test calling methods in the "TestClass" class. *)
44   let obj = Perl.call_class_method "TestClass" "new" [] in
45   let sv = Perl.call_method obj "get_foo" [] in
46   printf "TestClass.foo is %d\n" (Perl.int_of_sv sv); flush stdout;
47   Perl.call_method obj "set_foo" [Perl.sv_of_int 2];
48   let sv = Perl.call_method obj "get_foo" [] in
49   printf "TestClass.foo is %d\n" (Perl.int_of_sv sv); flush stdout;
50
51   (* Create an undef value and test it. *)
52   let undef = Perl.sv_undef () in
53   printf "sv_is_undef (undef) = %s\n"
54     (string_of_bool (Perl.sv_is_undef undef));
55
56   (* Perform a full collection - good way to find GC/allocation bugs. *)
57   Gc.full_major ()