Skip to main content

Jinja2 filter extension for detecting if a directory is a git repository

Project description

Git Directory Extension

Jinja2 filter extension for detecting if a directory is an (empty) git repository and determining the default branch.

Usage

gitdir

Detects if the path being filtered by gitdir is the top level git repository directory.

So, if my path is /git/path/here and there exists /git/path/here/.git, then {{ '/git/path/here' | gitdir }} will be true.

However, if my path is /git/path/here and there exists /git/path/.git, then {{ '/git/path/here' | gitdir }} will be false.

This is because the top level directory is /git/path, not the tested path of /git/path/here.

Examples:

  • Detect if git_path is a git directory
    {{ git_path | gitdir }}
  • Assert that git_path is a git directory
    {{ git_path | gitdir is true }}
  • Assert that git_path is NOT a git directory
    {{ git_path | gitdir is false }}
  • Using gitdir in a conditional
    {% if (git_path | gitdir) %}{{ git_path }} is a git directory{% else %}no git directory at {{ git_path }}{% endif %}

emptygit

Detects if the path being filtered by emptygit contains exactly 0 commits across all references. This will work for subdirectories within a git directory.

So, if my path is /git/path/here and there have been no commits, then {{ '/git/path/here' | emptygit }} will be true.

However, if my path is /git/path/here and there have been any commits anywhere, then {{ '/git/path/here' | emptygit }} will be false.

Examples:

  • Detect if git_path is an empty git directory
    {{ git_path | emptygit }}
  • Assert that git_path is an empty git directory
    {{ git_path | emptygit is true }}
  • Assert that git_path is NOT an empty git directory
    {{ git_path | emptygit is false }}
  • Using emptygit in a conditional
    {% if (git_path | emptygit) %}{{ git_path }} has commits{% else %}{{ git_path }} has NO commits{% endif %}

gitdefaultbranch

Returns the default branch name for the git repository at the given path. Uses a multi-layered fallback cascade to determine the default branch:

  1. git symbolic-ref refs/remotes/upstream/HEAD (local, fast)
  2. git symbolic-ref refs/remotes/origin/HEAD (local, fast)
  3. git ls-remote --symref upstream HEAD (network, read-only)
  4. git ls-remote --symref origin HEAD (network, read-only)
  5. git config init.defaultBranch (local config)
  6. Hardcoded fallback: main

Returns an empty string if the path is not a git repository.

Examples:

  • Get the default branch name {{ git_path | gitdefaultbranch }}
  • Using gitdefaultbranch in a conditional {% if (git_path | gitdefaultbranch) %}default branch: {{ git_path | gitdefaultbranch }}{% endif %}

Copier

This can be utilized within a Copier copier.yaml file for determining if the destination path is already initialized as a git directory.

Example:

This will configure a Copier _task to run git init but only if the destination path isn't already a git directory.

_jinja_extensions:
    - jinja2_git_dir.GitDirectoryExtension
_tasks:
  - command: "git init"
    when: "{{ _copier_conf.dst_path | realpath | gitdir is false }}"
  # ORDERING: `emptygit is false` test must come first, otherwise both tasks trigger
  - command: "git commit -am 'template update applied'"
    when: "{{ _copier_conf.dst_path | realpath | emptygit is false }}"
  - command: "git commit -am 'initial commit'"
    when: "{{ _copier_conf.dst_path | realpath | emptygit is true }}"

Development

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

jinja2_git_dir-0.5.0.tar.gz (4.6 kB view details)

Uploaded Source

Built Distribution

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

jinja2_git_dir-0.5.0-py3-none-any.whl (5.4 kB view details)

Uploaded Python 3

File details

Details for the file jinja2_git_dir-0.5.0.tar.gz.

File metadata

  • Download URL: jinja2_git_dir-0.5.0.tar.gz
  • Upload date:
  • Size: 4.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for jinja2_git_dir-0.5.0.tar.gz
Algorithm Hash digest
SHA256 04b0129059a58fa7572f95ad626ce152349fee0f86eb0be30c3f6c7b7b4ea529
MD5 de564a6c4663f62b74dacbb4b99d9125
BLAKE2b-256 25d5456e8a84d64ca8e29432909e3932a8f5a34fc65e0be7e852d4573154f335

See more details on using hashes here.

Provenance

The following attestation bundles were made for jinja2_git_dir-0.5.0.tar.gz:

Publisher: publish.yaml on gordon-code/jinja2-git-dir

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file jinja2_git_dir-0.5.0-py3-none-any.whl.

File metadata

  • Download URL: jinja2_git_dir-0.5.0-py3-none-any.whl
  • Upload date:
  • Size: 5.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for jinja2_git_dir-0.5.0-py3-none-any.whl
Algorithm Hash digest
SHA256 2186011255f1ee9763dd46165abcc2fecbbfc4fbde0e6c63b00ab3efca253a51
MD5 6a9a624a65d8aeecdb36094e0bb9f4a5
BLAKE2b-256 bfdb5559919247aacd3b7c6d5dfb30ce749b4693f444ba4fc19a358c1d1c76bc

See more details on using hashes here.

Provenance

The following attestation bundles were made for jinja2_git_dir-0.5.0-py3-none-any.whl:

Publisher: publish.yaml on gordon-code/jinja2-git-dir

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

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