From 94453812848733dbcd8f35fd56e6a018abffc950 Mon Sep 17 00:00:00 2001 From: Martin Kealey Date: Wed, 20 Nov 2019 16:45:19 +1100 Subject: [PATCH] apply to all Bash, Ksh, Zsh & POSIX Shell files Does not need bash to run; standard posix sh suffices. Apply shellcheck to: * files with shbang lines that indicate a shell (sh, bash, ash, bsh, ksh, zsh) * typical home directory shell startup files: for posix sh & all shells: .profile for bash: .bashrc, .bash_aliases, .bash_completion, .bash_login, .bash_logout, .bash_profile for ksh: .profile for zsh: .zprofile, .zlogin, .zlogout, .zshenv, .zshrc * typical system-wide shell startup files: for posix sh & all shells: /etc/profile for bash: /etc/bashrc, /etc/bash_profile for ksh: for zsh: /etc/zprofile, /etc/zlogin, /etc/zlogout, /etc/zshenv, /etc/zshrc * files with suffixes: .bash, .zsh, .ksh, & .sh --- runaction.sh | 47 ++++++++++++++++++++++++++++++++++++++++++----- 1 file changed, 42 insertions(+), 5 deletions(-) diff --git a/runaction.sh b/runaction.sh index bfdb171..8b09ce5 100644 --- a/runaction.sh +++ b/runaction.sh @@ -1,6 +1,43 @@ -#!/bin/bash +#!/bin/sh -cd "$GITHUB_WORKSPACE" || exit 1 -find . -name \*.sh -exec shellcheck {} + -find . -name \*.bashrc -exec shellcheck {} + -find . -name \*.bash_profile -exec shellcheck {} + \ No newline at end of file +cd "$GITHUB_WORKSPACE" || exit + +find . '(' -name '*.bash' \ + -o -path '*/.bash*' -o -path '*/bash*' \ + \ + -o -name '*.ksh' \ + -o -name 'ksh*' \ + -o -path '*/.ksh*' -o -path '*/ksh*' \ + \ + -o -name '*.zsh' \ + -o -name '.zlogin*' -o -name 'zlogin*' \ + -o -name '.zlogout*' -o -name 'zlogout*' \ + -o -name '.zprofile*' -o -name 'zprofile*' \ + -o -path '*/.zsh*' -o -path '*/zsh*' \ + \ + -o -name '*.sh' \ + -o -path '*/.profile*' -o -path '*/profile*' \ + -o -path '*/.shlib*' -o -path '*/shlib*' \ + ')' -exec shellcheck {} + || exit + +# shellcheck disable=SC2016 +find . -type f ! -name '*.*' -perm /111 -exec sh -c ' + for f + do + head -n1 "$f" | grep -Eqs "^#! */[^ ]*/[abkz]*sh" || continue + shellcheck "$f" || err=$? + done + exit $err + ' _ {} + || exit + +if find . -path '*bin/*/*' -type f -perm /111 -print | + grep . +then + echo >&2 "WARNING: subdirectories of bin directories are not usable via PATH" +fi + +if find . -path '*bin/*' -name '*.*' -type f -perm /111 -perm /444 -print | + grep . +then + echo >&2 "WARNING: programs in PATH should not have a filename suffix" +fi