Skip to main content

An extendable file generator

Project description

geny

An extendable file generator

publish PyPI - Package PyPI - Python PyPI - License PyPI - Downloads

Installation

Install via pip:

pip install geny

After installation, the CLI will expose the binary with the name:

geny

Extending the CLI

Currently, there are two main ways of extending the functionality of the CLI:

  1. Adding your own commands/plugins
  2. Overriding the provided resource templates

Including your own commands

If you would like to extend the functionality of this CLI, you can include your own plugins/commands by setting an environment variable: GENY_PLUGINS. Simply set this variable to the path where your plugins are.

Plugin commands are auto-discovered if they are placed under the plugins directory, but please be sure to do the following for this to work:

  1. Name your package and click command the same. That is, a package called get, for example, should define a get command.
  2. Place the command definition within the package's main.py module. For example:
# get/main.py
import click


@click.command()
@click.pass_context
def get(ctx):
    pass
  1. Sub-commands should be added to the top-most command group in the package's main.py module.
# get/main.py
import click


@click.group() # <- group
@click.pass_context
def get(ctx):
  pass


@click.command()
@click.pass_context
def foo(ctx):
  pass


get.add_command(foo)
  1. Access your commands via your top-most command group.
geny get foo

NOTE: If you would like to skip a plugin/command from being auto-discovered, simply rename the package by either prepending or appending any number of underscores (_). Any code contained within the package will be ignored.

Overriding the templates

The flag --templates-dir can be used to configure an additional path wherein the CLI can look for resource templates. Alternatively, you can use the environment variable GENY_TEMPLATES_DIR for the same purpose.

Development

Install from source:

git clone https://github.com/oleoneto/geny.git
cd geny
pip install --editable .

Dependencies

Check out pyproject.toml for all installation dependencies.

To Do

Check out our open issues.

Pull requests

Found a bug? See a typo? Have an idea for new command? Feel free to submit a pull request with your contributions. They are much welcome and appreciated.

LICENSE

geny is BSD Licensed.

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

geny-0.1.8.tar.gz (14.5 kB view details)

Uploaded Source

Built Distribution

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

geny-0.1.8-py3-none-any.whl (20.6 kB view details)

Uploaded Python 3

File details

Details for the file geny-0.1.8.tar.gz.

File metadata

  • Download URL: geny-0.1.8.tar.gz
  • Upload date:
  • Size: 14.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.2

File hashes

Hashes for geny-0.1.8.tar.gz
Algorithm Hash digest
SHA256 b717de4417a49af4d0d6c7648d424348a690d5807c9b568f7d7c21a4c671bf9f
MD5 3973b7ba0d9e4590e35399f0c9df292f
BLAKE2b-256 21bebc34a22cca08a24ae9041dc03ea0b4698d76f305e53ababe3d2c3a3d1833

See more details on using hashes here.

File details

Details for the file geny-0.1.8-py3-none-any.whl.

File metadata

  • Download URL: geny-0.1.8-py3-none-any.whl
  • Upload date:
  • Size: 20.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.2

File hashes

Hashes for geny-0.1.8-py3-none-any.whl
Algorithm Hash digest
SHA256 1e41e19e50b404be5f6a26f92d30d2b5ceb1c88ee967ebffcae9838f79ca23a0
MD5 4f499c369a39ba146be43294d9eb5b91
BLAKE2b-256 81851efc3600faa517ed73b2c07696dbd71783dfda857cf5a68f163eed21a58c

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