57 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
			
		
		
	
	
			57 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			C++
		
	
	
	
	
	
// JSON pretty formatting example
 | 
						|
// This example can handle UTF-8/UTF-16LE/UTF-16BE/UTF-32LE/UTF-32BE.
 | 
						|
// The input firstly convert to UTF8, and then write to the original encoding with pretty formatting.
 | 
						|
 | 
						|
#include "rapidjson/reader.h"
 | 
						|
#include "rapidjson/prettywriter.h"
 | 
						|
#include "rapidjson/filereadstream.h"
 | 
						|
#include "rapidjson/filewritestream.h"
 | 
						|
#include "rapidjson/encodedstream.h"    // NEW
 | 
						|
#include "rapidjson/error/en.h"
 | 
						|
#ifdef _WIN32
 | 
						|
#include <fcntl.h>
 | 
						|
#include <io.h>
 | 
						|
#endif
 | 
						|
 | 
						|
using namespace rapidjson;
 | 
						|
 | 
						|
int main(int, char*[]) {
 | 
						|
#ifdef _WIN32
 | 
						|
    // Prevent Windows converting between CR+LF and LF
 | 
						|
    _setmode(_fileno(stdin), _O_BINARY);    // NEW
 | 
						|
    _setmode(_fileno(stdout), _O_BINARY);   // NEW
 | 
						|
#endif
 | 
						|
 | 
						|
    // Prepare reader and input stream.
 | 
						|
    //Reader reader;
 | 
						|
    GenericReader<AutoUTF<unsigned>, UTF8<> > reader;       // CHANGED
 | 
						|
    char readBuffer[65536];
 | 
						|
    FileReadStream is(stdin, readBuffer, sizeof(readBuffer));
 | 
						|
    AutoUTFInputStream<unsigned, FileReadStream> eis(is);   // NEW
 | 
						|
 | 
						|
    // Prepare writer and output stream.
 | 
						|
    char writeBuffer[65536];
 | 
						|
    FileWriteStream os(stdout, writeBuffer, sizeof(writeBuffer));
 | 
						|
 | 
						|
#if 1
 | 
						|
    // Use the same Encoding of the input. Also use BOM according to input.
 | 
						|
    typedef AutoUTFOutputStream<unsigned, FileWriteStream> OutputStream;    // NEW
 | 
						|
    OutputStream eos(os, eis.GetType(), eis.HasBOM());                      // NEW
 | 
						|
    PrettyWriter<OutputStream, UTF8<>, AutoUTF<unsigned> > writer(eos);     // CHANGED
 | 
						|
#else
 | 
						|
    // You may also use static bound encoding type, such as output to UTF-16LE with BOM
 | 
						|
    typedef EncodedOutputStream<UTF16LE<>,FileWriteStream> OutputStream;    // NEW
 | 
						|
    OutputStream eos(os, true);                                             // NEW
 | 
						|
    PrettyWriter<OutputStream, UTF8<>, UTF16LE<> > writer(eos);             // CHANGED
 | 
						|
#endif
 | 
						|
 | 
						|
    // JSON reader parse from the input stream and let writer generate the output.
 | 
						|
    //if (!reader.Parse<kParseValidateEncodingFlag>(is, writer)) {
 | 
						|
    if (!reader.Parse<kParseValidateEncodingFlag>(eis, writer)) {   // CHANGED
 | 
						|
        fprintf(stderr, "\nError(%u): %s\n", static_cast<unsigned>(reader.GetErrorOffset()), GetParseError_En(reader.GetParseErrorCode()));
 | 
						|
        return 1;
 | 
						|
    }
 | 
						|
 | 
						|
    return 0;
 | 
						|
}
 |