Project Access
- Made more POSIX compliant - pnew: Now accepts a remote git repo - pnew: Creates git repo on new (not git) projects Aliases - Dev aliases moved to this repo instead of dotfiles - Create aliases when the underlying programs are installed - Alias to copy my template .gitignore to current directory
This commit is contained in:
@@ -1,53 +1,71 @@
|
||||
#!/bin/sh
|
||||
|
||||
# TODO: Alias to quickly add my template .gitignore file to any location
|
||||
# - Create fuzzy finder for cht.sh & tldr
|
||||
# - Move all dev prod scripts to its own project
|
||||
# - Create fuzzy finder for cht.sh & tldr + system man pages + learnxinyminutes github
|
||||
|
||||
op() {
|
||||
local chosen_project
|
||||
chosen_project="$(find -L ~/Code -mindepth 2 -maxdepth 2 -not -path '*/.*' -printf "%T@ %p\n" | sort -nr | cut -d ' ' -f 2- | fzf --prompt='Select a project: ')"
|
||||
if ! command -v fzf >/dev/null; then
|
||||
echo "Install fzf to use this function."
|
||||
return 1
|
||||
fi
|
||||
|
||||
project_dir="$(find -L ~/Code -mindepth 2 -maxdepth 2 -not -path '*/.*' -printf "%T@ %p\n" | sort -nr | cut -d ' ' -f 2- | fzf --prompt='Select a project: ')"
|
||||
|
||||
# Do nothing and return if user cancelled out
|
||||
if [ -z "$chosen_project" ]; then
|
||||
if [ "$project_dir" = "" ]; then
|
||||
return 0
|
||||
fi
|
||||
|
||||
cd "$chosen_project" || return
|
||||
cd "$project_dir" || return
|
||||
nvim
|
||||
}
|
||||
|
||||
pnew(){
|
||||
local directory
|
||||
directory="$(find -L ~/Code/ -mindepth 1 -maxdepth 1 -not -path '*/.*' -type d | sed '/Squbix\|KeepWorks\|Supra/d' | sort | fzf --prompt='In which directory? ')"
|
||||
pnew() {
|
||||
if ! command -v fzf >/dev/null; then
|
||||
echo "Install fzf to use this function."
|
||||
return 1
|
||||
fi
|
||||
|
||||
directory="$(find -L ~/Code/ -mindepth 1 -maxdepth 1 -not -path '*/.*' -type d | sed '/Squbix\|KeepWorks\|Supra/d' | sort | fzf --prompt='Creating new project. In which directory? ')"
|
||||
|
||||
# Do nothing and return if user cancelled out
|
||||
if [ -z "$directory" ]; then
|
||||
if [ "$directory" = "" ]; then
|
||||
return 0
|
||||
fi
|
||||
|
||||
local project_name
|
||||
# FIX: User cancelling out here
|
||||
is_clone=$(printf 'yes\nno' | fzf)
|
||||
|
||||
# Until user provides a good directory name or cancels out
|
||||
while [ -d "$directory/$project_name" ]; do
|
||||
if [ -n "$1" ]; then
|
||||
project_name="$1"
|
||||
else
|
||||
project_name=$(find -L "$directory" -mindepth 1 -maxdepth 1 -not -path '*/.*' -type d | fzf --print-query -e +i --prompt='Project name (AVOID EXISTING ONES BELOW): ' | head -1)
|
||||
fi
|
||||
if [ "$is_clone" = "yes" ]; then
|
||||
# Clone the repo and open nvim on it
|
||||
printf "Git repo URL: " >&2
|
||||
read -r git_url
|
||||
cd "$directory" || return
|
||||
git clone "$git_url" || cd - >/dev/null && return
|
||||
cd "$(basename "$git_url" | cut -d '.' -f 1)" || return
|
||||
else
|
||||
# Loop until user provides a valid directory name or cancels out
|
||||
while [ -d "$directory/$project_name" ]; do
|
||||
if [ "$1" != "" ]; then
|
||||
project_name="$1"
|
||||
else
|
||||
project_name=$(find -L "$directory" -mindepth 1 -maxdepth 1 -not -path '*/.*' -type d | fzf --print-query -e +i --prompt='Project name (AVOID EXISTING ONES BELOW): ' | head -1)
|
||||
fi
|
||||
|
||||
if [ -z "$project_name" ]; then
|
||||
echo "Cancelling..."
|
||||
return 0
|
||||
fi
|
||||
if [ "$project_name" = "" ]; then
|
||||
echo "Cancelling..."
|
||||
return 0
|
||||
fi
|
||||
|
||||
if [ -d "$directory/$project_name" ]; then
|
||||
echo "'$directory/$project_name' already exists"
|
||||
fi
|
||||
done
|
||||
if [ -d "$directory/$project_name" ]; then
|
||||
echo "'$directory/$project_name' already exists"
|
||||
fi
|
||||
done
|
||||
|
||||
[ -d "$directory/$project_name" ] || mkdir -p "$directory/$project_name" || return
|
||||
[ -d "$directory/$project_name" ] || mkdir -p "$directory/$project_name" || return
|
||||
cd "$directory/$project_name" || return
|
||||
git init || return
|
||||
fi
|
||||
|
||||
cd "$directory/$project_name" || return
|
||||
nvim
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user