Skip to main content

Extended support for git-submodule and git-sparse-checkout

Project description

git-fleximod

Flexible Submodule Management for Git

Overview

Git-fleximod is a Python-based tool that extends Git's submodule capabilities, offering additional features for managing submodules in a more flexible and efficient way.

Installation

#TODO Install using pip:

pip install git-fleximod

If you choose to locate git-fleximod in your path you can access it via command: git fleximod

Usage

Basic Usage:
    git fleximod <command> [options]
Available Commands:
    install: Install submodules according to configuration.
    status: Display the status of submodules.
    update: Update submodules to the tag indicated in .gitmodules variable fxtag.
Additional Options:
    See git fleximod --help for more details.

Supported .gitmodules Variables

fxtag: Specify a specific tag or branch to checkout for a submodule.
fxrequired: Mark a submodule's checkout behavior, with allowed values:
  - T:T: Top-level and required (checked out only when this is the Toplevel module).
  - T:F: Top-level and optional (checked out with --optional flag if this is the Toplevel module).
  - I:T: Internal and required (always checked out).
  - I:F: Internal and optional (checked out with --optional flag).
fxsparse: Enable sparse checkout for a submodule, pointing to a file containing sparse checkout paths.

Sparse Checkouts

To enable sparse checkout for a submodule, set the fxsparse variable
in the .gitmodules file to the path of a file containing the desired
sparse checkout paths. Git-fleximod will automatically configure
sparse checkout based on this file when applicable commands are run.
See [git-sparse-checkout](https://git-scm.com/docs/git-sparse-checkout#_internalsfull_pattern_set) for details on the format of this file.

Examples

Here are some common usage examples:

Installing submodules, including optional ones:

  git fleximod install --optional

Updating a specific submodule to the fxtag indicated in .gitmodules:

    git fleximod update submodule-name

Example .gitmodules entry:

    [submodule "cosp2"]
        path = src/physics/cosp2/src
        url = https://github.com/CFMIP/COSPv2.0
        fxsparse = ../.cosp_sparse_checkout
        fxtag = v2.1.4cesm

Explanation:

This entry indicates that the submodule named cosp2 at tag v2.1.4cesm should be checked out into the directory src/physics/cosp2/src relative to the .gitmodules directory. It should be checked out from the URL https://github.com/CFMIP/COSPv2.0 and use sparse checkout as described in the file ../.cosp_sparse_checkout relative to the path directory.

Additional example:

    [submodule "cime"]
        path = cime
        url = https://github.com/jedwards4b/cime
        fxrequired = T:T
        fxtag = cime6.0.198_rme01

Explanation:

This entry indicates that the submodule cime should be checked out into a directory named cime at tag cime6.0.198_rme01 from the URL https://github.com/jedwards4b/cime. This should only be done if the .gitmodules file is at the top level of the repository clone.

Contributing

We welcome contributions! Please see the CONTRIBUTING.md file for guidelines.

License

Git-fleximod is released under the MIT License.

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

fleximod-0.1.8.tar.gz (12.8 kB view details)

Uploaded Source

Built Distribution

fleximod-0.1.8-py3-none-any.whl (14.0 kB view details)

Uploaded Python 3

File details

Details for the file fleximod-0.1.8.tar.gz.

File metadata

  • Download URL: fleximod-0.1.8.tar.gz
  • Upload date:
  • Size: 12.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.12

File hashes

Hashes for fleximod-0.1.8.tar.gz
Algorithm Hash digest
SHA256 1ccf695f2270325274ccc9a2912f1e995647ab348fbe72ced0e8f2ed73cd481d
MD5 4615a39fe368bbd602db72062fc584c9
BLAKE2b-256 829de2ee70a03be7ec75f956b100479e0d697b160809edc0cb405f1d71c59b1c

See more details on using hashes here.

File details

Details for the file fleximod-0.1.8-py3-none-any.whl.

File metadata

  • Download URL: fleximod-0.1.8-py3-none-any.whl
  • Upload date:
  • Size: 14.0 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.12

File hashes

Hashes for fleximod-0.1.8-py3-none-any.whl
Algorithm Hash digest
SHA256 319a469d0c906f6926819a4bb6cb7d685220d91babb81a067480d4911857e14c
MD5 5051e86256f96ca3c9b0c1cb3a894d04
BLAKE2b-256 e271b75feb0c7a4673da22fb1f58054956eff022775bfa08460dbe526bb5f6f4

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page