Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Third Party CJSON
提交
cc514583
T
Third Party CJSON
项目概览
OpenHarmony
/
Third Party CJSON
大约 1 年 前同步成功
通知
6
Star
22
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
Third Party CJSON
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
cc514583
编写于
2月 07, 2017
作者:
M
Max Bruckner
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
cJSON_Duplicate: goto fail error handling
Simplify error handling using goto fail and improve some names.
上级
021b174e
变更
1
隐藏空白更改
内联
并排
Showing
1 changed file
with
25 addition
and
19 deletion
+25
-19
cJSON.c
cJSON.c
+25
-19
未找到文件。
cJSON.c
浏览文件 @
cc514583
...
@@ -2316,20 +2316,20 @@ cJSON *cJSON_CreateStringArray(const char **strings, int count)
...
@@ -2316,20 +2316,20 @@ cJSON *cJSON_CreateStringArray(const char **strings, int count)
cJSON
*
cJSON_Duplicate
(
const
cJSON
*
item
,
cjbool
recurse
)
cJSON
*
cJSON_Duplicate
(
const
cJSON
*
item
,
cjbool
recurse
)
{
{
cJSON
*
newitem
=
NULL
;
cJSON
*
newitem
=
NULL
;
cJSON
*
c
ptr
=
NULL
;
cJSON
*
c
hild
=
NULL
;
cJSON
*
n
ptr
=
NULL
;
cJSON
*
n
ext
=
NULL
;
cJSON
*
newchild
=
NULL
;
cJSON
*
newchild
=
NULL
;
/* Bail on bad ptr */
/* Bail on bad ptr */
if
(
!
item
)
if
(
!
item
)
{
{
return
NULL
;
goto
fail
;
}
}
/* Create new item */
/* Create new item */
newitem
=
cJSON_New_Item
();
newitem
=
cJSON_New_Item
();
if
(
!
newitem
)
if
(
!
newitem
)
{
{
return
NULL
;
goto
fail
;
}
}
/* Copy over all vars */
/* Copy over all vars */
newitem
->
type
=
item
->
type
&
(
~
cJSON_IsReference
);
newitem
->
type
=
item
->
type
&
(
~
cJSON_IsReference
);
...
@@ -2340,8 +2340,7 @@ cJSON *cJSON_Duplicate(const cJSON *item, cjbool recurse)
...
@@ -2340,8 +2340,7 @@ cJSON *cJSON_Duplicate(const cJSON *item, cjbool recurse)
newitem
->
valuestring
=
(
char
*
)
cJSON_strdup
((
unsigned
char
*
)
item
->
valuestring
);
newitem
->
valuestring
=
(
char
*
)
cJSON_strdup
((
unsigned
char
*
)
item
->
valuestring
);
if
(
!
newitem
->
valuestring
)
if
(
!
newitem
->
valuestring
)
{
{
cJSON_Delete
(
newitem
);
goto
fail
;
return
NULL
;
}
}
}
}
if
(
item
->
string
)
if
(
item
->
string
)
...
@@ -2349,8 +2348,7 @@ cJSON *cJSON_Duplicate(const cJSON *item, cjbool recurse)
...
@@ -2349,8 +2348,7 @@ cJSON *cJSON_Duplicate(const cJSON *item, cjbool recurse)
newitem
->
string
=
(
item
->
type
&
cJSON_StringIsConst
)
?
item
->
string
:
(
char
*
)
cJSON_strdup
((
unsigned
char
*
)
item
->
string
);
newitem
->
string
=
(
item
->
type
&
cJSON_StringIsConst
)
?
item
->
string
:
(
char
*
)
cJSON_strdup
((
unsigned
char
*
)
item
->
string
);
if
(
!
newitem
->
string
)
if
(
!
newitem
->
string
)
{
{
cJSON_Delete
(
newitem
);
goto
fail
;
return
NULL
;
}
}
}
}
/* If non-recursive, then we're done! */
/* If non-recursive, then we're done! */
...
@@ -2359,31 +2357,39 @@ cJSON *cJSON_Duplicate(const cJSON *item, cjbool recurse)
...
@@ -2359,31 +2357,39 @@ cJSON *cJSON_Duplicate(const cJSON *item, cjbool recurse)
return
newitem
;
return
newitem
;
}
}
/* Walk the ->next chain for the child. */
/* Walk the ->next chain for the child. */
c
ptr
=
item
->
child
;
c
hild
=
item
->
child
;
while
(
c
ptr
)
while
(
c
hild
!=
NULL
)
{
{
newchild
=
cJSON_Duplicate
(
c
ptr
,
1
);
/* Duplicate (with recurse) each item in the ->next chain */
newchild
=
cJSON_Duplicate
(
c
hild
,
true
);
/* Duplicate (with recurse) each item in the ->next chain */
if
(
!
newchild
)
if
(
!
newchild
)
{
{
cJSON_Delete
(
newitem
);
goto
fail
;
return
NULL
;
}
}
if
(
n
ptr
)
if
(
n
ext
!=
NULL
)
{
{
/* If newitem->child already set, then crosswire ->prev and ->next and move on */
/* If newitem->child already set, then crosswire ->prev and ->next and move on */
n
ptr
->
next
=
newchild
;
n
ext
->
next
=
newchild
;
newchild
->
prev
=
n
ptr
;
newchild
->
prev
=
n
ext
;
n
ptr
=
newchild
;
n
ext
=
newchild
;
}
}
else
else
{
{
/* Set newitem->child and move to it */
/* Set newitem->child and move to it */
newitem
->
child
=
newchild
;
nptr
=
newchild
;
newitem
->
child
=
newchild
;
next
=
newchild
;
}
}
c
ptr
=
cptr
->
next
;
c
hild
=
child
->
next
;
}
}
return
newitem
;
return
newitem
;
fail:
if
(
newitem
!=
NULL
)
{
cJSON_Delete
(
newitem
);
}
return
NULL
;
}
}
void
cJSON_Minify
(
char
*
json
)
void
cJSON_Minify
(
char
*
json
)
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录