Skip to main content

Tools and git hooks to make it easier to work with submodules that are updated frequently.

Project description

pre-commit Ruff image Downloads image


alt text

Git Submodule Flow (smflow) is a lightweight toolset and set of Git hooks designed to make working with Git submodules significantly easier. It helps keep submodules in sync with the parent repository, enabling a "virtual monorepo" workflow — without giving up the benefits of repository modularity.
Report Bug · Request Feature


🚀 Features

  • Intuitively work with submodules through VS Code git interface.
  • Automatically attaches submodule HEADs to the commits referenced by the parent repository.
  • Quickly see how many changes the current submodule is behind the tracked branch.
  • Correctly set local submodules when switching branches in the parent project.
  • Automatically update .gitmodules in parent when changing locally checking out branches for submodules.

📦 Installation

Note: Requires uv to be installed.

Install smflow with:

uv tool install smflow

🛠️ Usage

From the root of your parent repository (the one that contains submodules), run:

smflow init

This will configure your repository with the appropriate Git settings and install the necessary hooks.

For help and available commands, run: smflow --help:

usage: smflow [-h]
              {init,install-hooks,configure-git,attach-heads,sync-from-local}
              ...

Make the flow of working with Git submodules smoother.

positional arguments:
  {init,install-hooks,configure-git,attach-heads,sync-from-local}
                        command to run
    init                Setup all functionality of smflow.
    install-hooks       Installs the githooks.
    configure-git       Configures some ergonomic settings for git submodules
                        in local `.gitconfig`.
    attach-heads        Attaches the head of the submodules to the branch and
                        reset to the commit-sha.
    sync-from-local     Updates .gitmodules from local file state.

options:
  -h, --help            show this help message and exit

🔍 What smflow init Does

🔗 Git Hooks

The following hooks will be installed:

  • Post-checkout hook parent: Automatically attaches to branch and resets submodules to the correct commit when you checkout a branch in the parent repository.
  • Post-Checkout hook submodules: Updates .gitmodules when you switch between branches in the children, ensuring easy updates.

⚙️ Git Configuration

smflow sets these recommended Git config values:

git config submodule.recurse true

Ensures submodules are automatically checked out when switching branches.

git config push.recurseSubmodules on-demand

Allows pushing submodule commits automatically when pushing the parent repository — if the submodules and parent share the same branch name. If not, Git will warn and suggest pushing submodules first.

⚠️ Limitations

  • smflow does not currently support recursive submodules, i.e. submodules within submodules.

🧩 Why smflow?

Managing submodules manually is tedious and error-prone. smflow minimizes the overhead and makes it easier to:

  • Stay in sync with your team
  • Avoid detached HEAD states in submodules
  • Prevent pushing parent branches that reference unpublished submodule commits

Whether you’re working with multiple shared libraries or simply trying to tame Git submodules, smflow provides a smoother, safer workflow.

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

smflow-0.3.8.tar.gz (3.7 MB view details)

Uploaded Source

Built Distribution

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

smflow-0.3.8-py3-none-any.whl (11.4 kB view details)

Uploaded Python 3

File details

Details for the file smflow-0.3.8.tar.gz.

File metadata

  • Download URL: smflow-0.3.8.tar.gz
  • Upload date:
  • Size: 3.7 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.7.8

File hashes

Hashes for smflow-0.3.8.tar.gz
Algorithm Hash digest
SHA256 c2b9dfece4960c412f56f838303dce592139e812516f4bc7b95fe18c7fefddc8
MD5 4efdbb74738ec51268f210dd7665fcc1
BLAKE2b-256 86e954718ed12b7ecea79d0fbc31693102d0119d2eb0ba104b5507d23ec68453

See more details on using hashes here.

File details

Details for the file smflow-0.3.8-py3-none-any.whl.

File metadata

  • Download URL: smflow-0.3.8-py3-none-any.whl
  • Upload date:
  • Size: 11.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.7.8

File hashes

Hashes for smflow-0.3.8-py3-none-any.whl
Algorithm Hash digest
SHA256 0a6bb176c7145cec40467be17b0c4ee73ab1810efe42530776c05a1c072ddd40
MD5 9a2943911c0a8519f16035bef98ac1e3
BLAKE2b-256 cd83d20bbf20c5aaf1b73588291d406c2af028dea3411159815ef3913c0a39ad

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