Skip to main content

BoilerSync

Project description

BoilerSync CLI

boilersync scaffolds projects from templates and keeps templates alive as projects evolve.

BoilerSync Ensemble

BoilerSync works as a small ensemble of tools:

  • boilersync-cli for scaffold, pull, and push workflows.
  • boilersync-desktop for repository diff review, staging, commit, and push workflows.
  • Editor integration (Cursor/VS Code extension workflows) for fast editing and context switching.

For the full workflow guide, read docs/ensemble.md. For template metadata reference, read docs/template-metadata.md.

Quick Start

# 1) Clone a template source into your local BoilerSync cache
boilersync templates init https://github.com/your-org/your-templates.git

# 2) Initialize a project from a source-qualified template ref
boilersync init your-org/your-templates#python/service-template

# Well-defaulted templates can be initialized without prompts
mkdir my-app-workspace
cd my-app-workspace
boilersync init your-org/your-templates#python/service-template --non-interactive

# 3) Pull template updates into the current project when needed
boilersync pull

# 4) Push committed project changes back into the template source
boilersync push

Command Overview

  • boilersync init TEMPLATE_REF: create a project from a template (empty target directory).
  • boilersync init TEMPLATE_REF --non-interactive: create a project without prompts when defaults and automatic values cover all inputs.
  • boilersync check-pull: compare the project's recorded template repo commit against the current cached template repo HEAD.
  • boilersync pull [TEMPLATE_REF]: apply template updates to an existing project.
  • boilersync push: review and copy committed project changes back to the template.
  • boilersync templates init: clone a template source repository into the local cache.

Use command help for full flags:

boilersync --help
boilersync init --help
boilersync check-pull --help
boilersync pull --help
boilersync push --help
boilersync templates --help

Template References

Template commands accept:

  • org/repo#path/to/template
  • https://github.com/org/repo#path/to/template
  • https://github.com/org/repo.git#path/to/template

GitHub is the only supported host for source-qualified template refs.

Source-qualified refs clone (if missing) into:

${BOILERSYNC_TEMPLATE_DIR:-~/.boilersync/templates}/<org>/<repo>

Project Tracking

After scaffold or pull, BoilerSync writes .boilersync metadata in the project root so future pull/push operations can resolve the original template source. That metadata now includes the last pulled template repo commit so boilersync check-pull can tell whether the project is behind template HEAD. For the field-by-field schema and validation rules, see docs/project-metadata.md.

Template Conventions

  • Files ending in .boilersync are rendered and emitted without that extension.
  • Files with .starter as the first extension are starter-only files.
  • Every template root must include template.json, which supports inheritance (extends/parent), defaults, child templates, hooks, and optional GitHub repo creation.
  • Project naming is provided through standard template variables such as name_snake and name_pretty.
  • template.json defaults can derive variables from naming values, such as "api_package_name": "$${name_snake}_api" or "web_package_name": "$${name_kebab}-web".
  • Default project-name inference strips a trailing -workspace / _workspace suffix from the target directory name.
  • If a template references github_user, BoilerSync tries to populate it with gh api user --jq .login before prompting or failing in non-interactive mode.

Documentation Policy

This repository intentionally avoids hand-written API reference docs. If API docs are ever included, they should be generated and linked from this README.

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

boilersync-1.2.15.tar.gz (51.0 kB view details)

Uploaded Source

Built Distribution

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

boilersync-1.2.15-py3-none-any.whl (40.1 kB view details)

Uploaded Python 3

File details

Details for the file boilersync-1.2.15.tar.gz.

File metadata

  • Download URL: boilersync-1.2.15.tar.gz
  • Upload date:
  • Size: 51.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for boilersync-1.2.15.tar.gz
Algorithm Hash digest
SHA256 5b8d9356b390b0fb6091a7cfac79dcf357b35e45d2d0a0bd5c737a6b8505a444
MD5 aaf41b5ea29d83727f8e6a8bbb293078
BLAKE2b-256 4764d2e84b3e3804036b239a9d3edf8b93272e1828555ad2f5184477dfc9311e

See more details on using hashes here.

File details

Details for the file boilersync-1.2.15-py3-none-any.whl.

File metadata

  • Download URL: boilersync-1.2.15-py3-none-any.whl
  • Upload date:
  • Size: 40.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.15

File hashes

Hashes for boilersync-1.2.15-py3-none-any.whl
Algorithm Hash digest
SHA256 8891cc76f79962dd3fbdcbe28b8fdeab18137dd6f45b0db603c4165f9c8256df
MD5 afc6f2bf9e4972293d0db3cc33ae7f7b
BLAKE2b-256 c443b5eba033d106936a0380ee39ffe259933d65210fcca809f40b555b5004e8

See more details on using hashes here.

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