Skip to main content

Leave it to Cleverish, No more code breakage due to dependency. Dependency Handler

Project description

Unit Tests codecov PyPI - Python Version PyPI - Version Pepy Total Downloads

Overview

cleverish is a dependency and environment handler for python projects. Inspired from Cargo (from Rust programming language), cleverish brings a few greatly attractive features like the clever shell. cleverish aims to handle all dependency problems so that you don't have to rattle your brain for it.

Table of Contents

Features

cleverish brings a ton of features engineered with great attention to detail. Still, I wont claim it's perfect, This is still in beta and I am working on it still, improving it's decision making and working which in turn will improve the user comfort.

  • Initialization

    cleverish as inspired from Cargo, can initialize empty projects with structure complying with Python Packaging Index(PYPI)

    $ clever init
    

    Initializing a project creates a virtual environment for that particular project where all the dependencies will be added and maintained.

    All arguments and descriptions are provided in Usage

  • The Clever Shell

    As the name mentions, it is a clever shell. It is a python wrapped terminal which helps execute commands in the virtual environment created for the project.

    For example, you have a globally installed python and pip. But the virtual environment has it's own python and pip and any executable bins of libraries that you install for that particular virtual environment. Using the clever shell, when you call for a bin or simply python, it will be called from the virtual environment if the bin exists, and if it doesn't exist, then it will look globally.
    Overall, using the clever shell is the safest practice while interacting with the project and its dependencies.

    $ clever shell
    

    Apart from safe and valid execution of commands, clever shell has command history, auto-suggestion and free cursor movement.

    Other descriptive features are provided in Usage

  • Integration of dot-lock and toml file

    cleverish works with a set of configurations that are saved in a clever.toml file in the same directory as your project (same as pyproject.toml).

    Having this configuration file makes it easy to configure it based on user needs.

    cleverish maintains a dot-lock file (clever.lock) which keeps track of all dependencies and their requirements. This file is not for user intervention, it is generated and updated by cleverish.

  • Attention to detail

    cleverish is made with a lot of attention to detail which can be seen in it's working.

    For example, if a library is installed in your virtual environment and you don't know the version And you want to install it again, this time, say, >=v2.0.0. cleverish will find out the version of the currently installed library and checks if it matches the description, if it does, it will skip, else it will install.

    This avoids repeated installation of the same library.

    Apart from this, several more details are handled by cleverish and therefore it provides a smooth user experience.

  • Building and Uploading

    With cleverish you can build and upload your projects to Python Packaging Index. You will need an API key from the website and need to paste it in the terminal or you can create a .pypirc file in your home directory as per given below.

    .pypirc

    [pypi]
      username = __token__
      password = <paste your api token here>
    

Usage

NOTE: See the demo clever.toml file to know about the fields and values (For, pypi users, click here to go to the repository and see the clever.toml file.)

  • Init

    Initializing a new project with clever comes with a few benefits, such as, defining if you are creating a package or just a simple project.

    The base command is clever init. However there are a few sub arguments for it such as package and name.

    Let us see them all.

    • clever init

      This will create the following directory structure.

      project_name/
          | 
          | - .project_name/
          |       | 
          |       | - bin/
          |       |    |
          |       |    | - activate
          |       |    | - activate.csh
          |       |    | - activate.fish
          |       |    | - Activate.ps1
          |       |    | - pip
          |       |    | - pip3 # based on root python version
          |       |    | - pip3.13 # based on root python version
          |       |    | - build
          |       |    | - twine
          |       |    | - * and a few other bins * to start you off.
          |       |
          |       | - include/ # will contain python executable
          |       |
          |       | - lib/ # will contain libraries
          |       |
          |       | - pyvenv.cfg
          |
          |- src/
          |   |
          |   |- __init__.py
          |
          | - pyproject.toml
          | - clever.toml
          | - clever.lock
      

      where .project_name is the virtual environment name.

    • clever init package

      This command will create a package inside src directory

      ...
      | - src/
      |   | - project_name/
      |   |       | - __init__.py
      ...
      
    • clever init package name <some_name>

      This will change the default package_name to some_name

      ...
      | - src/
      |   | - some_name/
      |   |       | - __init__.py
      ...
      

      The presence of name argument will automatically set the package argument as True. i.e, clever init name <some_name> will have the same effect.

  • clever shell

    The clever shell will be automatically opened after clever init, however it's usage depends on the user.

    The use of clever shell is recommended for calling the environment python, pip and other bins installed in it.

    To open the shell,

    $ clever shell
    

    To exit, enter any of these: [exit, quit, deactivate, ctrl+c, ctrl+d, :q] and hit enter.

  • clever install

    Suppose you have already mentioned a few dependencies in the clever.toml, using this command, those dependencies will be installed.

    In other cases, if any installation you did using pip and did not add in the toml file, using this command will add it into the .lock and clever.toml file.

    Any dependency already present will be skipped.

    There is no sub-arguments for this command (YET!)

  • clever add <package-name>

    This command is for adding new or updating existing dependencies.

    if version is not provided: clever add modstore, the latest version will be installed. However, if the library already exists, it will skip it.

    If a library is installed, say, modstore v1.1.1, and you want to install version v1.0.0. using clever add modstore==1.0.0 will install v1.0.0. However, if you use clever add modstore==1.1.1, it will be skipped as it is already installed in the virtual environment.

    cleverish will check the toml file and the dot-lock file and system installations to tally the currently present and user requested dependency versions, and then make a decision on whether to skip it or install it. If will only install if necessary.

    The toml file and dot-lock file will be updated automatically upon using this command.

    Important:
    This command supports multiple packages at once and therefore the command: clever add modstore, wrapper-bar, numpy, pandas is valid. Any number of packages can be provided at once.

  • clever build

    This command uses the build library of python to build the project into sdist(.tar.gz) and wheel(.whl). The build will be available in the folder project_name/dist/.

    Important:
    If you are using maturin to create Python/Rust mix project or similar(using something other than setup-tools backend), then do not use this command. Use the related build command, for example, in case of maturin, it is maturin build.

    NOTE: You need to install maturin in the virtual environment using clever add maturin and then call maturin build. All this can be done in the clever shell. ;)

  • clever upload <distribution-folder>

    Using this command, dist packages can be upload to the Python Packaging Index.

    Let us take an example. You built the project using clever build and now it is available under ./dist

    Therefore, the command to upload it to pypi will be

    $ clever upload dist
    
  • clever help

    For a list of commands and sub commands and their usage, use clever help. The arguments have shorter counterparts, use clever help to find out.

