Automates the generation of project files and templates for repositories (and others) based on customizable YAML configurations
- Template Generation π: Generates files from templates for consistent repository setup.
- YAML Configuration βοΈ: Easy-to-define templates and file structures in YAML format.
- Repository Customization π: Unique configurations using a "mixin" approach for each repository.
- Content Flexibility βοΈ: Supports external template files, direct content in YAML, and files from URLs.
- Robust Validation π: Ensures configuration integrity with comprehensive validation checks before processing.
- Selective Processing π―: Processes a single or multiple repositories as needed.
- Clean Output π§Ή: Clears existing output directories for up-to-date content generation.
You can download the latest release of structuresmith with this one-liner on MacOS / Linux (amd64 + arm64):
wget -O- "https://github.com/cbrgm/structuresmith/releases/latest/download/structuresmith_$(uname -s)_$(uname -m).tar.gz" | tar -xz -C .
You may also download the latest pre-compiled binaries from the GitHub releases page or build structuresmith
from source using Go
(1.21+):
make build
After installing, you can run Structuresmith with the following command-line arguments:
structuresmith --config path/to/config.yaml --output output/directory --templates path/to/templates
-c
,--config
: Path to the YAML configuration file.-o
,--output
: Output path prefix for generated files. (default:./out
)-t
,--templates
: Directory for template files. (default:./templates
)-r
,--repo
: Specify a single repository to process.-p
,--max-parallel
: Maximum number of repositories to process in parallel. (default:5
)
Please take a look at the sample configuration.yml in this repository and check out the template directoy.
# Define template groups with a set of files
templateGroups:
# Group for common git files like .gitignore and LICENSE
commonGitFiles:
- filename: ".gitignore"
sourceFile: "gitignore.tmpl" # Template for .gitignore file
- filename: "LICENSE"
sourceFile: "license.tmpl" # Template for LICENSE file
- filename: ".img/logo.png" # Also supports binary or non-text copies
sourceFile: "logo.png"
# Also supports downloading text and non-text / binary files from (accessible) URLs
# You may also add values here used for templating after downloading the artifact
- filename: "Dockerfile"
sourceUrl: "https://raw.githubusercontent.com/cbrgm/promcheck/main/Dockerfile"
- filename: "archive.tar.gz"
sourceUrl: "https://github.com/cbrgm/promcheck/releases/download/v1.1.8/promcheck_darwin_amd64.tar.gz"
# Group for Go-specific files like .golangci.yml
goSpecificFiles:
- filename: ".golangci.yml"
sourceFile: "golangci.tmpl" # Template for .golangci.yml
values:
golangciVersion: "1.54.x"
# List of repositories / projects to apply the template groups
repositories:
# First repository configuration
- name: "example/repo1" # This will create a subdirectory ./out/example/repo1/
groups:
- groupName: "commonGitFiles" # Referencing commonGitFiles group
values:
Author: "Author Name" # Values to substitute in templates
Year: "2023"
- groupName: "goSpecificFiles" # Referencing goSpecificFiles group
# Second repository configuration
- name: "example/repo2"
groups:
- groupName: "commonGitFiles"
values:
Author: "Chris Bargmann"
Year: "2023"
# Third repository with individual files but no groups
- name: "some-project" # This will create a subdirectory ./out/some-project/
files:
- filename: "README.md"
content: |
# Welcome to example/repo3
This repository contains various examples.
# Inline content is used here instead of a template file
- filename: "config.json"
content: |
{
"version": "1.0",
"description": "Configuration file for example/repo3"
}
To get you started: A minimal configuration with all file content in yaml
may look like this:
repositories:
- name: "some-project"
files:
- filename: "README.md"
content: |
# Welcome to some-project, {{ .user }}!
This repository contains various examples.
values:
user: "Bob"
- filename: "config.json"
content: |
{
"version": "1.0",
"description": "Configuration file for some-project"
}
Render all files to ./out/some-project/
:
structuresmith --config ./examples/configuration-simple.yml
Please help us adding more examples.
When Structuresmith generates files, it creates an output directory structure that mirrors the structure defined in your YAML configuration. For each repository, a separate folder is created within the specified output directory.
Structuresmith leverages Go's powerful templating system, allowing you to define dynamic content in your templates. This system provides a flexible way to insert values into your files, making your templates adaptable to different contexts.
- Placeholders: In your templates, you can use placeholders in the form
{{ .VariableName }}
to insert values dynamically. These placeholders will be replaced with actual values when the template is processed. - YAML Configuration: Define the values for these placeholders in the YAML configuration under the
values
key for each template group or individual file. - Example: If your template contains
{{ .Author }}
, you can specify the author's name in the YAML configuration, and it will be replaced in the generated file.
- Structuresmith uses Go's
text/template
package syntax. This includes conditional statements, range loops, and more, providing a rich set of features for creating complex templates. - For detailed information on Go's templating syntax, visit the official documentation: Go's text/template package
Feel free to submit changes! See the Contributing Guide. This project is open-source and is developed under the terms of the Apache 2.0 License.