1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57
|
using System;
using li_std_stringNamespace;
public class runme
{
static void Main()
{
// Checking expected use of %typemap(in) std::string {}
li_std_string.test_value("Fee");
// Checking expected result of %typemap(out) std::string {}
if (li_std_string.test_value("Fi") != "Fi")
throw new Exception("Test 1 failed");
// Verify type-checking for %typemap(in) std::string {}
try {
li_std_string.test_value(null);
throw new Exception("Test 2 failed");
} catch (NullReferenceException) {
}
// Checking expected use of %typemap(in) const std::string & {}
li_std_string.test_const_reference("Fo");
// Checking expected result of %typemap(out) const std::string& {}
if (li_std_string.test_const_reference("Fum") != "Fum")
throw new Exception("Test 3 failed");
// Verify type-checking for %typemap(in) const std::string & {}
try {
li_std_string.test_const_reference(null);
throw new Exception("Test 4 failed");
} catch (NullReferenceException) {
}
//
// 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.
//
SWIGTYPE_p_std__string stringPtr = null;
stringPtr = li_std_string.test_pointer_out();
li_std_string.test_pointer(stringPtr);
stringPtr = li_std_string.test_const_pointer_out();
li_std_string.test_const_pointer(stringPtr);
stringPtr = li_std_string.test_reference_out();
li_std_string.test_reference(stringPtr);
}
}
|