ffizer

crates license crate version

Project Status: Active – The project has reached a stable, usable state and is being actively developed. Actions Status test coverage

crates download GitHub All Releases

ffizer is a files and folders initializer / generator. It creates or updates any kind (or part) of project from template(s).

keywords: file generator, project template, project scaffolding, quick start, project bootstrap, project skeleton

asciicast: ffizer demo

Features

Suggestions are welcomes ;-)

A list of alternatives is available on the wiki, feel free to complete / correct.

Usages

Install

sh curl https://raw.githubusercontent.com/ffizer/ffizer/master/scripts/getLatest.sh | bash

Or download the binary for your platform from github releases, then un-archive it and place it your PATH.

via homebrew (MacOs & Linux)

sh brew install ffizer/ffizer/ffizer-bin ffizer upgrade

via cargo

sh cargo install ffizer --force --features cli

Run

```txt ❯ ffizer --help ffizer 2.5.0 https://ffizer.github.io/ffizer/book/ ffizer is a files and folders initializer / generator. It creates or updates any kind (or part) of project from template(s)

USAGE: ffizer [OPTIONS]

OPTIONS: -h, --help Print help information -v, --verbose Verbose mode (-v, -vv (very verbose / level debug), -vvv) print on stderr -V, --version Print version information

SUBCOMMANDS: apply Apply a template into a target directory help Print this message or the help of the given subcommand(s) inspect Inspect configuration, caches,... (wip) show-json-schema Show the json schema of the .ffizer.yaml files test-samples test a template against its samples upgrade Self upgrade ffizer executable

```

Self upgrade the executable

sh ➜ ffizer upgrade

Apply a template (to create or update)

```sh ❯ ffizer apply --help ffizer-apply 2.5.0 https://ffizer.github.io/ffizer/book/ Apply a template into a target directory

USAGE: ffizer apply [OPTIONS] --source --destination

OPTIONS: --confirm ask for plan confirmation [default: Never] [possible values: auto, always, never]

-d, --destination <DST_FOLDER>
        destination folder (created if doesn't exist)

-h, --help
        Print help information

    --offline
        in offline, only local templates or cached templates are used

    --rev <REV>
        git revision of the template [default: master]

-s, --source <URI>
        uri / path of the template

    --source-subfolder <SUBFOLDER>
        path of the folder under the source uri to use for template

    --update-mode <UPDATE_MODE>
        mode to update existing file [default: Ask] [possible values: ask, keep, override,
        update-as-remote, current-as-local, show-diff, merge]

-v, --variables <KEY_VALUE>
        set variable's value from cli ("key=value")

-V, --version
        Print version information

-y, --no-interaction
        should not ask for confirmation (to use default value, to apply plan, to override, to
        run script,...)

```

Authoring a template

Start with Template Authoring Tutorial

Few templates

Build

sh cargo install cargo-make --force cargo make ci-flow

Update CHANGELOG.md

sh cargo make update-changelog git add CHANGELOG.md git commit -m ':memo: (CHANGELOG) update'

Release a new version by bump patch (or minoror major)

sh cargo make publish patch # dry-run cargo make publish --execute patch