[fix] not ignore notes in

This commit is contained in:
ZhaoCake 2025-01-08 15:00:29 +08:00 committed by Rbb666
parent 21414e8b8e
commit ad6ea0fb59
1 changed files with 33 additions and 45 deletions

View File

@ -20,6 +20,7 @@
# Change Logs: # Change Logs:
# Date Author Notes # Date Author Notes
# 2017-10-04 Bernard The first version # 2017-10-04 Bernard The first version
# 2025-01-07 ZhaoCake components copy and gen doc
import os import os
import subprocess import subprocess
@ -93,7 +94,7 @@ def walk_kconfig(RTT_ROOT, source_list):
def bsp_copy_files(bsp_root, dist_dir): def bsp_copy_files(bsp_root, dist_dir):
# copy BSP files # copy BSP files
do_copy_folder(os.path.join(bsp_root), dist_dir, do_copy_folder(os.path.join(bsp_root), dist_dir,
ignore_patterns('build', 'dist', '*.pyc', '*.old', '*.map', 'rtthread.bin', '.sconsign.dblite', '*.elf', '*.axf', 'cconfig.h')) ignore_patterns('build','__pycache__','dist', '*.pyc', '*.old', '*.map', 'rtthread.bin', '.sconsign.dblite', '*.elf', '*.axf', 'cconfig.h'))
def bsp_update_sconstruct(dist_dir): def bsp_update_sconstruct(dist_dir):
with open(os.path.join(dist_dir, 'SConstruct'), 'r') as f: with open(os.path.join(dist_dir, 'SConstruct'), 'r') as f:
@ -172,9 +173,9 @@ def zip_dist(dist_dir, dist_name):
zip.close() zip.close()
def get_system_features(): def get_system_features():
"""获取系统内置特性列表""" """Get system built-in feature list"""
return { return {
# 内核特性 # Kernel features
'components_init', 'components_init',
'console', 'console',
'cpu_usage_tracer', 'cpu_usage_tracer',
@ -202,7 +203,7 @@ def get_system_features():
} }
def parse_components_from_config(config_file): def parse_components_from_config(config_file):
"""从 .config 文件解析启用的组件""" """Parse enabled components from .config file"""
enabled_components = set() enabled_components = set()
if not os.path.exists(config_file): if not os.path.exists(config_file):
@ -212,26 +213,30 @@ def parse_components_from_config(config_file):
with open(config_file, 'r') as f: with open(config_file, 'r') as f:
for line in f: for line in f:
line = line.strip() line = line.strip()
# Skip empty lines and comments
if not line or line.startswith('#'):
continue
if line.startswith('CONFIG_'): if line.startswith('CONFIG_'):
if '=' in line: if '=' in line:
config = line.split('=')[0][7:] # 去掉 CONFIG_ 前缀 config = line.split('=')[0][7:] # Remove CONFIG_ prefix
if config.startswith('RT_USING_'): if config.startswith('RT_USING_'):
component = config[9:].lower() # 去掉 RT_USING_ 前缀 component = config[9:].lower() # Remove RT_USING_ prefix
enabled_components.add(component) enabled_components.add(component)
return enabled_components return enabled_components
def scan_components_dir(RTT_ROOT): def scan_components_dir(RTT_ROOT):
"""扫描组件目录结构,生成组件映射表""" """Scan component directory structure and generate component mapping"""
components_map = {} components_map = {}
components_root = os.path.join(RTT_ROOT, 'components') components_root = os.path.join(RTT_ROOT, 'components')
def parse_kconfig(kconfig_file): def parse_kconfig(kconfig_file):
"""解析 Kconfig 文件中的配置选项""" """Parse configuration options from Kconfig file"""
components = set() components = set()
try: try:
with open(kconfig_file, 'r') as f: with open(kconfig_file, 'r') as f:
content = f.read() content = f.read()
# 查找 config RT_USING_XXX 形式的配置 # Find configurations in the form of config RT_USING_XXX
import re import re
matches = re.finditer(r'config\s+RT_USING_(\w+)', content) matches = re.finditer(r'config\s+RT_USING_(\w+)', content)
for match in matches: for match in matches:
@ -242,25 +247,25 @@ def scan_components_dir(RTT_ROOT):
return components return components
def get_relative_path(full_path): def get_relative_path(full_path):
"""获取相对于 RTT_ROOT 的路径""" """Get path relative to RTT_ROOT"""
return os.path.relpath(os.path.dirname(full_path), RTT_ROOT) return os.path.relpath(os.path.dirname(full_path), RTT_ROOT)
# 扫描所有组件目录 # Scan all component directories
for root, dirs, files in os.walk(components_root): for root, dirs, files in os.walk(components_root):
if 'Kconfig' in files: if 'Kconfig' in files:
kconfig_path = os.path.join(root, 'Kconfig') kconfig_path = os.path.join(root, 'Kconfig')
component_configs = parse_kconfig(kconfig_path) component_configs = parse_kconfig(kconfig_path)
rel_path = get_relative_path(kconfig_path) rel_path = get_relative_path(kconfig_path)
# 将组件名称与路径关联 # Associate component names with paths
for comp_name in component_configs: for comp_name in component_configs:
components_map[comp_name] = rel_path components_map[comp_name] = rel_path
return components_map return components_map
def get_component_path(component_name, RTT_ROOT): def get_component_path(component_name, RTT_ROOT):
"""获取组件的实际路径""" """Get actual path of component"""
# 获取动态组件映射 # Get dynamic component mapping
dynamic_map = scan_components_dir(RTT_ROOT) dynamic_map = scan_components_dir(RTT_ROOT)
return dynamic_map.get(component_name) return dynamic_map.get(component_name)
@ -355,16 +360,16 @@ See `COPYING` file for details.
print(f"=> Generated distribution documentation: {doc_file}") print(f"=> Generated distribution documentation: {doc_file}")
def components_copy_files(RTT_ROOT, rtt_dir_path, config_file): def components_copy_files(RTT_ROOT, rtt_dir_path, config_file):
"""根据配置复制组件""" """Copy components based on configuration"""
print('=> components (selective copy)') print('=> components (selective copy)')
# 获取启用的组件 # Get enabled components
enabled_components = parse_components_from_config(config_file) enabled_components = parse_components_from_config(config_file)
if not enabled_components: if not enabled_components:
print("Warning: No components found in config file") print("Warning: No components found in config file")
return enabled_components return enabled_components
# 复制每个启用的组件 # Copy each enabled component
for comp_name in enabled_components: for comp_name in enabled_components:
comp_path = get_component_path(comp_name, RTT_ROOT) comp_path = get_component_path(comp_name, RTT_ROOT)
if comp_path: if comp_path:
@ -390,42 +395,43 @@ def MkDist(program, BSP_ROOT, RTT_ROOT, Env, project_name, project_path):
rtt_dir_path = os.path.join(dist_dir, 'rt-thread') rtt_dir_path = os.path.join(dist_dir, 'rt-thread')
# copy BSP files # Copy BSP files
print('=> %s' % os.path.basename(BSP_ROOT)) print('=> %s' % os.path.basename(BSP_ROOT))
bsp_copy_files(BSP_ROOT, dist_dir) bsp_copy_files(BSP_ROOT, dist_dir)
# do bsp special dist handle # Do BSP special dist handle
if 'dist_handle' in Env: if 'dist_handle' in Env:
print("=> start dist handle") print("=> start dist handle")
dist_handle = Env['dist_handle'] dist_handle = Env['dist_handle']
dist_handle(BSP_ROOT, dist_dir) dist_handle(BSP_ROOT, dist_dir)
# 使用新的组件复制函数并获取启用的组件列表 # Use new component copy function and get list of enabled components
config_file = os.path.join(BSP_ROOT, '.config') config_file = os.path.join(BSP_ROOT, '.config')
enabled_components = components_copy_files(RTT_ROOT, rtt_dir_path, config_file) enabled_components = components_copy_files(RTT_ROOT, rtt_dir_path, config_file)
# skip documentation directory # Skip documentation directory
# skip examples # Skip examples
# copy include directory # Copy include directory
print('=> include') print('=> include')
do_copy_folder(os.path.join(RTT_ROOT, 'include'), os.path.join(rtt_dir_path, 'include')) do_copy_folder(os.path.join(RTT_ROOT, 'include'), os.path.join(rtt_dir_path, 'include'))
# copy all libcpu/ARCH directory # Copy all libcpu/ARCH directory
print('=> libcpu') print('=> libcpu')
import rtconfig import rtconfig
do_copy_folder(os.path.join(RTT_ROOT, 'libcpu', rtconfig.ARCH), os.path.join(rtt_dir_path, 'libcpu', rtconfig.ARCH)) do_copy_folder(os.path.join(RTT_ROOT, 'libcpu', rtconfig.ARCH), os.path.join(rtt_dir_path, 'libcpu', rtconfig.ARCH))
do_copy_file(os.path.join(RTT_ROOT, 'libcpu', 'Kconfig'), os.path.join(rtt_dir_path, 'libcpu', 'Kconfig')) do_copy_file(os.path.join(RTT_ROOT, 'libcpu', 'Kconfig'), os.path.join(rtt_dir_path, 'libcpu', 'Kconfig'))
do_copy_file(os.path.join(RTT_ROOT, 'libcpu', 'SConscript'), os.path.join(rtt_dir_path, 'libcpu', 'SConscript')) do_copy_file(os.path.join(RTT_ROOT, 'libcpu', 'SConscript'), os.path.join(rtt_dir_path, 'libcpu', 'SConscript'))
# copy src directory # Copy src directory
print('=> src') print('=> src')
do_copy_folder(os.path.join(RTT_ROOT, 'src'), os.path.join(rtt_dir_path, 'src')) do_copy_folder(os.path.join(RTT_ROOT, 'src'), os.path.join(rtt_dir_path, 'src'))
# copy tools directory # Copy tools directory
print('=> tools') print('=> tools')
do_copy_folder(os.path.join(RTT_ROOT, 'tools'), os.path.join(rtt_dir_path, 'tools'), ignore_patterns('*.pyc')) do_copy_folder(os.path.join(RTT_ROOT, 'tools'), os.path.join(rtt_dir_path, 'tools'), ignore_patterns('*.pyc'))
# Copy necessary files
do_copy_file(os.path.join(RTT_ROOT, 'Kconfig'), os.path.join(rtt_dir_path, 'Kconfig')) do_copy_file(os.path.join(RTT_ROOT, 'Kconfig'), os.path.join(rtt_dir_path, 'Kconfig'))
do_copy_file(os.path.join(RTT_ROOT, 'AUTHORS'), os.path.join(rtt_dir_path, 'AUTHORS')) do_copy_file(os.path.join(RTT_ROOT, 'AUTHORS'), os.path.join(rtt_dir_path, 'AUTHORS'))
do_copy_file(os.path.join(RTT_ROOT, 'COPYING'), os.path.join(rtt_dir_path, 'COPYING')) do_copy_file(os.path.join(RTT_ROOT, 'COPYING'), os.path.join(rtt_dir_path, 'COPYING'))
@ -433,30 +439,12 @@ def MkDist(program, BSP_ROOT, RTT_ROOT, Env, project_name, project_path):
do_copy_file(os.path.join(RTT_ROOT, 'README_zh.md'), os.path.join(rtt_dir_path, 'README_zh.md')) do_copy_file(os.path.join(RTT_ROOT, 'README_zh.md'), os.path.join(rtt_dir_path, 'README_zh.md'))
print('Update configuration files...') print('Update configuration files...')
# change RTT_ROOT in SConstruct
bsp_update_sconstruct(dist_dir) bsp_update_sconstruct(dist_dir)
# change RTT_ROOT in Kconfig
bsp_update_kconfig(dist_dir) bsp_update_kconfig(dist_dir)
bsp_update_kconfig_library(dist_dir) bsp_update_kconfig_library(dist_dir)
# delete testcases in Kconfig
bsp_update_kconfig_testcases(dist_dir) bsp_update_kconfig_testcases(dist_dir)
target_project_type = GetOption('target') # Generate documentation
if target_project_type:
child = subprocess.Popen('scons --target={} --project-name="{}"'.format(target_project_type, project_name), cwd=dist_dir, stdout=subprocess.PIPE, stderr=subprocess.PIPE, shell=True)
stdout, stderr = child.communicate()
if child.returncode == 0:
print(stdout)
else:
print(stderr)
else:
print('suggest to use command scons --dist [--target=xxx] [--project-name="xxx"] [--project-path="xxx"]')
# make zip package
if project_path == None:
zip_dist(dist_dir, project_name)
# 生成说明文档
generate_dist_doc(dist_dir, enabled_components, project_name+'-dist', BSP_ROOT, RTT_ROOT) generate_dist_doc(dist_dir, enabled_components, project_name+'-dist', BSP_ROOT, RTT_ROOT)
print('dist project successfully!') print('dist project successfully!')