mirror of
				https://github.com/RetroDECK/ES-DE.git
				synced 2025-04-10 19:15:13 +00:00 
			
		
		
		
	
		
			
	
	
		
			182 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
		
		
			
		
	
	
			182 lines
		
	
	
		
			5.3 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
|   | // Tencent is pleased to support the open source community by making RapidJSON available.
 | ||
|  | // 
 | ||
|  | // Copyright (C) 2015 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"
 | ||
|  | 
 | ||
|  | #include "rapidjson/istreamwrapper.h"
 | ||
|  | #include "rapidjson/encodedstream.h"
 | ||
|  | #include "rapidjson/document.h"
 | ||
|  | #include <sstream>
 | ||
|  | #include <fstream>
 | ||
|  | 
 | ||
|  | #if defined(_MSC_VER) && !defined(__clang__)
 | ||
|  | RAPIDJSON_DIAG_PUSH | ||
|  | RAPIDJSON_DIAG_OFF(4702) // unreachable code
 | ||
|  | #endif
 | ||
|  | 
 | ||
|  | using namespace rapidjson; | ||
|  | using namespace std; | ||
|  | 
 | ||
|  | template <typename StringStreamType> | ||
|  | static void TestStringStream() { | ||
|  |     typedef typename StringStreamType::char_type Ch; | ||
|  | 
 | ||
|  |     { | ||
|  |         StringStreamType iss; | ||
|  |         BasicIStreamWrapper<StringStreamType> is(iss); | ||
|  |         EXPECT_EQ(0u, is.Tell()); | ||
|  |         if (sizeof(Ch) == 1) { | ||
|  |             EXPECT_EQ(0, is.Peek4()); | ||
|  |             EXPECT_EQ(0u, is.Tell()); | ||
|  |         } | ||
|  |         EXPECT_EQ(0, is.Peek()); | ||
|  |         EXPECT_EQ(0, is.Take()); | ||
|  |         EXPECT_EQ(0u, is.Tell()); | ||
|  |     } | ||
|  | 
 | ||
|  |     { | ||
|  |         Ch s[] = { 'A', 'B', 'C', '\0' }; | ||
|  |         StringStreamType iss(s); | ||
|  |         BasicIStreamWrapper<StringStreamType> is(iss); | ||
|  |         EXPECT_EQ(0u, is.Tell()); | ||
|  |         if (sizeof(Ch) == 1) { | ||
|  |             EXPECT_EQ(0, is.Peek4()); // less than 4 bytes
 | ||
|  |         } | ||
|  |         for (int i = 0; i < 3; i++) { | ||
|  |             EXPECT_EQ(static_cast<size_t>(i), is.Tell()); | ||
|  |             EXPECT_EQ('A' + i, is.Peek()); | ||
|  |             EXPECT_EQ('A' + i, is.Peek()); | ||
|  |             EXPECT_EQ('A' + i, is.Take()); | ||
|  |         } | ||
|  |         EXPECT_EQ(3u, is.Tell()); | ||
|  |         EXPECT_EQ(0, is.Peek()); | ||
|  |         EXPECT_EQ(0, is.Take()); | ||
|  |     } | ||
|  | 
 | ||
|  |     { | ||
|  |         Ch s[] = { 'A', 'B', 'C', 'D', 'E', '\0' }; | ||
|  |         StringStreamType iss(s); | ||
|  |         BasicIStreamWrapper<StringStreamType> is(iss); | ||
|  |         if (sizeof(Ch) == 1) { | ||
|  |             const Ch* c = is.Peek4(); | ||
|  |             for (int i = 0; i < 4; i++) | ||
|  |                 EXPECT_EQ('A' + i, c[i]); | ||
|  |             EXPECT_EQ(0u, is.Tell()); | ||
|  |         } | ||
|  |         for (int i = 0; i < 5; i++) { | ||
|  |             EXPECT_EQ(static_cast<size_t>(i), is.Tell()); | ||
|  |             EXPECT_EQ('A' + i, is.Peek()); | ||
|  |             EXPECT_EQ('A' + i, is.Peek()); | ||
|  |             EXPECT_EQ('A' + i, is.Take()); | ||
|  |         } | ||
|  |         EXPECT_EQ(5u, is.Tell()); | ||
|  |         EXPECT_EQ(0, is.Peek()); | ||
|  |         EXPECT_EQ(0, is.Take()); | ||
|  |     } | ||
|  | } | ||
|  | 
 | ||
|  | TEST(IStreamWrapper, istringstream) { | ||
|  |     TestStringStream<istringstream>(); | ||
|  | } | ||
|  | 
 | ||
|  | TEST(IStreamWrapper, stringstream) { | ||
|  |     TestStringStream<stringstream>(); | ||
|  | } | ||
|  | 
 | ||
