feat(cbuild): 添加SCC编译器支持并更新构建脚本
添加了新的SccCompiler类以支持SCC编译器,包括编译和链接功能。 更新了justfile中的构建任务,添加了clean、build、build-install和test-scc等新任务。 同时修复了异常处理语法错误并将wc.py工具文件移除。
This commit is contained in:
@@ -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())
|
||||
|
||||
|
||||
53
tools/wc.py
53
tools/wc.py
@@ -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()
|
||||
Reference in New Issue
Block a user