Skip to main content

Source code analyser — part of the analyser family

Project description

code-analyser

Analyses source code files and returns style violations, complexity metrics, and quality indicators. Designed as a low-level tool — feed it a file, get back structured JSON.

Part of the analyser family.

Status: Early development. Currently supports Python via ruff and basic AST metrics. Multi-language support and alignment with the family API pattern is in progress.

Install

pip install code-analyser

Requires Python 3.11+.

Usage

Python

from code_analyser import analyse

result = analyse("submission.py")

print(f"Lines:      {result['metrics']['lines_of_code']}")
print(f"Complexity: {result['metrics']['cyclomatic_complexity']}")
print(f"Issues:     {len(result['issues'])}")

HTTP API

# Start the server
uvicorn code_analyser.main:app --port 8004

curl -X POST http://localhost:8004/api/v1/analyze/python \
  -H "Content-Type: application/json" \
  -d '{"code": "def hello():\n    print(\"Hello\")", "language": "python"}'

Supported languages

Language Status
Python supported (ruff, AST metrics)
JavaScript, Java, others planned

Output

{
  "language": "python",
  "metrics": {
    "lines_of_code": 42,
    "cyclomatic_complexity": 3,
    "maintainability_index": 74.2
  },
  "issues": [
    {"rule": "E501", "line": 12, "message": "line too long (92 > 88 characters)"}
  ],
  "summary": {
    "error_count": 0,
    "warning_count": 1,
    "style_count": 2
  }
}

The analyser family

Low-level analysis tools. Each accepts files directly and returns structured JSON. Build your own UI or pipeline on top.

Package Handles
speech-analyser audio and video files — transcript and speech metrics
video-analyser video files — frames, scenes, and visual quality
document-analyser PDF, DOCX, PPTX, TXT — text and readability
code-analyser source code — style, complexity, and quality metrics
records-analyser CSV, Excel, SQLite, Parquet, JSON — data profiling
auto-analyser any file — detects format and routes to the right tool

License

MIT

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

code_analyser-1.0.2.tar.gz (92.3 kB view details)

Uploaded Source

Built Distribution

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

code_analyser-1.0.2-py3-none-any.whl (22.3 kB view details)

Uploaded Python 3

File details

Details for the file code_analyser-1.0.2.tar.gz.

File metadata

  • Download URL: code_analyser-1.0.2.tar.gz
  • Upload date:
  • Size: 92.3 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.0

File hashes

Hashes for code_analyser-1.0.2.tar.gz
Algorithm Hash digest
SHA256 76610fea88249a0e48ed9be409e3659827f2373fdfc5980519e153668f1f3185
MD5 c3ca58a86802c6cf68fbd960551ecd5e
BLAKE2b-256 5585cfdf173b1529b8504152f311ab8a7817df116a231dd63d5f32505fc04462

See more details on using hashes here.

File details

Details for the file code_analyser-1.0.2-py3-none-any.whl.

File metadata

  • Download URL: code_analyser-1.0.2-py3-none-any.whl
  • Upload date:
  • Size: 22.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.0

File hashes

Hashes for code_analyser-1.0.2-py3-none-any.whl
Algorithm Hash digest
SHA256 6d928553f38b8f5bf29663e638cbf241b1dbcae19c6a7c6bb35ea66f1bb478ed
MD5 69d0aebf57053f1430ab9a602138a029
BLAKE2b-256 485aa19bf4d7625bfe2c1f8f19232130a5c3cfc8e7c3a76a7666b12c2d53a015

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