Skip to main content

paxo: python ♡ terminal

Project description

paxo: python ♡ terminal

paxo is a small library that makes it fast and easy to create simple python command line tools.

PyPI Version Build Status PyPI License PyPI Python Versions Say Thanks!


What is this?

With paxo you can quickly create terminal applications with python. It handles a bunch of stuff in the background so that you do not need to worry about it.

Why Yet Another Command Line Library?

Well, for me paxo is not just a command line library managing your arguments and options but also managing everything related to those commands. It generates a quick info view of your commands and also provides a help command to learn more about each command. I hope that in the Future it will be able to handle everything documentation, manage all application configuration and data and be fully customizable so that you can create your own themes for a terminal app. If you just want a simple library to take care for shell arguments for you there are many other options available to you.

Paxo Terminal

Installation

It's as simple as:

$ pip install paxo

Usage

Paxo is really easy to use for anyone, whether you want to start quickly or customize your command line application to your own needs entirely. You can see paxo in action with some of my side projects. (e.g. pen or como). You can find a minimalistic script that makes use of this library inside the project's example folder:

from paxo import Paxo
from paxo.command import cmd


@cmd(help='Print out a help message.')
def hello(args):
    print 'Hello World!'

app = Paxo('example', 'a Cecil Woebker project.', '<command>', '0.1')

if __name__ == '__main__':
    app.go()

A simple command line call ./example.py hello prints “Hello World!“. Take a look at the above screenshot for the accompanying info screen of the example.py command.

Advanced

If you want to know even more make sure to check out the source code or look at some of the projects I mentioned above.

Features

  • Mange commands, usage and help information
  • Easily map commands to python functions
  • Declare a default action
  • Declare a dynamic action

TODO

  • Additional decorator for dynamic/default action
  • Route shell arguments to python functions automatically
  • Automatically create usage text from function signature
  • Cleanup Command management
  • Manage app configuration
  • Manage app data
  • Loose dependencies and become standalone
  • Support for command line options (ala -o, -a, -u)
  • Extended documentation feature - Create man pages
  • Cross Platform support
    • Additional decorator for OS support
  • Create sphinx documentation for “paxo“
  • Themes for “paxo“ - Design your own command line tool

Contribute

Beware: I developed this mainly for my own projects. Unfortunately this tool is not yet as versatile as I would like it to be. If you have any questions or would like some new features please let me know!

Fork and contribute!


For questions and suggestions, feel free to shoot me an email at me@cwoebker.com.

Also, follow or tweet @cwoebker.


Copyright (c) 2015-2018, Cecil Wöbker. License: BSD (see LICENSE for details)

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

paxo-0.3.0.tar.gz (11.5 kB view hashes)

Uploaded Source

Built Distribution

paxo-0.3.0-py2.py3-none-any.whl (10.8 kB view hashes)

Uploaded Python 2 Python 3

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