Skip to main content

No project description provided

Project description

EduLint

Pypi Python versions Tests ReadTheDocs Docker image

EduLint is a Python linter aimed at helping novice programmers improve their coding style. Presently, it integrates flake8 and pylint, with some tweaks to their default configuration.

This repository contains the linter itself, which is packaged and published as a Pypi package edulint. There is also a web version running at edulint.com for easy use. Its source code is in another repository.

Demo GIF

Usage

Web version

Are you just starting with programming in Python? Then the web UI (website, repo) might be the best choice for you.

Python package

You can install the latest release with pip:

python3 -m pip install --user edulint

Once installed, you can run it as a Python module:

python3 -m edulint check <file-to-lint>

Read the documentation for more options and configuration details.

Docker container

Don't want to install Python and Edulint as a Python package? You can also run it using Docker.

docker pull edulint/edulint-cli  # Optional

docker run -v ${PWD}:/app edulint/edulint-cli check some_file.py

# Additional example that lints a file with absolute path /tmp/some_file.py
docker run -v /tmp:/app edulint/edulint-cli check /app/some_file.py

It supports the same configuration options as the native Python package.

Road map (long-term)

  • Additional explanations for problems detected in code
  • Thonny plugin
  • More code quality defects (from WPS; detecting duplicate code)
  • Rewrite web to React
  • Add additional functionality to web (more settings, better teacher onboarding, …)
  • Speed-up linting by switching to Ruff
  • official VS Code plugin (3rd party plugin already exists: Github, VS Code Marketplace)

Sponsorship and academic collaboration

Are you interested in sponsoring this project, want to collaborate on an academic paper, or know of any interesting grants? Feel free to reach out to anna.rechtackova@mail.muni.cz.

Compatibility with other software

Python version

Supported: Python 3.8+ (tested up-to Python 3.12)

Python 3.7 is no-longer officially supported, as Python 3.7 is already EOL. Last version that supported it was Edulint v3.6.1. Be aware that some linting results may be different between 3.7 and 3.8 due to different parsing between package typed-ast (<=3.7) and Python's native ast (>=3.8).

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

edulint-4.1.5.tar.gz (213.6 kB view details)

Uploaded Source

Built Distribution

edulint-4.1.5-py3-none-any.whl (216.3 kB view details)

Uploaded Python 3

File details

Details for the file edulint-4.1.5.tar.gz.

File metadata

  • Download URL: edulint-4.1.5.tar.gz
  • Upload date:
  • Size: 213.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.9.20

File hashes

Hashes for edulint-4.1.5.tar.gz
Algorithm Hash digest
SHA256 27305b6a749296cf3120062d051fdb542b95014b37d1a7a5c16d29deb0e6cf8c
MD5 30ab6e8042e38dc7fb5450f29db5d5d5
BLAKE2b-256 2e934c48f0a38236e68e4689a8be3ac29a447c66367c3d8bca9986bc6aeebecf

See more details on using hashes here.

File details

Details for the file edulint-4.1.5-py3-none-any.whl.

File metadata

  • Download URL: edulint-4.1.5-py3-none-any.whl
  • Upload date:
  • Size: 216.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.9.20

File hashes

Hashes for edulint-4.1.5-py3-none-any.whl
Algorithm Hash digest
SHA256 5d943ae04e9f4e8bbc893b1256ab7d06c3cf18fe482b7ba24afaa460e35417f1
MD5 28facfae5679d641a3bc525130e22f8e
BLAKE2b-256 56f7bb011fe38a923af66571b762d72e3f75a46b516408826ca4f2a4e786ceae

See more details on using hashes here.

Supported by

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