优化编译脚本

This commit is contained in:
2025-06-26 17:41:33 +08:00
parent 262d5d3f90
commit e8d9f26c5c
5 changed files with 41 additions and 47 deletions

View File

@@ -87,7 +87,6 @@ def create_lambda(text:str):
# 生成lambda展开后的文件 返回新的源文件列表 # 生成lambda展开后的文件 返回新的源文件列表
def search_lambda(src_list:list) -> list: def search_lambda(src_list:list) -> list:
file_index=0
for index,item in enumerate(src_list): for index,item in enumerate(src_list):
with open(item,encoding='utf-8') as f: with open(item,encoding='utf-8') as f:
d=f.read() d=f.read()
@@ -98,18 +97,20 @@ def search_lambda(src_list:list) -> list:
if(lam_index!=0 and d[lam_index-1]!='\n'): if(lam_index!=0 and d[lam_index-1]!='\n'):
continue continue
# 获取lambda文件名 # 获取lambda文件名
dst_file_name=f"lambda_{file_index}_"+ os.path.basename(item) base_path=os.path.join(TMP_DIR,os.path.dirname(item))
file_index+=1 if not os.path.exists(base_path):
dst_path=os.path.join(TMP_DIR,dst_file_name) os.makedirs(base_path)
src_list[index]=dst_path dst_file_name=os.path.join(base_path, os.path.basename(item))
src_list[index]=dst_file_name
# 不需要重新生成lambda文件 # 不需要重新生成lambda文件
if(not check_rebuild(dst_path,[item])): if(not check_rebuild(dst_file_name,[item])):
continue continue
lam_list=calc_lambda_text(d) lam_list=calc_lambda_text(d)
lambda_funs=[] lambda_funs=[]
for lam in lam_list: for lam in lam_list:
lambda_funs.append(create_lambda(lam)) lambda_funs.append(create_lambda(lam))
with open(dst_path,mode='w+',encoding='utf-8') as f: print(f"生成 {dst_file_name}")
with open(dst_file_name,mode='w+',encoding='utf-8') as f:
lambda_funs_text="" lambda_funs_text=""
for lam,fun in zip(lam_list,lambda_funs): for lam,fun in zip(lam_list,lambda_funs):
lambda_funs_text+=f"static {fun.return_type} {fun.name}({','.join(fun.params)}){'{'}{fun.body}{'}'}\n" lambda_funs_text+=f"static {fun.return_type} {fun.name}({','.join(fun.params)}){'{'}{fun.body}{'}'}\n"

View File

@@ -125,9 +125,9 @@ def def_slot_fun_str(slot_fun:str,pars:list):
pars_names=get_pars_names(pars) pars_names=get_pars_names(pars)
for index,item in enumerate(pars_names): for index,item in enumerate(pars_names):
if(index<len(pars)-1): if(index<len(pars)-1):
pars_str+=f"a->{item}," pars_str+=f"self->{item},"
else: else:
pars_str+=f"a->{item}" pars_str+=f"self->{item}"
unsued_pars="" unsued_pars=""
for item in pars_names: for item in pars_names:
unsued_pars+=f" (void){item};\n" unsued_pars+=f" (void){item};\n"
@@ -136,7 +136,7 @@ __attribute__((weak)) void {slot_fun}({','.join(pars)}){'{'}
{unsued_pars}{'}'} {unsued_pars}{'}'}
static void {slot_fun}_caller(void *args){'{'} static void {slot_fun}_caller(void *args){'{'}
{slot_fun}_args *a = args; {slot_fun}_args *self = args;
{slot_fun}({pars_str}); {slot_fun}({pars_str});
{'}'} {'}'}
""" """
@@ -263,6 +263,7 @@ def moc_file_create(out_file_path,scan_path_list):
# 不需要重新生成 # 不需要重新生成
if(not check_rebuild(out_file_path,list_file)): if(not check_rebuild(out_file_path,list_file)):
return return
print(f"生成 {out_file_path}")
with open(out_file_path,"w+") as f: with open(out_file_path,"w+") as f:
f.write("#include \"stdlib.h\"\n") f.write("#include \"stdlib.h\"\n")
f.write("#include \"string.h\"\n") f.write("#include \"string.h\"\n")

30
make.py
View File

