*** empty log message ***
git-svn-id: https://swig.svn.sourceforge.net/svnroot/swig/trunk@4478 626c5289-ae23-0410-ae9c-e8d60b6d4f22
This commit is contained in:
parent
3525f78b58
commit
80c2ff17c4
2 changed files with 69 additions and 12 deletions
|
|
@ -3,23 +3,35 @@
|
|||
|
||||
%inline %{
|
||||
|
||||
std::string test_value_in(std::string x) {
|
||||
std::string test_value(std::string x) {
|
||||
return x;
|
||||
}
|
||||
|
||||
std::string *test_pointer_in(std::string *x) {
|
||||
const std::string& test_const_reference(const std::string &x) {
|
||||
return x;
|
||||
}
|
||||
|
||||
const std::string *test_const_pointer_in(const std::string *x) {
|
||||
return x;
|
||||
void test_pointer(std::string *x) {
|
||||
}
|
||||
|
||||
std::string test_reference_in(std::string &x) {
|
||||
return x;
|
||||
std::string *test_pointer_out() {
|
||||
static std::string x = "x";
|
||||
return &x;
|
||||
}
|
||||
|
||||
std::string test_const_reference_in(const std::string &x) {
|
||||
void test_const_pointer(const std::string *x) {
|
||||
}
|
||||
|
||||
const std::string *test_const_pointer_out() {
|
||||
static std::string x = "x";
|
||||
return &x;
|
||||
}
|
||||
|
||||
void test_reference(std::string &x) {
|
||||
}
|
||||
|
||||
std::string& test_reference_out() {
|
||||
static std::string x = "x";
|
||||
return x;
|
||||
}
|
||||
|
||||
|
|
|
|||
|
|
@ -3,15 +3,15 @@ require 'lib_std_string'
|
|||
include Lib_std_string
|
||||
|
||||
# Checking expected use of %typemap(in) std::string {}
|
||||
test_value_in("Fee")
|
||||
test_value("Fee")
|
||||
|
||||
# Checking expected result of %typemap(out) std::string {}
|
||||
raise RuntimeError unless test_value_in("Fi") == "Fi"
|
||||
raise RuntimeError unless test_value("Fi") == "Fi"
|
||||
|
||||
# Verify type-checking for %typemap(in) std::string {}
|
||||
exceptionRaised = false
|
||||
begin
|
||||
test_value_in(0)
|
||||
test_value(0)
|
||||
rescue TypeError
|
||||
exceptionRaised = true
|
||||
ensure
|
||||
|
|
@ -19,15 +19,60 @@ ensure
|
|||
end
|
||||
|
||||
# Checking expected use of %typemap(in) const std::string & {}
|
||||
test_const_reference_in("Fo")
|
||||
test_const_reference("Fo")
|
||||
|
||||
# Checking expected result of %typemap(out) const std::string& {}
|
||||
raise RuntimeError unless test_const_reference("Fum") == "Fum"
|
||||
|
||||
# Verify type-checking for %typemap(in) const std::string & {}
|
||||
exceptionRaised = false
|
||||
begin
|
||||
test_const_reference_in(0)
|
||||
test_const_reference(0)
|
||||
rescue TypeError
|
||||
exceptionRaised = true
|
||||
ensure
|
||||
raise RuntimeError unless exceptionRaised
|
||||
end
|
||||
|
||||
#
|
||||
# Input and output typemaps for pointers and non-const references to
|
||||
# std::string are *not* supported; the following tests confirm
|
||||
# that none of these cases are slipping through.
|
||||
#
|
||||
|
||||
exceptionRaised = false
|
||||
begin
|
||||
test_pointer("foo")
|
||||
rescue TypeError
|
||||
exceptionRaised = true
|
||||
ensure
|
||||
raise RuntimeError unless exceptionRaised
|
||||
end
|
||||
|
||||
result = test_pointer_out()
|
||||
raise RuntimeError if result.is_a? String
|
||||
|
||||
exceptionRaised = false
|
||||
begin
|
||||
test_const_pointer("bar")
|
||||
rescue TypeError
|
||||
exceptionRaised = true
|
||||
ensure
|
||||
raise RuntimeError unless exceptionRaised
|
||||
end
|
||||
|
||||
result = test_const_pointer_out()
|
||||
raise RuntimeError if result.is_a? String
|
||||
|
||||
exceptionRaised = false
|
||||
begin
|
||||
test_reference("foo")
|
||||
rescue TypeError
|
||||
exceptionRaised = true
|
||||
ensure
|
||||
raise RuntimeError unless exceptionRaised
|
||||
end
|
||||
|
||||
result = test_reference_out()
|
||||
raise RuntimeError if result.is_a? String
|
||||
|
||||
|
|
|
|||
Loading…
Add table
Add a link
Reference in a new issue