summaryrefslogtreecommitdiffstats
path: root/Tests
diff options
context:
space:
mode:
authorBrad King <brad.king@kitware.com>2018-10-04 00:08:18 (GMT)
committerBrad King <brad.king@kitware.com>2018-12-12 13:10:15 (GMT)
commit9d5fe8e96a074b6e112d981302c77e31a1bcde00 (patch)
tree9a080e37d2b2d6e111ca958e7d9482ed62083c63 /Tests
parent80802a002c16249e99c24f62adb8ffbe006b97e0 (diff)
downloadCMake-9d5fe8e96a074b6e112d981302c77e31a1bcde00.zip
CMake-9d5fe8e96a074b6e112d981302c77e31a1bcde00.tar.gz
CMake-9d5fe8e96a074b6e112d981302c77e31a1bcde00.tar.bz2
String: Add 'borrow' member to construct borrowing instances
This will allow creation of `cm::String` instances that borrow from non-owned storage. It is the caller's responsibility to ensure that no copy of the instance outlives the borrowed buffer.
Diffstat (limited to 'Tests')
-rw-r--r--Tests/CMakeLib/testString.cxx32
1 files changed, 32 insertions, 0 deletions
diff --git a/Tests/CMakeLib/testString.cxx b/Tests/CMakeLib/testString.cxx
index 63688af..411a61a 100644
--- a/Tests/CMakeLib/testString.cxx
+++ b/Tests/CMakeLib/testString.cxx
@@ -469,6 +469,17 @@ static bool testOperatorStdStringPlusEqual()
return true;
}
+static bool testMethod_borrow()
+{
+ std::cout << "testMethod_borrow()\n";
+ std::string s = "abc";
+ cm::String str = cm::String::borrow(s);
+ ASSERT_TRUE(str.data() == s.data());
+ ASSERT_TRUE(str.size() == s.size());
+ ASSERT_TRUE(str == s);
+ return true;
+}
+
static bool testMethod_view()
{
std::cout << "testMethod_view()\n";
@@ -716,6 +727,12 @@ static bool testMethod_substr_AtEnd(cm::String str)
return true;
}
+static bool testMethod_substr_AtEndBorrowed()
+{
+ std::cout << "testMethod_substr_AtEndBorrowed()\n";
+ return testMethod_substr_AtEnd(cm::String::borrow("abc"));
+}
+
static bool testMethod_substr_AtEndOwned()
{
std::cout << "testMethod_substr_AtEndOwned()\n";
@@ -764,6 +781,12 @@ static bool testMethod_substr_AtStart(cm::String str)
return true;
}
+static bool testMethod_substr_AtStartBorrowed()
+{
+ std::cout << "testMethod_substr_AtStartBorrowed()\n";
+ return testMethod_substr_AtStart(cm::String::borrow("abc"));
+}
+
static bool testMethod_substr_AtStartOwned()
{
std::cout << "testMethod_substr_AtStartOwned()\n";
@@ -1132,6 +1155,9 @@ int testString(int /*unused*/, char* /*unused*/ [])
if (!testOperatorStdStringPlusEqual()) {
return 1;
}
+ if (!testMethod_borrow()) {
+ return 1;
+ }
if (!testMethod_view()) {
return 1;
}
@@ -1177,9 +1203,15 @@ int testString(int /*unused*/, char* /*unused*/ [])
if (!testMethodIterators()) {
return 1;
}
+ if (!testMethod_substr_AtEndBorrowed()) {
+ return 1;
+ }
if (!testMethod_substr_AtEndOwned()) {
return 1;
}
+ if (!testMethod_substr_AtStartBorrowed()) {
+ return 1;
+ }
if (!testMethod_substr_AtStartOwned()) {
return 1;
}