Merge pull request #1877 from hendrikmuhs/windows-GetObject-conflict-#1418
add a workaround for GetObject macro defined by windows.h
This commit is contained in:
commit
e0f68a4356
@ -42,6 +42,15 @@ RAPIDJSON_DIAG_OFF(4244) // conversion from kXxxFlags to 'uint16_t', possible lo
|
|||||||
RAPIDJSON_DIAG_OFF(effc++)
|
RAPIDJSON_DIAG_OFF(effc++)
|
||||||
#endif // __GNUC__
|
#endif // __GNUC__
|
||||||
|
|
||||||
|
#ifdef GetObject
|
||||||
|
// see https://github.com/Tencent/rapidjson/issues/1448
|
||||||
|
// a former included windows.h might have defined a macro called GetObject, which affects
|
||||||
|
// GetObject defined here. This ensures the macro does not get applied
|
||||||
|
#pragma push_macro("GetObject")
|
||||||
|
#define RAPIDJSON_WINDOWS_GETOBJECT_WORKAROUND_APPLIED
|
||||||
|
#undef GetObject
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifndef RAPIDJSON_NOMEMBERITERATORCLASS
|
#ifndef RAPIDJSON_NOMEMBERITERATORCLASS
|
||||||
#include <iterator> // std::random_access_iterator_tag
|
#include <iterator> // std::random_access_iterator_tag
|
||||||
#endif
|
#endif
|
||||||
@ -1602,7 +1611,9 @@ public:
|
|||||||
}
|
}
|
||||||
|
|
||||||
Object GetObject() { RAPIDJSON_ASSERT(IsObject()); return Object(*this); }
|
Object GetObject() { RAPIDJSON_ASSERT(IsObject()); return Object(*this); }
|
||||||
|
Object GetObj() { RAPIDJSON_ASSERT(IsObject()); return Object(*this); }
|
||||||
ConstObject GetObject() const { RAPIDJSON_ASSERT(IsObject()); return ConstObject(*this); }
|
ConstObject GetObject() const { RAPIDJSON_ASSERT(IsObject()); return ConstObject(*this); }
|
||||||
|
ConstObject GetObj() const { RAPIDJSON_ASSERT(IsObject()); return ConstObject(*this); }
|
||||||
|
|
||||||
//@}
|
//@}
|
||||||
|
|
||||||
@ -3008,4 +3019,9 @@ private:
|
|||||||
RAPIDJSON_NAMESPACE_END
|
RAPIDJSON_NAMESPACE_END
|
||||||
RAPIDJSON_DIAG_POP
|
RAPIDJSON_DIAG_POP
|
||||||
|
|
||||||
|
#ifdef RAPIDJSON_WINDOWS_GETOBJECT_WORKAROUND_APPLIED
|
||||||
|
#pragma pop_macro("GetObject")
|
||||||
|
#undef RAPIDJSON_WINDOWS_GETOBJECT_WORKAROUND_APPLIED
|
||||||
|
#endif
|
||||||
|
|
||||||
#endif // RAPIDJSON_DOCUMENT_H_
|
#endif // RAPIDJSON_DOCUMENT_H_
|
||||||
|
@ -16,6 +16,7 @@ set(UNITTEST_SOURCES
|
|||||||
jsoncheckertest.cpp
|
jsoncheckertest.cpp
|
||||||
namespacetest.cpp
|
namespacetest.cpp
|
||||||
pointertest.cpp
|
pointertest.cpp
|
||||||
|
platformtest.cpp
|
||||||
prettywritertest.cpp
|
prettywritertest.cpp
|
||||||
ostreamwrappertest.cpp
|
ostreamwrappertest.cpp
|
||||||
readertest.cpp
|
readertest.cpp
|
||||||
|
40
test/unittest/platformtest.cpp
Normal file
40
test/unittest/platformtest.cpp
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
// Tencent is pleased to support the open source community by making RapidJSON available.
|
||||||
|
//
|
||||||
|
// Copyright (C) 2021 THL A29 Limited, a Tencent company, and Milo Yip.
|
||||||
|
//
|
||||||
|
// Licensed under the MIT License (the "License"); you may not use this file except
|
||||||
|
// in compliance with the License. You may obtain a copy of the License at
|
||||||
|
//
|
||||||
|
// http://opensource.org/licenses/MIT
|
||||||
|
//
|
||||||
|
// Unless required by applicable law or agreed to in writing, software distributed
|
||||||
|
// under the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR
|
||||||
|
// CONDITIONS OF ANY KIND, either express or implied. See the License for the
|
||||||
|
// specific language governing permissions and limitations under the License.
|
||||||
|
|
||||||
|
#include "unittest.h"
|
||||||
|
|
||||||
|
// see https://github.com/Tencent/rapidjson/issues/1448
|
||||||
|
// including windows.h on purpose to provoke a compile time problem as GetObject is a
|
||||||
|
// macro that gets defined when windows.h is included
|
||||||
|
#ifdef _WIN32
|
||||||
|
#include <windows.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#include "rapidjson/document.h"
|
||||||
|
#undef GetObject
|
||||||
|
|
||||||
|
using namespace rapidjson;
|
||||||
|
|
||||||
|
TEST(Platform, GetObject) {
|
||||||
|
Document doc;
|
||||||
|
doc.Parse(" { \"object\" : { \"pi\": 3.1416} } ");
|
||||||
|
EXPECT_TRUE(doc.IsObject());
|
||||||
|
EXPECT_TRUE(doc.HasMember("object"));
|
||||||
|
const Document::ValueType& o = doc["object"];
|
||||||
|
EXPECT_TRUE(o.IsObject());
|
||||||
|
Value::ConstObject sub = o.GetObject();
|
||||||
|
EXPECT_TRUE(sub.HasMember("pi"));
|
||||||
|
Value::ConstObject sub2 = o.GetObj();
|
||||||
|
EXPECT_TRUE(sub2.HasMember("pi"));
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user