Skip to main content

Generates the DAG of a git repository

Project description

Generates the DAG of a git repository

Install

  • pip install git-dag

Getting help

  • git dag -h to display help
usage: git-dag [-h] [-p PATH] [-f FILE] [-b {graphviz}] [--format FORMAT]
               [--dpi DPI] [-i INIT_REFS [INIT_REFS ...]]
               [-R RANGE [RANGE ...]] [-n MAX_NUMB_COMMITS]
               [--rankdir RANKDIR] [--bgcolor BGCOLOR] [-u] [-t] [-D] [-l]
               [-r] [-s] [-H] [-T] [-B]
               [--commit-message COMMIT_MESSAGE_AS_LABEL] [-o]
               [--log-level {NOTSET,INFO,WARNING,ERROR,CRITICAL}]

Visualize the git DAG.

options:
  -h, --help            show this help message and exit
  -p, --path PATH       Path to git repository.
  -f, --file FILE       Output graphviz file (could include a directory e.g.,
                        mydir/myfile).
  -b, --dag-backend {graphviz}
                        Backend DAG library.
  --format FORMAT       Graphviz output format (tooltips are available only
                        with svg). If the format is set to 'gv', only the
                        graphviz source file is generated
  --dpi DPI             DPI of output figure (used with --format png).
  -i, --init-refs INIT_REFS [INIT_REFS ...]
                        A list of branches, tags, objects' SHA (commits,
                        trees, blobs) that represents a limitation from where
                        to display the DAG
  -R, --range RANGE [RANGE ...]
                        A list to commits in a range to display.
  -n, --max-numb-commits MAX_NUMB_COMMITS
                        Max number of commits (set to 0 to remove limitation).
  --rankdir RANKDIR     rankdir argument of graphviz (LR, RL, TB, BT).
  --bgcolor BGCOLOR     bgcolor argument of graphviz (e.g., transparent).
  -u                    Show unreachable commits.
  -t                    Show tags.
  -D                    Show deleted annotated tags.
  -l                    Show local branches.
  -r                    Show remote branches.
  -s                    Show stash.
  -H                    Show head.
  -T                    Show trees (WARNING: should be used only with small
                        repositories).
  -B                    Show blobs (discarded if -T is not set).
  --commit-message COMMIT_MESSAGE_AS_LABEL
                        When greater than 0, this is the number of characters
                        from the commit message to use as a commit label. The
                        commit SHA is used otherwise.
  -o, --xdg-open        Open output SVG file with xdg-open.
  --log-level {NOTSET,INFO,WARNING,ERROR,CRITICAL}
                        Log level.

Examples

  • git dag -rlst -n 20 would generate git-dag.gv (a graphviz dot file) and git-dag.gv.svg with:

    • the 20 most recent commits (-n 20, use -n -1 to show all)
    • all local branches (-l)
    • all remote branches (-r)
    • the stash (-s)
    • all tags (-t)
  • displaying trees (-T) and blobs (-B) is recommended only for small(ish) repositories.

  • using -n 10 -i my-branch my-tag would display the 10 most recent commits accessible from my-branch or my-tag.

Default color-codes

object color name
commit ${\texttt{\color{#cdad00}gold3}}$
unreachable commit ${\texttt{\color{#ff8c00}darkorange}}$
tree ${\texttt{\color{#00688b}deepskyblue4}}$
the empty tree ${\texttt{\color{#00ced1}darkturquoise}}$
blob ${\texttt{\color{#bebebe}gray}}$
annotated tag ${\texttt{\color{#ffc0cb}pink}}$
deleted annotated tag ${\texttt{\color{#ffc0cb}rosybrown4}}$
lightweight tag ${\texttt{\color{#f08080}lightcoral}}$
local branch ${\texttt{\color{#228b22}forestgreen}}$
remote branch ${\texttt{\color{#b22222}firebrick}}$
stash ${\texttt{\color{#87ceeb}skyblue}}$
HEAD ${\texttt{\color{#6495ed}cornflowerblue}}$

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

git_dag-0.0.5.tar.gz (25.8 kB view details)

Uploaded Source

Built Distribution

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

git_dag-0.0.5-py3-none-any.whl (24.8 kB view details)

Uploaded Python 3

File details

Details for the file git_dag-0.0.5.tar.gz.

File metadata

  • Download URL: git_dag-0.0.5.tar.gz
  • Upload date:
  • Size: 25.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.1

File hashes

Hashes for git_dag-0.0.5.tar.gz
Algorithm Hash digest
SHA256 0d0723fcdf656949987f765f3a48556826ad29a43b299ac7c4962562912d0630
MD5 324c4450bcb89d38aac0c8517c5e38fc
BLAKE2b-256 cef37aceec8c7be81f587bdb1548afd64ed7a7bfb39f99184ba68fb646dc3662

See more details on using hashes here.

File details

Details for the file git_dag-0.0.5-py3-none-any.whl.

File metadata

  • Download URL: git_dag-0.0.5-py3-none-any.whl
  • Upload date:
  • Size: 24.8 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.13.1

File hashes

Hashes for git_dag-0.0.5-py3-none-any.whl
Algorithm Hash digest
SHA256 531275ef90b837fe0858697576938804e6ab444fb3c66b35609933e6ca9320ee
MD5 1f57f3577c58f0165f904f9ca03be953
BLAKE2b-256 728c9e35966bab5287572eaac50fb9e8367d4a282291f6b2e7ba8298588759ff

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