Skip to content
体验新版
项目
组织
正在加载...
登录
切换导航
打开侧边栏
BaiXuePrincess
rt-thread
提交
937e22fc
R
rt-thread
项目概览
BaiXuePrincess
/
rt-thread
与 Fork 源项目一致
Fork自
RT-Thread / rt-thread
通知
1
Star
0
Fork
0
代码
文件
提交
分支
Tags
贡献者
分支图
Diff
Issue
0
列表
看板
标记
里程碑
合并请求
0
DevOps
流水线
流水线任务
计划
Wiki
0
Wiki
分析
仓库
DevOps
项目成员
Pages
R
rt-thread
项目概览
项目概览
详情
发布
仓库
仓库
文件
提交
分支
标签
贡献者
分支图
比较
Issue
0
Issue
0
列表
看板
标记
里程碑
合并请求
0
合并请求
0
Pages
DevOps
DevOps
流水线
流水线任务
计划
分析
分析
仓库分析
DevOps
Wiki
0
Wiki
成员
成员
收起侧边栏
关闭侧边栏
动态
分支图
创建新Issue
流水线任务
提交
Issue看板
体验新版 GitCode,发现更多精彩内容 >>
提交
937e22fc
编写于
9月 04, 2018
作者:
W
weety
浏览文件
操作
浏览文件
下载
电子邮件补丁
差异文件
Add scons --pyconfig command for configure project.
上级
e166da99
变更
4
展开全部
隐藏空白更改
内联
并排
Showing
4 changed file
with
7380 addition
and
16 deletion
+7380
-16
tools/building.py
tools/building.py
+10
-0
tools/kconfiglib.py
tools/kconfiglib.py
+6159
-0
tools/menuconfig.py
tools/menuconfig.py
+108
-16
tools/pymenuconfig.py
tools/pymenuconfig.py
+1103
-0
未找到文件。
tools/building.py
浏览文件 @
937e22fc
...
@@ -335,6 +335,16 @@ def PrepareBuilding(env, root_directory, has_libcpu=False, remove_components = [
...
@@ -335,6 +335,16 @@ def PrepareBuilding(env, root_directory, has_libcpu=False, remove_components = [
menuconfig
(
Rtt_Root
)
menuconfig
(
Rtt_Root
)
exit
(
0
)
exit
(
0
)
AddOption
(
'--pyconfig'
,
dest
=
'pyconfig'
,
action
=
'store_true'
,
default
=
False
,
help
=
'make menuconfig for RT-Thread BSP'
)
if
GetOption
(
'pyconfig'
):
from
menuconfig
import
pyconfig
pyconfig
(
Rtt_Root
)
exit
(
0
)
configfn
=
GetOption
(
'useconfig'
)
configfn
=
GetOption
(
'useconfig'
)
if
configfn
:
if
configfn
:
from
menuconfig
import
mk_rtconfig
from
menuconfig
import
mk_rtconfig
...
...
tools/kconfiglib.py
0 → 100644
浏览文件 @
937e22fc
此差异已折叠。
点击以展开。
tools/menuconfig.py
浏览文件 @
937e22fc
...
@@ -20,8 +20,12 @@
...
@@ -20,8 +20,12 @@
# Change Logs:
# Change Logs:
# Date Author Notes
# Date Author Notes
# 2017-12-29 Bernard The first version
# 2017-12-29 Bernard The first version
# 2018-07-31.....weety Support pyconfig
import
os
import
os
import
sys
import
shutil
import
pymenuconfig
# make rtconfig.h from .config
# make rtconfig.h from .config
...
@@ -32,7 +36,7 @@ def mk_rtconfig(filename):
...
@@ -32,7 +36,7 @@ def mk_rtconfig(filename):
print
(
'open config:%s failed'
%
filename
)
print
(
'open config:%s failed'
%
filename
)
return
return
rtconfig
=
file
(
'rtconfig.h'
,
'w'
)
rtconfig
=
file
(
'rtconfig.h'
,
'w
b
'
)
rtconfig
.
write
(
'#ifndef RT_CONFIG_H__
\n
'
)
rtconfig
.
write
(
'#ifndef RT_CONFIG_H__
\n
'
)
rtconfig
.
write
(
'#define RT_CONFIG_H__
\n\n
'
)
rtconfig
.
write
(
'#define RT_CONFIG_H__
\n\n
'
)
...
@@ -88,8 +92,12 @@ def get_env_dir():
...
@@ -88,8 +92,12 @@ def get_env_dir():
if
os
.
environ
.
get
(
'ENV_ROOT'
):
if
os
.
environ
.
get
(
'ENV_ROOT'
):
return
os
.
environ
.
get
(
'ENV_ROOT'
)
return
os
.
environ
.
get
(
'ENV_ROOT'
)
home_dir
=
os
.
environ
[
'HOME'
]
if
sys
.
platform
==
'win32'
:
env_dir
=
os
.
path
.
join
(
home_dir
,
'.env'
)
home_dir
=
os
.
environ
[
'USERPROFILE'
]
env_dir
=
os
.
path
.
join
(
home_dir
,
'.env'
)
else
:
home_dir
=
os
.
environ
[
'HOME'
]
env_dir
=
os
.
path
.
join
(
home_dir
,
'.env'
)
if
not
os
.
path
.
exists
(
env_dir
):
if
not
os
.
path
.
exists
(
env_dir
):
return
None
return
None
...
@@ -97,23 +105,79 @@ def get_env_dir():
...
@@ -97,23 +105,79 @@ def get_env_dir():
return
env_dir
return
env_dir
def
touch_env
():
def
touch_env
():
home_dir
=
os
.
environ
[
'HOME'
]
if
sys
.
platform
!=
'win32'
:
env_dir
=
os
.
path
.
join
(
home_dir
,
'.env'
)
home_dir
=
os
.
environ
[
'HOME'
]
if
not
os
.
path
.
exists
(
env_dir
):
env_dir
=
os
.
path
.
join
(
home_dir
,
'.env'
)
os
.
mkdir
(
env_dir
)
if
not
os
.
path
.
exists
(
env_dir
):
os
.
mkdir
(
os
.
path
.
join
(
env_dir
,
'local_pkgs'
))
os
.
mkdir
(
env_dir
)
os
.
mkdir
(
os
.
path
.
join
(
env_dir
,
'packages'
))
os
.
mkdir
(
os
.
path
.
join
(
env_dir
,
'local_pkgs'
))
os
.
mkdir
(
os
.
path
.
join
(
env_dir
,
'packages'
))
os
.
system
(
'git clone https://github.com/RT-Thread/packages.git ~/.env/packages/packages'
)
os
.
system
(
'git clone https://github.com/RT-Thread/packages.git ~/.env/packages/packages'
)
kconfig
=
file
(
os
.
path
.
join
(
env_dir
,
'packages'
,
'Kconfig'
),
'w'
)
kconfig
=
file
(
os
.
path
.
join
(
env_dir
,
'packages'
,
'Kconfig'
),
'w'
)
kconfig
.
write
(
'source "$PKGS_DIR/packages/Kconfig"'
)
kconfig
.
write
(
'source "$PKGS_DIR/packages/Kconfig"'
)
os
.
mkdir
(
os
.
path
.
join
(
env_dir
,
'tools'
))
os
.
mkdir
(
os
.
path
.
join
(
env_dir
,
'tools'
))
os
.
system
(
'git clone https://github.com/RT-Thread/env.git ~/.env/tools/scripts'
)
os
.
system
(
'git clone https://github.com/RT-Thread/env.git ~/.env/tools/scripts'
)
env_sh
=
file
(
os
.
path
.
join
(
env_dir
,
'env.sh'
),
'w'
)
env_sh
=
file
(
os
.
path
.
join
(
env_dir
,
'env.sh'
),
'w'
)
env_sh
.
write
(
'export PATH=~/.env/tools/scripts:$PATH'
)
env_sh
.
write
(
'export PATH=~/.env/tools/scripts:$PATH'
)
else
:
home_dir
=
os
.
environ
[
'USERPROFILE'
]
env_dir
=
os
.
path
.
join
(
home_dir
,
'.env'
)
if
not
os
.
path
.
exists
(
env_dir
):
os
.
mkdir
(
env_dir
)
os
.
mkdir
(
os
.
path
.
join
(
env_dir
,
'local_pkgs'
))
os
.
mkdir
(
os
.
path
.
join
(
env_dir
,
'packages'
))
os
.
mkdir
(
os
.
path
.
join
(
env_dir
,
'tools'
))
kconfig
=
file
(
os
.
path
.
join
(
env_dir
,
'packages'
,
'Kconfig'
),
'wb'
)
kconfig
.
close
()
if
not
os
.
path
.
exists
(
os
.
path
.
join
(
env_dir
,
'packages'
,
'packages'
)):
try
:
ret
=
os
.
system
(
'git clone https://github.com/RT-Thread/packages.git %s'
%
os
.
path
.
join
(
env_dir
,
'packages'
,
'packages'
))
if
ret
!=
0
:
shutil
.
rmtree
(
os
.
path
.
join
(
env_dir
,
'packages'
,
'packages'
))
print
(
"********************************************************************************
\n
"
"* Run command error for
\"
git clone https://github.com/RT-Thread/packages.git
\"
.
\n
"
"* This error may have been caused by not found a git tool or network error.
\n
"
"* If the git tool is not installed, install the git tool first.
\n
"
"* If the git utility is installed, check whether the git command is added to the system PATH.
\n
"
"* This error may cause the RT-Thread packages to not work properly.
\n
"
"********************************************************************************
\n
"
)
else
:
kconfig
=
file
(
os
.
path
.
join
(
env_dir
,
'packages'
,
'Kconfig'
),
'wb'
)
kconfig
.
write
(
'source "$PKGS_DIR/packages/Kconfig"'
)
kconfig
.
close
()
except
:
print
(
"********************************************************************************
\n
"
"* Run command error for
\"
git clone https://github.com/RT-Thread/packages.git
\"
.
\n
"
"* This error may have been caused by not found a git tool or git tool not in the system PATH.
\n
"
"* This error may cause the RT-Thread packages to not work properly.
\n
"
"********************************************************************************
\n
"
)
if
not
os
.
path
.
exists
(
os
.
path
.
join
(
env_dir
,
'tools'
,
'scripts'
)):
try
:
ret
=
os
.
system
(
'git clone https://github.com/RT-Thread/env.git %s'
%
os
.
path
.
join
(
env_dir
,
'tools'
,
'scripts'
))
if
ret
!=
0
:
shutil
.
rmtree
(
os
.
path
.
join
(
env_dir
,
'tools'
,
'scripts'
))
print
(
"********************************************************************************
\n
"
"* Run command error for
\"
git clone https://github.com/RT-Thread/env.git
\"
.
\n
"
"* This error may have been caused by not found a git tool or network error.
\n
"
"* If the git tool is not installed, install the git tool first.
\n
"
"* If the git utility is installed, check whether the git command is added to the system PATH.
\n
"
"* This error may cause script tools to fail to work properly.
\n
"
"********************************************************************************
\n
"
)
except
:
print
(
"********************************************************************************
\n
"
"* Run command error for
\"
git clone https://github.com/RT-Thread/env.git
\"
.
\n
"
"* This error may have been caused by not found a git tool or git tool not in the system PATH.
\n
"
"* This error may cause script tools to fail to work properly.
\n
"
"********************************************************************************
\n
"
)
if
os
.
path
.
exists
(
os
.
path
.
join
(
env_dir
,
'tools'
,
'scripts'
)):
os
.
environ
[
"PATH"
]
=
os
.
path
.
join
(
env_dir
,
'tools'
,
'scripts'
)
+
';'
+
os
.
environ
[
"PATH"
]
# menuconfig for Linux
# menuconfig for Linux
def
menuconfig
(
RTT_ROOT
):
def
menuconfig
(
RTT_ROOT
):
...
@@ -146,3 +210,31 @@ def menuconfig(RTT_ROOT):
...
@@ -146,3 +210,31 @@ def menuconfig(RTT_ROOT):
if
mtime
!=
mtime2
:
if
mtime
!=
mtime2
:
mk_rtconfig
(
fn
)
mk_rtconfig
(
fn
)
# pyconfig for windows and linux
def
pyconfig
(
RTT_ROOT
):
env_dir
=
get_env_dir
()
if
not
env_dir
:
touch_env
()
env_dir
=
get_env_dir
()
os
.
environ
[
'PKGS_ROOT'
]
=
os
.
path
.
join
(
env_dir
,
'packages'
)
fn
=
'.config'
if
os
.
path
.
isfile
(
fn
):
mtime
=
os
.
path
.
getmtime
(
fn
)
else
:
mtime
=
-
1
pymenuconfig
.
main
([
'--kconfig'
,
'Kconfig'
,
'--config'
,
'.config'
])
if
os
.
path
.
isfile
(
fn
):
mtime2
=
os
.
path
.
getmtime
(
fn
)
else
:
mtime2
=
-
1
# make rtconfig.h
if
mtime
!=
mtime2
:
mk_rtconfig
(
fn
)
tools/pymenuconfig.py
0 → 100644
浏览文件 @
937e22fc
此差异已折叠。
点击以展开。
编辑
预览
Markdown
is supported
0%
请重试
或
添加新附件
.
添加附件
取消
You are about to add
0
people
to the discussion. Proceed with caution.
先完成此消息的编辑!
取消
想要评论请
注册
或
登录