summaryrefslogtreecommitdiff
path: root/Examples/test-suite/php/li_std_string_runme.php
blob: 169f947a7f4ad360a914bac5331756075a0c6998 (plain)
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
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
<?php

require "tests.php";

# Checking expected use of %typemap(in) std::string {}
li_std_string::test_value("Fee");

# Checking expected result of %typemap(out) std::string {}
check::equal(li_std_string::test_value("Fi"), "Fi", "Test 1");

# 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& {}
check::equal(li_std_string::test_const_reference("Fum"), "Fum", "Test 3");

# 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.

$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);

// Global variables
$s = "initial string";
check::equal(GlobalString2_get(), "global string 2", "GlobalString2 test 1");
GlobalString2_set($s);
check::equal(GlobalString2_get(), $s, "GlobalString2 test 2");
check::equal(ConstGlobalString_get(), "const global string", "ConstGlobalString test");

// Member variables
$myStructure = new Structure();
check::equal($myStructure->MemberString2, "member string 2", "MemberString2 test 1");
$myStructure->MemberString2 = $s;
check::equal($myStructure->MemberString2, $s, "MemberString2 test 2");
check::equal($myStructure->ConstMemberString, "const member string", "ConstMemberString test");

check::equal(Structure::StaticMemberString2(), "static member string 2", "StaticMemberString2 test 1");
Structure::StaticMemberString2($s);
check::equal(Structure::StaticMemberString2(), $s, "StaticMemberString2 test 2");
check::equal(Structure::ConstStaticMemberString(), "const static member string", "ConstStaticMemberString test");

// Test INPUT, INOUT and OUTPUT string& typemaps:
$input = "hello";
check::equal(li_std_string::test_reference_input($input), "hello");
// $input should be unchanged - this check is to catch if we incorrectly used
// the default string& typemap:
check::equal($input, "hello");
$s = li_std_string::test_reference_inout($input);
check::equal($s, "hellohello");
// $input should be unchanged - this check is to catch if we incorrectly used
// the default string& typemap:
check::equal($input, "hello");
check::equal(li_std_string::test_reference_output(), "output");

// Test default PHP wrapping of std::string& as a by-ref PHP string parameter:
$s = "byref";
check::equal(li_std_string::test_reference_php($s), null);
check::equal($s, "byref.php");

// This used to give "Undefined variable: r"
li_std_string::test_const_reference_returning_void("foo");

check::done();