Add a whole bunch of chicken runme scripts, and fix the bugs exposed by those scripts
git-svn-id: https://swig.svn.sourceforge.net/svnroot/swig/trunk@7155 626c5289-ae23-0410-ae9c-e8d60b6d4f22
This commit is contained in:
parent
c4dc892c23
commit
420ba48099
72 changed files with 1085 additions and 412 deletions
|
|
@ -18,7 +18,7 @@ SO = @SO@
|
|||
include $(srcdir)/../common.mk
|
||||
|
||||
# Overridden variables here
|
||||
SWIGOPT +=
|
||||
SWIGOPT += -nounit
|
||||
|
||||
# Rules for the different types of tests
|
||||
%.cpptest:
|
||||
|
|
@ -41,6 +41,9 @@ SWIGOPT +=
|
|||
$(setup) \
|
||||
($(swig_and_compile_multi_cpp); ) && \
|
||||
$(run_testcase)
|
||||
if [ -f $(srcdir)/$(SCRIPTPREFIX)$*$(PROXYSUFFIX) ]; then ( \
|
||||
$(MAKE) $*.multiproxy; ) \
|
||||
fi;
|
||||
|
||||
# Runs the testcase. A testcase is only run if
|
||||
# a file is found which has _runme.scm appended after the testcase name.
|
||||
|
|
@ -65,6 +68,13 @@ run_testcase = \
|
|||
($(swig_and_compile_c); ) && \
|
||||
$(run_testcase)
|
||||
|
||||
%.multiproxy: SWIGOPT += -proxy -noclosuses
|
||||
%.multiproxy: SCRIPTSUFFIX = $(PROXYSUFFIX)
|
||||
%.multiproxy:
|
||||
echo "Checking testcase $* (with run test) under chicken with -proxy"; \
|
||||
($(swig_and_compile_multi_cpp); ) && \
|
||||
$(run_testcase)
|
||||
|
||||
# Clean
|
||||
%.clean:
|
||||
|
||||
|
|
|
|||
|
|
@ -1,2 +1,2 @@
|
|||
(load-library 'casts "casts.so")
|
||||
(load "casts.so")
|
||||
(include "../schemerunme/casts.scm")
|
||||
|
|
|
|||
|
|
@ -1,2 +1,2 @@
|
|||
(load-library 'char_constant "char_constant.so")
|
||||
(load "char_constant.so")
|
||||
(include "../schemerunme/char_constant.scm")
|
||||
|
|
|
|||
|
|
@ -1,2 +1,2 @@
|
|||
(load-library 'class_ignore "class_ignore.so")
|
||||
(load "class_ignore.so")
|
||||
(include "../schemerunme/class_ignore.scm")
|
||||
|
|
|
|||
|
|
@ -0,0 +1,95 @@
|
|||
(require 'clientdata_prop_a)
|
||||
(require 'clientdata_prop_b)
|
||||
|
||||
(define a (make <A>))
|
||||
(test-A a)
|
||||
(test-tA a)
|
||||
(test-t2A a)
|
||||
(test-t3A a)
|
||||
(fA a)
|
||||
|
||||
(define b (make <B>))
|
||||
(test-A b)
|
||||
(test-tA b)
|
||||
(test-t2A b)
|
||||
(test-t3A b)
|
||||
(test-B b)
|
||||
(fA b)
|
||||
(fB b)
|
||||
|
||||
(define c (make <C>))
|
||||
(test-A c)
|
||||
(test-tA c)
|
||||
(test-t2A c)
|
||||
(test-t3A c)
|
||||
(test-C c)
|
||||
(fA c)
|
||||
(fC c)
|
||||
|
||||
(define d (make <D>))
|
||||
(test-A d)
|
||||
(test-tA d)
|
||||
(test-t2A d)
|
||||
(test-t3A d)
|
||||
(test-D d)
|
||||
(test-tD d)
|
||||
(test-t2D d)
|
||||
(fA d)
|
||||
(fD d)
|
||||
|
||||
;; here are the real tests... if the clientdata is correctly
|
||||
;; propegated, new-tA, new-t2A, should all return wrapped proxy's
|
||||
;; of class <A>
|
||||
|
||||
(define a2 (new-tA))
|
||||
(if (not (eq? (class-of a2) <A>))
|
||||
(error "Error 1"))
|
||||
(test-A a2)
|
||||
(test-tA a2)
|
||||
(test-t2A a2)
|
||||
(test-t3A a2)
|
||||
(fA a2)
|
||||
|
||||
(define a3 (new-t2A))
|
||||
(if (not (eq? (class-of a3) <A>))
|
||||
(error "Error 2"))
|
||||
(test-A a3)
|
||||
(test-tA a3)
|
||||
(test-t2A a3)
|
||||
(test-t3A a3)
|
||||
(fA a3)
|
||||
|
||||
(define a4 (new-t3A))
|
||||
(if (not (eq? (class-of a4) <A>))
|
||||
(error "Error 3"))
|
||||
(test-A a4)
|
||||
(test-tA a4)
|
||||
(test-t2A a4)
|
||||
(test-t3A a4)
|
||||
(fA a4)
|
||||
|
||||
(define d2 (new-tD))
|
||||
(if (not (eq? (class-of d2) <D>))
|
||||
(error "Error 4"))
|
||||
(test-A d2)
|
||||
(test-tA d2)
|
||||
(test-t2A d2)
|
||||
(test-t3A d2)
|
||||
(test-D d2)
|
||||
(test-tD d2)
|
||||
(fA d2)
|
||||
(fD d2)
|
||||
|
||||
(define d3 (new-t2D))
|
||||
(if (not (eq? (class-of d3) <D>))
|
||||
(error "Error 5"))
|
||||
(test-A d3)
|
||||
(test-tA d3)
|
||||
(test-t2A d3)
|
||||
(test-t3A d3)
|
||||
(test-D d3)
|
||||
(test-tD d3)
|
||||
(fA d3)
|
||||
(fD d3)
|
||||
|
||||
(exit 0)
|
||||
|
|
@ -1,2 +1,2 @@
|
|||
(load-library 'constover "constover.so")
|
||||
(load "constover.so")
|
||||
(include "../schemerunme/constover.scm")
|
||||
|
|
|
|||
|
|
@ -1,3 +1,3 @@
|
|||
(load-library 'contract "contract.so")
|
||||
(load "contract.so")
|
||||
(include "testsuite.ss")
|
||||
(include "../schemerunme/contract.scm")
|
||||
|
|
|
|||
51
SWIG/Examples/test-suite/chicken/cpp_basic_runme_proxy.ss
Normal file
51
SWIG/Examples/test-suite/chicken/cpp_basic_runme_proxy.ss
Normal file
|
|
@ -0,0 +1,51 @@
|
|||
(require 'cpp_basic)
|
||||
|
||||
(define-macro (check test)
|
||||
`(if (not ,test) (error "Error in test " ',test)))
|
||||
|
||||
(define f (make <Foo> 4))
|
||||
(check (= (slot-ref f 'num) 4))
|
||||
(slot-set! f 'num -17)
|
||||
(check (= (slot-ref f 'num) -17))
|
||||
|
||||
(define b (make <Bar>))
|
||||
|
||||
(slot-set! b 'fptr f)
|
||||
(check (= (slot-ref (slot-ref b 'fptr) 'num) -17))
|
||||
(check (= (test b -3 (slot-ref b 'fptr)) -5))
|
||||
(slot-set! f 'num 12)
|
||||
(check (= (slot-ref (slot-ref b 'fptr) 'num) 12))
|
||||
|
||||
(check (= (slot-ref (slot-ref b 'fref) 'num) -4))
|
||||
(check (= (test b 12 (slot-ref b 'fref)) 23))
|
||||
;; references don't take ownership, so if we didn't define this here it might get garbage collected
|
||||
(define f2 (make <Foo> 23))
|
||||
(slot-set! b 'fref f2)
|
||||
(check (= (slot-ref (slot-ref b 'fref) 'num) 23))
|
||||
(check (= (test b -3 (slot-ref b 'fref)) 35))
|
||||
|
||||
(check (= (slot-ref (slot-ref b 'fval) 'num) 15))
|
||||
(check (= (test b 3 (slot-ref b 'fval)) 33))
|
||||
(slot-set! b 'fval (make <Foo> -15))
|
||||
(check (= (slot-ref (slot-ref b 'fval) 'num) -15))
|
||||
(check (= (test b 3 (slot-ref b 'fval)) -27))
|
||||
|
||||
(define f3 (testFoo b 12 (slot-ref b 'fref)))
|
||||
(check (= (slot-ref f3 'num) 32))
|
||||
|
||||
;; now test global
|
||||
(define f4 (make <Foo> 6))
|
||||
(Bar-global-fptr f4)
|
||||
(check (= (slot-ref (Bar-global-fptr) 'num) 6))
|
||||
(slot-set! f4 'num 8)
|
||||
(check (= (slot-ref (Bar-global-fptr) 'num) 8))
|
||||
|
||||
(check (= (slot-ref (Bar-global-fref) 'num) 23))
|
||||
(Bar-global-fref (make <Foo> -7))
|
||||
(check (= (slot-ref (Bar-global-fref) 'num) -7))
|
||||
|
||||
(check (= (slot-ref (Bar-global-fval) 'num) 3))
|
||||
(Bar-global-fval (make <Foo> -34))
|
||||
(check (= (slot-ref (Bar-global-fval) 'num) -34))
|
||||
|
||||
(exit 0)
|
||||
|
|
@ -1,2 +1,2 @@
|
|||
(load-library 'cpp-enum "cpp_enum.so")
|
||||
(load "cpp_enum.so")
|
||||
(include "../schemerunme/cpp_enum.scm")
|
||||
|
|
|
|||
|
|
@ -1,2 +1,2 @@
|
|||
(load-library 'cpp_namespace "cpp_namespace.so")
|
||||
(load "cpp_namespace.so")
|
||||
(include "../schemerunme/cpp_namespace.scm")
|
||||
|
|
|
|||
|
|
@ -1,2 +1,2 @@
|
|||
(load-library 'dynamic_cast "dynamic_cast.so")
|
||||
(load "dynamic_cast.so")
|
||||
(include "../schemerunme/dynamic_cast.scm")
|
||||
|
|
|
|||
2
SWIG/Examples/test-suite/chicken/global_vars_runme.ss
Normal file
2
SWIG/Examples/test-suite/chicken/global_vars_runme.ss
Normal file
|
|
@ -0,0 +1,2 @@
|
|||
(require 'global_vars)
|
||||
(load "../schemerunme/global_vars.scm")
|
||||
|
|
@ -0,0 +1,2 @@
|
|||
(require 'global_vars)
|
||||
(load "../schemerunme/global_vars_proxy.scm")
|
||||
|
|
@ -1,2 +1,2 @@
|
|||
(load-library 'import_nomodule "import_nomodule.so")
|
||||
(load "import_nomodule.so")
|
||||
(include "../schemerunme/import_nomodule.scm")
|
||||
|
|
|
|||
|
|
@ -1,3 +1,3 @@
|
|||
(load-library 'imports_a "imports_a.so")
|
||||
(load-library 'imports_b "imports_b.so")
|
||||
(load "imports_a.so")
|
||||
(load "imports_b.so")
|
||||
(include "../schemerunme/imports.scm")
|
||||
|
|
|
|||
|
|
@ -1,2 +1,2 @@
|
|||
(load-library 'inherit_missing "inherit_missing.so")
|
||||
(load "inherit_missing.so")
|
||||
(include "../schemerunme/inherit_missing.scm")
|
||||
|
|
|
|||
|
|
@ -1,2 +1,2 @@
|
|||
(load-library 'li-std-string "li_std_string.so")
|
||||
(load "li_std_string.so")
|
||||
(include "../schemerunme/li_std_string.scm")
|
||||
|
|
|
|||
|
|
@ -0,0 +1,48 @@
|
|||
(load "li_std_string.so")
|
||||
|
||||
(define x "hello")
|
||||
|
||||
(if (not (string=? (test-value x) x))
|
||||
(begin (error "Error 1") (exit 1)))
|
||||
|
||||
(if (not (string=? (test-const-reference x) x))
|
||||
(begin (error "Error 2") (exit 1)))
|
||||
|
||||
(define y (test-pointer-out))
|
||||
(test-pointer y)
|
||||
(define z (test-const-pointer-out))
|
||||
(test-const-pointer z)
|
||||
|
||||
(define a (test-reference-out))
|
||||
(test-reference a)
|
||||
|
||||
;; test global variables
|
||||
(GlobalString "whee")
|
||||
(if (not (string=? (GlobalString) "whee"))
|
||||
(error "Error 3"))
|
||||
(if (not (string=? (GlobalString2) "global string 2"))
|
||||
(error "Error 4"))
|
||||
|
||||
(define struct (make <Structure>))
|
||||
|
||||
;; MemberString should be a wrapped class
|
||||
(define scl (slot-ref struct 'MemberString))
|
||||
(if (not (string=? (slot-ref scl 'str) ""))
|
||||
(error "Error 4.5"))
|
||||
(slot-set! scl 'str "and how")
|
||||
(if (not (string=? (slot-ref (slot-ref struct 'MemberString) 'str) "and how"))
|
||||
(error "Error 5"))
|
||||
(if (not (string=? (slot-ref struct 'MemberString2) "member string 2"))
|
||||
(error "Error 6"))
|
||||
(Structure-StaticMemberString "static str")
|
||||
(if (not (string=? (Structure-StaticMemberString) "static str"))
|
||||
(error "Error 7"))
|
||||
(if (not (string=? (Structure-StaticMemberString2) "static member string 2"))
|
||||
(error "Error 8"))
|
||||
|
||||
;(if (not (string=? (Structure-ConstMemberString-get struct) "const member string"))
|
||||
; (error "Error 9"))
|
||||
(if (not (string=? (Structure-ConstStaticMemberString) "const static member string"))
|
||||
(error "Error 10"))
|
||||
|
||||
(exit 0)
|
||||
2
SWIG/Examples/test-suite/chicken/li_typemaps_runme.ss
Normal file
2
SWIG/Examples/test-suite/chicken/li_typemaps_runme.ss
Normal file
|
|
@ -0,0 +1,2 @@
|
|||
(require 'li_typemaps)
|
||||
(load "../schemerunme/li_typemaps.scm")
|
||||
|
|
@ -0,0 +1,2 @@
|
|||
(require 'li_typemaps)
|
||||
(load "../schemerunme/li_typemaps_proxy.scm")
|
||||
|
|
@ -1,2 +1,2 @@
|
|||
(load-library 'list_vector "list_vector.so")
|
||||
(load "list_vector.so")
|
||||
(include "../schemerunme/list_vector.scm")
|
||||
|
|
|
|||
|
|
@ -0,0 +1,2 @@
|
|||
(require 'multiple_inheritance)
|
||||
(load "../schemerunme/multiple_inheritance_proxy.scm")
|
||||
|
|
@ -1,4 +1,4 @@
|
|||
;; this doesn't work yet :(
|
||||
(load-library 'multivalue "multivalue.so")
|
||||
(load "multivalue.so")
|
||||
(include "../schemerunme/multivalue.scm")
|
||||
(exit 0)
|
||||
|
|
|
|||
|
|
@ -1,2 +1,2 @@
|
|||
(load-library 'name "name.so")
|
||||
(load "name.so")
|
||||
(include "../schemerunme/name.scm")
|
||||
|
|
|
|||
30
SWIG/Examples/test-suite/chicken/newobject1_runme_proxy.ss
Normal file
30
SWIG/Examples/test-suite/chicken/newobject1_runme_proxy.ss
Normal file
|
|
@ -0,0 +1,30 @@
|
|||
(require 'newobject1)
|
||||
|
||||
(define-macro (check-count val)
|
||||
`(if (not (= (Foo-fooCount) ,val)) (error "Error checking val " ,val " != " ,(Foo-fooCount))))
|
||||
|
||||
(define f (Foo-makeFoo))
|
||||
|
||||
(check-count 1)
|
||||
|
||||
(define f2 (makeMore f))
|
||||
|
||||
(check-count 2)
|
||||
|
||||
(set! f #f)
|
||||
(gc #t)
|
||||
|
||||
(check-count 1)
|
||||
|
||||
(define f3 (makeMore f2))
|
||||
|
||||
(check-count 2)
|
||||
|
||||
(set! f3 #f)
|
||||
(set! f2 #f)
|
||||
|
||||
(gc #t)
|
||||
|
||||
(check-count 0)
|
||||
|
||||
(exit 0)
|
||||
|
|
@ -1,4 +1,4 @@
|
|||
(load-library 'newobject2 "newobject2.so")
|
||||
(load "newobject2.so")
|
||||
|
||||
(define f (new-Foo))
|
||||
|
||||
|
|
|
|||
|
|
@ -1,4 +1,4 @@
|
|||
(load-library 'newobject2 "newobject2.so")
|
||||
(load "newobject2.so")
|
||||
|
||||
(define f (make <Foo>))
|
||||
|
||||
|
|
|
|||
|
|
@ -1,2 +1,2 @@
|
|||
(load-library 'overload_complicated "overload_complicated.so")
|
||||
(load "overload_complicated.so")
|
||||
(include "../schemerunme/overload_complicated.scm")
|
||||
|
|
|
|||
|
|
@ -1,2 +1,2 @@
|
|||
(load-library 'overload_copy "overload_copy.so")
|
||||
(load "overload_copy.so")
|
||||
(include "../schemerunme/overload_copy.scm")
|
||||
|
|
|
|||
|
|
@ -1,6 +1,4 @@
|
|||
(require 'tinyclos)
|
||||
(load "../../../Lib/chicken/multi-generic.scm")
|
||||
(load-library 'overload-copy "./overload_copy.so")
|
||||
(load "./overload_copy.so")
|
||||
|
||||
(define f (make <Foo>))
|
||||
(define g (make <Foo> f))
|
||||
|
|
|
|||
|
|
@ -1,2 +1,2 @@
|
|||
(load-library 'overload_extend "overload_extend.so")
|
||||
(load "overload_extend.so")
|
||||
(include "../schemerunme/overload_extend.scm")
|
||||
|
|
|
|||
|
|
@ -1,6 +1,4 @@
|
|||
(require 'tinyclos)
|
||||
(load "../../../Lib/chicken/multi-generic.scm")
|
||||
(load-library 'overload-extend "./overload_extend.so")
|
||||
(load "./overload_extend.so")
|
||||
|
||||
(define f (make <Foo>))
|
||||
|
||||
|
|
|
|||
|
|
@ -1,2 +1,2 @@
|
|||
(load-library 'overload_simple "overload_simple.so")
|
||||
(load "overload_simple.so")
|
||||
(include "../schemerunme/overload_simple.scm")
|
||||
|
|
|
|||
|
|
@ -1,6 +1,4 @@
|
|||
(require 'tinyclos)
|
||||
(load "../../../Lib/chicken/multi-generic.scm")
|
||||
(load-library 'overload_simple "overload_simple.so")
|
||||
(load "overload_simple.so")
|
||||
|
||||
(define-macro (check test)
|
||||
`(if (not ,test) (error ',test)))
|
||||
|
|
|
|||
|
|
@ -1,2 +1,2 @@
|
|||
(load-library 'overload_subtype "overload_subtype.so")
|
||||
(load "overload_subtype.so")
|
||||
(include "../schemerunme/overload_subtype.scm")
|
||||
|
|
|
|||
|
|
@ -1,4 +1,4 @@
|
|||
(load-library 'overload-subtype "./overload_subtype.so")
|
||||
(load "./overload_subtype.so")
|
||||
|
||||
(define f (make <Foo>))
|
||||
(define b (make <Bar>))
|
||||
|
|
|
|||
|
|
@ -1,2 +1,2 @@
|
|||
(load-library 'pointer_in_out "pointer_in_out.so")
|
||||
(load "pointer_in_out.so")
|
||||
(include "../schemerunme/pointer_in_out.scm")
|
||||
|
|
|
|||
|
|
@ -1,2 +1,2 @@
|
|||
(load-library 'reference_global_vars "reference_global_vars.so")
|
||||
(load "reference_global_vars.so")
|
||||
(include "../schemerunme/reference_global_vars.scm")
|
||||
|
|
|
|||
|
|
@ -1,4 +1,4 @@
|
|||
(load-library 'throw-exception "throw_exception.so")
|
||||
(load "throw_exception.so")
|
||||
|
||||
(define-macro (check-throw expr check)
|
||||
`(if (handle-exceptions exvar (if ,check #f (begin (print "Error executing: " ',expr " " exvar) (exit 1))) ,expr #t)
|
||||
|
|
|
|||
|
|
@ -1,2 +1,2 @@
|
|||
(load-library 'typedef_inherit "typedef_inherit.so")
|
||||
(load "typedef_inherit.so")
|
||||
(include "../schemerunme/typedef_inherit.scm")
|
||||
|
|
|
|||
|
|
@ -1,2 +1,2 @@
|
|||
(load-library 'typename "typename.so")
|
||||
(load "typename.so")
|
||||
(include "../schemerunme/typename.scm")
|
||||
|
|
|
|||
|
|
@ -1,2 +1,2 @@
|
|||
(load-library 'unions "unions.so")
|
||||
(load "unions.so")
|
||||
(include "../schemerunme/unions.scm")
|
||||
|
|
|
|||
2
SWIG/Examples/test-suite/chicken/unions_runme_proxy.ss
Normal file
2
SWIG/Examples/test-suite/chicken/unions_runme_proxy.ss
Normal file
|
|
@ -0,0 +1,2 @@
|
|||
(load "unions.so")
|
||||
(include "../schemerunme/unions_proxy.scm")
|
||||
|
|
@ -96,6 +96,7 @@ CPP_TEST_CASES += \
|
|||
conversion_namespace \
|
||||
conversion_ns_template \
|
||||
cplusplus_throw \
|
||||
cpp_basic \
|
||||
cpp_enum \
|
||||
cpp_namespace \
|
||||
cpp_nodefault \
|
||||
|
|
|
|||
52
SWIG/Examples/test-suite/cpp_basic.i
Normal file
52
SWIG/Examples/test-suite/cpp_basic.i
Normal file
|
|
@ -0,0 +1,52 @@
|
|||
/* This is a basic test of proxy classes, used by chicken */
|
||||
|
||||
%module cpp_basic
|
||||
|
||||
%newobject Bar::testFoo;
|
||||
|
||||
%inline %{
|
||||
|
||||
class Foo {
|
||||
public:
|
||||
Foo(int a) : num(a) {}
|
||||
int num;
|
||||
};
|
||||
|
||||
%}
|
||||
|
||||
%{
|
||||
static Foo init_ref = Foo(-4);
|
||||
%}
|
||||
|
||||
%inline %{
|
||||
class Bar {
|
||||
public:
|
||||
Bar() : fptr(0), fref(init_ref), fval(15) , cint(3) {}
|
||||
|
||||
Foo *fptr;
|
||||
Foo &fref;
|
||||
Foo fval;
|
||||
|
||||
const int cint;
|
||||
static const int global_cint = -4;
|
||||
|
||||
static Foo *global_fptr;
|
||||
static Foo &global_fref;
|
||||
static Foo global_fval;
|
||||
|
||||
int test(int a, Foo *f) {
|
||||
return a + (f ? f->num : 0) + fval.num;
|
||||
}
|
||||
|
||||
Foo *testFoo(int a, Foo *f) {
|
||||
return new Foo(2 * a + (f ? f->num : 0) + fval.num);
|
||||
}
|
||||
};
|
||||
|
||||
%}
|
||||
|
||||
%{
|
||||
Foo *Bar::global_fptr = NULL;
|
||||
Foo &Bar::global_fref = init_ref;
|
||||
Foo Bar::global_fval = Foo(3);
|
||||
%}
|
||||
8
SWIG/Examples/test-suite/guile/li_typemaps_runme.scm
Normal file
8
SWIG/Examples/test-suite/guile/li_typemaps_runme.scm
Normal file
|
|
@ -0,0 +1,8 @@
|
|||
;;; This is the union runtime testcase. It ensures that values within a
|
||||
;;; union embedded within a struct can be set and read correctly.
|
||||
|
||||
;; The SWIG modules have "passive" Linkage, i.e., they don't generate
|
||||
;; Guile modules (namespaces) but simply put all the bindings into the
|
||||
;; current module. That's enough for such a simple test.
|
||||
(dynamic-call "scm_init_li_typemaps_module" (dynamic-link "./libli_typemaps.so"))
|
||||
(load "../schemerunme/li_typemaps.scm")
|
||||
|
|
@ -3,8 +3,11 @@
|
|||
%include "typemaps.i"
|
||||
|
||||
%apply int &INOUT { int &INOUT2 };
|
||||
%newobject out_foo;
|
||||
%inline %{
|
||||
|
||||
struct Foo { int a; };
|
||||
|
||||
bool in_bool(bool *INPUT) { return *INPUT; }
|
||||
int in_int(int *INPUT) { return *INPUT; }
|
||||
long in_long(long *INPUT) { return *INPUT; }
|
||||
|
|
@ -47,6 +50,14 @@ void out_double(double x, double *OUTPUT) { *OUTPUT = x; }
|
|||
void out_longlong(long long x, long long *OUTPUT) { *OUTPUT = x; }
|
||||
void out_ulonglong(unsigned long long x, unsigned long long *OUTPUT) { *OUTPUT = x; }
|
||||
|
||||
/* Tests a returning a wrapped pointer and an output argument */
|
||||
struct Foo *out_foo(int a, int *OUTPUT) {
|
||||
struct Foo *f = new struct Foo();
|
||||
f->a = a;
|
||||
*OUTPUT = a * 2;
|
||||
return f;
|
||||
}
|
||||
|
||||
void outr_bool(bool x, bool &OUTPUT) { OUTPUT = x; }
|
||||
void outr_int(int x, int &OUTPUT) { OUTPUT = x; }
|
||||
void outr_short(short x, short &OUTPUT) { OUTPUT = x; }
|
||||
|
|
|
|||
31
SWIG/Examples/test-suite/schemerunme/global_vars.scm
Normal file
31
SWIG/Examples/test-suite/schemerunme/global_vars.scm
Normal file
|
|
@ -0,0 +1,31 @@
|
|||
(define-macro (check test)
|
||||
`(if (not ,test) (error "Error in test" ',test)))
|
||||
|
||||
(b "hello")
|
||||
(check (string=? (b) "hello"))
|
||||
|
||||
(define sa (new-A))
|
||||
(A-x-set sa 5)
|
||||
(a sa)
|
||||
(check (= (A-x-get (a)) 5))
|
||||
|
||||
(ap sa)
|
||||
(check (= (A-x-get (ap)) 5))
|
||||
(A-x-set sa 10)
|
||||
(check (= (A-x-get (ap)) 10))
|
||||
|
||||
(define sa2 (new-A))
|
||||
(A-x-set sa2 -4)
|
||||
(cap sa2)
|
||||
(check (= (A-x-get (cap)) -4))
|
||||
(A-x-set sa2 -7)
|
||||
(check (= (A-x-get (cap)) -7))
|
||||
|
||||
(check (= (A-x-get (ar)) 5))
|
||||
(ar sa2)
|
||||
(check (= (A-x-get (ar)) -7))
|
||||
|
||||
(x 4)
|
||||
(check (= (x) 4))
|
||||
|
||||
(exit 0)
|
||||
31
SWIG/Examples/test-suite/schemerunme/global_vars_proxy.scm
Normal file
31
SWIG/Examples/test-suite/schemerunme/global_vars_proxy.scm
Normal file
|
|
@ -0,0 +1,31 @@
|
|||
(define-macro (check test)
|
||||
`(if (not ,test) (error "Error in test" ',test)))
|
||||
|
||||
(b "hello")
|
||||
(check (string=? (b) "hello"))
|
||||
|
||||
(define sa (make <A>))
|
||||
(slot-set! sa 'x 5)
|
||||
(a sa)
|
||||
(check (= (slot-ref (a) 'x) 5))
|
||||
|
||||
(ap sa)
|
||||
(check (= (slot-ref (ap) 'x) 5))
|
||||
(slot-set! sa 'x 10)
|
||||
(check (= (slot-ref (ap) 'x) 10))
|
||||
|
||||
(define sa2 (make <A>))
|
||||
(slot-set! sa2 'x -4)
|
||||
(cap sa2)
|
||||
(check (= (slot-ref (cap) 'x) -4))
|
||||
(slot-set! sa2 'x -7)
|
||||
(check (= (slot-ref (cap) 'x) -7))
|
||||
|
||||
(check (= (slot-ref (ar) 'x) 5))
|
||||
(ar sa2)
|
||||
(check (= (slot-ref (ar) 'x) -7))
|
||||
|
||||
(x 4)
|
||||
(check (= (x) 4))
|
||||
|
||||
(exit 0)
|
||||
|
|
@ -14,4 +14,33 @@
|
|||
(define a (test-reference-out))
|
||||
(test-reference a)
|
||||
|
||||
;; test global variables
|
||||
(GlobalString "whee")
|
||||
(if (not (string=? (GlobalString) "whee"))
|
||||
(error "Error 3"))
|
||||
(if (not (string=? (GlobalString2) "global string 2"))
|
||||
(error "Error 4"))
|
||||
|
||||
(define struct (new-Structure))
|
||||
|
||||
;; MemberString should be a wrapped class
|
||||
(define scl (Structure-MemberString-get struct))
|
||||
(if (not (string=? (std-string-str-get scl) ""))
|
||||
(error "Error 4.5"))
|
||||
(std-string-str-set scl "and how")
|
||||
(if (not (string=? (std-string-str-get (Structure-MemberString-get struct)) "and how"))
|
||||
(error "Error 5"))
|
||||
(if (not (string=? (Structure-MemberString2-get struct) "member string 2"))
|
||||
(error "Error 6"))
|
||||
(Structure-StaticMemberString "static str")
|
||||
(if (not (string=? (Structure-StaticMemberString) "static str"))
|
||||
(error "Error 7"))
|
||||
(if (not (string=? (Structure-StaticMemberString2) "static member string 2"))
|
||||
(error "Error 8"))
|
||||
|
||||
;(if (not (string=? (Structure-ConstMemberString-get struct) "const member string"))
|
||||
; (error "Error 9"))
|
||||
(if (not (string=? (Structure-ConstStaticMemberString) "const static member string"))
|
||||
(error "Error 10"))
|
||||
|
||||
(exit 0)
|
||||
|
|
|
|||
34
SWIG/Examples/test-suite/schemerunme/li_typemaps.scm
Normal file
34
SWIG/Examples/test-suite/schemerunme/li_typemaps.scm
Normal file
|
|
@ -0,0 +1,34 @@
|
|||
(define-macro (check func val test)
|
||||
(cons 'begin
|
||||
(map
|
||||
(lambda (x)
|
||||
`(if (not (,test (,(string->symbol (string-append x func)) ,val) ,val))
|
||||
(error ,(string-append "Error in test " x func))))
|
||||
(list "in-" "inr-" "out-" "outr-" "inout-" "inoutr-"))))
|
||||
|
||||
(define (=~ a b)
|
||||
(< (abs (- a b)) 1e-5))
|
||||
|
||||
(check "bool" #t and)
|
||||
(check "int" -2 =)
|
||||
(check "long" -32 =)
|
||||
(check "short" -15 =)
|
||||
(check "uint" 75 =)
|
||||
(check "ushort" 123 =)
|
||||
(check "ulong" 462 =)
|
||||
;(check "uchar" 16 =)
|
||||
;(check "schar" -53 =)
|
||||
(check "float" 4.3 =~)
|
||||
(check "double" -175.42 =~)
|
||||
;(check "longlong" 1634 =)
|
||||
;(check "ulonglong" 6432 =)
|
||||
|
||||
(let ((lst (inoutr-int2 3 -2)))
|
||||
(if (not (and (= (car lst) 3) (= (cadr lst) -2)))
|
||||
(error "Error in inoutr-int2")))
|
||||
|
||||
(let ((lst (out-foo 4)))
|
||||
(if (not (and (= (Foo-a-get (car lst)) 4) (= (cadr lst) 8)))
|
||||
(error "Error in out-foo")))
|
||||
|
||||
(exit 0)
|
||||
34
SWIG/Examples/test-suite/schemerunme/li_typemaps_proxy.scm
Normal file
34
SWIG/Examples/test-suite/schemerunme/li_typemaps_proxy.scm
Normal file
|
|
@ -0,0 +1,34 @@
|
|||
(define-macro (check func val test)
|
||||
(cons 'begin
|
||||
(map
|
||||
(lambda (x)
|
||||
`(if (not (,test (,(string->symbol (string-append x func)) ,val) ,val))
|
||||
(error ,(string-append "Error in test " x func))))
|
||||
(list "in-" "inr-" "out-" "outr-" "inout-" "inoutr-"))))
|
||||
|
||||
(define (=~ a b)
|
||||
(< (abs (- a b)) 1e-5))
|
||||
|
||||
(check "bool" #t and)
|
||||
(check "int" -2 =)
|
||||
(check "long" -32 =)
|
||||
(check "short" -15 =)
|
||||
(check "uint" 75 =)
|
||||
(check "ushort" 123 =)
|
||||
(check "ulong" 462 =)
|
||||
;(check "uchar" 16 =)
|
||||
;(check "schar" -53 =)
|
||||
(check "float" 4.3 =~)
|
||||
(check "double" -175.42 =~)
|
||||
(check "longlong" 1634 =)
|
||||
(check "ulonglong" 6432 =)
|
||||
|
||||
(let ((lst (inoutr-int2 3 -2)))
|
||||
(if (not (and (= (car lst) 3) (= (cadr lst) -2)))
|
||||
(error "Error in inoutr-int2")))
|
||||
|
||||
(let ((lst (out-foo 4)))
|
||||
(if (not (and (= (slot-ref (car lst) 'a) 4) (= (cadr lst) 8)))
|
||||
(error "Error in out-foo")))
|
||||
|
||||
(exit 0)
|
||||
|
|
@ -0,0 +1,15 @@
|
|||
(define-macro (check test)
|
||||
`(if (not ,test) (error "Error in test" ',test)))
|
||||
|
||||
(define b (make <Bar>))
|
||||
(check (= (bar b) 1))
|
||||
|
||||
(define f (make <Foo>))
|
||||
(check (= (foo f) 2))
|
||||
|
||||
(define fb (make <FooBar>))
|
||||
(check (= (bar fb) 1))
|
||||
(check (= (foo fb) 2))
|
||||
(check (= (fooBar fb) 3))
|
||||
|
||||
(exit 0)
|
||||
37
SWIG/Examples/test-suite/schemerunme/unions_proxy.scm
Normal file
37
SWIG/Examples/test-suite/schemerunme/unions_proxy.scm
Normal file
|
|
@ -0,0 +1,37 @@
|
|||
;;; This is the union runtime testcase. It ensures that values within a
|
||||
;;; union embedded within a struct can be set and read correctly.
|
||||
|
||||
;; Create new instances of SmallStruct and BigStruct for later use
|
||||
(define small (make <SmallStruct>))
|
||||
(slot-set! small 'jill 200)
|
||||
|
||||
(define big (make <BigStruct>))
|
||||
(slot-set! big 'smallstruct small)
|
||||
(slot-set! big 'jack 300)
|
||||
|
||||
;; Use SmallStruct then BigStruct to setup EmbeddedUnionTest.
|
||||
;; Ensure values in EmbeddedUnionTest are set correctly for each.
|
||||
(define eut (make <EmbeddedUnionTest>))
|
||||
|
||||
;; First check the SmallStruct in EmbeddedUnionTest
|
||||
(slot-set! eut 'number 1)
|
||||
(slot-set! (slot-ref eut 'uni) 'small small)
|
||||
(let ((Jill1 (slot-ref
|
||||
(slot-ref
|
||||
(slot-ref eut 'uni)
|
||||
'small)
|
||||
'jill)))
|
||||
(if (not (= Jill1 200))
|
||||
(begin
|
||||
(display "Runtime test 1 failed.")
|
||||
(exit 1))))
|
||||
|
||||
(let ((Num1 (slot-ref eut 'number)))
|
||||
(if (not (= Num1 1))
|
||||
(begin
|
||||
(display "Runtime test 2 failed.")
|
||||
(exit 1))))
|
||||
|
||||
;; that should do
|
||||
|
||||
(exit 0)
|
||||
Loading…
Add table
Add a link
Reference in a new issue