Skip to content

Commit

Permalink
Update clean.sh script to reflect changes introduced in clean.cmd, un…
Browse files Browse the repository at this point in the history
…ify messages and functionality
  • Loading branch information
4creators committed Nov 8, 2017
1 parent 8110e41 commit 3bc27d5
Show file tree
Hide file tree
Showing 2 changed files with 28 additions and 72 deletions.
15 changes: 9 additions & 6 deletions clean.cmd
Original file line number Diff line number Diff line change
@@ -1,6 +1,9 @@
@if not defined _echo @echo off
setlocal EnableDelayedExpansion

set NO_DASHES_ARG=%1
if /I [%NO_DASHES_ARG:-=%] == [?] goto Usage
if /I [%NO_DASHES_ARG:-=%] == [h] goto Usage

:: Check if VBCSCompiler.exe is running
tasklist /fi "imagename eq VBCSCompiler.exe" |find ":" > nul
Expand All @@ -13,7 +16,6 @@ if errorlevel 1 (
:: Strip all dashes off the argument and use invariant
:: compare to match as many versions of "all" that we can
:: All other argument validation happens inside Run.exe
set NO_DASHES_ARG=%1
if not defined NO_DASHES_ARG goto no_args
if /I [%NO_DASHES_ARG:-=%] == [all] (
echo Cleaning entire working directory ...
Expand All @@ -28,12 +30,13 @@ exit /b %ERRORLEVEL%

:Usage
echo.
echo Usage: clean [-b] [-p] [-c] [-all]
echo Repository cleaning script.
echo Options:
echo -b - Cleans the bin directory
echo -p - Cleans the packages directory
echo -c - Deletes the user-local nuget package cache.
echo -all - Cleans everything and restores repository to pristine state
echo -b - Delete the binary output directory.
echo -p - Delete the repo-local NuGet package directory.
echo -c - Deletes the user-local NuGet package cache.
echo -all - Cleans repository and restores it to pristine state.
echo.
echo If no option is specified then clean.cmd -b is implied.
echo ^If no option is specified then "clean -b" is implied.
exit /b
85 changes: 19 additions & 66 deletions clean.sh
Original file line number Diff line number Diff line change
Expand Up @@ -2,82 +2,35 @@

usage()
{
echo "Usage: clean [-b] [-t] [-p]"
echo "Usage: clean [-b] [-p] [-c] [-all]"
echo "Repository cleaning script."
echo " -b Clean bin directory"
echo " -t Clean tools directory"
echo " -p Clean packages directory"
echo " -all Clean everything"
echo " -b Delete the binary output directory."
echo " -p Delete the repo-local NuGet package directory."
echo " -c Delete the user-local NuGet package caches."
echo " -all Cleans repository and restores it to pristine state."
echo
echo "If no option is specified, then \"clean.sh -b -t -p\" is implied."
echo "If no option is specified, then \"clean.sh -b\" is implied."
exit 1
}

# Obtain the location of the bash script to figure out where the root of the repo is.
__ProjectRoot="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"

echo Cleaning previous output for the selected configuration

# Parse arguments
if [ $# == 0 ]; then
clean_bin=true
clean_tools=true
clean_packages=true
if [ "$1" == "-?" ] || [ "$1" == "-h" ]; then
usage
fi

while [[ $# -gt 0 ]]
do
opt="$1"
case $opt in
-h|--help)
usage
;;
-b)
clean_bin=true
;;
-t)
clean_tools=true
;;
-p)
clean_packages=true
;;
-all)
clean_bin=true
clean_tools=true
clean_packages=true
;;
*)
esac
shift
done
# Implement VBCSCompiler.exe kill logic once VBCSCompiler.exe is ported to unixes

if [ "$clean_bin" == true ]; then
echo "Deleting bin directory"
rm -rf "$__ProjectRoot/bin"
if [ $? -ne 0 ]; then
echo "Error while deleting bin directory - error code was $?"
exit 1
fi
fi
__working_tree_root="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"

if [ "$clean_tools" == true ]; then
echo "Deleting tools directory"
rm -rf "$__ProjectRoot/Tools"
if [ $? -ne 0 ]; then
echo "Error while deleting tools directory - error code was $?"
exit 1
fi
if [ "$*" == "-all" ]
then
echo "Removing all untracked files in the working tree"
git clean -xdf $__working_tree_root
exit $?
fi

if [ "$clean_packages" == true ]; then
echo "Deleting packages directory"
rm -rf "$__ProjectRoot/packages"
if [ $? -ne 0 ]; then
echo "Error while deleting packages directory - error code was $?"
exit 1
fi
if [ $# == 0 ]; then
__args=-b
fi

echo "Clean was successful"

exit 0
$__working_tree_root/run.sh clean $__args $*
exit $?

0 comments on commit 3bc27d5

Please sign in to comment.