Use cases

Now typically this is ideal for pure python projects currently. Future updates will include other language support such as Python/Rust mix projects.

  • For people who work on multiple projects at the same time, like me, cleverish is a great fit to maintain virtual environment and dependencies of different projects separate and iron clad.

  • Clever Shell provides a locked environment to run commands which prevents breaking dependencies upon accidental mistakes or typos and even saves from accidentally calling libraries outside the project scope.

  • Support for VSCode, Once using clever init, the virtual environment can be selected in vscode which will then help in environment specific hinting and code suggestions.

  • Overall saving time and effort.

Upcoming Features

There are a lot of upcoming features on my mind, like..

  • Extending the clever shell functionalities
  • Adding sub-arguments for clever install
  • Adding support for Mix Python projects in build, init and upload arguments
  • Adding a test argument for testing (might even check docstring codes, if found)
  • Customize init argument for more specific initializing options
  • and a few secrets :D

Contributing

Contributions are welcome for this project. Please submit any issues or PRs and I will get back to it asap.

Thank you for your interest in contributing! cleverish aims to shorten the time it takes to create projects and the ease of use. We welcome contributions of all kinds, including bug reports, feature requests, documentation improvements, and more.

Find the Code of Conduct here. If you are seeing this page on PYPI, go to the repository using the GitHub link listed above and see CODE_OF_CONDUCT.md

Find the Contribution Instructions here. If you are seeing this page on PYPI, go to the repository using the GitHub link listed above and see CONTRIBUTING.md

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

cleverish-0.0.3.tar.gz (28.5 kB view details)

Uploaded Source

Built Distribution

cleverish-0.0.3-py3-none-any.whl (30.3 kB view details)

Uploaded Python 3

File details

Details for the file cleverish-0.0.3.tar.gz.

File metadata

  • Download URL: cleverish-0.0.3.tar.gz
  • Upload date:
  • Size: 28.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.13.0

File hashes

Hashes for cleverish-0.0.3.tar.gz
Algorithm Hash digest
SHA256 9ce23d65acfcc7379edbd063d6481d8590159f0bf931d67758897c86e3616d3a
MD5 54943b06abfc3376f99003f736dcc205
BLAKE2b-256 698420d20ad22647fde9cefc42c54b888bc975de00f48cbafb94fd22d9503537

See more details on using hashes here.

File details

Details for the file cleverish-0.0.3-py3-none-any.whl.

File metadata

  • Download URL: cleverish-0.0.3-py3-none-any.whl
  • Upload date:
  • Size: 30.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.13.0

File hashes

Hashes for cleverish-0.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 d356fe2fcd02fa8e05dd37a8f39f815bc5c81d21d5bc3dba9663b88bbbc2e674
MD5 968c1db7e970faf15795211e6e0e4fa3
BLAKE2b-256 b51566051650997c1bf3adf8c84209fc9cd33cb240b2774aec0ef2f96514b1f8

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