uia 0.0.4 → 0.0.5

Sign up to get free protection for your applications and to get access to all the features.
Files changed (90) hide show
  1. data/.rspec +1 -0
  2. data/ChangeLog +11 -0
  3. data/README.md +18 -1
  4. data/Rakefile +6 -1
  5. data/ext/UiaDll/UIA.Helper/Element.cs +52 -32
  6. data/ext/UiaDll/UiaDll.Test/AssemblyInfo.cpp +40 -0
  7. data/ext/UiaDll/UiaDll.Test/ElementInformationTest.cpp +89 -0
  8. data/ext/UiaDll/UiaDll.Test/ElementStub.h +59 -0
  9. data/ext/UiaDll/UiaDll.Test/ElementsTest.cpp +22 -0
  10. data/ext/UiaDll/UiaDll.Test/MemoryLeakDetector.h +47 -0
  11. data/ext/UiaDll/UiaDll.Test/ReadMe.txt +35 -0
  12. data/ext/UiaDll/UiaDll.Test/StringHelperTest.cpp +14 -0
  13. data/ext/UiaDll/UiaDll.Test/UiaDll.Test.cpp +16 -0
  14. data/ext/UiaDll/UiaDll.Test/UiaDll.Test.vcxproj +127 -0
  15. data/ext/UiaDll/UiaDll.Test/UiaDll.Test.vcxproj.filters +67 -0
  16. data/ext/UiaDll/UiaDll.Test/app.ico +0 -0
  17. data/ext/UiaDll/UiaDll.Test/app.rc +0 -0
  18. data/ext/UiaDll/UiaDll.Test/gmock/include/gmock/gmock-actions.h +1078 -0
  19. data/ext/UiaDll/UiaDll.Test/gmock/include/gmock/gmock-cardinalities.h +147 -0
  20. data/ext/UiaDll/UiaDll.Test/gmock/include/gmock/gmock-generated-actions.h +2415 -0
  21. data/ext/UiaDll/UiaDll.Test/gmock/include/gmock/gmock-generated-actions.h.pump +821 -0
  22. data/ext/UiaDll/UiaDll.Test/gmock/include/gmock/gmock-generated-function-mockers.h +991 -0
  23. data/ext/UiaDll/UiaDll.Test/gmock/include/gmock/gmock-generated-function-mockers.h.pump +265 -0
  24. data/ext/UiaDll/UiaDll.Test/gmock/include/gmock/gmock-generated-matchers.h +2190 -0
  25. data/ext/UiaDll/UiaDll.Test/gmock/include/gmock/gmock-generated-matchers.h.pump +674 -0
  26. data/ext/UiaDll/UiaDll.Test/gmock/include/gmock/gmock-generated-nice-strict.h +397 -0
  27. data/ext/UiaDll/UiaDll.Test/gmock/include/gmock/gmock-generated-nice-strict.h.pump +161 -0
  28. data/ext/UiaDll/UiaDll.Test/gmock/include/gmock/gmock-matchers.h +3986 -0
  29. data/ext/UiaDll/UiaDll.Test/gmock/include/gmock/gmock-more-actions.h +233 -0
  30. data/ext/UiaDll/UiaDll.Test/gmock/include/gmock/gmock-more-matchers.h +58 -0
  31. data/ext/UiaDll/UiaDll.Test/gmock/include/gmock/gmock-spec-builders.h +1791 -0
  32. data/ext/UiaDll/UiaDll.Test/gmock/include/gmock/gmock.h +94 -0
  33. data/ext/UiaDll/UiaDll.Test/gmock/include/gmock/internal/gmock-generated-internal-utils.h +279 -0
  34. data/ext/UiaDll/UiaDll.Test/gmock/include/gmock/internal/gmock-generated-internal-utils.h.pump +136 -0
  35. data/ext/UiaDll/UiaDll.Test/gmock/include/gmock/internal/gmock-internal-utils.h +498 -0
  36. data/ext/UiaDll/UiaDll.Test/gmock/include/gmock/internal/gmock-port.h +78 -0
  37. data/ext/UiaDll/UiaDll.Test/gmock/lib/gmock.lib +0 -0
  38. data/ext/UiaDll/UiaDll.Test/gmock/lib/gmockd.lib +0 -0
  39. data/ext/UiaDll/UiaDll.Test/gtest/include/gtest/gtest-death-test.h +294 -0
  40. data/ext/UiaDll/UiaDll.Test/gtest/include/gtest/gtest-message.h +250 -0
  41. data/ext/UiaDll/UiaDll.Test/gtest/include/gtest/gtest-param-test.h +1421 -0
  42. data/ext/UiaDll/UiaDll.Test/gtest/include/gtest/gtest-param-test.h.pump +487 -0
  43. data/ext/UiaDll/UiaDll.Test/gtest/include/gtest/gtest-printers.h +855 -0
  44. data/ext/UiaDll/UiaDll.Test/gtest/include/gtest/gtest-spi.h +232 -0
  45. data/ext/UiaDll/UiaDll.Test/gtest/include/gtest/gtest-test-part.h +179 -0
  46. data/ext/UiaDll/UiaDll.Test/gtest/include/gtest/gtest-typed-test.h +259 -0
  47. data/ext/UiaDll/UiaDll.Test/gtest/include/gtest/gtest.h +2291 -0
  48. data/ext/UiaDll/UiaDll.Test/gtest/include/gtest/gtest_pred_impl.h +358 -0
  49. data/ext/UiaDll/UiaDll.Test/gtest/include/gtest/gtest_prod.h +58 -0
  50. data/ext/UiaDll/UiaDll.Test/gtest/include/gtest/internal/gtest-death-test-internal.h +319 -0
  51. data/ext/UiaDll/UiaDll.Test/gtest/include/gtest/internal/gtest-filepath.h +206 -0
  52. data/ext/UiaDll/UiaDll.Test/gtest/include/gtest/internal/gtest-internal.h +1158 -0
  53. data/ext/UiaDll/UiaDll.Test/gtest/include/gtest/internal/gtest-linked_ptr.h +233 -0
  54. data/ext/UiaDll/UiaDll.Test/gtest/include/gtest/internal/gtest-param-util-generated.h +5143 -0
  55. data/ext/UiaDll/UiaDll.Test/gtest/include/gtest/internal/gtest-param-util-generated.h.pump +301 -0
  56. data/ext/UiaDll/UiaDll.Test/gtest/include/gtest/internal/gtest-param-util.h +619 -0
  57. data/ext/UiaDll/UiaDll.Test/gtest/include/gtest/internal/gtest-port.h +1947 -0
  58. data/ext/UiaDll/UiaDll.Test/gtest/include/gtest/internal/gtest-string.h +167 -0
  59. data/ext/UiaDll/UiaDll.Test/gtest/include/gtest/internal/gtest-tuple.h +1012 -0
  60. data/ext/UiaDll/UiaDll.Test/gtest/include/gtest/internal/gtest-tuple.h.pump +339 -0
  61. data/ext/UiaDll/UiaDll.Test/gtest/include/gtest/internal/gtest-type-util.h +3331 -0
  62. data/ext/UiaDll/UiaDll.Test/gtest/include/gtest/internal/gtest-type-util.h.pump +297 -0
  63. data/ext/UiaDll/UiaDll.Test/gtest/lib/gtest.lib +0 -0
  64. data/ext/UiaDll/UiaDll.Test/gtest/lib/gtestd.lib +0 -0
  65. data/ext/UiaDll/UiaDll.Test/resource.h +3 -0
  66. data/ext/UiaDll/UiaDll.Test/stdafx.cpp +7 -0
  67. data/ext/UiaDll/UiaDll.Test/stdafx.h +7 -0
  68. data/ext/UiaDll/UiaDll.sln +15 -0
  69. data/ext/UiaDll/UiaDll/ArrayHelper.h +20 -2
  70. data/ext/UiaDll/UiaDll/ElementMethods.cpp +18 -0
  71. data/ext/UiaDll/UiaDll/ElementStructures.h +36 -24
  72. data/ext/UiaDll/UiaDll/StringHelper.h +16 -2
  73. data/ext/UiaDll/UiaDll/UiaDll.vcxproj +0 -2
  74. data/ext/UiaDll/UiaDll/UiaDll.vcxproj.filters +0 -6
  75. data/lib/uia.rb +23 -117
  76. data/lib/uia/element.rb +38 -0
  77. data/lib/uia/library.rb +60 -0
  78. data/lib/uia/library/constants.rb +85 -0
  79. data/lib/uia/library/structs.rb +85 -0
  80. data/lib/uia/version.rb +1 -1
  81. data/spec/app/FizzWare.NBuilder.dll +0 -0
  82. data/spec/app/UIA.Extensions.dll +0 -0
  83. data/spec/app/WindowsForms.exe +0 -0
  84. data/spec/spec_helper.rb +21 -0
  85. data/spec/uia/element_spec.rb +56 -0
  86. data/spec/uia_spec.rb +28 -0
  87. data/uia.gemspec +13 -10
  88. metadata +134 -8
  89. data/ext/UiaDll/UiaDll/ArrayHelper.cpp +0 -22
  90. data/ext/UiaDll/UiaDll/StringHelper.cpp +0 -17
