1// Copyright 2007, Google Inc.
2// All rights reserved.
3//
4// Redistribution and use in source and binary forms, with or without
5// modification, are permitted provided that the following conditions are
6// met:
7//
8// * Redistributions of source code must retain the above copyright
9// notice, this list of conditions and the following disclaimer.
10// * Redistributions in binary form must reproduce the above
11// copyright notice, this list of conditions and the following disclaimer
12// in the documentation and/or other materials provided with the
13// distribution.
14// * Neither the name of Google Inc. nor the names of its
15// contributors may be used to endorse or promote products derived from
16// this software without specific prior written permission.
17//
18// THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
19// "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
20// LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
21// A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
22// OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
23// SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
24// LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
25// DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
26// THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
27// (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
28// OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
29
30// The Google C++ Testing and Mocking Framework (Google Test)
31//
32// This file implements just enough of the matcher interface to allow
33// EXPECT_DEATH and friends to accept a matcher argument.
34
35#include "gtest/gtest-matchers.h"
36
37#include <string>
38
39#include "gtest/internal/gtest-internal.h"
40#include "gtest/internal/gtest-port.h"
41
42namespace testing {
43
44// Constructs a matcher that matches a const std::string& whose value is
45// equal to s.
46Matcher<const std::string&>::Matcher(const std::string& s) { *this = Eq(x: s); }
47
48// Constructs a matcher that matches a const std::string& whose value is
49// equal to s.
50Matcher<const std::string&>::Matcher(const char* s) {
51 *this = Eq(x: std::string(s));
52}
53
54// Constructs a matcher that matches a std::string whose value is equal to
55// s.
56Matcher<std::string>::Matcher(const std::string& s) { *this = Eq(x: s); }
57
58// Constructs a matcher that matches a std::string whose value is equal to
59// s.
60Matcher<std::string>::Matcher(const char* s) { *this = Eq(x: std::string(s)); }
61
62#if GTEST_INTERNAL_HAS_STRING_VIEW
63// Constructs a matcher that matches a const StringView& whose value is
64// equal to s.
65Matcher<const internal::StringView&>::Matcher(const std::string& s) {
66 *this = Eq(x: s);
67}
68
69// Constructs a matcher that matches a const StringView& whose value is
70// equal to s.
71Matcher<const internal::StringView&>::Matcher(const char* s) {
72 *this = Eq(x: std::string(s));
73}
74
75// Constructs a matcher that matches a const StringView& whose value is
76// equal to s.
77Matcher<const internal::StringView&>::Matcher(internal::StringView s) {
78 *this = Eq(x: std::string(s));
79}
80
81// Constructs a matcher that matches a StringView whose value is equal to
82// s.
83Matcher<internal::StringView>::Matcher(const std::string& s) { *this = Eq(x: s); }
84
85// Constructs a matcher that matches a StringView whose value is equal to
86// s.
87Matcher<internal::StringView>::Matcher(const char* s) {
88 *this = Eq(x: std::string(s));
89}
90
91// Constructs a matcher that matches a StringView whose value is equal to
92// s.
93Matcher<internal::StringView>::Matcher(internal::StringView s) {
94 *this = Eq(x: std::string(s));
95}
96#endif // GTEST_INTERNAL_HAS_STRING_VIEW
97
98} // namespace testing
99