How to use `git-deps` ======================= Usage is fairly self-explanatory if you run `git deps -h`: ``` usage: git-deps [options] COMMIT-ISH [COMMIT-ISH...] Auto-detects commits on which the given commit(s) depend. optional arguments: -h, --help Show this help message and exit -v, --version show program's version number and exit -l, --log Show commit logs for calculated dependencies -j, --json Output dependencies as JSON -s, --serve Run a web server for visualizing the dependency graph -b IP, --bind-ip IP IP address for webserver to bind to [127.0.0.1] -p PORT, --port PORT Port number for webserver [5000] -r, --recurse Follow dependencies recursively -e COMMITISH, --exclude-commits COMMITISH Exclude commits which are ancestors of the given COMMITISH (can be repeated) -c NUM, --context-lines NUM Number of lines of diff context to use [1] -d, --debug Show debugging ``` Currently you should run it from the root (i.e. top directory) of the git repository you want to examine; this is a [known limitation](https://github.com/aspiers/git-deps/issues/27). By default it will output the SHA1s of all dependencies of the given commit-ish(s), one per line. With `--recurse`, it will traverse dependencies of dependencies, and so on until it cannot find any more. In recursion mode, two SHA1s are output per line, indicating that the first depends on the second. Web UI for visualizing and navigating the dependency graph ---------------------------------------------------------- If you run it with the `--serve` option and no COMMIT-ISH parameters, then it will start a lightweight webserver and output a URL you can connect to for dynamically visualizing and navigating the dependency graph. Optionally choose a commit-ish (the form defaults to `master`), click the `Submit` button, and you should see a graph appear with one node per commit. By hovering the mouse over a node you will see more details, and a little `+` icon will appear which can be clicked to calculate dependencies of that commit, further growing the dependency tree. You can zoom in and out with the mousewheel, and drag the background to pan around. If you set up a MIME handler for the `gitfile://` protocol during setup, [as documented](INSTALL.md) you will be able to double-click on nodes to launch a viewer to inspect individual commits in more detail.