|  | TEST(IStreamWrapper, wistringstream) { | ||
|  |     TestStringStream<wistringstream>(); | ||
|  | } | ||
|  | 
 | ||
|  | TEST(IStreamWrapper, wstringstream) { | ||
|  |     TestStringStream<wstringstream>(); | ||
|  | } | ||
|  | 
 | ||
|  | template <typename FileStreamType> | ||
|  | static bool Open(FileStreamType& fs, const char* filename) { | ||
|  |     const char *paths[] = { | ||
|  |         "encodings", | ||
|  |         "bin/encodings", | ||
|  |         "../bin/encodings", | ||
|  |         "../../bin/encodings", | ||
|  |         "../../../bin/encodings" | ||
|  |     }; | ||
|  |     char buffer[1024]; | ||
|  |     for (size_t i = 0; i < sizeof(paths) / sizeof(paths[0]); i++) { | ||
|  |         sprintf(buffer, "%s/%s", paths[i], filename); | ||
|  |         fs.open(buffer, ios_base::in | ios_base::binary); | ||
|  |         if (fs.is_open()) | ||
|  |             return true; | ||
|  |     } | ||
|  |     return false; | ||
|  | } | ||
|  | 
 | ||
|  | TEST(IStreamWrapper, ifstream) { | ||
|  |     ifstream ifs; | ||
|  |     ASSERT_TRUE(Open(ifs, "utf8bom.json")); | ||
|  |     IStreamWrapper isw(ifs); | ||
|  |     EncodedInputStream<UTF8<>, IStreamWrapper> eis(isw); | ||
|  |     Document d; | ||
|  |     EXPECT_TRUE(!d.ParseStream(eis).HasParseError()); | ||
|  |     EXPECT_TRUE(d.IsObject()); | ||
|  |     EXPECT_EQ(5u, d.MemberCount()); | ||
|  | } | ||
|  | 
 | ||
|  | TEST(IStreamWrapper, fstream) { | ||
|  |     fstream fs; | ||
|  |     ASSERT_TRUE(Open(fs, "utf8bom.json")); | ||
|  |     IStreamWrapper isw(fs); | ||
|  |     EncodedInputStream<UTF8<>, IStreamWrapper> eis(isw); | ||
|  |     Document d; | ||
|  |     EXPECT_TRUE(!d.ParseStream(eis).HasParseError()); | ||
|  |     EXPECT_TRUE(d.IsObject()); | ||
|  |     EXPECT_EQ(5u, d.MemberCount()); | ||
|  | } | ||
|  | 
 | ||
|  | // wifstream/wfstream only works on C++11 with codecvt_utf16
 | ||
|  | // But many C++11 library still not have it.
 | ||
|  | #if 0
 | ||
|  | #include <codecvt>
 | ||
|  | 
 | ||
|  | TEST(IStreamWrapper, wifstream) { | ||
|  |     wifstream ifs; | ||
|  |     ASSERT_TRUE(Open(ifs, "utf16bebom.json")); | ||
|  |     ifs.imbue(std::locale(ifs.getloc(), | ||
|  |        new std::codecvt_utf16<wchar_t, 0x10ffff, std::consume_header>)); | ||
|  |     WIStreamWrapper isw(ifs); | ||
|  |     GenericDocument<UTF16<> > d; | ||
|  |     d.ParseStream<kParseDefaultFlags, UTF16<>, WIStreamWrapper>(isw); | ||
|  |     EXPECT_TRUE(!d.HasParseError()); | ||
|  |     EXPECT_TRUE(d.IsObject()); | ||
|  |     EXPECT_EQ(5, d.MemberCount()); | ||
|  | } | ||
|  | 
 | ||
|  | TEST(IStreamWrapper, wfstream) { | ||
|  |     wfstream fs; | ||
|  |     ASSERT_TRUE(Open(fs, "utf16bebom.json")); | ||
|  |     fs.imbue(std::locale(fs.getloc(), | ||
|  |        new std::codecvt_utf16<wchar_t, 0x10ffff, std::consume_header>)); | ||
|  |     WIStreamWrapper isw(fs); | ||
|  |     GenericDocument<UTF16<> > d; | ||
|  |     d.ParseStream<kParseDefaultFlags, UTF16<>, WIStreamWrapper>(isw); | ||
|  |     EXPECT_TRUE(!d.HasParseError()); | ||
|  |     EXPECT_TRUE(d.IsObject()); | ||
|  |     EXPECT_EQ(5, d.MemberCount()); | ||
|  | } | ||
|  | 
 | ||
|  | #endif
 | ||
|  | 
 | ||
|  | #if defined(_MSC_VER) && !defined(__clang__)
 | ||
|  | RAPIDJSON_DIAG_POP | ||
|  | #endif
 |