Skip to content
Projects
Groups
Snippets
Help
Loading...
Sign in / Register
Toggle navigation
R
rapidjson
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Packages
Packages
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
submodule
rapidjson
Commits
feb5dde7
Commit
feb5dde7
authored
Jul 02, 2014
by
Milo Yip
Browse files
Options
Browse Files
Download
Plain Diff
Merge pull request #40 from miloyip/warning
Fix/Suppress all -Wall -Wextra -Weffc++ warnings on gcc 4.6.x - 4.8.x
parents
0c81ed77
49b1a127
Hide whitespace changes
Inline
Side-by-side
Showing
17 changed files
with
185 additions
and
35 deletions
+185
-35
premake4.lua
build/premake4.lua
+5
-3
serialize.cpp
example/serialize/serialize.cpp
+11
-2
document.h
include/rapidjson/document.h
+21
-12
encodedstream.h
include/rapidjson/encodedstream.h
+17
-2
encodings.h
include/rapidjson/encodings.h
+9
-0
filestream.h
include/rapidjson/filestream.h
+4
-0
filewritestream.h
include/rapidjson/filewritestream.h
+4
-0
stack.h
include/rapidjson/internal/stack.h
+4
-0
prettywriter.h
include/rapidjson/prettywriter.h
+14
-0
writer.h
include/rapidjson/writer.h
+3
-2
perftest.h
test/perftest/perftest.h
+22
-0
rapidjsontest.cpp
test/perftest/rapidjsontest.cpp
+15
-0
encodedstreamtest.cpp
test/unittest/encodedstreamtest.cpp
+9
-3
filestreamtest.cpp
test/unittest/filestreamtest.cpp
+10
-2
jsoncheckertest.cpp
test/unittest/jsoncheckertest.cpp
+2
-2
readertest.cpp
test/unittest/readertest.cpp
+19
-6
unittest.h
test/unittest/unittest.h
+16
-1
No files found.
build/premake4.lua
View file @
feb5dde7
...
...
@@ -64,7 +64,7 @@ solution "test"
defines
{
"_CRT_SECURE_NO_WARNINGS"
}
configuration
"gmake"
buildoptions
"-msse4.2 -Werror
=cast-qual
"
buildoptions
"-msse4.2 -Werror
-Wall -Wextra
"
project
"gtest"
kind
"StaticLib"
...
...
@@ -86,6 +86,8 @@ solution "test"
project
"unittest"
kind
"ConsoleApp"
buildoptions
"-Weffc++"
files
{
"../include/**.h"
,
"../test/unittest/**.cpp"
,
...
...
@@ -149,8 +151,8 @@ solution "example"
configuration
"vs*"
defines
{
"_CRT_SECURE_NO_WARNINGS"
}
--
configuration "gmake"
-- buildoptions "-Weverything
"
configuration
"gmake"
buildoptions
"-Werror -Wall -Wextra -Weffc++
"
project
"condense"
kind
"ConsoleApp"
...
...
example/serialize/serialize.cpp
View file @
feb5dde7
...
...
@@ -58,9 +58,17 @@ private:
class
Dependent
:
public
Person
{
public
:
Dependent
(
const
std
::
string
&
name
,
unsigned
age
,
Education
*
education
=
0
)
:
Person
(
name
,
age
),
education_
(
education
)
{}
Dependent
(
const
Dependent
&
rhs
)
:
Person
(
rhs
)
{
education_
=
(
rhs
.
education_
==
0
)
?
0
:
new
Education
(
*
rhs
.
education_
);
}
Dependent
(
const
Dependent
&
rhs
)
:
Person
(
rhs
)
,
education_
(
0
)
{
education_
=
(
rhs
.
education_
==
0
)
?
0
:
new
Education
(
*
rhs
.
education_
);
}
virtual
~
Dependent
();
Dependent
&
operator
=
(
const
Dependent
&
rhs
)
{
if
(
this
==
&
rhs
)
return
*
this
;
delete
education_
;
education_
=
(
rhs
.
education_
==
0
)
?
0
:
new
Education
(
*
rhs
.
education_
);
return
*
this
;
}
template
<
typename
Writer
>
void
Serialize
(
Writer
&
writer
)
const
{
writer
.
StartObject
();
...
...
@@ -77,6 +85,7 @@ public:
}
private
:
Education
*
education_
;
};
...
...
@@ -86,7 +95,7 @@ Dependent::~Dependent() {
class
Employee
:
public
Person
{
public
:
Employee
(
const
std
::
string
&
name
,
unsigned
age
,
bool
married
)
:
Person
(
name
,
age
),
married_
(
married
)
{}
Employee
(
const
std
::
string
&
name
,
unsigned
age
,
bool
married
)
:
Person
(
name
,
age
),
dependents_
(),
married_
(
married
)
{}
virtual
~
Employee
();
void
AddDependent
(
const
Dependent
&
dependent
)
{
...
...
include/rapidjson/document.h
View file @
feb5dde7
...
...
@@ -10,6 +10,11 @@
#pragma warning(disable : 4127) // conditional expression is constant
#endif
#ifdef __GNUC__
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Weffc++"
#endif
namespace
rapidjson
{
// Forward declaration.
...
...
@@ -59,7 +64,7 @@ public:
//@{
//! Default constructor creates a null value.
GenericValue
()
:
flags_
(
kNullFlag
)
{}
GenericValue
()
:
data_
(),
flags_
(
kNullFlag
)
{}
//! Copy constructor is not permitted.
private
:
...
...
@@ -72,7 +77,7 @@ public:
\param type Type of the value.
\note Default content for number is zero.
*/
GenericValue
(
Type
type
)
:
data_
()
{
GenericValue
(
Type
type
)
:
data_
()
,
flags_
()
{
static
const
unsigned
defaultFlags
[
7
]
=
{
kNullFlag
,
kFalseFlag
,
kTrueFlag
,
kObjectFlag
,
kArrayFlag
,
kConstStringFlag
,
kNumberAnyFlag
...
...
@@ -92,24 +97,24 @@ public:
GenericValue
(
const
GenericValue
<
Encoding
,
SourceAllocator
>&
rhs
,
Allocator
&
allocator
);
//! Constructor for boolean value.
explicit
GenericValue
(
bool
b
)
:
flags_
(
b
?
kTrueFlag
:
kFalseFlag
)
{}
explicit
GenericValue
(
bool
b
)
:
data_
(),
flags_
(
b
?
kTrueFlag
:
kFalseFlag
)
{}
//! Constructor for int value.
explicit
GenericValue
(
int
i
)
:
flags_
(
kNumberIntFlag
)
{
explicit
GenericValue
(
int
i
)
:
data_
(),
flags_
(
kNumberIntFlag
)
{
data_
.
n
.
i64
=
i
;
if
(
i
>=
0
)
flags_
|=
kUintFlag
|
kUint64Flag
;
}
//! Constructor for unsigned value.
explicit
GenericValue
(
unsigned
u
)
:
flags_
(
kNumberUintFlag
)
{
explicit
GenericValue
(
unsigned
u
)
:
data_
(),
flags_
(
kNumberUintFlag
)
{
data_
.
n
.
u64
=
u
;
if
(
!
(
u
&
0x80000000
))
flags_
|=
kIntFlag
|
kInt64Flag
;
}
//! Constructor for int64_t value.
explicit
GenericValue
(
int64_t
i64
)
:
flags_
(
kNumberInt64Flag
)
{
explicit
GenericValue
(
int64_t
i64
)
:
data_
(),
flags_
(
kNumberInt64Flag
)
{
data_
.
n
.
i64
=
i64
;
if
(
i64
>=
0
)
{
flags_
|=
kNumberUint64Flag
;
...
...
@@ -123,7 +128,7 @@ public:
}
//! Constructor for uint64_t value.
explicit
GenericValue
(
uint64_t
u64
)
:
flags_
(
kNumberUint64Flag
)
{
explicit
GenericValue
(
uint64_t
u64
)
:
data_
(),
flags_
(
kNumberUint64Flag
)
{
data_
.
n
.
u64
=
u64
;
if
(
!
(
u64
&
UINT64_C
(
0x8000000000000000
)))
flags_
|=
kInt64Flag
;
...
...
@@ -134,10 +139,10 @@ public:
}
//! Constructor for double value.
explicit
GenericValue
(
double
d
)
:
flags_
(
kNumberDoubleFlag
)
{
data_
.
n
.
d
=
d
;
}
explicit
GenericValue
(
double
d
)
:
data_
(),
flags_
(
kNumberDoubleFlag
)
{
data_
.
n
.
d
=
d
;
}
//! Constructor for constant string (i.e. do not make a copy of string)
GenericValue
(
const
Ch
*
s
,
SizeType
length
)
{
GenericValue
(
const
Ch
*
s
,
SizeType
length
)
:
data_
(),
flags_
()
{
RAPIDJSON_ASSERT
(
s
!=
NULL
);
flags_
=
kConstStringFlag
;
data_
.
s
.
str
=
s
;
...
...
@@ -145,13 +150,13 @@ public:
}
//! Constructor for constant string (i.e. do not make a copy of string)
explicit
GenericValue
(
const
Ch
*
s
)
{
SetStringRaw
(
s
,
internal
::
StrLen
(
s
));
}
explicit
GenericValue
(
const
Ch
*
s
)
:
data_
(),
flags_
()
{
SetStringRaw
(
s
,
internal
::
StrLen
(
s
));
}
//! Constructor for copy-string (i.e. do make a copy of string)
GenericValue
(
const
Ch
*
s
,
SizeType
length
,
Allocator
&
allocator
)
{
SetStringRaw
(
s
,
length
,
allocator
);
}
GenericValue
(
const
Ch
*
s
,
SizeType
length
,
Allocator
&
allocator
)
:
data_
(),
flags_
()
{
SetStringRaw
(
s
,
length
,
allocator
);
}
//! Constructor for copy-string (i.e. do make a copy of string)
GenericValue
(
const
Ch
*
s
,
Allocator
&
allocator
)
{
SetStringRaw
(
s
,
internal
::
StrLen
(
s
),
allocator
);
}
GenericValue
(
const
Ch
*
s
,
Allocator
&
allocator
)
:
data_
(),
flags_
()
{
SetStringRaw
(
s
,
internal
::
StrLen
(
s
),
allocator
);
}
//! Destructor.
/*! Need to destruct elements of array, members of object, or copy-string.
...
...
@@ -962,4 +967,8 @@ GenericValue<Encoding,Allocator>::GenericValue(const GenericValue<Encoding,Sourc
#pragma warning(pop)
#endif
#ifdef __GNUC__
#pragma GCC diagnostic pop
#endif
#endif // RAPIDJSON_DOCUMENT_H_
include/rapidjson/encodedstream.h
View file @
feb5dde7
...
...
@@ -3,6 +3,11 @@
#include "rapidjson.h"
#ifdef __GNUC__
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Weffc++"
#endif
namespace
rapidjson
{
//! Input byte stream wrapper with a statically bound encoding.
...
...
@@ -31,7 +36,7 @@ public:
size_t
PutEnd
(
Ch
*
)
{
RAPIDJSON_ASSERT
(
false
);
return
0
;
}
private
:
// Prohibit assignment for VC C4512 warning
EncodedInputStream
(
const
EncodedInputStream
&
);
EncodedInputStream
&
operator
=
(
const
EncodedInputStream
&
);
InputByteStream
&
is_
;
...
...
@@ -65,7 +70,7 @@ public:
size_t
PutEnd
(
Ch
*
)
{
RAPIDJSON_ASSERT
(
false
);
return
0
;
}
private
:
// Prohibit assignment for VC C4512 warning
EncodedOutputStream
(
const
EncodedOutputStream
&
);
EncodedOutputStream
&
operator
=
(
const
EncodedOutputStream
&
);
OutputByteStream
&
os_
;
...
...
@@ -110,6 +115,9 @@ public:
size_t
PutEnd
(
Ch
*
)
{
RAPIDJSON_ASSERT
(
false
);
return
0
;
}
private
:
AutoUTFInputStream
(
const
AutoUTFInputStream
&
);
AutoUTFInputStream
&
operator
=
(
const
AutoUTFInputStream
&
);
// Detect encoding type with BOM or RFC 4627
void
DetectType
()
{
// BOM (Byte Order Mark):
...
...
@@ -230,6 +238,9 @@ public:
size_t
PutEnd
(
Ch
*
)
{
RAPIDJSON_ASSERT
(
false
);
return
0
;
}
private
:
AutoUTFOutputStream
(
const
AutoUTFOutputStream
&
);
AutoUTFOutputStream
&
operator
=
(
const
AutoUTFOutputStream
&
);
void
PutBOM
()
{
typedef
void
(
*
PutBOMFunc
)(
OutputByteStream
&
);
static
const
PutBOMFunc
f
[]
=
{
RAPIDJSON_ENCODINGS_FUNC
(
PutBOM
)
};
...
...
@@ -247,4 +258,8 @@ private:
}
// namespace rapidjson
#ifdef __GNUC__
#pragma GCC diagnostic pop
#endif
#endif // RAPIDJSON_FILESTREAM_H_
include/rapidjson/encodings.h
View file @
feb5dde7
...
...
@@ -3,6 +3,11 @@
#include "rapidjson.h"
#ifdef __GNUC__
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Weffc++"
#endif
namespace
rapidjson
{
///////////////////////////////////////////////////////////////////////////////
...
...
@@ -524,4 +529,8 @@ struct Transcoder<Encoding, Encoding> {
}
// namespace rapidjson
#ifdef __GNUC__
#pragma GCC diagnostic pop
#endif
#endif // RAPIDJSON_ENCODINGS_H_
include/rapidjson/filestream.h
View file @
feb5dde7
...
...
@@ -28,6 +28,10 @@ public:
size_t
PutEnd
(
char
*
)
{
return
0
;
}
private
:
// Prohibit copy constructor & assignment operator.
FileStream
(
const
FileStream
&
);
FileStream
&
operator
=
(
const
FileStream
&
);
void
Read
()
{
RAPIDJSON_ASSERT
(
fp_
!=
0
);
int
c
=
fgetc
(
fp_
);
...
...
include/rapidjson/filewritestream.h
View file @
feb5dde7
...
...
@@ -56,6 +56,10 @@ public:
size_t
PutEnd
(
char
*
)
{
RAPIDJSON_ASSERT
(
false
);
return
0
;
}
private
:
// Prohibit copy constructor & assignment operator.
FileWriteStream
(
const
FileWriteStream
&
);
FileWriteStream
&
operator
=
(
const
FileWriteStream
&
);
FILE
*
fp_
;
char
*
buffer_
;
char
*
bufferEnd_
;
...
...
include/rapidjson/internal/stack.h
View file @
feb5dde7
...
...
@@ -69,6 +69,10 @@ public:
size_t
GetCapacity
()
const
{
return
stack_capacity_
;
}
private
:
// Prohibit copy constructor & assignment operator.
Stack
(
const
Stack
&
);
Stack
&
operator
=
(
const
Stack
&
);
Allocator
*
allocator_
;
Allocator
*
own_allocator_
;
char
*
stack_
;
...
...
include/rapidjson/prettywriter.h
View file @
feb5dde7
...
...
@@ -3,6 +3,11 @@
#include "writer.h"
#ifdef __GNUC__
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Weffc++"
#endif
namespace
rapidjson
{
//! Writer with indentation and spacing.
...
...
@@ -162,8 +167,17 @@ protected:
Ch
indentChar_
;
unsigned
indentCharCount_
;
private
:
// Prohibit copy constructor & assignment operator.
PrettyWriter
(
const
PrettyWriter
&
);
PrettyWriter
&
operator
=
(
const
PrettyWriter
&
);
};
}
// namespace rapidjson
#ifdef __GNUC__
#pragma GCC diagnostic pop
#endif
#endif // RAPIDJSON_RAPIDJSON_H_
include/rapidjson/writer.h
View file @
feb5dde7
...
...
@@ -284,8 +284,9 @@ protected:
static
const
int
kDefaultDoublePrecision
=
6
;
private
:
// Prohibit assignment for VC C4512 warning
Writer
&
operator
=
(
const
Writer
&
w
);
// Prohibit copy constructor & assignment operator.
Writer
(
const
Writer
&
);
Writer
&
operator
=
(
const
Writer
&
);
};
}
// namespace rapidjson
...
...
test/perftest/perftest.h
View file @
feb5dde7
...
...
@@ -24,8 +24,22 @@
#ifdef __cplusplus
// gtest indirectly included inttypes.h, without __STDC_CONSTANT_MACROS.
#ifndef __STDC_CONSTANT_MACROS
# define __STDC_CONSTANT_MACROS 1 // required by C++ standard
#endif
#ifdef __GNUC__
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Weffc++"
#endif
#include "gtest/gtest.h"
#ifdef __GNUC__
#pragma GCC diagnostic pop
#endif
#ifdef _MSC_VER
#define _CRTDBG_MAP_ALLOC
#include <crtdbg.h>
...
...
@@ -35,6 +49,8 @@
//! Base class for all performance tests
class
PerfTest
:
public
::
testing
::
Test
{
public
:
PerfTest
()
:
filename_
(),
json_
(),
length_
(),
whitespace_
(),
whitespace_length_
()
{}
virtual
void
SetUp
()
{
FILE
*
fp
=
fopen
(
filename_
=
"data/sample.json"
,
"rb"
);
if
(
!
fp
)
...
...
@@ -68,8 +84,14 @@ public:
virtual
void
TearDown
()
{
free
(
json_
);
free
(
whitespace_
);
json_
=
0
;
whitespace_
=
0
;
}
private
:
PerfTest
(
const
PerfTest
&
);
PerfTest
&
operator
=
(
const
PerfTest
&
);
protected
:
const
char
*
filename_
;
char
*
json_
;
...
...
test/perftest/rapidjsontest.cpp
View file @
feb5dde7
...
...
@@ -21,6 +21,8 @@ using namespace rapidjson;
class
RapidJson
:
public
PerfTest
{
public
:
RapidJson
()
:
temp_
(),
doc_
()
{}
virtual
void
SetUp
()
{
PerfTest
::
SetUp
();
...
...
@@ -36,6 +38,10 @@ public:
free
(
temp_
);
}
private
:
RapidJson
(
const
RapidJson
&
);
RapidJson
&
operator
=
(
const
RapidJson
&
);
protected
:
char
*
temp_
;
Document
doc_
;
...
...
@@ -165,6 +171,11 @@ TEST_F(RapidJson, DocumentTraverse) {
}
}
#ifdef __GNUC__
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Weffc++"
#endif
struct
ValueCounter
:
public
BaseReaderHandler
<>
{
ValueCounter
()
:
count_
(
1
)
{}
// root
...
...
@@ -174,6 +185,10 @@ struct ValueCounter : public BaseReaderHandler<> {
SizeType
count_
;
};
#ifdef __GNUC__
#pragma GCC diagnostic pop
#endif
TEST_F
(
RapidJson
,
DocumentAccept
)
{
for
(
size_t
i
=
0
;
i
<
kTrialCount
;
i
++
)
{
ValueCounter
counter
;
...
...
test/unittest/encodedstreamtest.cpp
View file @
feb5dde7
...
...
@@ -8,14 +8,21 @@ using namespace rapidjson;
class
EncodedStreamTest
:
public
::
testing
::
Test
{
public
:
EncodedStreamTest
()
:
json_
(),
length_
()
{}
virtual
void
SetUp
()
{
json_
=
ReadFile
(
"utf8.json"
,
true
,
&
length_
);
}
virtual
void
TearDown
()
{
free
(
json_
);
json_
=
0
;
}
private
:
EncodedStreamTest
(
const
EncodedStreamTest
&
);
EncodedStreamTest
&
operator
=
(
const
EncodedStreamTest
&
);
protected
:
static
FILE
*
Open
(
const
char
*
filename
)
{
char
buffer
[
1024
];
...
...
@@ -40,8 +47,8 @@ protected:
*
outLength
=
(
size_t
)
ftell
(
fp
);
fseek
(
fp
,
0
,
SEEK_SET
);
char
*
buffer
=
(
char
*
)
malloc
(
*
outLength
+
1
);
fread
(
buffer
,
1
,
*
outLength
,
fp
);
buffer
[
*
out
Length
]
=
'\0'
;
size_t
readLength
=
fread
(
buffer
,
1
,
*
outLength
,
fp
);
buffer
[
read
Length
]
=
'\0'
;
fclose
(
fp
);
return
buffer
;
}
...
...
@@ -131,7 +138,6 @@ protected:
remove
(
filename
);
}
const
char
*
filename_
;
char
*
json_
;
size_t
length_
;
};
...
...
test/unittest/filestreamtest.cpp
View file @
feb5dde7
...
...
@@ -7,6 +7,9 @@
using
namespace
rapidjson
;
class
FileStreamTest
:
public
::
testing
::
Test
{
public
:
FileStreamTest
()
:
filename_
(),
json_
(),
length_
()
{}
virtual
void
SetUp
()
{
FILE
*
fp
=
fopen
(
filename_
=
"data/sample.json"
,
"rb"
);
if
(
!
fp
)
...
...
@@ -17,15 +20,20 @@ class FileStreamTest : public ::testing::Test {
length_
=
(
size_t
)
ftell
(
fp
);
fseek
(
fp
,
0
,
SEEK_SET
);
json_
=
(
char
*
)
malloc
(
length_
+
1
);
fread
(
json_
,
1
,
length_
,
fp
);
json_
[
length_
]
=
'\0'
;
size_t
readLength
=
fread
(
json_
,
1
,
length_
,
fp
);
json_
[
readLength
]
=
'\0'
;
fclose
(
fp
);
}
virtual
void
TearDown
()
{
free
(
json_
);
json_
=
0
;
}
private
:
FileStreamTest
(
const
FileStreamTest
&
);
FileStreamTest
&
operator
=
(
const
FileStreamTest
&
);
protected
:
const
char
*
filename_
;
char
*
json_
;
...
...
test/unittest/jsoncheckertest.cpp
View file @
feb5dde7
...
...
@@ -15,8 +15,8 @@ static char* ReadFile(const char* filename, size_t& length) {
length
=
(
size_t
)
ftell
(
fp
);
fseek
(
fp
,
0
,
SEEK_SET
);
char
*
json
=
(
char
*
)
malloc
(
length
+
1
);
fread
(
json
,
1
,
length
,
fp
);
json
[
l
ength
]
=
'\0'
;
size_t
readLength
=
fread
(
json
,
1
,
length
,
fp
);
json
[
readL
ength
]
=
'\0'
;
fclose
(
fp
);
return
json
;
}
...
...
test/unittest/readertest.cpp
View file @
feb5dde7
...
...
@@ -5,6 +5,11 @@
using
namespace
rapidjson
;
#ifdef __GNUC__
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Weffc++"
#endif
template
<
bool
expect
>
struct
ParseBoolHandler
:
BaseReaderHandler
<>
{
ParseBoolHandler
()
:
step_
(
0
)
{}
...
...
@@ -33,7 +38,7 @@ TEST(Reader, ParseFalse) {
}
struct
ParseIntHandler
:
BaseReaderHandler
<>
{
ParseIntHandler
()
:
step_
(
0
)
{}
ParseIntHandler
()
:
step_
(
0
)
,
actual_
()
{}
void
Default
()
{
FAIL
();
}
void
Int
(
int
i
)
{
actual_
=
i
;
step_
++
;
}
...
...
@@ -42,7 +47,7 @@ struct ParseIntHandler : BaseReaderHandler<> {
};
struct
ParseUintHandler
:
BaseReaderHandler
<>
{
ParseUintHandler
()
:
step_
(
0
)
{}
ParseUintHandler
()
:
step_
(
0
)
,
actual_
()
{}
void
Default
()
{
FAIL
();
}
void
Uint
(
unsigned
i
)
{
actual_
=
i
;
step_
++
;
}
...
...
@@ -51,7 +56,7 @@ struct ParseUintHandler : BaseReaderHandler<> {
};
struct
ParseInt64Handler
:
BaseReaderHandler
<>
{
ParseInt64Handler
()
:
step_
(
0
)
{}
ParseInt64Handler
()
:
step_
(
0
)
,
actual_
()
{}
void
Default
()
{
FAIL
();
}
void
Int64
(
int64_t
i
)
{
actual_
=
i
;
step_
++
;
}
...
...
@@ -60,7 +65,7 @@ struct ParseInt64Handler : BaseReaderHandler<> {
};
struct
ParseUint64Handler
:
BaseReaderHandler
<>
{
ParseUint64Handler
()
:
step_
(
0
)
{}
ParseUint64Handler
()
:
step_
(
0
)
,
actual_
()
{}
void
Default
()
{
FAIL
();
}
void
Uint64
(
uint64_t
i
)
{
actual_
=
i
;
step_
++
;
}
...
...
@@ -69,7 +74,7 @@ struct ParseUint64Handler : BaseReaderHandler<> {
};
struct
ParseDoubleHandler
:
BaseReaderHandler
<>
{
ParseDoubleHandler
()
:
step_
(
0
)
{}
ParseDoubleHandler
()
:
step_
(
0
)
,
actual_
()
{}
void
Default
()
{
FAIL
();
}
void
Double
(
double
d
)
{
actual_
=
d
;
step_
++
;
}
...
...
@@ -183,8 +188,12 @@ TEST(Reader, ParseNumber_Error) {
template
<
typename
Encoding
>
struct
ParseStringHandler
:
BaseReaderHandler
<
Encoding
>
{
ParseStringHandler
()
:
str_
(
0
),
length_
(
0
)
{}
ParseStringHandler
()
:
str_
(
0
),
length_
(
0
)
,
copy_
()
{}
~
ParseStringHandler
()
{
EXPECT_TRUE
(
str_
!=
0
);
if
(
copy_
)
free
(
const_cast
<
typename
Encoding
::
Ch
*>
(
str_
));
}
ParseStringHandler
(
const
ParseStringHandler
&
);
ParseStringHandler
&
operator
=
(
const
ParseStringHandler
&
);
void
Default
()
{
FAIL
();
}
void
String
(
const
typename
Encoding
::
Ch
*
str
,
size_t
length
,
bool
copy
)
{
EXPECT_EQ
(
0
,
str_
);
...
...
@@ -652,3 +661,7 @@ TEST(Reader, CustomStringStream) {
reader
.
ParseObject
<
0
>
(
s
,
h
);
EXPECT_EQ
(
20u
,
h
.
step_
);
}
#ifdef __GNUC__
#pragma GCC diagnostic pop
#endif
test/unittest/unittest.h
View file @
feb5dde7
#ifndef UNITTEST_H_
#define UNITTEST_H_
// gtest indirectly included inttypes.h, without __STDC_CONSTANT_MACROS.
#ifndef __STDC_CONSTANT_MACROS
# define __STDC_CONSTANT_MACROS 1 // required by C++ standard
#endif
#ifdef _MSC_VER
#define _CRTDBG_MAP_ALLOC
#include <crtdbg.h>
#pragma warning(disable : 4996) // 'function': was declared deprecated
#endif
#ifdef __GNUC__
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Weffc++"
#endif
#include "gtest/gtest.h"
#ifdef __GNUC__
#pragma GCC diagnostic pop
#endif
template
<
typename
Ch
>
inline
size_t
StrLen
(
const
Ch
*
s
)
{
const
Ch
*
p
=
s
;
...
...
@@ -31,7 +46,7 @@ inline Ch* StrDup(const Ch* str) {
}
inline
void
TempFilename
(
char
*
filename
)
{
tmpnam
(
filename
);
filename
=
tmpnam
(
filename
);
// For Visual Studio, tmpnam() adds a backslash in front. Remove it.
if
(
filename
[
0
]
==
'\\'
)
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment