summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAndrew Scott <andj.scott@gmail.com>2016-06-14 13:58:33 +0300
committerAndrew Scott <andj.scott@gmail.com>2016-06-14 13:58:33 +0300
commitd720b725e8644072a240be924eec09d1f0d21edb (patch)
tree0872c69407de30bc6adfc7881fa1572f5cd1aed4
parentc3019d11ef2a8e1b550b4d05e22473ef6e3e8596 (diff)
Use git's show-toplevel to get top level directory
-rwxr-xr-xpowerlevel9k.zsh-theme32
1 files changed, 10 insertions, 22 deletions
diff --git a/powerlevel9k.zsh-theme b/powerlevel9k.zsh-theme
index b3873429..0bbeb7c5 100755
--- a/powerlevel9k.zsh-theme
+++ b/powerlevel9k.zsh-theme
@@ -467,30 +467,18 @@ prompt_dir() {
local name repo_path package_path current_dir zero
# Get the path of the Git repo, which should have the package.json file
- if repo_path=$(git rev-parse --git-dir 2>/dev/null); then
- if [[ "$repo_path" == ".git" ]]; then
- # If the current path is the root of the project, then the package path is
- # the current directory and we don't want to append anything to represent
- # the path to a subdirectory
- package_path="."
- subdirectory_path=""
- else
- # Handle the edge case where $repo_path is '.' due to the current directory being the .git directory.
- if [[ "$repo_path" == "." ]]; then
- repo_path=$(pwd)
- fi
- # If the current path is something else, get the path to the package.json
- # file by finding the repo path and removing the '.git` from the path
- package_path=${repo_path:0:-4}
- zero='%([BSUbfksu]|([FB]|){*})'
- current_dir=$(pwd)
- # Then, find the length of the package_path string, and save the
- # subdirectory path as a substring of the current directory's path from 0
- # to the length of the package path's string
- subdirectory_path=$(truncatePathFromRight "/${current_dir:${#${(S%%)package_path//$~zero/}}}")
- fi
+ if [[ $(git rev-parse --is-inside-work-tree 2> /dev/null) == "true" ]]; then
+ package_path=$(git rev-parse --show-toplevel)
+ elif [[ $(git rev-parse --is-inside-git-dir 2> /dev/null) == "true" ]]; then
+ package_path=${$(pwd)%%/.git*}
fi
+ zero='%([BSUbfksu]|([FB]|){*})'
+ current_dir=$(pwd)
+ # Then, find the length of the package_path string, and save the
+ # subdirectory path as a substring of the current directory's path from 0
+ # to the length of the package path's string
+ subdirectory_path=$(truncatePathFromRight "${current_dir:${#${(S%%)package_path//$~zero/}}}")
# Parse the 'name' from the package.json; if there are any problems, just
# print the file path
if name=$( cat "$package_path/package.json" 2> /dev/null | grep "\"name\""); then