Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
畅游知识海洋
json
提交
18e0430b
J
json
项目概览
畅游知识海洋
/
json
与 Fork 源项目一致
从无法访问的项目Fork
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
J
json
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
未验证
提交
18e0430b
编写于
7月 22, 2017
作者:
N
Niels Lohmann
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
🔨
adding destroy function to discard values
上级
5b5f0090
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
45 addition
and
35 deletion
+45
-35
src/json.hpp
src/json.hpp
+45
-35
未找到文件。
src/json.hpp
浏览文件 @
18e0430b
...
@@ -3172,6 +3172,7 @@ class parser
...
@@ -3172,6 +3172,7 @@ class parser
// start with a discarded value
// start with a discarded value
if
(
not
result
.
is_discarded
())
if
(
not
result
.
is_discarded
())
{
{
result
.
m_value
.
destroy
(
result
.
m_type
);
result
.
m_type
=
value_t
::
discarded
;
result
.
m_type
=
value_t
::
discarded
;
}
}
...
@@ -3194,6 +3195,7 @@ class parser
...
@@ -3194,6 +3195,7 @@ class parser
{
{
if
(
keep
and
callback
and
not
callback
(
--
depth
,
parse_event_t
::
object_end
,
result
))
if
(
keep
and
callback
and
not
callback
(
--
depth
,
parse_event_t
::
object_end
,
result
))
{
{
result
.
m_value
.
destroy
(
result
.
m_type
);
result
.
m_type
=
value_t
::
discarded
;
result
.
m_type
=
value_t
::
discarded
;
}
}
break
;
break
;
...
@@ -3227,7 +3229,8 @@ class parser
...
@@ -3227,7 +3229,8 @@ class parser
// parse and add value
// parse and add value
get_token
();
get_token
();
value
=
value_t
::
discarded
;
value
.
m_value
.
destroy
(
value
.
m_type
);
value
.
m_type
=
value_t
::
discarded
;
parse_internal
(
keep
,
value
);
parse_internal
(
keep
,
value
);
if
(
keep
and
keep_tag
and
not
value
.
is_discarded
())
if
(
keep
and
keep_tag
and
not
value
.
is_discarded
())
{
{
...
@@ -3249,6 +3252,7 @@ class parser
...
@@ -3249,6 +3252,7 @@ class parser
if
(
keep
and
callback
and
not
callback
(
--
depth
,
parse_event_t
::
object_end
,
result
))
if
(
keep
and
callback
and
not
callback
(
--
depth
,
parse_event_t
::
object_end
,
result
))
{
{
result
.
m_value
.
destroy
(
result
.
m_type
);
result
.
m_type
=
value_t
::
discarded
;
result
.
m_type
=
value_t
::
discarded
;
}
}
break
;
break
;
...
@@ -3271,6 +3275,7 @@ class parser
...
@@ -3271,6 +3275,7 @@ class parser
{
{
if
(
callback
and
not
callback
(
--
depth
,
parse_event_t
::
array_end
,
result
))
if
(
callback
and
not
callback
(
--
depth
,
parse_event_t
::
array_end
,
result
))
{
{
result
.
m_value
.
destroy
(
result
.
m_type
);
result
.
m_type
=
value_t
::
discarded
;
result
.
m_type
=
value_t
::
discarded
;
}
}
break
;
break
;
...
@@ -3281,7 +3286,8 @@ class parser
...
@@ -3281,7 +3286,8 @@ class parser
while
(
true
)
while
(
true
)
{
{
// parse value
// parse value
value
=
value_t
::
discarded
;
value
.
m_value
.
destroy
(
value
.
m_type
);
value
.
m_type
=
value_t
::
discarded
;
parse_internal
(
keep
,
value
);
parse_internal
(
keep
,
value
);
if
(
keep
and
not
value
.
is_discarded
())
if
(
keep
and
not
value
.
is_discarded
())
{
{
...
@@ -3303,6 +3309,7 @@ class parser
...
@@ -3303,6 +3309,7 @@ class parser
if
(
keep
and
callback
and
not
callback
(
--
depth
,
parse_event_t
::
array_end
,
result
))
if
(
keep
and
callback
and
not
callback
(
--
depth
,
parse_event_t
::
array_end
,
result
))
{
{
result
.
m_value
.
destroy
(
result
.
m_type
);
result
.
m_type
=
value_t
::
discarded
;
result
.
m_type
=
value_t
::
discarded
;
}
}
break
;
break
;
...
@@ -8278,6 +8285,41 @@ class basic_json
...
@@ -8278,6 +8285,41 @@ class basic_json
{
{
array
=
create
<
array_t
>
(
value
);
array
=
create
<
array_t
>
(
value
);
}
}
void
destroy
(
value_t
t
)
{
switch
(
t
)
{
case
value_t
::
object
:
{
AllocatorType
<
object_t
>
alloc
;
alloc
.
destroy
(
object
);
alloc
.
deallocate
(
object
,
1
);
break
;
}
case
value_t
::
array
:
{
AllocatorType
<
array_t
>
alloc
;
alloc
.
destroy
(
array
);
alloc
.
deallocate
(
array
,
1
);
break
;
}
case
value_t
::
string
:
{
AllocatorType
<
string_t
>
alloc
;
alloc
.
destroy
(
string
);
alloc
.
deallocate
(
string
,
1
);
break
;
}
default:
{
break
;
}
}
}
};
};
/*!
/*!
...
@@ -9026,39 +9068,7 @@ class basic_json
...
@@ -9026,39 +9068,7 @@ class basic_json
~
basic_json
()
~
basic_json
()
{
{
assert_invariant
();
assert_invariant
();
m_value
.
destroy
(
m_type
);
switch
(
m_type
)
{
case
value_t
::
object
:
{
AllocatorType
<
object_t
>
alloc
;
alloc
.
destroy
(
m_value
.
object
);
alloc
.
deallocate
(
m_value
.
object
,
1
);
break
;
}
case
value_t
::
array
:
{
AllocatorType
<
array_t
>
alloc
;
alloc
.
destroy
(
m_value
.
array
);
alloc
.
deallocate
(
m_value
.
array
,
1
);
break
;
}
case
value_t
::
string
:
{
AllocatorType
<
string_t
>
alloc
;
alloc
.
destroy
(
m_value
.
string
);
alloc
.
deallocate
(
m_value
.
string
,
1
);
break
;
}
default:
{
// all other types need no specific destructor
break
;
}
}
}
}
/// @}
/// @}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录