Skip to main content

A tool to scaffold projects from templates

Project description

skaf

Overview

skaf is a Python tool designed to simplify project scaffolding. It provides a simple interface for defining project templates that can be rendered with minimal effort. Here's a quick guide to installing and making templates:

Installation

Ensure you have Python 3.10 or above. Install using pip:

pip install skaf

Alternatively, you can clone and install the local package:

git clone <repository-url>
cd skaf
pip install .

Features

  • Users can define project templates locally or in a git repo
  • Simple CLI command to apply scaffolding
  • Users can provide variable values via a yaml, environment variables, or interactively at the command line at scaffolding time.
  • Variable values can be used in directory names

Creating your own templates

  1. Create a template directory
    In skaf, templates are directories of files that may or may not contain templating blocks. The default templater is jinja2, which is a full-featured templating engine with advanced features. (Note that skaf does not currently use jinja Loaders)

    Any files that have a .jinja file suffix will be rendered. Otherwise, the file will be left as-is.

    All files should be placed in a directory structure that looks like:

    my-template-root/
       ├── template/
       │   └── [any files you want]
       ├── template_properties.yaml   # this is metadata. required.
       └── variables_helper.py        # optional
       
    

    For example, imagine I want to generate a customized hello world printer that is hard-coded to say hello to a specific person named John. I would create the following file:

    # my-template-root/template/hello.py.jinja
    
    print("Hello {{ some_name }}!")
    
  2. Create a template_properties.yaml
    Next, we can declare metadata about the template. At this point, that primarily looks like declaring a list of variables that might have default values. There are a couple of other optional top-level fields as well:

    templater: jinja2  # default
    auto_use_defaults: false  # default
    custom_variables:
    - name: "some_name"
      type: "str"  # optional
      default: "World"  # optional
      description: Who are we saying hello to?  # optional
    

    For custom variables, the type, default, and description fields are optional. Only name is required.

    When rendering is run, you will be prompted to enter a value for the some_name variable or to accept the default value World. If we had instead specified that top-level value auto_use_defaults: true, then the templater would run without asking for input, and would provide World in as the value for some_name. (This particular behavior can also be overridden when invoking the CLI command.)

    The two top-level fields templater and auto_use_defaults are shown here with default values.

  3. (Optional) Create a variables_helper.py
    It may be the case that you want to use some user-provided variable values to derive some other template variable value. For this, you can create a python file outside your template/ directory, next to template_properties.yaml called variables_helper.py and define a variables_helper function that has the following form:

    # variables_helper.py
    
    def variables_helper(variables: dict) -> dict:
       ...
    

    The function should accept a dictionary of variable values and return a dict. For example, imagine that you were provided a namespace variable with a value like "com.mydomain.example" and you wanted to turn that into a directory path string like "com/mydomain/example". You could define a variables helper function like:

    # variables_helper.py
    
    def variables_helper(variables: dict) -> dict:
       variables["namespace_path"] = variables["namespace"].replace(".", "/")
    

    This particular use case could be helpful in a templating scenario where you declared a template directory like:

    my-template-root/
       ├── template/
             └──src/
                └──main/
                   └──java/
                      └── {{ namespace_path }}
                            └── MyClass.java
    

    When the user provides a namespace com.mydomain.example, the rendered template would look like

    my-template-root/
       ├── template/
             └──src/
                └──main/
                   └──java/
                      └──com/
                         └──mydomain/
                            └──example/
                               └── MyClass.java
    

Command-line Usage

The CLI provides several flags and arguments to customize the initialization of a project with templates:

skaf <project_name> [options]

Positional Arguments:

  • <project_name>: The name of the project to create.

Options:

Must have one of these

  • -t, --template <template_name>: Specify the name of the project template to use. Must proivde one of --path, --template, or --git.
  • -p, --path <template_directory>: Provide the path to a local template directory. Must proivde one of --path, --template, or --git.
  • -g, --git <git_connection_string>: Provide a git repo that has the template directory structure to be used as a template source. Must proivde one of --path, --template, or --git.

Entirely optional

  • -o, --output <output_directory>: Set the output directory for the project. Defaults to the current working directory.
  • --varfile <variables_filepath>: Provide a filepath to a yaml file with key-values that provide variable values.
  • --overwrite: Allow overwrite of existing project directory if it exists.
  • --auto-use-defaults: Override the template properties' auto_use_defaults with an explicit value here.
  • --no-project-dir: Do not create a top-level <project_name> directory, but scaffold all templates directly into the output directory.
  • --debug: Enable debug mode, which will raise exceptions rather than catching them with a tidier output.

Example Commands

  1. Creating a project with a template that is included in the package:

    skaf my_project -t setuptools_pyproject
    
  2. Using a local, user-defined template:

    skaf my_project -p /path/to/my/template
    
  3. Defining an Output Directory:

    skaf my_project -o /path/to/output -p /path/to/my/template
    

Development Dependencies

To contribute or run tests, install development dependencies:

pip install .[dev]

Contribute

If you find a bug or have a feature request, please file an issue.

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

skaf-0.1.6.tar.gz (21.4 kB view details)

Uploaded Source

Built Distribution

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

skaf-0.1.6-py3-none-any.whl (19.0 kB view details)

Uploaded Python 3

File details

Details for the file skaf-0.1.6.tar.gz.

File metadata

  • Download URL: skaf-0.1.6.tar.gz
  • Upload date:
  • Size: 21.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for skaf-0.1.6.tar.gz
Algorithm Hash digest
SHA256 f39a6aa3b70dd95f0cbbef6ca45d657a04dcc018f9fab88fb8d5454259466754
MD5 7128150e8430b9aa5d62ca70ab9384dd
BLAKE2b-256 f7a61b6c9e755ad0d3413fec89c9b51fa28fd01123fcb5914e1729775cf98379

See more details on using hashes here.

Provenance

The following attestation bundles were made for skaf-0.1.6.tar.gz:

Publisher: workflow.on-pr-merge.yml on jdraines/skaf

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file skaf-0.1.6-py3-none-any.whl.

File metadata

  • Download URL: skaf-0.1.6-py3-none-any.whl
  • Upload date:
  • Size: 19.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.12.9

File hashes

Hashes for skaf-0.1.6-py3-none-any.whl
Algorithm Hash digest
SHA256 d65be058070f175210992577e59243316fec9d9907e2d67b6a4998a179872a4f
MD5 53f10245a89e912c9a8374e083280eeb
BLAKE2b-256 648c69fec1df6e20fc9dd1768febe743d24adaaac994b2f6abdc65a9d399dce7

See more details on using hashes here.

Provenance

The following attestation bundles were made for skaf-0.1.6-py3-none-any.whl:

Publisher: workflow.on-pr-merge.yml on jdraines/skaf

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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