Skip to content
Projects
Groups
Snippets
Help
Loading...
Help
Support
Keyboard shortcuts
?
Submit feedback
Contribute to GitLab
Sign in / Register
Toggle navigation
J
json
Project overview
Project overview
Details
Activity
Releases
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Issues
0
Issues
0
List
Boards
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Analytics
Analytics
CI / CD
Repository
Value Stream
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
Libraries
json
Commits
aed4a080
Commit
aed4a080
authored
Jan 31, 2018
by
Kaido
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
Templatize std::string in binary_reader #941
parent
e8bf1f62
Changes
2
Hide whitespace changes
Inline
Side-by-side
Showing
2 changed files
with
22 additions
and
20 deletions
+22
-20
develop/detail/input/binary_reader.hpp
develop/detail/input/binary_reader.hpp
+11
-10
src/json.hpp
src/json.hpp
+11
-10
No files found.
develop/detail/input/binary_reader.hpp
View file @
aed4a080
...
...
@@ -36,6 +36,7 @@ class binary_reader
{
using
number_integer_t
=
typename
BasicJsonType
::
number_integer_t
;
using
number_unsigned_t
=
typename
BasicJsonType
::
number_unsigned_t
;
using
string_t
=
typename
BasicJsonType
::
string_t
;
public:
/*!
...
...
@@ -863,9 +864,9 @@ class binary_reader
@throw parse_error.110 if input has less than @a len bytes
*/
template
<
typename
NumberType
>
st
d
::
string
get_string
(
const
NumberType
len
)
st
ring_t
get_string
(
const
NumberType
len
)
{
st
d
::
string
result
;
st
ring_t
result
;
std
::
generate_n
(
std
::
back_inserter
(
result
),
len
,
[
this
]()
{
get
();
...
...
@@ -887,7 +888,7 @@ class binary_reader
@throw parse_error.110 if input ended
@throw parse_error.113 if an unexpected byte is read
*/
st
d
::
string
get_cbor_string
()
st
ring_t
get_cbor_string
()
{
unexpect_eof
();
...
...
@@ -944,7 +945,7 @@ class binary_reader
case
0x7F
:
// UTF-8 string (indefinite length)
{
st
d
::
string
result
;
st
ring_t
result
;
while
(
get
()
!=
0xFF
)
{
unexpect_eof
();
...
...
@@ -1000,7 +1001,7 @@ class binary_reader
@throw parse_error.110 if input ended
@throw parse_error.113 if an unexpected byte is read
*/
st
d
::
string
get_msgpack_string
()
st
ring_t
get_msgpack_string
()
{
unexpect_eof
();
...
...
@@ -1111,7 +1112,7 @@ class binary_reader
@throw parse_error.110 if input ended
@throw parse_error.113 if an unexpected byte is read
*/
st
d
::
string
get_ubjson_string
(
const
bool
get_char
=
true
)
st
ring_t
get_ubjson_string
(
const
bool
get_char
=
true
)
{
if
(
get_char
)
{
...
...
@@ -1150,7 +1151,7 @@ class binary_reader
*/
std
::
pair
<
std
::
size_t
,
int
>
get_ubjson_size_type
()
{
std
::
size_t
sz
=
st
d
::
string
::
npos
;
std
::
size_t
sz
=
st
ring_t
::
npos
;
int
tc
=
0
;
get_ignore_noop
();
...
...
@@ -1219,7 +1220,7 @@ class binary_reader
JSON_THROW
(
parse_error
::
create
(
113
,
chars_read
,
"byte after 'C' must be in range 0x00..0x7F; last byte: 0x"
+
ss
.
str
()));
}
return
st
d
::
string
(
1
,
static_cast
<
char
>
(
current
));
return
st
ring_t
(
1
,
static_cast
<
char
>
(
current
));
}
case
'S'
:
// string
...
...
@@ -1244,7 +1245,7 @@ class binary_reader
BasicJsonType
result
=
value_t
::
array
;
const
auto
size_and_type
=
get_ubjson_size_type
();
if
(
size_and_type
.
first
!=
st
d
::
string
::
npos
)
if
(
size_and_type
.
first
!=
st
ring_t
::
npos
)
{
if
(
size_and_type
.
second
!=
0
)
{
...
...
@@ -1281,7 +1282,7 @@ class binary_reader
BasicJsonType
result
=
value_t
::
object
;
const
auto
size_and_type
=
get_ubjson_size_type
();
if
(
size_and_type
.
first
!=
st
d
::
string
::
npos
)
if
(
size_and_type
.
first
!=
st
ring_t
::
npos
)
{
if
(
size_and_type
.
second
!=
0
)
{
...
...
src/json.hpp
View file @
aed4a080
...
...
@@ -4856,6 +4856,7 @@ class binary_reader
{
using
number_integer_t
=
typename
BasicJsonType
::
number_integer_t
;
using
number_unsigned_t
=
typename
BasicJsonType
::
number_unsigned_t
;
using
string_t
=
typename
BasicJsonType
::
string_t
;
public:
/*!
...
...
@@ -5683,9 +5684,9 @@ class binary_reader
@throw parse_error.110 if input has less than @a len bytes
*/
template
<
typename
NumberType
>
st
d::string
get_string(const NumberType len)
st
ring_t
get_string
(
const
NumberType
len
)
{
st
d::string
result;
st
ring_t
result
;
std
::
generate_n
(
std
::
back_inserter
(
result
),
len
,
[
this
]()
{
get
();
...
...
@@ -5707,7 +5708,7 @@ class binary_reader
@throw parse_error.110 if input ended
@throw parse_error.113 if an unexpected byte is read
*/
st
d::string
get_cbor_string()
st
ring_t
get_cbor_string
()
{
unexpect_eof
();
...
...
@@ -5764,7 +5765,7 @@ class binary_reader
case
0x7F
:
// UTF-8 string (indefinite length)
{
st
d::string
result;
st
ring_t
result
;
while
(
get
()
!=
0xFF
)
{
unexpect_eof
();
...
...
@@ -5820,7 +5821,7 @@ class binary_reader
@throw parse_error.110 if input ended
@throw parse_error.113 if an unexpected byte is read
*/
st
d::string
get_msgpack_string()
st
ring_t
get_msgpack_string
()
{
unexpect_eof
();
...
...
@@ -5931,7 +5932,7 @@ class binary_reader
@throw parse_error.110 if input ended
@throw parse_error.113 if an unexpected byte is read
*/
st
d::string
get_ubjson_string(const bool get_char = true)
st
ring_t
get_ubjson_string
(
const
bool
get_char
=
true
)
{
if
(
get_char
)
{
...
...
@@ -5970,7 +5971,7 @@ class binary_reader
*/
std
::
pair
<
std
::
size_t
,
int
>
get_ubjson_size_type
()
{
std::size_t sz = st
d::string
::npos;
std
::
size_t
sz
=
st
ring_t
::
npos
;
int
tc
=
0
;
get_ignore_noop
();
...
...
@@ -6039,7 +6040,7 @@ class binary_reader
JSON_THROW
(
parse_error
::
create
(
113
,
chars_read
,
"byte after 'C' must be in range 0x00..0x7F; last byte: 0x"
+
ss
.
str
()));
}
return st
d::string
(1, static_cast<char>(current));
return
st
ring_t
(
1
,
static_cast
<
char
>
(
current
));
}
case
'S'
:
// string
...
...
@@ -6064,7 +6065,7 @@ class binary_reader
BasicJsonType
result
=
value_t
::
array
;
const
auto
size_and_type
=
get_ubjson_size_type
();
if (size_and_type.first != st
d::string
::npos)
if
(
size_and_type
.
first
!=
st
ring_t
::
npos
)
{
if
(
size_and_type
.
second
!=
0
)
{
...
...
@@ -6101,7 +6102,7 @@ class binary_reader
BasicJsonType
result
=
value_t
::
object
;
const
auto
size_and_type
=
get_ubjson_size_type
();
if (size_and_type.first != st
d::string
::npos)
if
(
size_and_type
.
first
!=
st
ring_t
::
npos
)
{
if
(
size_and_type
.
second
!=
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