Kurze Lösungen, die mit Submodulen, in Hooks und innerhalb des .git
Verzeichnisses funktionieren
Hier ist die kurze Antwort, die die meisten wollen:
r=$(git rev-parse --git-dir) && r=$(cd "$r" && pwd)/ && echo "${r%%/.git/*}"
Dies funktioniert überall in einem Git-Arbeitsbaum (einschließlich innerhalb des .git
Verzeichnisses), setzt jedoch voraus, dass Repository-Verzeichnisse aufgerufen werden .git
(dies ist die Standardeinstellung). Bei Submodulen geht dies zum Stammverzeichnis des äußersten Repositorys.
Wenn Sie zum Stammverzeichnis des aktuellen Submoduls gelangen möchten, verwenden Sie:
echo $(r=$(git rev-parse --show-toplevel) && ([[ -n $r ]] && echo "$r" || (cd $(git rev-parse --git-dir)/.. && pwd) ))
Um einen Befehl in Ihrem Submodul-Stammverzeichnis einfach auszuführen , fügen Sie unter [alias]
in Folgendes .gitconfig
hinzu:
sh = "!f() { root=$(pwd)/ && cd ${root%%/.git/*} && git rev-parse && exec \"$@\"; }; f"
Dies ermöglicht es Ihnen, Dinge wie zu tun git sh ag <string>
Robuste Lösung, die unterschiedlich benannte oder externe .git
oder $GIT_DIR
Verzeichnisse unterstützt.
Beachten Sie, dass dies $GIT_DIR
möglicherweise auf eine externe Stelle verweist (und nicht aufgerufen werden kann .git
), weshalb weitere Überprüfungen erforderlich sind.
Setzen Sie dies in Ihre .bashrc
:
# Print the name of the git working tree's root directory
function git_root() {
local root first_commit
# git displays its own error if not in a repository
root=$(git rev-parse --show-toplevel) || return
if [[ -n $root ]]; then
echo $root
return
elif [[ $(git rev-parse --is-inside-git-dir) = true ]]; then
# We're inside the .git directory
# Store the commit id of the first commit to compare later
# It's possible that $GIT_DIR points somewhere not inside the repo
first_commit=$(git rev-list --parents HEAD | tail -1) ||
echo "$0: Can't get initial commit" 2>&1 && false && return
root=$(git rev-parse --git-dir)/.. &&
# subshell so we don't change the user's working directory
( cd "$root" &&
if [[ $(git rev-list --parents HEAD | tail -1) = $first_commit ]]; then
pwd
else
echo "$FUNCNAME: git directory is not inside its repository" 2>&1
false
fi
)
else
echo "$FUNCNAME: Can't determine repository root" 2>&1
false
fi
}
# Change working directory to git repository root
function cd_git_root() {
local root
root=$(git_root) || return 1 # git_root will print any errors
cd "$root"
}
Führen Sie es durch Eingabe git_root
(nach der Shell neu zu starten: exec bash
)