Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
OpenHarmony
Startup Init Lite
提交
d273f671
S
Startup Init Lite
项目概览
OpenHarmony
/
Startup Init Lite
1 年多 前同步成功
通知
3
Star
37
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
S
Startup Init Lite
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
提交
Issue看板
未验证
提交
d273f671
编写于
4月 19, 2022
作者:
O
openharmony_ci
提交者:
Gitee
4月 19, 2022
浏览文件
操作
浏览文件
下载
差异文件
!525 统一L1 、L2 execv 命令执行统一,统一采用export 命令即setenv。
Merge pull request !525 from 熊磊/init418_1
上级
f369f334
e2892325
变更
2
隐藏空白更改
内联
并排
Showing
2 changed file
with
14 addition
and
8 deletion
+14
-8
services/init/lite/init_service.c
services/init/lite/init_service.c
+12
-8
test/unittest/common/cmd_func_test.cpp
test/unittest/common/cmd_func_test.cpp
+2
-0
未找到文件。
services/init/lite/init_service.c
浏览文件 @
d273f671
...
...
@@ -67,16 +67,20 @@ int ServiceExec(const Service *service)
INIT_ERROR_CHECK
(
service
!=
NULL
&&
service
->
pathArgs
.
count
>
0
,
return
SERVICE_FAILURE
,
"Exec service failed! null ptr."
);
INIT_LOGI
(
"service->name is %s "
,
service
->
name
);
char
*
env
[]
=
{
"LD_LIBRARY_PATH=/storage/app/libs"
,
NULL
,
NULL
};
char
sockEnv
[
MAX_ENV_NAME
]
=
{
0
};
char
sockEnvName
[
MAX_ENV_NAME
]
=
{
0
};
char
sockEnv
Value
[
MAX_ENV_NAME
]
=
{
0
};
if
(
service
->
socketCfg
!=
NULL
)
{
INIT_ERROR_CHECK
(
snprintf_s
(
sockEnv
,
sizeof
(
sockEnv
),
sizeof
(
sockEnv
)
-
1
,
"OHOS_SOCKET_%s=%d"
,
service
->
socketCfg
->
name
,
service
->
socketCfg
->
sockFd
)
!=
-
1
,
return
SERVICE_FAILURE
,
"format socket env failed!"
);
env
[
1
]
=
sockEnv
;
INIT_ERROR_CHECK
(
snprintf_s
(
sockEnvName
,
MAX_ENV_NAME
,
MAX_ENV_NAME
-
1
,
"OHOS_SOCKET_%s"
,
service
->
socketCfg
->
name
)
!=
-
1
,
return
SERVICE_FAILURE
,
"format socket env name failed!"
);
INIT_ERROR_CHECK
(
snprintf_s
(
sockEnvValue
,
MAX_ENV_NAME
,
MAX_ENV_NAME
-
1
,
"%d"
,
service
->
socketCfg
->
sockFd
)
!=
-
1
,
return
SERVICE_FAILURE
,
"format socket env value failed!"
);
}
if
(
execve
(
service
->
pathArgs
.
argv
[
0
],
service
->
pathArgs
.
argv
,
env
)
!=
0
)
{
INIT_LOGE
(
"service %s execve failed! err %d."
,
service
->
name
,
errno
);
INIT_CHECK_ONLY_ELOG
(
setenv
(
sockEnvName
,
sockEnvValue
,
1
)
==
0
,
"DoExport: set %s with %s failed: %d"
,
sockEnvName
,
sockEnvValue
,
errno
);
if
(
execv
(
service
->
pathArgs
.
argv
[
0
],
service
->
pathArgs
.
argv
)
!=
0
)
{
INIT_LOGE
(
"service %s execv failed! err %d."
,
service
->
name
,
errno
);
return
errno
;
}
return
SERVICE_SUCCESS
;
...
...
test/unittest/common/cmd_func_test.cpp
浏览文件 @
d273f671
...
...
@@ -733,6 +733,8 @@ static void CheckCmd(const TestCmdLine *resCmd)
EXPECT_NE
(
' '
,
resCmd
->
cmdContent
[
0
]);
// should not start with space
}
else
if
(
strcmp
(
"loadcfg "
,
resCmd
->
name
)
==
0
)
{
EXPECT_NE
(
' '
,
resCmd
->
cmdContent
[
0
]);
// should not start with space
}
else
if
(
strcmp
(
"export "
,
resCmd
->
name
)
==
0
)
{
EXPECT_NE
(
' '
,
resCmd
->
cmdContent
[
0
]);
// should not start with space
}
else
{
// unknown cmd
EXPECT_TRUE
(
false
);
}
...
...
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录