Skip to main content

This project is a code inspection tool for teaching purposes in the "High-level Language Programming" course at Tongji University, used to check whether C/C++ code uses syntax features that violate assignment requirements.

Project description

TJHLP-CHECKER 同济高程代码合规检查

Continuous Integration cov

简介

高级语言程序设计 是为同济大学信息类大一学生开设的专业入门课,使用 C/C++ 教学。由于教学需求,课程对作业中允许使用的语言特性做出了一定的限制。本项目基于 libclangPython binding 实现,提供 AST 级别的准确检测工具。

使用

tjhlp-checker既可以用库的形式引入,也可以直接作为 CLI 工具使用。

安装

pip install tjhlp-checker
# 若需直接在命令行使用,则改为:
# pip install tjhlp-checker[cli]

作为库引入

import sys

from tjhlp-checker import load_config, find_all_violations

if __name__ == '__main__':
    """
    Usage: python main.py <cpp file> <config file>
    """
    with open(sys.argv[2], 'rb') as conf:
        violations = find_all_violations(
            sys.argv[1],
            load_config(conf)
        )
    print(violations)

直接在命令行使用

pip install tjhlp-checker[cli]
tjhlp-checker --config-file=<PATH TO CONFIG FILE> <FILE>

配置文件使用 TOML 格式。由于本项目使用 Pydantic 验证配置文件格式,因此具体配置项可以直接参考 src/tjhlp_checker/config.py

构建

本项目使用 uv 进行项目管理。

git clone https://github.com/Maoyao233/tjhlp-checker && cd tjhlp-checker
uv sync --all-extras --dev
uv build

使用 Docker

也可以直接使用 Docker:

docker build -t tjhlp-checker .
docker run -it tjhlp-checker

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

tjhlp_checker-0.1.0.tar.gz (19.4 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

tjhlp_checker-0.1.0-py3-none-any.whl (7.7 kB view details)

Uploaded Python 3

File details

Details for the file tjhlp_checker-0.1.0.tar.gz.

File metadata

  • Download URL: tjhlp_checker-0.1.0.tar.gz
  • Upload date:
  • Size: 19.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.6.11

File hashes

Hashes for tjhlp_checker-0.1.0.tar.gz
Algorithm Hash digest
SHA256 32c715b7f3a25eead0e294d3a5d44b00165895defbe756444d1a0f2917aaf877
MD5 9638763799232923dff7c9c803c8c139
BLAKE2b-256 91543a6b8e9e5b50a5f3cf14c972458456e1c1f5ad63895be6cf55011cbab26d

See more details on using hashes here.

File details

Details for the file tjhlp_checker-0.1.0-py3-none-any.whl.

File metadata

File hashes

Hashes for tjhlp_checker-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 31bd2cdf5637efe06f5bce4661622178697e5f07cb4fd7d6c8c21b3a6a390c28
MD5 1039e2aba97c0297e6534742b1588240
BLAKE2b-256 4bd599503c08dc7c4df8878fbb2a7b259c08861f73976f04c95a6ecab7522eda

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page