Name |
Last commit
|
Last update |
---|---|---|
.. | ||
add.c | ||
init.c | ||
lookup.c | ||
modify.c | ||
nosubs.c | ||
open.c | ||
repository_init.c | ||
status.c | ||
submodule_helpers.c | ||
submodule_helpers.h | ||
update.c |
To determine if a repository is a worktree or not, we currently check for the existence of a "gitdir" file inside of the repository's gitdir. While this is sufficient for non-broken repositories, we have at least one case of a subtly broken repository where there exists a gitdir file inside of a gitmodule. This will cause us to misidentify the submodule as a worktree. While this is not really a fault of ours, we can do better here by observing that a repository can only ever be a worktree iff its common directory and dotgit directory are different. This allows us to make our check whether a repo is a worktree or not more strict by doing a simple string comparison of these two directories. This will also allow us to do the right thing in the above case of a broken repository, as for submodules these directories will be the same. At the same time, this allows us to skip the `stat` check for the "gitdir" file for most repositories.
Name |
Last commit
|
Last update |
---|---|---|
.. | ||
add.c | Loading commit data... | |
init.c | Loading commit data... | |
lookup.c | Loading commit data... | |
modify.c | Loading commit data... | |
nosubs.c | Loading commit data... | |
open.c | Loading commit data... | |
repository_init.c | Loading commit data... | |
status.c | Loading commit data... | |
submodule_helpers.c | Loading commit data... | |
submodule_helpers.h | Loading commit data... | |
update.c | Loading commit data... |