Do a single grep to compare the contents of the module file (if exists) against the results of all_modules for the provided arguments. If there's no module file, this is still just pass through to all_modules. Signed-off-by: Dave Reisner <d@falconindy.com> --- functions | 11 +++-------- 1 files changed, 3 insertions(+), 8 deletions(-) diff --git a/functions b/functions index c93701d..5aa8435 100644 --- a/functions +++ b/functions @@ -66,16 +66,11 @@ all_modules () checked_modules () { - if [ -e "${MODULE_FILE}" ]; then - for mod in $(all_modules $@); do - modname=$(get_module_name "${mod}") - if grep -q "^${modname}$" "${MODULE_FILE}"; then - echo ${modname} - fi - done + if [ -s "${MODULE_FILE}" ]; then + grep -xFf "$MODULE_FILE" <(all_modules "$@") return 1 else - all_modules ${@} + all_modules "$@" fi } -- 1.7.5.4