@@ -0,0 +1,855 @@
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
+ // Author: wan@google.com (Zhanyong Wan)
31
+
32
+ // Google Test - The Google C++ Testing Framework
33
+ //
34
+ // This file implements a universal value printer that can print a
35
+ // value of any type T:
36
+ //
37
+ // void ::testing::internal::UniversalPrinter<T>::Print(value, ostream_ptr);
38
+ //
39
+ // A user can teach this function how to print a class type T by
40
+ // defining either operator<<() or PrintTo() in the namespace that
41
+ // defines T. More specifically, the FIRST defined function in the
42
+ // following list will be used (assuming T is defined in namespace
43
+ // foo):
44
+ //
45
+ // 1. foo::PrintTo(const T&, ostream*)
46
+ // 2. operator<<(ostream&, const T&) defined in either foo or the
47
+ // global namespace.
48
+ //
49
+ // If none of the above is defined, it will print the debug string of
50
+ // the value if it is a protocol buffer, or print the raw bytes in the
51
+ // value otherwise.
52
+ //
53
+ // To aid debugging: when T is a reference type, the address of the
54
+ // value is also printed; when T is a (const) char pointer, both the
55
+ // pointer value and the NUL-terminated string it points to are
56
+ // printed.
57
+ //
58
+ // We also provide some convenient wrappers:
59
+ //
60
+ // // Prints a value to a string. For a (const or not) char
61
+ // // pointer, the NUL-terminated string (but not the pointer) is
62
+ // // printed.
63
+ // std::string ::testing::PrintToString(const T& value);
64
+ //
65
+ // // Prints a value tersely: for a reference type, the referenced
66
+ // // value (but not the address) is printed; for a (const or not) char
67
+ // // pointer, the NUL-terminated string (but not the pointer) is
68
+ // // printed.
69
+ // void ::testing::internal::UniversalTersePrint(const T& value, ostream*);
70
+ //
71
+ // // Prints value using the type inferred by the compiler. The difference
72
+ // // from UniversalTersePrint() is that this function prints both the
73
+ // // pointer and the NUL-terminated string for a (const or not) char pointer.
74
+ // void ::testing::internal::UniversalPrint(const T& value, ostream*);
75
+ //
76
+ // // Prints the fields of a tuple tersely to a string vector, one
77
+ // // element for each field. Tuple support must be enabled in
78
+ // // gtest-port.h.
79
+ // std::vector<string> UniversalTersePrintTupleFieldsToStrings(
80
+ // const Tuple& value);
81
+ //
82
+ // Known limitation:
83
+ //
84
+ // The print primitives print the elements of an STL-style container
85
+ // using the compiler-inferred type of *iter where iter is a
86
+ // const_iterator of the container. When const_iterator is an input
87
+ // iterator but not a forward iterator, this inferred type may not
88
+ // match value_type, and the print output may be incorrect. In
89
+ // practice, this is rarely a problem as for most containers
90
+ // const_iterator is a forward iterator. We'll fix this if there's an
91
+ // actual need for it. Note that this fix cannot rely on value_type
92
+ // being defined as many user-defined container types don't have
93
+ // value_type.
94
+
95
+ #ifndef GTEST_INCLUDE_GTEST_GTEST_PRINTERS_H_
96
+ #define GTEST_INCLUDE_GTEST_GTEST_PRINTERS_H_
97
+
98
+ #include <ostream> // NOLINT
99
+ #include <sstream>
100
+ #include <string>
101
+ #include <utility>
102
+ #include <vector>
103
+ #include "gtest/internal/gtest-port.h"
104
+ #include "gtest/internal/gtest-internal.h"
105
+
106
+ namespace testing {
107
+
108
+ // Definitions in the 'internal' and 'internal2' name spaces are
109
+ // subject to change without notice. DO NOT USE THEM IN USER CODE!
110
+ namespace internal2 {
111
+
112
+ // Prints the given number of bytes in the given object to the given
113
+ // ostream.
114
+ GTEST_API_ void PrintBytesInObjectTo(const unsigned char* obj_bytes,
115
+ size_t count,
116
+ ::std::ostream* os);
117
+
118
+ // For selecting which printer to use when a given type has neither <<
119
+ // nor PrintTo().
120
+ enum TypeKind {
121
+ kProtobuf, // a protobuf type
122
+ kConvertibleToInteger, // a type implicitly convertible to BiggestInt
123
+ // (e.g. a named or unnamed enum type)
124
+ kOtherType // anything else
125
+ };
126
+
127
+ // TypeWithoutFormatter<T, kTypeKind>::PrintValue(value, os) is called
128
+ // by the universal printer to print a value of type T when neither
129
+ // operator<< nor PrintTo() is defined for T, where kTypeKind is the
130
+ // "kind" of T as defined by enum TypeKind.
131
+ template <typename T, TypeKind kTypeKind>
132
+ class TypeWithoutFormatter {
133
+ public:
134
+ // This default version is called when kTypeKind is kOtherType.
135
+ static void PrintValue(const T& value, ::std::ostream* os) {
136
+ PrintBytesInObjectTo(reinterpret_cast<const unsigned char*>(&value),
137
+ sizeof(value), os);
138
+ }
139
+ };
140
+
141
+ // We print a protobuf using its ShortDebugString() when the string
142
+ // doesn't exceed this many characters; otherwise we print it using
143
+ // DebugString() for better readability.
144
+ const size_t kProtobufOneLinerMaxLength = 50;
145
+
146
+ template <typename T>
147
+ class TypeWithoutFormatter<T, kProtobuf> {
148
+ public:
149
+ static void PrintValue(const T& value, ::std::ostream* os) {
150
+ const ::testing::internal::string short_str = value.ShortDebugString();
151
+ const ::testing::internal::string pretty_str =
152
+ short_str.length() <= kProtobufOneLinerMaxLength ?
153
+ short_str : ("\n" + value.DebugString());
154
+ *os << ("<" + pretty_str + ">");
155
+ }
156
+ };
157
+
158
+ template <typename T>
159
+ class TypeWithoutFormatter<T, kConvertibleToInteger> {
160
+ public:
161
+ // Since T has no << operator or PrintTo() but can be implicitly
162
+ // converted to BiggestInt, we print it as a BiggestInt.
163
+ //
164
+ // Most likely T is an enum type (either named or unnamed), in which
165
+ // case printing it as an integer is the desired behavior. In case
166
+ // T is not an enum, printing it as an integer is the best we can do
167
+ // given that it has no user-defined printer.
168
+ static void PrintValue(const T& value, ::std::ostream* os) {
169
+ const internal::BiggestInt kBigInt = value;
170
+ *os << kBigInt;
171
+ }
172
+ };
173
+
174
+ // Prints the given value to the given ostream. If the value is a
175
+ // protocol message, its debug string is printed; if it's an enum or
176
+ // of a type implicitly convertible to BiggestInt, it's printed as an
177
+ // integer; otherwise the bytes in the value are printed. This is
178
+ // what UniversalPrinter<T>::Print() does when it knows nothing about
179
+ // type T and T has neither << operator nor PrintTo().
180
+ //
181
+ // A user can override this behavior for a class type Foo by defining
182
+ // a << operator in the namespace where Foo is defined.
183
+ //
184
+ // We put this operator in namespace 'internal2' instead of 'internal'
185
+ // to simplify the implementation, as much code in 'internal' needs to
186
+ // use << in STL, which would conflict with our own << were it defined
187
+ // in 'internal'.
188
+ //
189
+ // Note that this operator<< takes a generic std::basic_ostream<Char,
190
+ // CharTraits> type instead of the more restricted std::ostream. If
191
+ // we define it to take an std::ostream instead, we'll get an
192
+ // "ambiguous overloads" compiler error when trying to print a type
193
+ // Foo that supports streaming to std::basic_ostream<Char,
194
+ // CharTraits>, as the compiler cannot tell whether
195
+ // operator<<(std::ostream&, const T&) or
196
+ // operator<<(std::basic_stream<Char, CharTraits>, const Foo&) is more
197
+ // specific.
198
+ template <typename Char, typename CharTraits, typename T>
199
+ ::std::basic_ostream<Char, CharTraits>& operator<<(
200
+ ::std::basic_ostream<Char, CharTraits>& os, const T& x) {
201
+ TypeWithoutFormatter<T,
202
+ (internal::IsAProtocolMessage<T>::value ? kProtobuf :
203
+ internal::ImplicitlyConvertible<const T&, internal::BiggestInt>::value ?
204
+ kConvertibleToInteger : kOtherType)>::PrintValue(x, &os);
205
+ return os;
206
+ }
207
+
208
+ } // namespace internal2
209
+ } // namespace testing
210
+
211
+ // This namespace MUST NOT BE NESTED IN ::testing, or the name look-up
212
+ // magic needed for implementing UniversalPrinter won't work.
213
+ namespace testing_internal {
214
+
215
+ // Used to print a value that is not an STL-style container when the
216
+ // user doesn't define PrintTo() for it.
217
+ template <typename T>
218
+ void DefaultPrintNonContainerTo(const T& value, ::std::ostream* os) {
219
+ // With the following statement, during unqualified name lookup,
220
+ // testing::internal2::operator<< appears as if it was declared in
221
+ // the nearest enclosing namespace that contains both
222
+ // ::testing_internal and ::testing::internal2, i.e. the global
223
+ // namespace. For more details, refer to the C++ Standard section
224
+ // 7.3.4-1 [namespace.udir]. This allows us to fall back onto
225
+ // testing::internal2::operator<< in case T doesn't come with a <<
226
+ // operator.
227
+ //
228
+ // We cannot write 'using ::testing::internal2::operator<<;', which
229
+ // gcc 3.3 fails to compile due to a compiler bug.
230
+ using namespace ::testing::internal2; // NOLINT
231
+
232
+ // Assuming T is defined in namespace foo, in the next statement,
233
+ // the compiler will consider all of:
234
+ //
235
+ // 1. foo::operator<< (thanks to Koenig look-up),
236
+ // 2. ::operator<< (as the current namespace is enclosed in ::),
237
+ // 3. testing::internal2::operator<< (thanks to the using statement above).
238
+ //
239
+ // The operator<< whose type matches T best will be picked.
240
+ //
241
+ // We deliberately allow #2 to be a candidate, as sometimes it's
242
+ // impossible to define #1 (e.g. when foo is ::std, defining
243
+ // anything in it is undefined behavior unless you are a compiler
244
+ // vendor.).
245
+ *os << value;
246
+ }
247
+
248
+ } // namespace testing_internal
249
+
250
+ namespace testing {
251
+ namespace internal {
252
+
253
+ // UniversalPrinter<T>::Print(value, ostream_ptr) prints the given
254
+ // value to the given ostream. The caller must ensure that
255
+ // 'ostream_ptr' is not NULL, or the behavior is undefined.
256
+ //
257
+ // We define UniversalPrinter as a class template (as opposed to a
258
+ // function template), as we need to partially specialize it for
259
+ // reference types, which cannot be done with function templates.
260
+ template <typename T>
261
+ class UniversalPrinter;
262
+
263
+ template <typename T>
264
+ void UniversalPrint(const T& value, ::std::ostream* os);
265
+
266
+ // Used to print an STL-style container when the user doesn't define
267
+ // a PrintTo() for it.
268
+ template <typename C>
269
+ void DefaultPrintTo(IsContainer /* dummy */,
270
+ false_type /* is not a pointer */,
271
+ const C& container, ::std::ostream* os) {
272
+ const size_t kMaxCount = 32; // The maximum number of elements to print.
273
+ *os << '{';
274
+ size_t count = 0;
275
+ for (typename C::const_iterator it = container.begin();
276
+ it != container.end(); ++it, ++count) {
277
+ if (count > 0) {
278
+ *os << ',';
279
+ if (count == kMaxCount) { // Enough has been printed.
280
+ *os << " ...";
281
+ break;
282
+ }
283
+ }
284
+ *os << ' ';
285
+ // We cannot call PrintTo(*it, os) here as PrintTo() doesn't
286
+ // handle *it being a native array.
287
+ internal::UniversalPrint(*it, os);
288
+ }
289
+
290
+ if (count > 0) {
291
+ *os << ' ';
292
+ }
293
+ *os << '}';
294
+ }
295
+
296
+ // Used to print a pointer that is neither a char pointer nor a member
297
+ // pointer, when the user doesn't define PrintTo() for it. (A member
298
+ // variable pointer or member function pointer doesn't really point to
299
+ // a location in the address space. Their representation is
300
+ // implementation-defined. Therefore they will be printed as raw
301
+ // bytes.)
302
+ template <typename T>
303
+ void DefaultPrintTo(IsNotContainer /* dummy */,
304
+ true_type /* is a pointer */,
305
+ T* p, ::std::ostream* os) {
306
+ if (p == NULL) {
307
+ *os << "NULL";
308
+ } else {
309
+ // C++ doesn't allow casting from a function pointer to any object
310
+ // pointer.
311
+ //
312
+ // IsTrue() silences warnings: "Condition is always true",
313
+ // "unreachable code".
314
+ if (IsTrue(ImplicitlyConvertible<T*, const void*>::value)) {
315
+ // T is not a function type. We just call << to print p,
316
+ // relying on ADL to pick up user-defined << for their pointer
317
+ // types, if any.
318
+ *os << p;
319
+ } else {
320
+ // T is a function type, so '*os << p' doesn't do what we want
321
+ // (it just prints p as bool). We want to print p as a const
322
+ // void*. However, we cannot cast it to const void* directly,
323
+ // even using reinterpret_cast, as earlier versions of gcc
324
+ // (e.g. 3.4.5) cannot compile the cast when p is a function
325
+ // pointer. Casting to UInt64 first solves the problem.
326
+ *os << reinterpret_cast<const void*>(
327
+ reinterpret_cast<internal::UInt64>(p));
328
+ }
329
+ }
330
+ }
331
+
332
+ // Used to print a non-container, non-pointer value when the user
333
+ // doesn't define PrintTo() for it.
334
+ template <typename T>
335
+ void DefaultPrintTo(IsNotContainer /* dummy */,
336
+ false_type /* is not a pointer */,
337
+ const T& value, ::std::ostream* os) {
338
+ ::testing_internal::DefaultPrintNonContainerTo(value, os);
339
+ }
340
+
341
+ // Prints the given value using the << operator if it has one;
342
+ // otherwise prints the bytes in it. This is what
343
+ // UniversalPrinter<T>::Print() does when PrintTo() is not specialized
344
+ // or overloaded for type T.
345
+ //
346
+ // A user can override this behavior for a class type Foo by defining
347
+ // an overload of PrintTo() in the namespace where Foo is defined. We
348
+ // give the user this option as sometimes defining a << operator for
349
+ // Foo is not desirable (e.g. the coding style may prevent doing it,
350
+ // or there is already a << operator but it doesn't do what the user
351
+ // wants).
352
+ template <typename T>
353
+ void PrintTo(const T& value, ::std::ostream* os) {
354
+ // DefaultPrintTo() is overloaded. The type of its first two
355
+ // arguments determine which version will be picked. If T is an
356
+ // STL-style container, the version for container will be called; if
357
+ // T is a pointer, the pointer version will be called; otherwise the
358
+ // generic version will be called.
359
+ //
360
+ // Note that we check for container types here, prior to we check
361
+ // for protocol message types in our operator<<. The rationale is:
362
+ //
363
+ // For protocol messages, we want to give people a chance to
364
+ // override Google Mock's format by defining a PrintTo() or
365
+ // operator<<. For STL containers, other formats can be
366
+ // incompatible with Google Mock's format for the container
367
+ // elements; therefore we check for container types here to ensure
368
+ // that our format is used.
369
+ //
370
+ // The second argument of DefaultPrintTo() is needed to bypass a bug
371
+ // in Symbian's C++ compiler that prevents it from picking the right
372
+ // overload between:
373
+ //
374
+ // PrintTo(const T& x, ...);
375
+ // PrintTo(T* x, ...);
376
+ DefaultPrintTo(IsContainerTest<T>(0), is_pointer<T>(), value, os);
377
+ }
378
+
379
+ // The following list of PrintTo() overloads tells
380
+ // UniversalPrinter<T>::Print() how to print standard types (built-in
381
+ // types, strings, plain arrays, and pointers).
382
+
383
+ // Overloads for various char types.
384
+ GTEST_API_ void PrintTo(unsigned char c, ::std::ostream* os);
385
+ GTEST_API_ void PrintTo(signed char c, ::std::ostream* os);
386
+ inline void PrintTo(char c, ::std::ostream* os) {
387
+ // When printing a plain char, we always treat it as unsigned. This
388
+ // way, the output won't be affected by whether the compiler thinks
389
+ // char is signed or not.
390
+ PrintTo(static_cast<unsigned char>(c), os);
391
+ }
392
+
393
+ // Overloads for other simple built-in types.
394
+ inline void PrintTo(bool x, ::std::ostream* os) {
395
+ *os << (x ? "true" : "false");
396
+ }
397
+
398
+ // Overload for wchar_t type.
399
+ // Prints a wchar_t as a symbol if it is printable or as its internal
400
+ // code otherwise and also as its decimal code (except for L'\0').
401
+ // The L'\0' char is printed as "L'\\0'". The decimal code is printed
402
+ // as signed integer when wchar_t is implemented by the compiler
403
+ // as a signed type and is printed as an unsigned integer when wchar_t
404
+ // is implemented as an unsigned type.
405
+ GTEST_API_ void PrintTo(wchar_t wc, ::std::ostream* os);
406
+
407
+ // Overloads for C strings.
408
+ GTEST_API_ void PrintTo(const char* s, ::std::ostream* os);
409
+ inline void PrintTo(char* s, ::std::ostream* os) {
410
+ PrintTo(ImplicitCast_<const char*>(s), os);
411
+ }
412
+
413
+ // signed/unsigned char is often used for representing binary data, so
414
+ // we print pointers to it as void* to be safe.
415
+ inline void PrintTo(const signed char* s, ::std::ostream* os) {
416
+ PrintTo(ImplicitCast_<const void*>(s), os);
417
+ }
418
+ inline void PrintTo(signed char* s, ::std::ostream* os) {
419
+ PrintTo(ImplicitCast_<const void*>(s), os);
420
+ }
421
+ inline void PrintTo(const unsigned char* s, ::std::ostream* os) {
422
+ PrintTo(ImplicitCast_<const void*>(s), os);
423
+ }
424
+ inline void PrintTo(unsigned char* s, ::std::ostream* os) {
425
+ PrintTo(ImplicitCast_<const void*>(s), os);
426
+ }
427
+
428
+ // MSVC can be configured to define wchar_t as a typedef of unsigned
429
+ // short. It defines _NATIVE_WCHAR_T_DEFINED when wchar_t is a native
430
+ // type. When wchar_t is a typedef, defining an overload for const
431
+ // wchar_t* would cause unsigned short* be printed as a wide string,
432
+ // possibly causing invalid memory accesses.
433
+ #if !defined(_MSC_VER) || defined(_NATIVE_WCHAR_T_DEFINED)
434
+ // Overloads for wide C strings
435
+ GTEST_API_ void PrintTo(const wchar_t* s, ::std::ostream* os);
436
+ inline void PrintTo(wchar_t* s, ::std::ostream* os) {
437
+ PrintTo(ImplicitCast_<const wchar_t*>(s), os);
438
+ }
439
+ #endif
440
+
441
+ // Overload for C arrays. Multi-dimensional arrays are printed
442
+ // properly.
443
+
444
+ // Prints the given number of elements in an array, without printing
445
+ // the curly braces.
446
+ template <typename T>
447
+ void PrintRawArrayTo(const T a[], size_t count, ::std::ostream* os) {
448
+ UniversalPrint(a[0], os);
449
+ for (size_t i = 1; i != count; i++) {
450
+ *os << ", ";
451
+ UniversalPrint(a[i], os);
452
+ }
453
+ }
454
+
455
+ // Overloads for ::string and ::std::string.
456
+ #if GTEST_HAS_GLOBAL_STRING
457
+ GTEST_API_ void PrintStringTo(const ::string&s, ::std::ostream* os);
458
+ inline void PrintTo(const ::string& s, ::std::ostream* os) {
459
+ PrintStringTo(s, os);
460
+ }
461
+ #endif // GTEST_HAS_GLOBAL_STRING
462
+
463
+ GTEST_API_ void PrintStringTo(const ::std::string&s, ::std::ostream* os);
464
+ inline void PrintTo(const ::std::string& s, ::std::ostream* os) {
465
+ PrintStringTo(s, os);
466
+ }
467
+
468
+ // Overloads for ::wstring and ::std::wstring.
469
+ #if GTEST_HAS_GLOBAL_WSTRING
470
+ GTEST_API_ void PrintWideStringTo(const ::wstring&s, ::std::ostream* os);
471
+ inline void PrintTo(const ::wstring& s, ::std::ostream* os) {
472
+ PrintWideStringTo(s, os);
473
+ }
474
+ #endif // GTEST_HAS_GLOBAL_WSTRING
475
+
476
+ #if GTEST_HAS_STD_WSTRING
477
+ GTEST_API_ void PrintWideStringTo(const ::std::wstring&s, ::std::ostream* os);
478
+ inline void PrintTo(const ::std::wstring& s, ::std::ostream* os) {
479
+ PrintWideStringTo(s, os);
480
+ }
481
+ #endif // GTEST_HAS_STD_WSTRING
482
+
483
+ #if GTEST_HAS_TR1_TUPLE
484
+ // Overload for ::std::tr1::tuple. Needed for printing function arguments,
485
+ // which are packed as tuples.
486
+
487
+ // Helper function for printing a tuple. T must be instantiated with
488
+ // a tuple type.
489
+ template <typename T>
490
+ void PrintTupleTo(const T& t, ::std::ostream* os);
491
+
492
+ // Overloaded PrintTo() for tuples of various arities. We support
493
+ // tuples of up-to 10 fields. The following implementation works
494
+ // regardless of whether tr1::tuple is implemented using the
495
+ // non-standard variadic template feature or not.
496
+
497
+ inline void PrintTo(const ::std::tr1::tuple<>& t, ::std::ostream* os) {
498
+ PrintTupleTo(t, os);
499
+ }
500
+
501
+ template <typename T1>
502
+ void PrintTo(const ::std::tr1::tuple<T1>& t, ::std::ostream* os) {
503
+ PrintTupleTo(t, os);
504
+ }
505
+
506
+ template <typename T1, typename T2>
507
+ void PrintTo(const ::std::tr1::tuple<T1, T2>& t, ::std::ostream* os) {
508
+ PrintTupleTo(t, os);
509
+ }
510
+
511
+ template <typename T1, typename T2, typename T3>
512
+ void PrintTo(const ::std::tr1::tuple<T1, T2, T3>& t, ::std::ostream* os) {
513
+ PrintTupleTo(t, os);
514
+ }
515
+
516
+ template <typename T1, typename T2, typename T3, typename T4>
517
+ void PrintTo(const ::std::tr1::tuple<T1, T2, T3, T4>& t, ::std::ostream* os) {
518
+ PrintTupleTo(t, os);
519
+ }
520
+
521
+ template <typename T1, typename T2, typename T3, typename T4, typename T5>
522
+ void PrintTo(const ::std::tr1::tuple<T1, T2, T3, T4, T5>& t,
523
+ ::std::ostream* os) {
524
+ PrintTupleTo(t, os);
525
+ }
526
+
527
+ template <typename T1, typename T2, typename T3, typename T4, typename T5,
528
+ typename T6>
529
+ void PrintTo(const ::std::tr1::tuple<T1, T2, T3, T4, T5, T6>& t,
530
+ ::std::ostream* os) {
531
+ PrintTupleTo(t, os);
532
+ }
533
+
534
+ template <typename T1, typename T2, typename T3, typename T4, typename T5,
535
+ typename T6, typename T7>
536
+ void PrintTo(const ::std::tr1::tuple<T1, T2, T3, T4, T5, T6, T7>& t,
537
+ ::std::ostream* os) {
538
+ PrintTupleTo(t, os);
539
+ }
540
+
541
+ template <typename T1, typename T2, typename T3, typename T4, typename T5,
542
+ typename T6, typename T7, typename T8>
543
+ void PrintTo(const ::std::tr1::tuple<T1, T2, T3, T4, T5, T6, T7, T8>& t,
544
+ ::std::ostream* os) {
545
+ PrintTupleTo(t, os);
546
+ }
547
+
548
+ template <typename T1, typename T2, typename T3, typename T4, typename T5,
549
+ typename T6, typename T7, typename T8, typename T9>
550
+ void PrintTo(const ::std::tr1::tuple<T1, T2, T3, T4, T5, T6, T7, T8, T9>& t,
551
+ ::std::ostream* os) {
552
+ PrintTupleTo(t, os);
553
+ }
554
+
555
+ template <typename T1, typename T2, typename T3, typename T4, typename T5,
556
+ typename T6, typename T7, typename T8, typename T9, typename T10>
557
+ void PrintTo(
558
+ const ::std::tr1::tuple<T1, T2, T3, T4, T5, T6, T7, T8, T9, T10>& t,
559
+ ::std::ostream* os) {
560
+ PrintTupleTo(t, os);
561
+ }
562
+ #endif // GTEST_HAS_TR1_TUPLE
563
+
564
+ // Overload for std::pair.
565
+ template <typename T1, typename T2>
566
+ void PrintTo(const ::std::pair<T1, T2>& value, ::std::ostream* os) {
567
+ *os << '(';
568
+ // We cannot use UniversalPrint(value.first, os) here, as T1 may be
569
+ // a reference type. The same for printing value.second.
570
+ UniversalPrinter<T1>::Print(value.first, os);
571
+ *os << ", ";
572
+ UniversalPrinter<T2>::Print(value.second, os);
573
+ *os << ')';
574
+ }
575
+
576
+ // Implements printing a non-reference type T by letting the compiler
577
+ // pick the right overload of PrintTo() for T.
578
+ template <typename T>
579
+ class UniversalPrinter {
580
+ public:
581
+ // MSVC warns about adding const to a function type, so we want to
582
+ // disable the warning.
583
+ #ifdef _MSC_VER
584
+ # pragma warning(push) // Saves the current warning state.
585
+ # pragma warning(disable:4180) // Temporarily disables warning 4180.
586
+ #endif // _MSC_VER
587
+
588
+ // Note: we deliberately don't call this PrintTo(), as that name
589
+ // conflicts with ::testing::internal::PrintTo in the body of the
590
+ // function.
591
+ static void Print(const T& value, ::std::ostream* os) {
592
+ // By default, ::testing::internal::PrintTo() is used for printing
593
+ // the value.
594
+ //
595
+ // Thanks to Koenig look-up, if T is a class and has its own
596
+ // PrintTo() function defined in its namespace, that function will
597
+ // be visible here. Since it is more specific than the generic ones
598
+ // in ::testing::internal, it will be picked by the compiler in the
599
+ // following statement - exactly what we want.
600
+ PrintTo(value, os);
601
+ }
602
+
603
+ #ifdef _MSC_VER
604
+ # pragma warning(pop) // Restores the warning state.
605
+ #endif // _MSC_VER
606
+ };
607
+
608
+ // UniversalPrintArray(begin, len, os) prints an array of 'len'
609
+ // elements, starting at address 'begin'.
610
+ template <typename T>
611
+ void UniversalPrintArray(const T* begin, size_t len, ::std::ostream* os) {
612
+ if (len == 0) {
613
+ *os << "{}";
614
+ } else {
615
+ *os << "{ ";
616
+ const size_t kThreshold = 18;
617
+ const size_t kChunkSize = 8;
618
+ // If the array has more than kThreshold elements, we'll have to
619
+ // omit some details by printing only the first and the last
620
+ // kChunkSize elements.
621
+ // TODO(wan@google.com): let the user control the threshold using a flag.
622
+ if (len <= kThreshold) {
623
+ PrintRawArrayTo(begin, len, os);
624
+ } else {
625
+ PrintRawArrayTo(begin, kChunkSize, os);
626
+ *os << ", ..., ";
627
+ PrintRawArrayTo(begin + len - kChunkSize, kChunkSize, os);
628
+ }
629
+ *os << " }";
630
+ }
631
+ }
632
+ // This overload prints a (const) char array compactly.
633
+ GTEST_API_ void UniversalPrintArray(
634
+ const char* begin, size_t len, ::std::ostream* os);
635
+
636
+ // This overload prints a (const) wchar_t array compactly.
637
+ GTEST_API_ void UniversalPrintArray(
638
+ const wchar_t* begin, size_t len, ::std::ostream* os);
639
+
640
+ // Implements printing an array type T[N].
641
+ template <typename T, size_t N>
642
+ class UniversalPrinter<T[N]> {
643
+ public:
644
+ // Prints the given array, omitting some elements when there are too
645
+ // many.
646
+ static void Print(const T (&a)[N], ::std::ostream* os) {
647
+ UniversalPrintArray(a, N, os);
648
+ }
649
+ };
650
+
651
+ // Implements printing a reference type T&.
652
+ template <typename T>
653
+ class UniversalPrinter<T&> {
654
+ public:
655
+ // MSVC warns about adding const to a function type, so we want to
656
+ // disable the warning.
657
+ #ifdef _MSC_VER
658
+ # pragma warning(push) // Saves the current warning state.
659
+ # pragma warning(disable:4180) // Temporarily disables warning 4180.
660
+ #endif // _MSC_VER
661
+
662
+ static void Print(const T& value, ::std::ostream* os) {
663
+ // Prints the address of the value. We use reinterpret_cast here
664
+ // as static_cast doesn't compile when T is a function type.
665
+ *os << "@" << reinterpret_cast<const void*>(&value) << " ";
666
+
667
+ // Then prints the value itself.
668
+ UniversalPrint(value, os);
669
+ }
670
+
671
+ #ifdef _MSC_VER
672
+ # pragma warning(pop) // Restores the warning state.
673
+ #endif // _MSC_VER
674
+ };
675
+
676
+ // Prints a value tersely: for a reference type, the referenced value
677
+ // (but not the address) is printed; for a (const) char pointer, the
678
+ // NUL-terminated string (but not the pointer) is printed.
679
+
680
+ template <typename T>
681
+ class UniversalTersePrinter {
682
+ public:
683
+ static void Print(const T& value, ::std::ostream* os) {
684
+ UniversalPrint(value, os);
685
+ }
686
+ };
687
+ template <typename T>
688
+ class UniversalTersePrinter<T&> {
689
+ public:
690
+ static void Print(const T& value, ::std::ostream* os) {
691
+ UniversalPrint(value, os);
692
+ }
693
+ };
694
+ template <typename T, size_t N>
695
+ class UniversalTersePrinter<T[N]> {
696
+ public:
697
+ static void Print(const T (&value)[N], ::std::ostream* os) {
698
+ UniversalPrinter<T[N]>::Print(value, os);
699
+ }
700
+ };
701
+ template <>
702
+ class UniversalTersePrinter<const char*> {
703
+ public:
704
+ static void Print(const char* str, ::std::ostream* os) {
705
+ if (str == NULL) {
706
+ *os << "NULL";
707
+ } else {
708
+ UniversalPrint(string(str), os);
709
+ }
710
+ }
711
+ };
712
+ template <>
713
+ class UniversalTersePrinter<char*> {
714
+ public:
715
+ static void Print(char* str, ::std::ostream* os) {
716
+ UniversalTersePrinter<const char*>::Print(str, os);
717
+ }
718
+ };
719
+
720
+ #if GTEST_HAS_STD_WSTRING
721
+ template <>
722
+ class UniversalTersePrinter<const wchar_t*> {
723
+ public:
724
+ static void Print(const wchar_t* str, ::std::ostream* os) {
725
+ if (str == NULL) {
726
+ *os << "NULL";
727
+ } else {
728
+ UniversalPrint(::std::wstring(str), os);
729
+ }
730
+ }
731
+ };
732
+ #endif
733
+
734
+ template <>
735
+ class UniversalTersePrinter<wchar_t*> {
736
+ public:
737
+ static void Print(wchar_t* str, ::std::ostream* os) {
738
+ UniversalTersePrinter<const wchar_t*>::Print(str, os);
739
+ }
740
+ };
741
+
742
+ template <typename T>
743
+ void UniversalTersePrint(const T& value, ::std::ostream* os) {
744
+ UniversalTersePrinter<T>::Print(value, os);
745
+ }
746
+
747
+ // Prints a value using the type inferred by the compiler. The
748
+ // difference between this and UniversalTersePrint() is that for a
749
+ // (const) char pointer, this prints both the pointer and the
750
+ // NUL-terminated string.
751
+ template <typename T>
752
+ void UniversalPrint(const T& value, ::std::ostream* os) {
753
+ // A workarond for the bug in VC++ 7.1 that prevents us from instantiating
754
+ // UniversalPrinter with T directly.
755
+ typedef T T1;
756
+ UniversalPrinter<T1>::Print(value, os);
757
+ }
758
+
759
+ #if GTEST_HAS_TR1_TUPLE
760
+ typedef ::std::vector<string> Strings;
761
+
762
+ // This helper template allows PrintTo() for tuples and
763
+ // UniversalTersePrintTupleFieldsToStrings() to be defined by
764
+ // induction on the number of tuple fields. The idea is that
765
+ // TuplePrefixPrinter<N>::PrintPrefixTo(t, os) prints the first N
766
+ // fields in tuple t, and can be defined in terms of
767
+ // TuplePrefixPrinter<N - 1>.
768
+
769
+ // The inductive case.
770
+ template <size_t N>
771
+ struct TuplePrefixPrinter {
772
+ // Prints the first N fields of a tuple.
773
+ template <typename Tuple>
774
+ static void PrintPrefixTo(const Tuple& t, ::std::ostream* os) {
775
+ TuplePrefixPrinter<N - 1>::PrintPrefixTo(t, os);
776
+ *os << ", ";
777
+ UniversalPrinter<typename ::std::tr1::tuple_element<N - 1, Tuple>::type>
778
+ ::Print(::std::tr1::get<N - 1>(t), os);
779
+ }
780
+
781
+ // Tersely prints the first N fields of a tuple to a string vector,
782
+ // one element for each field.
783
+ template <typename Tuple>
784
+ static void TersePrintPrefixToStrings(const Tuple& t, Strings* strings) {
785
+ TuplePrefixPrinter<N - 1>::TersePrintPrefixToStrings(t, strings);
786
+ ::std::stringstream ss;
787
+ UniversalTersePrint(::std::tr1::get<N - 1>(t), &ss);
788
+ strings->push_back(ss.str());
789
+ }
790
+ };
791
+
792
+ // Base cases.
793
+ template <>
794
+ struct TuplePrefixPrinter<0> {
795
+ template <typename Tuple>
796
+ static void PrintPrefixTo(const Tuple&, ::std::ostream*) {}
797
+
798
+ template <typename Tuple>
799
+ static void TersePrintPrefixToStrings(const Tuple&, Strings*) {}
800
+ };
801
+ // We have to specialize the entire TuplePrefixPrinter<> class
802
+ // template here, even though the definition of
803
+ // TersePrintPrefixToStrings() is the same as the generic version, as
804
+ // Embarcadero (formerly CodeGear, formerly Borland) C++ doesn't
805
+ // support specializing a method template of a class template.
806
+ template <>
807
+ struct TuplePrefixPrinter<1> {
808
+ template <typename Tuple>
809
+ static void PrintPrefixTo(const Tuple& t, ::std::ostream* os) {
810
+ UniversalPrinter<typename ::std::tr1::tuple_element<0, Tuple>::type>::
811
+ Print(::std::tr1::get<0>(t), os);
812
+ }
813
+
814
+ template <typename Tuple>
815
+ static void TersePrintPrefixToStrings(const Tuple& t, Strings* strings) {
816
+ ::std::stringstream ss;
817
+ UniversalTersePrint(::std::tr1::get<0>(t), &ss);
818
+ strings->push_back(ss.str());
819
+ }
820
+ };
821
+
822
+ // Helper function for printing a tuple. T must be instantiated with
823
+ // a tuple type.
824
+ template <typename T>
825
+ void PrintTupleTo(const T& t, ::std::ostream* os) {
826
+ *os << "(";
827
+ TuplePrefixPrinter< ::std::tr1::tuple_size<T>::value>::
828
+ PrintPrefixTo(t, os);
829
+ *os << ")";
830
+ }
831
+
832
+ // Prints the fields of a tuple tersely to a string vector, one
833
+ // element for each field. See the comment before
834
+ // UniversalTersePrint() for how we define "tersely".
835
+ template <typename Tuple>
836
+ Strings UniversalTersePrintTupleFieldsToStrings(const Tuple& value) {
837
+ Strings result;
838
+ TuplePrefixPrinter< ::std::tr1::tuple_size<Tuple>::value>::
839
+ TersePrintPrefixToStrings(value, &result);
840
+ return result;
841
+ }
842
+ #endif // GTEST_HAS_TR1_TUPLE
843
+
844
+ } // namespace internal
845
+
846
+ template <typename T>
847
+ ::std::string PrintToString(const T& value) {
848
+ ::std::stringstream ss;
849
+ internal::UniversalTersePrinter<T>::Print(value, &ss);
850
+ return ss.str();
851
+ }
852
+
853
+ } // namespace testing
854
+
855
+ #endif // GTEST_INCLUDE_GTEST_GTEST_PRINTERS_H_