cppjieba_rb 0.4.1 → 0.4.4
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +4 -4
- data/.editorconfig +21 -0
- data/.github/workflows/linting.yml +30 -0
- data/.github/workflows/release.yml +42 -0
- data/.github/workflows/tests.yml +47 -0
- data/.gitignore +1 -0
- data/.rubocop.yml +45 -0
- data/.ruby-version +1 -0
- data/.yamllint +35 -0
- data/CHANGELOG.md +17 -0
- data/Gemfile +11 -0
- data/README.md +5 -5
- data/Rakefile +16 -7
- data/cppjieba_rb.gemspec +46 -33
- data/ext/cppjieba/.github/workflows/cmake.yml +52 -0
- data/ext/cppjieba/.github/workflows/stale-issues.yml +24 -0
- data/ext/cppjieba/.gitmodules +3 -0
- data/ext/cppjieba/{ChangeLog.md → CHANGELOG.md} +50 -1
- data/ext/cppjieba/CMakeLists.txt +11 -14
- data/ext/cppjieba/LICENSE +20 -0
- data/ext/cppjieba/README.md +9 -18
- data/ext/cppjieba/deps/limonp/.github/workflows/cmake.yml +43 -0
- data/ext/cppjieba/deps/limonp/.gitignore +9 -0
- data/ext/cppjieba/deps/limonp/CHANGELOG.md +160 -0
- data/ext/cppjieba/deps/limonp/CMakeLists.txt +61 -0
- data/ext/cppjieba/deps/limonp/LICENSE +20 -0
- data/ext/cppjieba/deps/limonp/README.md +38 -0
- data/ext/cppjieba/deps/limonp/{LocalVector.hpp → include/limonp/LocalVector.hpp} +3 -3
- data/ext/cppjieba/deps/limonp/{Logging.hpp → include/limonp/Logging.hpp} +17 -3
- data/ext/cppjieba/deps/limonp/{StringUtil.hpp → include/limonp/StringUtil.hpp} +31 -10
- data/ext/cppjieba/deps/limonp/test/CMakeLists.txt +8 -0
- data/ext/cppjieba/deps/limonp/test/demo.cpp +40 -0
- data/ext/cppjieba/deps/limonp/test/testdata/1.conf +5 -0
- data/ext/cppjieba/deps/limonp/test/testdata/StdExtension.data +3 -0
- data/ext/cppjieba/deps/limonp/test/testdata/dict.gbk +50 -0
- data/ext/cppjieba/deps/limonp/test/testdata/dict.utf8 +50 -0
- data/ext/cppjieba/deps/limonp/test/testdata/io_testfile +2 -0
- data/ext/cppjieba/deps/limonp/test/testdata/jieba.dict.0.1.utf8 +93 -0
- data/ext/cppjieba/deps/limonp/test/testdata/jieba.dict.0.utf8 +93 -0
- data/ext/cppjieba/deps/limonp/test/testdata/jieba.dict.1.utf8 +67 -0
- data/ext/cppjieba/deps/limonp/test/testdata/jieba.dict.2.utf8 +64 -0
- data/ext/cppjieba/deps/limonp/test/unittest/CMakeLists.txt +30 -0
- data/ext/cppjieba/deps/limonp/test/unittest/TArgvContext.cpp +16 -0
- data/ext/cppjieba/deps/limonp/test/unittest/TCastFloat.cpp +19 -0
- data/ext/cppjieba/deps/limonp/test/unittest/TClosure.cpp +85 -0
- data/ext/cppjieba/deps/limonp/test/unittest/TColorPrint.cpp +20 -0
- data/ext/cppjieba/deps/limonp/test/unittest/TConfig.cpp +17 -0
- data/ext/cppjieba/deps/limonp/test/unittest/TLocalVector.cpp +41 -0
- data/ext/cppjieba/deps/limonp/test/unittest/TLogging.cpp +12 -0
- data/ext/cppjieba/deps/limonp/test/unittest/TStdExtension.cpp +95 -0
- data/ext/cppjieba/deps/limonp/test/unittest/TStringUtil.cpp +183 -0
- data/ext/cppjieba/include/cppjieba/DictTrie.hpp +9 -0
- data/ext/cppjieba/include/cppjieba/Jieba.hpp +4 -0
- data/ext/cppjieba/include/cppjieba/Trie.hpp +27 -1
- data/ext/cppjieba/test/CMakeLists.txt +4 -3
- data/ext/cppjieba/test/unittest/CMakeLists.txt +16 -7
- data/ext/cppjieba_rb/extconf.rb +11 -6
- data/ext/cppjieba_rb/internal.cc +1 -1
- data/lib/cppjieba_rb/segment.rb +4 -1
- data/lib/cppjieba_rb/version.rb +3 -1
- data/lib/cppjieba_rb.rb +12 -5
- data/test/test_keyword.rb +8 -8
- data/test/test_segment.rb +14 -10
- data/test/test_stop_word_filter.rb +5 -3
- data/test/test_tagging.rb +5 -2
- metadata +63 -140
- data/.travis.yml +0 -30
- data/ext/cppjieba/.travis.yml +0 -21
- data/ext/cppjieba/README_EN.md +0 -115
- data/ext/cppjieba/appveyor.yml +0 -32
- data/ext/cppjieba/deps/CMakeLists.txt +0 -1
- data/ext/cppjieba/deps/gtest/CMakeLists.txt +0 -5
- data/ext/cppjieba/deps/gtest/include/gtest/gtest-death-test.h +0 -283
- data/ext/cppjieba/deps/gtest/include/gtest/gtest-message.h +0 -230
- data/ext/cppjieba/deps/gtest/include/gtest/gtest-param-test.h +0 -1421
- data/ext/cppjieba/deps/gtest/include/gtest/gtest-param-test.h.pump +0 -487
- data/ext/cppjieba/deps/gtest/include/gtest/gtest-printers.h +0 -796
- data/ext/cppjieba/deps/gtest/include/gtest/gtest-spi.h +0 -232
- data/ext/cppjieba/deps/gtest/include/gtest/gtest-test-part.h +0 -176
- data/ext/cppjieba/deps/gtest/include/gtest/gtest-typed-test.h +0 -259
- data/ext/cppjieba/deps/gtest/include/gtest/gtest.h +0 -2155
- data/ext/cppjieba/deps/gtest/include/gtest/gtest_pred_impl.h +0 -358
- data/ext/cppjieba/deps/gtest/include/gtest/gtest_prod.h +0 -58
- data/ext/cppjieba/deps/gtest/include/gtest/internal/gtest-death-test-internal.h +0 -308
- data/ext/cppjieba/deps/gtest/include/gtest/internal/gtest-filepath.h +0 -210
- data/ext/cppjieba/deps/gtest/include/gtest/internal/gtest-internal.h +0 -1226
- data/ext/cppjieba/deps/gtest/include/gtest/internal/gtest-linked_ptr.h +0 -233
- data/ext/cppjieba/deps/gtest/include/gtest/internal/gtest-param-util-generated.h +0 -4822
- data/ext/cppjieba/deps/gtest/include/gtest/internal/gtest-param-util-generated.h.pump +0 -301
- data/ext/cppjieba/deps/gtest/include/gtest/internal/gtest-param-util.h +0 -619
- data/ext/cppjieba/deps/gtest/include/gtest/internal/gtest-port.h +0 -1788
- data/ext/cppjieba/deps/gtest/include/gtest/internal/gtest-string.h +0 -350
- data/ext/cppjieba/deps/gtest/include/gtest/internal/gtest-tuple.h +0 -968
- data/ext/cppjieba/deps/gtest/include/gtest/internal/gtest-tuple.h.pump +0 -336
- data/ext/cppjieba/deps/gtest/include/gtest/internal/gtest-type-util.h +0 -3330
- data/ext/cppjieba/deps/gtest/include/gtest/internal/gtest-type-util.h.pump +0 -296
- data/ext/cppjieba/deps/gtest/src/.deps/gtest-all.Plo +0 -681
- data/ext/cppjieba/deps/gtest/src/.deps/gtest_main.Plo +0 -509
- data/ext/cppjieba/deps/gtest/src/.dirstamp +0 -0
- data/ext/cppjieba/deps/gtest/src/gtest-all.cc +0 -48
- data/ext/cppjieba/deps/gtest/src/gtest-death-test.cc +0 -1234
- data/ext/cppjieba/deps/gtest/src/gtest-filepath.cc +0 -380
- data/ext/cppjieba/deps/gtest/src/gtest-internal-inl.h +0 -1038
- data/ext/cppjieba/deps/gtest/src/gtest-port.cc +0 -746
- data/ext/cppjieba/deps/gtest/src/gtest-printers.cc +0 -356
- data/ext/cppjieba/deps/gtest/src/gtest-test-part.cc +0 -110
- data/ext/cppjieba/deps/gtest/src/gtest-typed-test.cc +0 -110
- data/ext/cppjieba/deps/gtest/src/gtest.cc +0 -4898
- data/ext/cppjieba/deps/limonp/BlockingQueue.hpp +0 -49
- data/ext/cppjieba/deps/limonp/BoundedBlockingQueue.hpp +0 -67
- data/ext/cppjieba/deps/limonp/BoundedQueue.hpp +0 -65
- data/ext/cppjieba/deps/limonp/FileLock.hpp +0 -74
- data/ext/cppjieba/deps/limonp/Md5.hpp +0 -411
- data/ext/cppjieba/deps/limonp/MutexLock.hpp +0 -51
- data/ext/cppjieba/deps/limonp/Thread.hpp +0 -44
- data/ext/cppjieba/deps/limonp/ThreadPool.hpp +0 -86
- data/ext/cppjieba/test/demo.cpp +0 -80
- /data/ext/cppjieba/deps/{gtest/src/.deps/.dirstamp → limonp/.gitmodules} +0 -0
- /data/ext/cppjieba/deps/limonp/{ArgvContext.hpp → include/limonp/ArgvContext.hpp} +0 -0
- /data/ext/cppjieba/deps/limonp/{Closure.hpp → include/limonp/Closure.hpp} +0 -0
- /data/ext/cppjieba/deps/limonp/{Colors.hpp → include/limonp/Colors.hpp} +0 -0
- /data/ext/cppjieba/deps/limonp/{Condition.hpp → include/limonp/Condition.hpp} +0 -0
- /data/ext/cppjieba/deps/limonp/{Config.hpp → include/limonp/Config.hpp} +0 -0
- /data/ext/cppjieba/deps/limonp/{ForcePublic.hpp → include/limonp/ForcePublic.hpp} +0 -0
- /data/ext/cppjieba/deps/limonp/{NonCopyable.hpp → include/limonp/NonCopyable.hpp} +0 -0
- /data/ext/cppjieba/deps/limonp/{StdExtension.hpp → include/limonp/StdExtension.hpp} +0 -0
- /data/ext/cppjieba/deps/{gtest/src/gtest_main.cc → limonp/test/unittest/gtest_main.cpp} +0 -0
@@ -1,283 +0,0 @@
|
|
1
|
-
// Copyright 2005, 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
|
-
// Author: wan@google.com (Zhanyong Wan)
|
31
|
-
//
|
32
|
-
// The Google C++ Testing Framework (Google Test)
|
33
|
-
//
|
34
|
-
// This header file defines the public API for death tests. It is
|
35
|
-
// #included by gtest.h so a user doesn't need to include this
|
36
|
-
// directly.
|
37
|
-
|
38
|
-
#ifndef GTEST_INCLUDE_GTEST_GTEST_DEATH_TEST_H_
|
39
|
-
#define GTEST_INCLUDE_GTEST_GTEST_DEATH_TEST_H_
|
40
|
-
|
41
|
-
#include "gtest/internal/gtest-death-test-internal.h"
|
42
|
-
|
43
|
-
namespace testing {
|
44
|
-
|
45
|
-
// This flag controls the style of death tests. Valid values are "threadsafe",
|
46
|
-
// meaning that the death test child process will re-execute the test binary
|
47
|
-
// from the start, running only a single death test, or "fast",
|
48
|
-
// meaning that the child process will execute the test logic immediately
|
49
|
-
// after forking.
|
50
|
-
GTEST_DECLARE_string_(death_test_style);
|
51
|
-
|
52
|
-
#if GTEST_HAS_DEATH_TEST
|
53
|
-
|
54
|
-
// The following macros are useful for writing death tests.
|
55
|
-
|
56
|
-
// Here's what happens when an ASSERT_DEATH* or EXPECT_DEATH* is
|
57
|
-
// executed:
|
58
|
-
//
|
59
|
-
// 1. It generates a warning if there is more than one active
|
60
|
-
// thread. This is because it's safe to fork() or clone() only
|
61
|
-
// when there is a single thread.
|
62
|
-
//
|
63
|
-
// 2. The parent process clone()s a sub-process and runs the death
|
64
|
-
// test in it; the sub-process exits with code 0 at the end of the
|
65
|
-
// death test, if it hasn't exited already.
|
66
|
-
//
|
67
|
-
// 3. The parent process waits for the sub-process to terminate.
|
68
|
-
//
|
69
|
-
// 4. The parent process checks the exit code and error message of
|
70
|
-
// the sub-process.
|
71
|
-
//
|
72
|
-
// Examples:
|
73
|
-
//
|
74
|
-
// ASSERT_DEATH(server.SendMessage(56, "Hello"), "Invalid port number");
|
75
|
-
// for (int i = 0; i < 5; i++) {
|
76
|
-
// EXPECT_DEATH(server.ProcessRequest(i),
|
77
|
-
// "Invalid request .* in ProcessRequest()")
|
78
|
-
// << "Failed to die on request " << i);
|
79
|
-
// }
|
80
|
-
//
|
81
|
-
// ASSERT_EXIT(server.ExitNow(), ::testing::ExitedWithCode(0), "Exiting");
|
82
|
-
//
|
83
|
-
// bool KilledBySIGHUP(int exit_code) {
|
84
|
-
// return WIFSIGNALED(exit_code) && WTERMSIG(exit_code) == SIGHUP;
|
85
|
-
// }
|
86
|
-
//
|
87
|
-
// ASSERT_EXIT(client.HangUpServer(), KilledBySIGHUP, "Hanging up!");
|
88
|
-
//
|
89
|
-
// On the regular expressions used in death tests:
|
90
|
-
//
|
91
|
-
// On POSIX-compliant systems (*nix), we use the <regex.h> library,
|
92
|
-
// which uses the POSIX extended regex syntax.
|
93
|
-
//
|
94
|
-
// On other platforms (e.g. Windows), we only support a simple regex
|
95
|
-
// syntax implemented as part of Google Test. This limited
|
96
|
-
// implementation should be enough most of the time when writing
|
97
|
-
// death tests; though it lacks many features you can find in PCRE
|
98
|
-
// or POSIX extended regex syntax. For example, we don't support
|
99
|
-
// union ("x|y"), grouping ("(xy)"), brackets ("[xy]"), and
|
100
|
-
// repetition count ("x{5,7}"), among others.
|
101
|
-
//
|
102
|
-
// Below is the syntax that we do support. We chose it to be a
|
103
|
-
// subset of both PCRE and POSIX extended regex, so it's easy to
|
104
|
-
// learn wherever you come from. In the following: 'A' denotes a
|
105
|
-
// literal character, period (.), or a single \\ escape sequence;
|
106
|
-
// 'x' and 'y' denote regular expressions; 'm' and 'n' are for
|
107
|
-
// natural numbers.
|
108
|
-
//
|
109
|
-
// c matches any literal character c
|
110
|
-
// \\d matches any decimal digit
|
111
|
-
// \\D matches any character that's not a decimal digit
|
112
|
-
// \\f matches \f
|
113
|
-
// \\n matches \n
|
114
|
-
// \\r matches \r
|
115
|
-
// \\s matches any ASCII whitespace, including \n
|
116
|
-
// \\S matches any character that's not a whitespace
|
117
|
-
// \\t matches \t
|
118
|
-
// \\v matches \v
|
119
|
-
// \\w matches any letter, _, or decimal digit
|
120
|
-
// \\W matches any character that \\w doesn't match
|
121
|
-
// \\c matches any literal character c, which must be a punctuation
|
122
|
-
// . matches any single character except \n
|
123
|
-
// A? matches 0 or 1 occurrences of A
|
124
|
-
// A* matches 0 or many occurrences of A
|
125
|
-
// A+ matches 1 or many occurrences of A
|
126
|
-
// ^ matches the beginning of a string (not that of each line)
|
127
|
-
// $ matches the end of a string (not that of each line)
|
128
|
-
// xy matches x followed by y
|
129
|
-
//
|
130
|
-
// If you accidentally use PCRE or POSIX extended regex features
|
131
|
-
// not implemented by us, you will get a run-time failure. In that
|
132
|
-
// case, please try to rewrite your regular expression within the
|
133
|
-
// above syntax.
|
134
|
-
//
|
135
|
-
// This implementation is *not* meant to be as highly tuned or robust
|
136
|
-
// as a compiled regex library, but should perform well enough for a
|
137
|
-
// death test, which already incurs significant overhead by launching
|
138
|
-
// a child process.
|
139
|
-
//
|
140
|
-
// Known caveats:
|
141
|
-
//
|
142
|
-
// A "threadsafe" style death test obtains the path to the test
|
143
|
-
// program from argv[0] and re-executes it in the sub-process. For
|
144
|
-
// simplicity, the current implementation doesn't search the PATH
|
145
|
-
// when launching the sub-process. This means that the user must
|
146
|
-
// invoke the test program via a path that contains at least one
|
147
|
-
// path separator (e.g. path/to/foo_test and
|
148
|
-
// /absolute/path/to/bar_test are fine, but foo_test is not). This
|
149
|
-
// is rarely a problem as people usually don't put the test binary
|
150
|
-
// directory in PATH.
|
151
|
-
//
|
152
|
-
// TODO(wan@google.com): make thread-safe death tests search the PATH.
|
153
|
-
|
154
|
-
// Asserts that a given statement causes the program to exit, with an
|
155
|
-
// integer exit status that satisfies predicate, and emitting error output
|
156
|
-
// that matches regex.
|
157
|
-
# define ASSERT_EXIT(statement, predicate, regex) \
|
158
|
-
GTEST_DEATH_TEST_(statement, predicate, regex, GTEST_FATAL_FAILURE_)
|
159
|
-
|
160
|
-
// Like ASSERT_EXIT, but continues on to successive tests in the
|
161
|
-
// test case, if any:
|
162
|
-
# define EXPECT_EXIT(statement, predicate, regex) \
|
163
|
-
GTEST_DEATH_TEST_(statement, predicate, regex, GTEST_NONFATAL_FAILURE_)
|
164
|
-
|
165
|
-
// Asserts that a given statement causes the program to exit, either by
|
166
|
-
// explicitly exiting with a nonzero exit code or being killed by a
|
167
|
-
// signal, and emitting error output that matches regex.
|
168
|
-
# define ASSERT_DEATH(statement, regex) \
|
169
|
-
ASSERT_EXIT(statement, ::testing::internal::ExitedUnsuccessfully, regex)
|
170
|
-
|
171
|
-
// Like ASSERT_DEATH, but continues on to successive tests in the
|
172
|
-
// test case, if any:
|
173
|
-
# define EXPECT_DEATH(statement, regex) \
|
174
|
-
EXPECT_EXIT(statement, ::testing::internal::ExitedUnsuccessfully, regex)
|
175
|
-
|
176
|
-
// Two predicate classes that can be used in {ASSERT,EXPECT}_EXIT*:
|
177
|
-
|
178
|
-
// Tests that an exit code describes a normal exit with a given exit code.
|
179
|
-
class GTEST_API_ ExitedWithCode {
|
180
|
-
public:
|
181
|
-
explicit ExitedWithCode(int exit_code);
|
182
|
-
bool operator()(int exit_status) const;
|
183
|
-
private:
|
184
|
-
// No implementation - assignment is unsupported.
|
185
|
-
void operator=(const ExitedWithCode& other);
|
186
|
-
|
187
|
-
const int exit_code_;
|
188
|
-
};
|
189
|
-
|
190
|
-
# if !GTEST_OS_WINDOWS
|
191
|
-
// Tests that an exit code describes an exit due to termination by a
|
192
|
-
// given signal.
|
193
|
-
class GTEST_API_ KilledBySignal {
|
194
|
-
public:
|
195
|
-
explicit KilledBySignal(int signum);
|
196
|
-
bool operator()(int exit_status) const;
|
197
|
-
private:
|
198
|
-
const int signum_;
|
199
|
-
};
|
200
|
-
# endif // !GTEST_OS_WINDOWS
|
201
|
-
|
202
|
-
// EXPECT_DEBUG_DEATH asserts that the given statements die in debug mode.
|
203
|
-
// The death testing framework causes this to have interesting semantics,
|
204
|
-
// since the sideeffects of the call are only visible in opt mode, and not
|
205
|
-
// in debug mode.
|
206
|
-
//
|
207
|
-
// In practice, this can be used to test functions that utilize the
|
208
|
-
// LOG(DFATAL) macro using the following style:
|
209
|
-
//
|
210
|
-
// int DieInDebugOr12(int* sideeffect) {
|
211
|
-
// if (sideeffect) {
|
212
|
-
// *sideeffect = 12;
|
213
|
-
// }
|
214
|
-
// LOG(DFATAL) << "death";
|
215
|
-
// return 12;
|
216
|
-
// }
|
217
|
-
//
|
218
|
-
// TEST(TestCase, TestDieOr12WorksInDgbAndOpt) {
|
219
|
-
// int sideeffect = 0;
|
220
|
-
// // Only asserts in dbg.
|
221
|
-
// EXPECT_DEBUG_DEATH(DieInDebugOr12(&sideeffect), "death");
|
222
|
-
//
|
223
|
-
// #ifdef NDEBUG
|
224
|
-
// // opt-mode has sideeffect visible.
|
225
|
-
// EXPECT_EQ(12, sideeffect);
|
226
|
-
// #else
|
227
|
-
// // dbg-mode no visible sideeffect.
|
228
|
-
// EXPECT_EQ(0, sideeffect);
|
229
|
-
// #endif
|
230
|
-
// }
|
231
|
-
//
|
232
|
-
// This will assert that DieInDebugReturn12InOpt() crashes in debug
|
233
|
-
// mode, usually due to a DCHECK or LOG(DFATAL), but returns the
|
234
|
-
// appropriate fallback value (12 in this case) in opt mode. If you
|
235
|
-
// need to test that a function has appropriate side-effects in opt
|
236
|
-
// mode, include assertions against the side-effects. A general
|
237
|
-
// pattern for this is:
|
238
|
-
//
|
239
|
-
// EXPECT_DEBUG_DEATH({
|
240
|
-
// // Side-effects here will have an effect after this statement in
|
241
|
-
// // opt mode, but none in debug mode.
|
242
|
-
// EXPECT_EQ(12, DieInDebugOr12(&sideeffect));
|
243
|
-
// }, "death");
|
244
|
-
//
|
245
|
-
# ifdef NDEBUG
|
246
|
-
|
247
|
-
# define EXPECT_DEBUG_DEATH(statement, regex) \
|
248
|
-
do { statement; } while (::testing::internal::AlwaysFalse())
|
249
|
-
|
250
|
-
# define ASSERT_DEBUG_DEATH(statement, regex) \
|
251
|
-
do { statement; } while (::testing::internal::AlwaysFalse())
|
252
|
-
|
253
|
-
# else
|
254
|
-
|
255
|
-
# define EXPECT_DEBUG_DEATH(statement, regex) \
|
256
|
-
EXPECT_DEATH(statement, regex)
|
257
|
-
|
258
|
-
# define ASSERT_DEBUG_DEATH(statement, regex) \
|
259
|
-
ASSERT_DEATH(statement, regex)
|
260
|
-
|
261
|
-
# endif // NDEBUG for EXPECT_DEBUG_DEATH
|
262
|
-
#endif // GTEST_HAS_DEATH_TEST
|
263
|
-
|
264
|
-
// EXPECT_DEATH_IF_SUPPORTED(statement, regex) and
|
265
|
-
// ASSERT_DEATH_IF_SUPPORTED(statement, regex) expand to real death tests if
|
266
|
-
// death tests are supported; otherwise they just issue a warning. This is
|
267
|
-
// useful when you are combining death test assertions with normal test
|
268
|
-
// assertions in one test.
|
269
|
-
#if GTEST_HAS_DEATH_TEST
|
270
|
-
# define EXPECT_DEATH_IF_SUPPORTED(statement, regex) \
|
271
|
-
EXPECT_DEATH(statement, regex)
|
272
|
-
# define ASSERT_DEATH_IF_SUPPORTED(statement, regex) \
|
273
|
-
ASSERT_DEATH(statement, regex)
|
274
|
-
#else
|
275
|
-
# define EXPECT_DEATH_IF_SUPPORTED(statement, regex) \
|
276
|
-
GTEST_UNSUPPORTED_DEATH_TEST_(statement, regex, )
|
277
|
-
# define ASSERT_DEATH_IF_SUPPORTED(statement, regex) \
|
278
|
-
GTEST_UNSUPPORTED_DEATH_TEST_(statement, regex, return)
|
279
|
-
#endif
|
280
|
-
|
281
|
-
} // namespace testing
|
282
|
-
|
283
|
-
#endif // GTEST_INCLUDE_GTEST_GTEST_DEATH_TEST_H_
|
@@ -1,230 +0,0 @@
|
|
1
|
-
// Copyright 2005, 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
|
-
// Author: wan@google.com (Zhanyong Wan)
|
31
|
-
//
|
32
|
-
// The Google C++ Testing Framework (Google Test)
|
33
|
-
//
|
34
|
-
// This header file defines the Message class.
|
35
|
-
//
|
36
|
-
// IMPORTANT NOTE: Due to limitation of the C++ language, we have to
|
37
|
-
// leave some internal implementation details in this header file.
|
38
|
-
// They are clearly marked by comments like this:
|
39
|
-
//
|
40
|
-
// // INTERNAL IMPLEMENTATION - DO NOT USE IN A USER PROGRAM.
|
41
|
-
//
|
42
|
-
// Such code is NOT meant to be used by a user directly, and is subject
|
43
|
-
// to CHANGE WITHOUT NOTICE. Therefore DO NOT DEPEND ON IT in a user
|
44
|
-
// program!
|
45
|
-
|
46
|
-
#ifndef GTEST_INCLUDE_GTEST_GTEST_MESSAGE_H_
|
47
|
-
#define GTEST_INCLUDE_GTEST_GTEST_MESSAGE_H_
|
48
|
-
|
49
|
-
#include <limits>
|
50
|
-
|
51
|
-
#include "gtest/internal/gtest-string.h"
|
52
|
-
#include "gtest/internal/gtest-internal.h"
|
53
|
-
|
54
|
-
namespace testing {
|
55
|
-
|
56
|
-
// The Message class works like an ostream repeater.
|
57
|
-
//
|
58
|
-
// Typical usage:
|
59
|
-
//
|
60
|
-
// 1. You stream a bunch of values to a Message object.
|
61
|
-
// It will remember the text in a stringstream.
|
62
|
-
// 2. Then you stream the Message object to an ostream.
|
63
|
-
// This causes the text in the Message to be streamed
|
64
|
-
// to the ostream.
|
65
|
-
//
|
66
|
-
// For example;
|
67
|
-
//
|
68
|
-
// testing::Message foo;
|
69
|
-
// foo << 1 << " != " << 2;
|
70
|
-
// std::cout << foo;
|
71
|
-
//
|
72
|
-
// will print "1 != 2".
|
73
|
-
//
|
74
|
-
// Message is not intended to be inherited from. In particular, its
|
75
|
-
// destructor is not virtual.
|
76
|
-
//
|
77
|
-
// Note that stringstream behaves differently in gcc and in MSVC. You
|
78
|
-
// can stream a NULL char pointer to it in the former, but not in the
|
79
|
-
// latter (it causes an access violation if you do). The Message
|
80
|
-
// class hides this difference by treating a NULL char pointer as
|
81
|
-
// "(null)".
|
82
|
-
class GTEST_API_ Message {
|
83
|
-
private:
|
84
|
-
// The type of basic IO manipulators (endl, ends, and flush) for
|
85
|
-
// narrow streams.
|
86
|
-
typedef std::ostream& (*BasicNarrowIoManip)(std::ostream&);
|
87
|
-
|
88
|
-
public:
|
89
|
-
// Constructs an empty Message.
|
90
|
-
// We allocate the stringstream separately because otherwise each use of
|
91
|
-
// ASSERT/EXPECT in a procedure adds over 200 bytes to the procedure's
|
92
|
-
// stack frame leading to huge stack frames in some cases; gcc does not reuse
|
93
|
-
// the stack space.
|
94
|
-
Message() : ss_(new ::std::stringstream) {
|
95
|
-
// By default, we want there to be enough precision when printing
|
96
|
-
// a double to a Message.
|
97
|
-
*ss_ << std::setprecision(std::numeric_limits<double>::digits10 + 2);
|
98
|
-
}
|
99
|
-
|
100
|
-
// Copy constructor.
|
101
|
-
Message(const Message& msg) : ss_(new ::std::stringstream) { // NOLINT
|
102
|
-
*ss_ << msg.GetString();
|
103
|
-
}
|
104
|
-
|
105
|
-
// Constructs a Message from a C-string.
|
106
|
-
explicit Message(const char* str) : ss_(new ::std::stringstream) {
|
107
|
-
*ss_ << str;
|
108
|
-
}
|
109
|
-
|
110
|
-
#if GTEST_OS_SYMBIAN
|
111
|
-
// Streams a value (either a pointer or not) to this object.
|
112
|
-
template <typename T>
|
113
|
-
inline Message& operator <<(const T& value) {
|
114
|
-
StreamHelper(typename internal::is_pointer<T>::type(), value);
|
115
|
-
return *this;
|
116
|
-
}
|
117
|
-
#else
|
118
|
-
// Streams a non-pointer value to this object.
|
119
|
-
template <typename T>
|
120
|
-
inline Message& operator <<(const T& val) {
|
121
|
-
::GTestStreamToHelper(ss_.get(), val);
|
122
|
-
return *this;
|
123
|
-
}
|
124
|
-
|
125
|
-
// Streams a pointer value to this object.
|
126
|
-
//
|
127
|
-
// This function is an overload of the previous one. When you
|
128
|
-
// stream a pointer to a Message, this definition will be used as it
|
129
|
-
// is more specialized. (The C++ Standard, section
|
130
|
-
// [temp.func.order].) If you stream a non-pointer, then the
|
131
|
-
// previous definition will be used.
|
132
|
-
//
|
133
|
-
// The reason for this overload is that streaming a NULL pointer to
|
134
|
-
// ostream is undefined behavior. Depending on the compiler, you
|
135
|
-
// may get "0", "(nil)", "(null)", or an access violation. To
|
136
|
-
// ensure consistent result across compilers, we always treat NULL
|
137
|
-
// as "(null)".
|
138
|
-
template <typename T>
|
139
|
-
inline Message& operator <<(T* const& pointer) { // NOLINT
|
140
|
-
if (pointer == NULL) {
|
141
|
-
*ss_ << "(null)";
|
142
|
-
} else {
|
143
|
-
::GTestStreamToHelper(ss_.get(), pointer);
|
144
|
-
}
|
145
|
-
return *this;
|
146
|
-
}
|
147
|
-
#endif // GTEST_OS_SYMBIAN
|
148
|
-
|
149
|
-
// Since the basic IO manipulators are overloaded for both narrow
|
150
|
-
// and wide streams, we have to provide this specialized definition
|
151
|
-
// of operator <<, even though its body is the same as the
|
152
|
-
// templatized version above. Without this definition, streaming
|
153
|
-
// endl or other basic IO manipulators to Message will confuse the
|
154
|
-
// compiler.
|
155
|
-
Message& operator <<(BasicNarrowIoManip val) {
|
156
|
-
*ss_ << val;
|
157
|
-
return *this;
|
158
|
-
}
|
159
|
-
|
160
|
-
// Instead of 1/0, we want to see true/false for bool values.
|
161
|
-
Message& operator <<(bool b) {
|
162
|
-
return *this << (b ? "true" : "false");
|
163
|
-
}
|
164
|
-
|
165
|
-
// These two overloads allow streaming a wide C string to a Message
|
166
|
-
// using the UTF-8 encoding.
|
167
|
-
Message& operator <<(const wchar_t* wide_c_str) {
|
168
|
-
return *this << internal::String::ShowWideCString(wide_c_str);
|
169
|
-
}
|
170
|
-
Message& operator <<(wchar_t* wide_c_str) {
|
171
|
-
return *this << internal::String::ShowWideCString(wide_c_str);
|
172
|
-
}
|
173
|
-
|
174
|
-
#if GTEST_HAS_STD_WSTRING
|
175
|
-
// Converts the given wide string to a narrow string using the UTF-8
|
176
|
-
// encoding, and streams the result to this Message object.
|
177
|
-
Message& operator <<(const ::std::wstring& wstr);
|
178
|
-
#endif // GTEST_HAS_STD_WSTRING
|
179
|
-
|
180
|
-
#if GTEST_HAS_GLOBAL_WSTRING
|
181
|
-
// Converts the given wide string to a narrow string using the UTF-8
|
182
|
-
// encoding, and streams the result to this Message object.
|
183
|
-
Message& operator <<(const ::wstring& wstr);
|
184
|
-
#endif // GTEST_HAS_GLOBAL_WSTRING
|
185
|
-
|
186
|
-
// Gets the text streamed to this object so far as a String.
|
187
|
-
// Each '\0' character in the buffer is replaced with "\\0".
|
188
|
-
//
|
189
|
-
// INTERNAL IMPLEMENTATION - DO NOT USE IN A USER PROGRAM.
|
190
|
-
internal::String GetString() const {
|
191
|
-
return internal::StringStreamToString(ss_.get());
|
192
|
-
}
|
193
|
-
|
194
|
-
private:
|
195
|
-
|
196
|
-
#if GTEST_OS_SYMBIAN
|
197
|
-
// These are needed as the Nokia Symbian Compiler cannot decide between
|
198
|
-
// const T& and const T* in a function template. The Nokia compiler _can_
|
199
|
-
// decide between class template specializations for T and T*, so a
|
200
|
-
// tr1::type_traits-like is_pointer works, and we can overload on that.
|
201
|
-
template <typename T>
|
202
|
-
inline void StreamHelper(internal::true_type /*dummy*/, T* pointer) {
|
203
|
-
if (pointer == NULL) {
|
204
|
-
*ss_ << "(null)";
|
205
|
-
} else {
|
206
|
-
::GTestStreamToHelper(ss_.get(), pointer);
|
207
|
-
}
|
208
|
-
}
|
209
|
-
template <typename T>
|
210
|
-
inline void StreamHelper(internal::false_type /*dummy*/, const T& value) {
|
211
|
-
::GTestStreamToHelper(ss_.get(), value);
|
212
|
-
}
|
213
|
-
#endif // GTEST_OS_SYMBIAN
|
214
|
-
|
215
|
-
// We'll hold the text streamed to this object here.
|
216
|
-
const internal::scoped_ptr< ::std::stringstream> ss_;
|
217
|
-
|
218
|
-
// We declare (but don't implement) this to prevent the compiler
|
219
|
-
// from implementing the assignment operator.
|
220
|
-
void operator=(const Message&);
|
221
|
-
};
|
222
|
-
|
223
|
-
// Streams a Message to an ostream.
|
224
|
-
inline std::ostream& operator <<(std::ostream& os, const Message& sb) {
|
225
|
-
return os << sb.GetString();
|
226
|
-
}
|
227
|
-
|
228
|
-
} // namespace testing
|
229
|
-
|
230
|
-
#endif // GTEST_INCLUDE_GTEST_GTEST_MESSAGE_H_
|