Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nickderobertis/flexlate
A CLI tool for managing project generator templates such as Cookiecutter and Copier
https://github.com/nickderobertis/flexlate
cli cookiecutter copier git python scaffolding template
Last synced: 2 months ago
JSON representation
A CLI tool for managing project generator templates such as Cookiecutter and Copier
- Host: GitHub
- URL: https://github.com/nickderobertis/flexlate
- Owner: nickderobertis
- License: mit
- Created: 2021-12-04T23:08:43.000Z (about 3 years ago)
- Default Branch: master
- Last Pushed: 2022-08-14T15:53:45.000Z (over 2 years ago)
- Last Synced: 2024-11-09T01:08:55.212Z (3 months ago)
- Topics: cli, cookiecutter, copier, git, python, scaffolding, template
- Language: Python
- Homepage:
- Size: 6.68 MB
- Stars: 21
- Watchers: 1
- Forks: 0
- Open Issues: 39
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
[![](https://codecov.io/gh/nickderobertis/flexlate/branch/master/graph/badge.svg)](https://codecov.io/gh/nickderobertis/flexlate)
[![PyPI](https://img.shields.io/pypi/v/flexlate)](https://pypi.org/project/flexlate/)
![PyPI - License](https://img.shields.io/pypi/l/flexlate)
[![Documentation](https://img.shields.io/badge/documentation-pass-green)](https://nickderobertis.github.io/flexlate/)
![Tests Run on Ubuntu Python Versions](https://img.shields.io/badge/Tests%20Ubuntu%2FPython-3.8%20%7C%203.9%20%7C%203.10-blue)
![Tests Run on Macos Python Versions](https://img.shields.io/badge/Tests%20Macos%2FPython-3.8%20%7C%203.9%20%7C%203.10-blue)
[![Github Repo](https://img.shields.io/badge/repo-github-informational)](https://github.com/nickderobertis/flexlate/)# flexlate
## Overview
Flexlate is a composable, maintainable system for managing [project
and file generator templates](https://nickderobertis.github.io/flexlate/faqs.html#what-is-a-project-or-file-generator).Update your projects generated from [`cookiecutter`](https://github.com/cookiecutter/cookiecutter)
and [`copier`](https://github.com/copier-org/copier) and compose projects
from multiple templates.### Features
- [**Update template outputs**](https://nickderobertis.github.io/flexlate/tutorial/updating.html)
after there are changes to the template
- When there is a conflict, it creates a
[Git merge conflict](https://nickderobertis.github.io/flexlate/core-concepts.html#real-merge-conflicts)
so that you can resolve it with your favorite tooling
- It keeps a history of the conflict resolution so you are not resolving
the same conflicts repeatedly
- Use [pre-built Github Actions](https://nickderobertis.github.io/flexlate/core-concepts.html#ci-workflows)
to automatically get a PR in your project after
the template has been updated
- **Compose a project** with multiple templates
- [Add template sources and then you can apply outputs](https://nickderobertis.github.io/flexlate/tutorial/get-started/add-to-project.html)
anywhere with a simple
CLI command
- **[Use your existing templates](https://nickderobertis.github.io/flexlate/faqs.html#what-templates-can-i-use-what-projects-can-i-generate-with-flexlate)**:
both [`cookiecutter`](https://github.com/cookiecutter/cookiecutter)
and [`copier`](https://github.com/copier-org/copier) templates are supported
- [Works with both local and remote templates](https://nickderobertis.github.io/flexlate/core-concepts.html#local-and-remote-template-sources).
You can even keep a template
in your project and be able to update outputs whenever it changes
- **Apply it to your existing projects** with [a `bootstrap` functionality](https://nickderobertis.github.io/flexlate/tutorial/get-started/existing-project.html)
- **Update your projects automatically on CI** with [official Github Actions](https://nickderobertis.github.io/flexlate/core-concepts.html#ci-workflows)
- (planned) **Use flexlate projects as templates themselves**, enabling nested templates
and sharing data across templates
- (planned) **Allow multiple templates to coordinate on specific files** in arbitrary
ways, e.g. think about applying a template and it adds its required packages
to `package.json` in a JS project### Use Cases
- You want to create or already have projects that are generated from a `cookiecutter`
or `copier` template, and keep those projects up to date with changes in the template
- You want to create a project from standard building blocks that can also be
updated systematically. For example think of something like a React component
with tests, a Java class and tests, or any set of files you want to generate### Locally or Remote With a Team
In either case, you can use Flexlate 100% locally even on a team project
without anyone else knowing you are using it via
[the `user` mode](https://nickderobertis.github.io/flexlate/core-concepts.html#project-and-user-configuration).But Flexlate really shines when you embrace it fully and include it in
your remote repo. This enables you [use CI](https://nickderobertis.github.io/flexlate/core-concepts.html#ci-workflows)
to automatically open PRs with
template updates and merge Flexlate branches.### Why Flexlate?
Flexlate is born out of frustration with using project generator templates.
You generate your project from a template, but later update the template
and need to bring the changes back to your project. There are only a
few tools for this and they do not have a great developer experience.
Flexlate is [Git-native](https://nickderobertis.github.io/flexlate/core-concepts.html#git-native),
so you resolve template conflicts in Git as you would any
other merge conflicts.Further, there is not really any ability to compose a project template from
smaller templates with any existing tools.Check out a [much more detailed explanation and story](https://nickderobertis.github.io/flexlate/faqs.html#why-create-flexlate)
as well as a
[comparison to other tools](https://nickderobertis.github.io/flexlate/faqs.html#existing-tools-to-update-applied-templates).### How does it Work?
Flexlate is [Git-native](https://nickderobertis.github.io/flexlate/core-concepts.html#git-native):
it carries out all its operations via commits to
[Git branches](https://nickderobertis.github.io/flexlate/core-concepts.html#branches-for-flexlate-operations).
It maintains two branches, one that contains the history of
the template output and the other than contains the merged output between
your project and the template. This means that you resolve any conflicts
with the template changes in Git and the merge conflict resolution is stored
in the output branch.It enables composability by using [config files](https://nickderobertis.github.io/flexlate/core-concepts.html#flexlate-json)
to keep track of where
multiple templates should be rendered and with what data.[Learn more about Flexlate core concepts here.](https://nickderobertis.github.io/flexlate/core-concepts.html)
## Getting Started
### Documentation
Visit the [documentation](https://nickderobertis.github.io/flexlate/) for
more detail on getting started. Start by learning about
[Flexlate core concepts](https://nickderobertis.github.io/flexlate/core-concepts.html)
before reading the [user guide](https://nickderobertis.github.io/flexlate/tutorial/index.html),
which contains more detailed information on
[getting started](https://nickderobertis.github.io/flexlate/tutorial/get-started/index.html).Or, you can keep reading this high-level overview for abbreviated
getting started steps.### Installing
Flexlate is a Python package that includes the `fxt` command line utility.
If you do not have Python, you will need to [install it](https://www.python.org/downloads/)
first (required version is `>=3.8`).The recommended way to install Flexlate is with [`pipx`](https://github.com/pypa/pipx),
though it can also be installed with `pip`.```
pipx install flexlate
```Or, if you don't have/don't want to install `pipx`:
```
pip install flexlate
```Before using Flexlate, you will also need to have
[Git installed](https://git-scm.com/book/en/v2/Getting-Started-Installing-Git).See the [install guide](https://nickderobertis.github.io/flexlate/tutorial/get-started/installing.html)
for more information.### First Steps
Your first steps will depend on what you are trying to accomplish.
See the ["Next Steps" section of the installing guide](https://nickderobertis.github.io/flexlate/tutorial/get-started/installing.html#next-steps)
for more information.#### New Project from a Template
To generate a new project from a template, use
[`init-from`](https://nickderobertis.github.io/flexlate/commands.html#fxt-init-from),
e.g.:```shell
fxt init-from https://github.com/nickderobertis/copier-pypi-sphinx-flexlate
```See the user guide on [creating a new project](https://nickderobertis.github.io/flexlate/tutorial/get-started/new-project.html)
for more information.#### Existing Project from a Template
To add Flexlate to your project that is already generated from a `cookiecutter`
or `cruft` template, use
[`bootstrap`](https://nickderobertis.github.io/flexlate/commands.html#fxt-bootstrap),
e.g.:```shell
fxt bootstrap https://github.com/nickderobertis/copier-pypi-sphinx-flexlate
```See the user guide on [adding Flexlate to an existing project from a template](https://nickderobertis.github.io/flexlate/tutorial/get-started/existing-project.html)
for more information.#### Compose a Project from Multiple Templates
You can
[add a template source](https://nickderobertis.github.io/flexlate/commands.html#fxt-add-source)
and then [add as many outputs from that source](https://nickderobertis.github.io/flexlate/commands.html#fxt-add-output)
as you want.Before you can do this, you must
[initialize a Flexlate project](https://nickderobertis.github.io/flexlate/commands.html#fxt-init):```shell
fxt init
```Then you can add the template source:
```shell
fxt add source https://github.com/nickderobertis/copier-pypi-sphinx-flexlate
```Then you can apply the output anywhere in the project:
```shell
fxt add output copier-pypi-sphinx-flexlate
```See the user guide on [adding templates within an existing project](https://nickderobertis.github.io/flexlate/tutorial/get-started/add-to-project.html)
for more information.### Updating a Template
See the user guide on [updating a template](https://nickderobertis.github.io/flexlate/tutorial/updating.html)
for more information, but here's some quick info.#### Re-prompt Questions
Once you have updates in the template that you want to bring to your project,
use [the update command](https://nickderobertis.github.io/flexlate/commands.html#fxt-update):```shell
fxt update
```This will prompt for all the questions again, using your previous answers
as defaults. If there are new questions from the update, or if you want
to change any of the answers, you should follow this flow.#### No Question Prompts
If instead you
know that there are only changes in the outputs and not questions/answers,
you can pass `--no-input` or `-n` to skip the questions:```shell
fxt update -n
```#### Saving your Work
See the user guide on [saving Flexlate updates](https://nickderobertis.github.io/flexlate/tutorial/saving.html)
for more information, but here's some quick info.##### Local Repo Flows
If you are following a local repo flow, then you can use the
[`fxt merge`](https://nickderobertis.github.io/flexlate/commands.html#fxt-merge) command
to merge the Flexlate feature branches into the Flexlate main branches. If
you are using a feature-branch flow, then you would want to run `fxt merge` just
before merging your feature branch into the main branch. If you are simply
commititng to the main branch, just run `fxt merge` after any Flexlate command.##### Remote Repo/PR Flows
If you are merging PRs in your repo rather than following a local flow, then
you will want to
[`fxt push feature`](https://nickderobertis.github.io/flexlate/commands.html#fxt-push-feature)
just before/after your push your feature branch
and open a PR. If you use the official Flexlate Github Merge Action,
the Flexlate branches will be merged automatically after the PR is merged.### Get Help
You can run `--help` on the end of any command to see documentation.
You will see similar output to what is in the
[command reference](https://nickderobertis.github.io/flexlate/commands.html).```shell
$ fxt --help
Usage: fxt [OPTIONS] COMMAND [ARGS]...fxt is a CLI tool to manage project and file generator templates.
[See the Flexlate documentation](
https://nickderobertis.github.io/flexlate/ ) for more information.Options:
-v, --version Show Flexlate version and exit
--install-completion Install completion for the current shell.
--show-completion Show completion for the current shell, to copy it or
customize the installation.--help Show this message and exit.
Commands:
add Add template sources and generate new projects and files from...
bootstrap Sets up a Flexlate project from an existing project that was...
check Checks whether there are any updates available for the current...
config Modify Flexlate configs via CLI
init Initializes a flexlate project.
init-from Generates a project from a template and sets it up as a...
merge Merges feature flexlate branches into the main flexlate...
push Push Flexlate branches to remote repositories.
remove Remove template sources and previously generated outputs
sync Syncs manual changes to the flexlate branches, and updates...
undo Undoes the last flexlate operation, like ctrl/cmd + z for...
update Updates applied templates in the project to the newest
versions...
```Please raise an issue if anything is confusing or does not work properly.
See a
[more in-depth tutorial here.](
https://nickderobertis.github.io/flexlate/tutorial/
)## Development Status
This project is currently in early-stage development. There may be
breaking changes often. While the major version is 0, minor version
upgrades will often have breaking changes.## Developing
First ensure that you have `pipx` installed, if not, install it with `pip install pipx`.
Then clone the repo and run `npm install` and `pipenv sync`. Run `pipenv shell`
to use the virtual environment. Make your changes and then run `nox` to run formatting,
linting, and tests.Develop documentation by running `nox -s docs` to start up a dev server.
To run tests only, run `nox -s test`. You can pass additional arguments to pytest
by adding them after `--`, e.g. `nox -s test -- -k test_something`.## Author
Created by Nick DeRobertis. MIT License.
## Links
See the
[documentation here.](
https://nickderobertis.github.io/flexlate/
)