Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Third Party Unity
提交
ccb29e80
T
Third Party Unity
项目概览
OpenHarmony
/
Third Party Unity
1 年多 前同步成功
通知
36
Star
144
Fork
2
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
T
Third Party Unity
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
提交
ccb29e80
编写于
1月 31, 2016
作者:
J
jsalling
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Add NULL safety checks to Fixture allocation functions
Consistent use of one-liners and NULL
上级
e2ad88b9
变更
1
显示空白变更内容
内联
并排
Showing
1 changed file
with
7 addition
and
5 deletion
+7
-5
extras/fixture/src/unity_fixture.c
extras/fixture/src/unity_fixture.c
+7
-5
未找到文件。
extras/fixture/src/unity_fixture.c
浏览文件 @
ccb29e80
...
@@ -179,9 +179,11 @@ void* unity_malloc(size_t size)
...
@@ -179,9 +179,11 @@ void* unity_malloc(size_t size)
malloc_fail_countdown
--
;
malloc_fail_countdown
--
;
}
}
if
(
size
==
0
)
return
NULL
;
malloc_count
++
;
malloc_count
++
;
guard
=
(
Guard
*
)
UNITY_FIXTURE_MALLOC
(
size
+
sizeof
(
Guard
)
+
sizeof
(
end
));
guard
=
(
Guard
*
)
UNITY_FIXTURE_MALLOC
(
size
+
sizeof
(
Guard
)
+
sizeof
(
end
));
if
(
guard
==
NULL
)
return
NULL
;
guard
->
size
=
size
;
guard
->
size
=
size
;
mem
=
(
char
*
)
&
(
guard
[
1
]);
mem
=
(
char
*
)
&
(
guard
[
1
]);
memcpy
(
&
mem
[
size
],
end
,
sizeof
(
end
));
memcpy
(
&
mem
[
size
],
end
,
sizeof
(
end
));
...
@@ -227,6 +229,7 @@ void unity_free(void* mem)
...
@@ -227,6 +229,7 @@ void unity_free(void* mem)
void
*
unity_calloc
(
size_t
num
,
size_t
size
)
void
*
unity_calloc
(
size_t
num
,
size_t
size
)
{
{
void
*
mem
=
unity_malloc
(
num
*
size
);
void
*
mem
=
unity_malloc
(
num
*
size
);
if
(
mem
==
NULL
)
return
NULL
;
memset
(
mem
,
0
,
num
*
size
);
memset
(
mem
,
0
,
num
*
size
);
return
mem
;
return
mem
;
}
}
...
@@ -237,8 +240,7 @@ void* unity_realloc(void* oldMem, size_t size)
...
@@ -237,8 +240,7 @@ void* unity_realloc(void* oldMem, size_t size)
// char* memAsChar = (char*)oldMem;
// char* memAsChar = (char*)oldMem;
void
*
newMem
;
void
*
newMem
;
if
(
oldMem
==
0
)
if
(
oldMem
==
NULL
)
return
unity_malloc
(
size
);
return
unity_malloc
(
size
);
guard
--
;
guard
--
;
if
(
isOverrun
(
oldMem
))
if
(
isOverrun
(
oldMem
))
...
@@ -250,13 +252,13 @@ void* unity_realloc(void* oldMem, size_t size)
...
@@ -250,13 +252,13 @@ void* unity_realloc(void* oldMem, size_t size)
if
(
size
==
0
)
if
(
size
==
0
)
{
{
release_memory
(
oldMem
);
release_memory
(
oldMem
);
return
0
;
return
NULL
;
}
}
if
(
guard
->
size
>=
size
)
if
(
guard
->
size
>=
size
)
return
oldMem
;
return
oldMem
;
newMem
=
unity_malloc
(
size
);
newMem
=
unity_malloc
(
size
);
if
(
newMem
==
NULL
)
return
NULL
;
// Do not release old memory
memcpy
(
newMem
,
oldMem
,
guard
->
size
);
memcpy
(
newMem
,
oldMem
,
guard
->
size
);
unity_free
(
oldMem
);
unity_free
(
oldMem
);
return
newMem
;
return
newMem
;
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录