Upload files to "Mac App Uninstall"
This commit is contained in:
parent
abf2044c3d
commit
1ec559d07c
|
@ -0,0 +1,122 @@
|
||||||
|
#! /bin/bash
|
||||||
|
|
||||||
|
if [ -z "$1" ] || [ "$1" = "--help" ]; then
|
||||||
|
printf "%s\n" "Usage: app-cleaner.sh /path/to/app.app"
|
||||||
|
exit 0
|
||||||
|
fi
|
||||||
|
|
||||||
|
IFS=$'\n'
|
||||||
|
|
||||||
|
red=$(tput setaf 1)
|
||||||
|
normal=$(tput sgr0)
|
||||||
|
|
||||||
|
if [ ! -e "$1/Contents/Info.plist" ]; then
|
||||||
|
printf "%s\n" "Cannot find app plist"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
bundle_identifier=$(/usr/libexec/PlistBuddy -c "Print CFBundleIdentifier" "$1/Contents/Info.plist" 2> /dev/null)
|
||||||
|
|
||||||
|
if [ "$bundle_identifier" = "" ]; then
|
||||||
|
printf "%s\n" "Cannot find app bundle identifier"
|
||||||
|
exit 1
|
||||||
|
fi
|
||||||
|
|
||||||
|
printf "%s\n" "Checking for running processes…"
|
||||||
|
sleep 1
|
||||||
|
|
||||||
|
app_name=$(basename $1 .app)
|
||||||
|
|
||||||
|
processes=($(pgrep -afil "$app_name" | grep -v "app-cleaner.sh"))
|
||||||
|
|
||||||
|
if [ ${#processes[@]} -gt 0 ]; then
|
||||||
|
printf "%s\n" "${processes[@]}"
|
||||||
|
printf "$red%s$normal" "Kill running processes (y or n)? "
|
||||||
|
read -r answer
|
||||||
|
if [ "$answer" = "y" ]; then
|
||||||
|
printf "%s\n" "Killing running processes…"
|
||||||
|
sleep 1
|
||||||
|
for process in "${processes[@]}"; do
|
||||||
|
echo $process | awk '{print $1}' | xargs sudo kill 2>&1 | grep -v "No such process"
|
||||||
|
done
|
||||||
|
fi
|
||||||
|
fi
|
||||||
|
|
||||||
|
paths=()
|
||||||
|
|
||||||
|
paths+=($(find /private/var/db/receipts -iname "*$app_name*.bom" -maxdepth 1 -prune 2>&1 | grep -v "Permission denied"))
|
||||||
|
paths+=($(find /private/var/db/receipts -iname "*$bundle_identifier*.bom" -maxdepth 1 -prune 2>&1 | grep -v "Permission denied"))
|
||||||
|
|
||||||
|
if [ ${#paths[@]} -gt 0 ]; then
|
||||||
|
printf "%s\n" "Saving bill of material logs to desktop…"
|
||||||
|
sleep 1
|
||||||
|
for path in "${paths[@]}"; do
|
||||||
|
mkdir -p "$HOME/Desktop/$app_name"
|
||||||
|
lsbom -f -l -s -p f $path > "$HOME/Desktop/$app_name/$(basename $path).log"
|
||||||
|
done
|
||||||
|
fi
|
||||||
|
|
||||||
|
printf "%s\n" "Finding app data…"
|
||||||
|
sleep 1
|
||||||
|
|
||||||
|
locations=(
|
||||||
|
"$HOME/Library"
|
||||||
|
"$HOME/Library/Application Scripts"
|
||||||
|
"$HOME/Library/Application Support"
|
||||||
|
"$HOME/Library/Application Support/CrashReporter"
|
||||||
|
"$HOME/Library/Containers"
|
||||||
|
"$HOME/Library/Caches"
|
||||||
|
"$HOME/Library/HTTPStorages"
|
||||||
|
"$HOME/Library/Group Containers"
|
||||||
|
"$HOME/Library/Internet Plug-Ins"
|
||||||
|
"$HOME/Library/LaunchAgents"
|
||||||
|
"$HOME/Library/Logs"
|
||||||
|
"$HOME/Library/Preferences"
|
||||||
|
"$HOME/Library/Preferences/ByHost"
|
||||||
|
"$HOME/Library/Saved Application State"
|
||||||
|
"$HOME/Library/WebKit"
|
||||||
|
"/Library"
|
||||||
|
"/Library/Application Support"
|
||||||
|
"/Library/Application Support/CrashReporter"
|
||||||
|
"/Library/Caches"
|
||||||
|
"/Library/Extensions"
|
||||||
|
"/Library/Internet Plug-Ins"
|
||||||
|
"/Library/LaunchAgents"
|
||||||
|
"/Library/LaunchDaemons"
|
||||||
|
"/Library/Logs"
|
||||||
|
"/Library/Preferences"
|
||||||
|
"/Library/PrivilegedHelperTools"
|
||||||
|
"/private/var/db/receipts"
|
||||||
|
"/usr/local/bin"
|
||||||
|
"/usr/local/etc"
|
||||||
|
"/usr/local/opt"
|
||||||
|
"/usr/local/sbin"
|
||||||
|
"/usr/local/share"
|
||||||
|
"/usr/local/var"
|
||||||
|
$(getconf DARWIN_USER_CACHE_DIR | sed "s/\/$//")
|
||||||
|
$(getconf DARWIN_USER_TEMP_DIR | sed "s/\/$//")
|
||||||
|
)
|
||||||
|
|
||||||
|
paths=($1)
|
||||||
|
|
||||||
|
for location in "${locations[@]}"; do
|
||||||
|
paths+=($(find "$location" -iname "*$app_name*" -maxdepth 1 -prune 2>&1 | grep -v "No such file or directory" | grep -v "Operation not permitted" | grep -v "Permission denied"))
|
||||||
|
done
|
||||||
|
|
||||||
|
for location in "${locations[@]}"; do
|
||||||
|
paths+=($(find "$location" -iname "*$bundle_identifier*" -maxdepth 1 -prune 2>&1 | grep -v "No such file or directory" | grep -v "Operation not permitted" | grep -v "Permission denied"))
|
||||||
|
done
|
||||||
|
|
||||||
|
paths=($(printf "%s\n" "${paths[@]}" | sort -u));
|
||||||
|
|
||||||
|
printf "%s\n" "${paths[@]}"
|
||||||
|
|
||||||
|
printf "$red%s$normal" "Move app data to trash (y or n)? "
|
||||||
|
read -r answer
|
||||||
|
if [ "$answer" = "y" ]; then
|
||||||
|
printf "%s\n" "Moving app data to trash…"
|
||||||
|
sleep 1
|
||||||
|
posixFiles=$(printf ", POSIX file \"%s\"" "${paths[@]}" | awk '{print substr($0,3)}')
|
||||||
|
osascript -e "tell application \"Finder\" to delete { $posixFiles }" > /dev/null
|
||||||
|
printf "%s\n" "Done"
|
||||||
|
fi
|
|
@ -0,0 +1,8 @@
|
||||||
|
Installation, Open Terminal
|
||||||
|
1. sudo mkdir -p /usr/local/bin
|
||||||
|
2. sudo chown ${USER}:staff /usr/local/bin
|
||||||
|
3. chmod +x /usr/local/bin/app-cleaner.sh
|
||||||
|
|
||||||
|
|
||||||
|
Usage guide
|
||||||
|
$ app-cleaner.sh /Applications/[App_Name].app
|
Loading…
Reference in New Issue