feat(cbuild): 添加SCC编译器支持并更新构建脚本

添加了新的SccCompiler类以支持SCC编译器,包括编译和链接功能。
更新了justfile中的构建任务,添加了clean、build、build-install和test-scc等新任务。
同时修复了异常处理语法错误并将wc.py工具文件移除。
This commit is contained in:
zzy
2026-02-21 16:02:53 +08:00
parent 8007825800
commit 4940b652eb
3 changed files with 43 additions and 58 deletions

View File

@@ -15,5 +15,19 @@ count-file:
# you need download `tokei` it can download by cargo
tokei libs runtime src -e tests --files
build_lexer:
python ./tools/cbuild/cbuild.py --path libs/lexer build
clean:
cbuild clean
build:
cbuild build -cclang
build-install: build
cp ./build/dev/scc.exe ./scc.exe
test-scc:
# windows: (Get-Content a.txt -Raw) -replace '\x1b\[[0-9;]*[a-zA-Z]', '' | Set-Content clean.txt
# linux: sed 's/\x1b\[[0-9;]*[a-zA-Z]//g' a.txt > clean.txt
just clean
just build-install
just clean
cbuild run -cscc -- -h

View File

@@ -1,4 +1,4 @@
"""cbuild.py - 优化的轻量C构建系统"""
"""cbuild.py - 优化的轻量C构建系统""" # pylint: disable=too-many-lines
from abc import ABC, abstractmethod
import tomllib
@@ -517,7 +517,7 @@ class BuildCache:
with open(self.cache_file, "r", encoding="utf-8") as f:
data = json.load(f)
self.cache = {k: CacheEntry(**v) for k, v in data.items()}
except OSError, json.JSONDecodeError, TypeError:
except (OSError, json.JSONDecodeError, TypeError):
self.cache = {}
def save(self):
@@ -679,6 +679,24 @@ class ClangCompiler(Compiler):
self.run(cmd)
class SccCompiler(Compiler):
"""SCC编译器"""
def get_flags(self, mode: BuildMode) -> list[str]:
return []
def compile(
self, source: Path, output: Path, includes: list[Path], flags: list[str]
):
# cmd = ["clang"] + flags + ["-c", str(source), "-o", str(output)]
cmd = ["scc", "--emit-pp", "-o", str(output), str(source)]
cmd += [f"-I{inc}" for inc in includes]
self.run(cmd)
def link(self, objects: list[Path], output: Path, flags: list[str]):
pass
class DummyCompiler(Compiler):
"""虚拟编译器(用于测试)"""
@@ -1023,7 +1041,11 @@ def create_parser():
def add_common_args(subparser):
subparser.add_argument(
"--compiler", "-c", choices=["gcc", "clang"], default="gcc", help="编译器"
"--compiler",
"-c",
choices=["gcc", "clang", "scc"],
default="gcc",
help="编译器",
)
subparser.add_argument("--record", "-r", action="store_true", help="记录命令")
subparser.add_argument(
@@ -1102,6 +1124,7 @@ def create_parser():
def main():
"""主函数"""
# print("current cwd: " + os.getcwd())
parser = create_parser()
args = parser.parse_args()
@@ -1117,6 +1140,7 @@ def main():
compiler_map = {
"gcc": GccCompiler(),
"clang": ClangCompiler(),
"scc": SccCompiler(),
}
compiler = compiler_map.get(args.compiler, GccCompiler())

View File

@@ -1,53 +0,0 @@
"""统计目录下C/C++文件的行数(write by AI)"""
import os
def count_lines(file_path):
"""统计单个文件的代码行数"""
try:
with open(file_path, "rb") as f: # 二进制模式读取避免编码问题
return sum(1 for _ in f)
except UnicodeDecodeError:
print(f"警告:无法解码文件 {file_path}(可能不是文本文件)")
return 0
except Exception as e:
print(f"读取 {file_path} 出错: {str(e)}")
return 0
def scan_files(directory, exclude_dirs=None):
"""扫描目录获取所有C/C++文件"""
if exclude_dirs is None:
exclude_dirs = [".git", "venv", "__pycache__", ".old"] # 默认排除的目录
c_files = []
for root, dirs, files in os.walk(directory):
# 跳过排除目录
dirs[:] = [d for d in dirs if d not in exclude_dirs]
for file in files:
if file.endswith((".c", ".h")):
full_path = os.path.join(root, file)
c_files.append(full_path)
return c_files
def main():
"""main function"""
target_dir = input("请输入要扫描的目录路径(留空为当前目录): ") or "."
files = scan_files(target_dir)
total_lines = 0
print("\n统计结果:")
for idx, file in enumerate(files, 1):
lines = count_lines(file)
total_lines += lines
print(f"{idx:4d}. {file} ({lines} 行)")
print(f"\n总计: {len(files)} 个C/C++文件,共 {total_lines} 行代码")
if __name__ == "__main__":
main()