Skip to main content

(graph).

Project description

NOTE: I'm thankful for any bug fix or report; They are more than welcome.
However, I want to keep the scope of this project very small, so any other kind of pull-requests are discouraged.

Hecto(graph)

Coverage Status Tests

A small and simple library for rendering projects templates.

  • Works with local paths and git URLs.
  • Your project can include any file and Hecto can dynamically replace values in any kind of text files.
  • It generates a beautiful output and take care of not overwrite existing files, unless instructed to do so.

How to use

pip install hecto
from hecto import copy

# Create a project from a local path
copy('path/to/project/template', 'path/to/destination')

# Or from a git URL.
# You can also use "gh:" as a shortcut of "https://github.com/"
# Or "gl:"  as a shortcut of "https://gitlab.com/"
copy('https://github.com/jpsca/base36.git', 'path/to/destination')
copy('gh:jpsca/base36.git', 'path/to/destination')
copy('gl:jpsca/base36.git', 'path/to/destination')

How it works

The content of the files inside the project template are copied to the destination without changes, unless are suffixed with the extension '.tmpl'. (you can customize that with the render_as setting). In that case, the templating engine is used to render them.

A slightly customized Jinja2 templates are used. The main difference is that variables are referenced with [[ name ]] instead of {{ name }} and blocks are [% if name %] instead of {% if name %}. To read more about templating see the Jinja2 documentation.

Use the data argument to pass whatever extra context you want to be available in the templates. The arguments can be any valid Python value, even a function.

API

hecto.copy()

hecto.copy(
    src_path,
    dst_path,

    data=DEFAULT_DATA,
    *,
    exclude=DEFAULT_EXCLUDE,
    include=[],
    skip_if_exists=[],
    envops={},
    render_as=DEFAULT_RENDER_AS,

    pretend=False,
    force=False,
    skip=False,
    quiet=False,
)

Uses the template in src_path to generate a new project at dst_path.

Arguments:

  • src_path (str):
    Absolute path to the project skeleton. May be a version control system URL.

  • dst_path (str):
    Absolute path to where to render the project template.

  • data (dict):
    Optional. Data to be passed to the templates.

  • exclude (list of str):
    Optional. A list of names or shell-style patterns matching files or folders that must not be copied.

  • include (list of str):
    Optional. A list of names or shell-style patterns matching files or folders that must be included, even if its name is a match for the exclude list. Eg: ['.gitignore']. The default is an empty list.

  • skip_if_exists (list of str):
    Optional. Skip any of these file names or shell-style patterns, without asking, if another with the same name already exists in the destination folder. It only makes sense if you are copying to a folder that already exists.

  • envops (dict):
    Optional. Extra options for the Jinja template environment.

  • render_as (function):
    An optional hook that takes the absolute source path and the relative destination path of a file as arguments.

    It should return None if the file must be copied as-is or a Path object of the new relative destination (can be the same as the one received).

    By default all the files with the .tmpl postfix are rendered and saved without that postfix. Eg: readme.md.tmpl becomes readme.md.

  • get_context (function):
    An optional hook called before rendering a file. Takes the relative destination path of the file as argument, and should return a dictionary with the context for its rendering.

  • pretend (bool):
    Optional. Run but do not make any changes

  • force (bool):
    Optional. Overwrite files that already exist, without asking

  • skip (bool):
    Optional. Skip files that already exist, without asking

  • quiet (bool):
    Optional. Suppress the status output

The hecto.yaml file

If a YAML file named hecto.yaml is found in the root of the project, it will be read and used for arguments defaults.

Note that they become just the defaults, so any explicitly-passed argument will overwrite them.

# Shell-style patterns files/folders that must not be copied.
exclude:
  - "*.bar"
  - ".git"
  - ".git/*"

# Shell-style patterns files/folders that *must be* copied, even if
# they are in the exclude list
include:
  - "foo.bar"

# Shell-style patterns files to skip, without asking, if they already exists
# in the destination folder
skip_if_exists:
  - ".gitignore"

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

hecto-1.200708.tar.gz (15.4 kB view details)

Uploaded Source

Built Distribution

hecto-1.200708-py3-none-any.whl (15.4 kB view details)

Uploaded Python 3

File details

Details for the file hecto-1.200708.tar.gz.

File metadata

  • Download URL: hecto-1.200708.tar.gz
  • Upload date:
  • Size: 15.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.47.0 CPython/3.8.1

File hashes

Hashes for hecto-1.200708.tar.gz
Algorithm Hash digest
SHA256 a6be4ecfacf1b092f5c399bc057c6a3604b77f3f2f91f862b8257128a5e2f87b
MD5 d6906bc372ac286cb9b21e89debfacee
BLAKE2b-256 146c501bfafb1a0fc809882aef0cce9095dff63cfa45e8e4170125fb2c3c6de0

See more details on using hashes here.

File details

Details for the file hecto-1.200708-py3-none-any.whl.

File metadata

  • Download URL: hecto-1.200708-py3-none-any.whl
  • Upload date:
  • Size: 15.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/41.2.0 requests-toolbelt/0.9.1 tqdm/4.47.0 CPython/3.8.1

File hashes

Hashes for hecto-1.200708-py3-none-any.whl
Algorithm Hash digest
SHA256 326e98c716bbbe2c72b0e28603a0a390bc3c69b8d25d8f54c3a414e8e641e7bf
MD5 1830d5274723c5e0bf16ff12224a13d1
BLAKE2b-256 62a735ceb86c0762c55dc6fba1a16c27c79663f9f50c2d9bc1bdb904f0f744f1

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