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