Skip to main content

TOPyN: Typed Opinionated PYthon Normalizer

Project description

TOPyN: Typed Opinionated PYthon Normalizer

Actions Status Actions Status Coverage Status License: MIT PyPI

About

Scooter*

Python is quite a flexible language, something that is not so good if you start working in mid level size projects and/or in teams. Over the time we have found a set of rules that makes working with Python in this context easier, and once you get you use to them you want to apply them to every small Python snippet that you write.

The problem is that these rules depend on a set of packages and config files, and every time we change our mind about one rule, or add new ones, we need to update multiple projects. Topyn solves this by providing in one single place all the tools and configurations we use in our projects.

All the configurations are part of the project (topyn/configs) and is not the purpose of this project to make them flexible, if you need that please check the packages that we use, and run them with your configuration.

Install

pip install topyn

Command line

There are two possible arguments:

  • path is the path that you want to check, if it is empty it defaults to the current directory.
  • --fix if you use this flag topyn will try to fix the code for you

Examples

Check the code inside directory_with_code : topyn directory_with_code

Check the code inside current directory : topyn

Check the code inside current directory and try to fix it: topyn --fix

topyn --help output

Typed Opinionated PYthon Normalizer

positional arguments:
  path        path to topynize (default: .)

optional arguments:
  -h, --help  show this help message and exit
  --fix       try to fix my code (default: False)
  --version   show program's version number and exit

topyn output

➡️ Checking formatting ...
All done! ✨ 🍰 ✨
8 files would be left unchanged.
➡️ Checking rules ...
➡️ Checking types ...
✅ Everything is OK! 😎"

🔴

➡️ Checking formatting ...
All done! ✨ 🍰 ✨
1 file would be left unchanged.
➡️ Checking rules ...
➡️ Checking types ...
tests/resources/wrong_types/wrong_types.py:2: error: Incompatible return value type (got "int", expected "str")
Found 1 error in 1 file (checked 1 source file)

🔴 Sadly, types failed 😢

Tools included

Flake8

flake8 is a command-line utility for enforcing style consistency across Python projects

Flake8 plugins

  • flake8-bugbear

    A plugin for flake8 finding likely bugs and design problems in your program. Contains warnings that don't belong in pyflakes and pycodestyle.
  • flake8-print

    Check for print statements in python files.
  • flake8-comprehensions

    A flake8 plugin that helps you write better list/set/dict comprehensions.
  • pep8-naming

    Naming Convention checker for Python (PEP 8)

Black

The Uncompromising Code Formatter

Mypy

Optional static typing for Python (PEP 484)

Contributors

Leandro Leites Barrios : Main developer

Denada Korita : UX & Documentation consultant


* scooter icon source: icons8

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

topyn-0.7.0.tar.gz (7.9 kB view details)

Uploaded Source

Built Distribution

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

topyn-0.7.0-py3-none-any.whl (8.3 kB view details)

Uploaded Python 3

File details

Details for the file topyn-0.7.0.tar.gz.

File metadata

  • Download URL: topyn-0.7.0.tar.gz
  • Upload date:
  • Size: 7.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.13 CPython/3.10.4 Darwin/21.5.0

File hashes

Hashes for topyn-0.7.0.tar.gz
Algorithm Hash digest
SHA256 6a8d2c73f2805a57f2f7e91023a21dd83508fcc9df0cc1d8be7c02c69cf6be66
MD5 4ac62d2b302387df8cca81262a070d35
BLAKE2b-256 557f5faca26fdad46e0c94d3f6d98a7a3f4ec71cb4212a721626a4a4f46b210f

See more details on using hashes here.

File details

Details for the file topyn-0.7.0-py3-none-any.whl.

File metadata

  • Download URL: topyn-0.7.0-py3-none-any.whl
  • Upload date:
  • Size: 8.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.1.13 CPython/3.10.4 Darwin/21.5.0

File hashes

Hashes for topyn-0.7.0-py3-none-any.whl
Algorithm Hash digest
SHA256 efaf9272509151343712c5a83abf13a84df420860c512e0c32ec153f4844842a
MD5 4bb3f0c2129bfe9aa7478284642a245b
BLAKE2b-256 d5b38611f936ba6ddcced1a31dc9223e79a2eee83363de6c76bd470f611e9670

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