2017-01-22 09:54:57 -05:00
|
|
|
#!/bin/bash -eu
|
|
|
|
|
|
|
|
# This Bash script implements custom sanity checks for scripts beyond what
|
|
|
|
# Vint covers, which are easy to check with regex.
|
|
|
|
|
|
|
|
# A flag for automatically fixing some errors.
|
|
|
|
FIX_ERRORS=0
|
|
|
|
RETURN_CODE=0
|
|
|
|
|
|
|
|
function print_help() {
|
|
|
|
echo "Usage: ./custom-checks [--fix] [DIRECTORY]" 1>&2
|
|
|
|
echo 1>&2
|
|
|
|
echo " -h, --help Print this help text" 1>&2
|
|
|
|
echo " --fix Automatically fix some errors" 1>&2
|
|
|
|
exit 1
|
|
|
|
}
|
|
|
|
|
|
|
|
while [ $# -ne 0 ]; do
|
|
|
|
case $1 in
|
|
|
|
-h) ;& --help)
|
|
|
|
print_help
|
|
|
|
;;
|
|
|
|
--fix)
|
|
|
|
FIX_ERRORS=1
|
|
|
|
shift
|
|
|
|
;;
|
|
|
|
--)
|
|
|
|
shift
|
|
|
|
break
|
|
|
|
;;
|
|
|
|
-?*)
|
|
|
|
echo "Invalid argument: $1" 1>&2
|
|
|
|
exit 1
|
|
|
|
;;
|
|
|
|
*)
|
|
|
|
break
|
|
|
|
;;
|
|
|
|
esac
|
|
|
|
done
|
|
|
|
|
|
|
|
if [ $# -eq 0 ] || [ -z "$1" ]; then
|
|
|
|
print_help
|
|
|
|
fi
|
|
|
|
|
2017-03-06 19:16:35 -05:00
|
|
|
shopt -s globstar
|
2017-01-22 09:54:57 -05:00
|
|
|
|
2017-04-27 16:09:23 -04:00
|
|
|
directories=("$@")
|
2017-02-21 06:50:59 -05:00
|
|
|
|
2017-03-06 19:16:35 -05:00
|
|
|
check_errors() {
|
|
|
|
regex="$1"
|
|
|
|
message="$2"
|
2017-02-21 06:50:59 -05:00
|
|
|
|
2017-04-27 16:09:23 -04:00
|
|
|
for directory in "${directories[@]}"; do
|
|
|
|
while IFS= read -r match; do
|
|
|
|
RETURN_CODE=1
|
|
|
|
echo "$match $message"
|
|
|
|
done < <(grep -n "$regex" "$directory"/**/*.vim \
|
2017-06-06 05:22:52 -04:00
|
|
|
| grep -v 'no-custom-checks' \
|
2017-04-27 16:09:23 -04:00
|
|
|
| grep -o '^[^:]\+:[0-9]\+' \
|
|
|
|
| sed 's:^\./::')
|
2017-03-06 19:16:35 -05:00
|
|
|
done
|
2017-01-22 09:54:57 -05:00
|
|
|
}
|
|
|
|
|
2017-03-06 19:16:35 -05:00
|
|
|
if (( FIX_ERRORS )); then
|
2017-04-27 16:09:23 -04:00
|
|
|
for directory in "${directories[@]}"; do
|
|
|
|
sed -i "s/^\(function.*)\) *$/\1 abort/" "$directory"/**/*.vim
|
2017-05-15 15:21:18 -04:00
|
|
|
sed -i "s/shellescape(/ale#Escape(/" "$directory"/**/*.vim
|
2017-08-08 03:39:13 -04:00
|
|
|
sed -i 's/==#/is#/g' "$directory"/**/*.vim
|
|
|
|
sed -i 's/==?/is?/g' "$directory"/**/*.vim
|
2017-04-27 16:09:23 -04:00
|
|
|
done
|
2017-03-06 19:16:35 -05:00
|
|
|
fi
|
2017-01-22 09:54:57 -05:00
|
|
|
|
2017-03-06 19:16:35 -05:00
|
|
|
check_errors \
|
2017-04-15 07:52:25 -04:00
|
|
|
'^function.*) *$' \
|
2017-03-06 19:16:35 -05:00
|
|
|
'Function without abort keyword (See :help except-compat)'
|
2017-04-15 07:52:25 -04:00
|
|
|
check_errors ' \+$' 'Trailing whitespace'
|
|
|
|
check_errors '^ * end\?i\? *$' 'Write endif, not en, end, or endi'
|
|
|
|
check_errors '^ [^ ]' 'Use four spaces, not two spaces'
|
|
|
|
check_errors $'\t' 'Use four spaces, not tabs'
|
2017-04-15 08:35:54 -04:00
|
|
|
# This check should prevent people from using a particular inconsistent name.
|
|
|
|
check_errors 'let g:ale_\w\+_\w\+_args =' 'Name your option g:ale_<filetype>_<lintername>_options instead'
|
2017-05-15 15:21:18 -04:00
|
|
|
check_errors 'shellescape(' 'Use ale#Escape instead of shellescape'
|
2017-07-05 10:51:31 -04:00
|
|
|
check_errors 'simplify(' 'Use ale#path#Simplify instead of simplify'
|
2017-06-06 05:22:52 -04:00
|
|
|
check_errors "expand(['\"]%" "Use expand('#' . a:buffer . '...') instead. You might get a filename for the wrong buffer."
|
2017-08-08 03:39:13 -04:00
|
|
|
check_errors '==#' "Use 'is#' instead of '==#'. 0 ==# 'foobar' is true"
|
|
|
|
check_errors '==?' "Use 'is?' instead of '==?'. 0 ==? 'foobar' is true"
|
2017-01-22 09:54:57 -05:00
|
|
|
|
|
|
|
exit $RETURN_CODE
|