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 PyPI - Version

简介

高级语言程序设计 是为同济大学信息类大一学生开设的专业入门课,使用 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.1.tar.gz (20.5 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.1-py3-none-any.whl (8.8 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for tjhlp_checker-0.1.1.tar.gz
Algorithm Hash digest
SHA256 9b4019b1a10397e04f0ac4595cce7013ee5ec35ae79056766152085f61ee857a
MD5 6ba34d41451f386b3200deda1883525d
BLAKE2b-256 78d8f112a2f8e7c3d0455c960a5e87a5f2d2615a96d33181b911ddb432bc2b05

See more details on using hashes here.

File details

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

File metadata

File hashes

Hashes for tjhlp_checker-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 be0b2f0864413426654f44bfea3adaf690afa9c5de7a77671e4e9023bdc811d9
MD5 dcfc80049384b785b4d9d15f1b6e7687
BLAKE2b-256 64d73124dd01d957aea42f1ef96e6c57069a5909d9596fd2dc6caa02a64e00a0

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