Skip to main content

No project description provided

Reason this release was yanked:

bugs

Project description

cleandoc

Description

Python package leveraging doq, black, pylint, mypy and sphinx to automatically clean and document python code.

Install

pip install cleandoc

Usage

Command Line Usage

cleandoc [-h] [-file FILE] [-dir DIR] [-write] [-ignore] [-noclean] [-nodoc] [-release]

optional arguments:

  • -h, --help
    • show this help message and exit
  • -file FILE,-f FILE
    • Python (.py) file to clean
  • -dir DIR, -d DIR
    • Directory containing Python (.py) files to clean and/or document
  • -write, -w
    • Flag to write changes to files in-place
  • -ignore, -i
    • Flag to continue through warnings
  • -noclean, -nc
    • Flag to prevent cleaning of py files
  • -nodoc, -nd
    • Flag to prevent html doc creation
  • -release RELEASE, -r RELEASE
    • Release or version number of documentation (X.Y.Z)

Python In-Line Usage

  • Example below can be ran as a standalone code example
  • Example includes standard Python packages shutil, os, and webbrowser
  • In-line usage of cleandoc is shown when calling "cd."
  • Recommended use case is running "cleandoc_all" on your python module folders
# -*- coding: utf-8 -*-
# Pylint will be mad because there is no script docstring

import shutil
import webbrowser
import cleandoc as cd
import os  # this import should be before cleandoc, pylint will complain

def example_fxn_1()->str:
    """
    Set a variable that get flagged by Pylint
    """
    ISSUE_2 = 0 # pylint complains because variables in functions should be snake or lowercase
    ISSUE_2 = "setting a previous int to a string now. Mypy will complain"
    return ISSUE_2


if __name__=="__main__":
    # Create nested source file folder and copy in this script
    maindir = os.path.dirname(os.path.abspath(__file__))
    srcpath = os.path.join(maindir, "src")
    os.mkdir(srcpath)
    dirpath = os.path.join(srcpath, "readme_test")
    os.mkdir(dirpath)
    scriptpath = os.path.join(maindir, "src", "readme_test", os.path.basename(os.path.abspath(__file__)))
    shutil.copyfile(os.path.abspath(__file__), scriptpath)

    print("\n\n>>> Cleaning One Python File <<<\n")
    cd.clean_pyfile(scriptpath, write=True)
    print("\n\n>>> Cleaning All Python Files in Directory <<<\n")
    cd.clean_all(dirpath, ignore=True, write=False, skip=True)
    print("\n\n>>> Cleaning All and Generating HTML Docs <<<\n")
    try:
        # Below line runs clean_all and gen_docs functions
        # Raises a syntax warnings because ignore=False, so docs are not generated
        cd.cleandoc_all(dirpath, ignore=False, write=True, release="0.0.1")
    except SyntaxWarning as error:
        print(f"syntax warning:\n\n{error}")
    print("\n\n>>> Generating HTML Documents with Sphinx <<<\n")
    webpage = cd.gen_docs(dirpath, changed=True, release="0.0.1")

    issue_1 = "This string line is way too long. Why did you need to type this all in one line? Black is going to try to shorten this and pylint will complain. Pylint also complains because constaints in main script should be all uppercase."
    ISSUE_2 = example_fxn_1()
    ISSUE_3 = ["really","long","list","so","black","reformats","it","and","turns","the","one","line","list","into","multi","line"]

    # Delete src folder created at begining of script
    shutil.rmtree(srcpath)
    webbrowser.open(webpage)

Read The Docs

Download "docs" folder or check preview.

Contributing

Message me on Github.

License

GNU GPLv3

Copyright:

(c) 2023, Jason Krist

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

cleandoc-0.0.11.tar.gz (26.0 kB view details)

Uploaded Source

Built Distribution

cleandoc-0.0.11-py3-none-any.whl (26.5 kB view details)

Uploaded Python 3

File details

Details for the file cleandoc-0.0.11.tar.gz.

File metadata

  • Download URL: cleandoc-0.0.11.tar.gz
  • Upload date:
  • Size: 26.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.12.0

File hashes

Hashes for cleandoc-0.0.11.tar.gz
Algorithm Hash digest
SHA256 97c7d322d8e4618630bf89d7604cd623c82a332014c58389e17782bd7a15a0a7
MD5 d73c2ebadf864210af1e7c2d7f9d1f98
BLAKE2b-256 2a939e3038e9b5103818b0a614af74876ef965c0e6e8b114723efe29e9279453

See more details on using hashes here.

File details

Details for the file cleandoc-0.0.11-py3-none-any.whl.

File metadata

  • Download URL: cleandoc-0.0.11-py3-none-any.whl
  • Upload date:
  • Size: 26.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.12.0

File hashes

Hashes for cleandoc-0.0.11-py3-none-any.whl
Algorithm Hash digest
SHA256 ad79be9df5b8b1e1930b573856d3c357715b9ede26857a063605aefb0c4c64ef
MD5 aa70514062d78fd63e0c5496c9144046
BLAKE2b-256 30d83a7bc6c0d6df6e538a93200a733c16872b4f795336c6a7962ec92d210ba2

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