@@ -75,12 +75,11 @@ gcc -MM main.c -o build/main.d
def tran_path(path:str): def tran_path(path:str):
p=path.replace('\\','/') path=os.path.normpath(os.path.join(BUILD_DIR,path))
p=p.replace('/','_') base_path=os.path.dirname(path)
if(p[0]=='.'): if not os.path.exists(base_path):
return p[1:] os.makedirs(base_path)
else: return path
return p
# 判断是否需要重新生成 # 判断是否需要重新生成
@@ -123,9 +122,8 @@ def read_depend_files(name:str):
def build_depend(src:list): def build_depend(src:list):
flags=f"{' '.join(CINC)} {' '.join(CDEF)} {' '.join(CFLAG)}" flags=f"{' '.join(CINC)} {' '.join(CDEF)} {' '.join(CFLAG)}"
for i in src: for i in src:
name=tran_path(i).split('.')[0] name=os.path.splitext(tran_path(i))[0]
dst='.'.join([name,'d']) dst='.'.join([name,'d'])
dst=os.path.join(BUILD_DIR,dst)
if(check_rebuild(dst,[i])): if(check_rebuild(dst,[i])):
cmd=f"{CC} -MM {i} -o {dst} {flags}" cmd=f"{CC} -MM {i} -o {dst} {flags}"
print(f"更新 {dst}") print(f"更新 {dst}")
@@ -140,21 +138,19 @@ def build_depend(src:list):
def build_object(src:list): def build_object(src:list):
flags=f"{' '.join(CINC)} {' '.join(CDEF)} {' '.join(CFLAG)}" flags=f"{' '.join(CINC)} {' '.join(CDEF)} {' '.join(CFLAG)}"
for i in src: for i in src:
name_l=tran_path(i).split('.') name_t=os.path.splitext(tran_path(i))
name=name_l[0] name=name_t[0]
file_type=name_l[-1] file_type=name_t[-1]
dst='.'.join([name,'o']) dst='.'.join([name,'o'])
dst=os.path.join(BUILD_DIR,dst)
cd='.'.join([name,'d']) cd='.'.join([name,'d'])
cmd = '' cmd = ''
if(file_type in ['c','.C']): if(file_type in ['.c','.C']):
cd=os.path.join(BUILD_DIR,cd)
if(check_rebuild(dst,read_depend_files(cd))): if(check_rebuild(dst,read_depend_files(cd))):
cmd=f"{CC} -c {i} -o {dst} {flags}" cmd=f"{CC} -c {i} -o {dst} {flags}"
else: else:
# print(f"{i} 没有更新依赖关系") # print(f"{i} 没有更新依赖关系")
pass pass
elif(file_type in ['s','S','asm','ASM']): elif(file_type in ['.s','.S','.asm','.ASM']):
if(check_rebuild(dst,[i])): if(check_rebuild(dst,[i])):
# cmd=f"{AS} -c {i} -o {dst} {flags}" # cmd=f"{AS} -c {i} -o {dst} {flags}"
pass pass
@@ -173,8 +169,8 @@ def build_target(src:list):
flags=f"{' '.join(CINC)} {' '.join(CDEF)} {' '.join(CFLAG)}" flags=f"{' '.join(CINC)} {' '.join(CDEF)} {' '.join(CFLAG)}"
obj_list=[] obj_list=[]
for i in src: for i in src:
name=tran_path(i).split('.')[0] name=os.path.splitext(tran_path(i))[0]
obj_list.append(BUILD_DIR+'/'+'.'.join([name,'o'])) obj_list.append('.'.join([name,'o']))
dst=os.path.join(BUILD_DIR,TARGET) dst=os.path.join(BUILD_DIR,TARGET)
if(check_rebuild(dst,obj_list)): if(check_rebuild(dst,obj_list)):
cmd=f"{CC} {' '.join(obj_list)} -o {dst} {flags}" cmd=f"{CC} {' '.join(obj_list)} -o {dst} {flags}"

View File

@@ -12,7 +12,7 @@ OBJCPY="riscv64-unknown-elf-objcopy"
OBJDUMP="riscv64-unknown-elf-objdump" OBJDUMP="riscv64-unknown-elf-objdump"
CFLAG=[ CFLAG=[
"-march=rv32i_zicsr", "-march=rv32i",
"-mabi=ilp32", "-mabi=ilp32",
"-ffunction-sections", "-ffunction-sections",
"-fdata-sections", "-fdata-sections",
@@ -75,7 +75,7 @@ SRC=[
"riscv/rtthread/components/drivers/core/device.c" "riscv/rtthread/components/drivers/core/device.c"
] ]
LD_FILE="riscv.ld" LD_FILE="riscv/riscv.ld"
TARGET="riscv" TARGET="riscv"
@@ -84,12 +84,11 @@ OUTPUT="output"
def tran_path(path:str): def tran_path(path:str):
p=path.replace('\\','/') path=os.path.normpath(os.path.join(OUTPUT,path))
p=p.replace('/','_') base_path=os.path.dirname(path)
if(p[0]=='.'): if not os.path.exists(base_path):
return p[1:] os.makedirs(base_path)
else: return path
return p
# 判断是否需要重新生成 # 判断是否需要重新生成
@@ -132,9 +131,8 @@ def read_depend_files(name:str):
def build_depend(src:list): def build_depend(src:list):
flags=f"{' '.join(INC)} {' '.join(DEF)} {' '.join(CFLAG)}" flags=f"{' '.join(INC)} {' '.join(DEF)} {' '.join(CFLAG)}"
for i in src: for i in src:
name=tran_path(i).split('.')[0] name=os.path.splitext(tran_path(i))[0]
dst='.'.join([name,'d']) dst='.'.join([name,'d'])
dst=os.path.join(OUTPUT,dst)
if(check_rebuild(dst,[i])): if(check_rebuild(dst,[i])):
cmd=f"{CC} -MM {i} -o {dst} {flags}" cmd=f"{CC} -MM {i} -o {dst} {flags}"
print(f"更新 {dst}") print(f"更新 {dst}")
@@ -149,22 +147,20 @@ def build_depend(src:list):
def build_object(src:list): def build_object(src:list):
flags=f"{' '.join(INC)} {' '.join(DEF)} {' '.join(CFLAG)}" flags=f"{' '.join(INC)} {' '.join(DEF)} {' '.join(CFLAG)}"
for i in src: for i in src:
name_l=tran_path(i).split('.') name_t=os.path.splitext(tran_path(i))
name=name_l[0] name=name_t[0]
file_type=name_l[-1] file_type=name_t[-1]
dst='.'.join([name,'o']) dst='.'.join([name,'o'])
dst=os.path.join(OUTPUT,dst)
cd='.'.join([name,'d']) cd='.'.join([name,'d'])
cmd = '' cmd = ''
if(file_type in ['c','.C']): if(file_type in ['.c','.C']):
cd=os.path.join(OUTPUT,cd)
if(check_rebuild(dst,read_depend_files(cd))): if(check_rebuild(dst,read_depend_files(cd))):
cmd=f"{CC} -c {i} -o {dst} {flags}" cmd=f"{CC} -c {i} -o {dst} {flags}"
else: else:
# print(f"{i} 没有更新依赖关系") # print(f"{i} 没有更新依赖关系")
pass pass
elif(file_type in ['s','S','asm','ASM']): elif(file_type in ['.s','.S','.asm','.ASM']):
if(check_rebuild(dst,[i])): if(check_rebuild(dst,read_depend_files(cd))):
cmd=f"{CC} -c {i} -o {dst} {flags}" cmd=f"{CC} -c {i} -o {dst} {flags}"
else: else:
# print(f"{i} 没有更新依赖关系") # print(f"{i} 没有更新依赖关系")
@@ -181,8 +177,8 @@ def build_target(src:list):
flags=f"{' '.join(INC)} {' '.join(DEF)} {' '.join(CFLAG)}" flags=f"{' '.join(INC)} {' '.join(DEF)} {' '.join(CFLAG)}"
obj_list=[] obj_list=[]
for i in src: for i in src:
name=tran_path(i).split('.')[0] name=os.path.splitext(tran_path(i))[0]
obj_list.append(OUTPUT+'/'+'.'.join([name,'o'])) obj_list.append('.'.join([name,'o']))
dst=os.path.join(OUTPUT,TARGET)+".elf" dst=os.path.join(OUTPUT,TARGET)+".elf"
if(check_rebuild(dst,obj_list)): if(check_rebuild(dst,obj_list)):
cmd=f"{CC} {' '.join(obj_list)} -o {dst} {flags} -T{LD_FILE} -Wall -Wextra -nostartfiles -Wl,-Map,\"{OUTPUT}/{TARGET}.map\"" cmd=f"{CC} {' '.join(obj_list)} -o {dst} {flags} -T{LD_FILE} -Wall -Wextra -nostartfiles -Wl,-Map,\"{OUTPUT}/{TARGET}.map\""