X-Git-Url: https://git.danieliu.xyz/?a=blobdiff_plain;f=dmenu_path;h=7896a9e957fa1e274805c0641c841a6b82334667;hb=8911aa10606b4fda9d766973b1c3e0e23bb2c266;hp=84e3015d74f758c52ae62b0d91608996bacf7fa6;hpb=8369e1736b4778e766f55d5476bbbd38a8b46331;p=dmenu.git diff --git a/dmenu_path b/dmenu_path index 84e3015..7896a9e 100755 --- a/dmenu_path +++ b/dmenu_path @@ -1,26 +1,26 @@ -#!/bin/sh -f +#!/bin/sh CACHE=$HOME/.dmenu_cache IFS=: -qfind() { - find "$@" 2>/dev/null -} - -uptodate() { - test -f $CACHE && - test "$(echo "$PATH")" = "$(sed 1q "$CACHE")" && - qfind $PATH -maxdepth 0 -newer $CACHE +uptodate() { + test -f "$CACHE" && + for dir in $PATH + do + test ! $dir -nt "$CACHE" || return 1 + done } if ! uptodate then - { - echo "$PATH" - qfind $PATH -type f -maxdepth 1 -perm -u+x -o -perm -g+x -o -perm -o+x | - sed 's,.*/,,' | sort | uniq - } > $CACHE.$pid - mv $CACHE.$pid $CACHE + for dir in $PATH + do + cd "$dir" && + for file in * + do + test -x "$file" && echo "$file" + done + done | sort | uniq > "$CACHE".$$ && + mv "$CACHE".$$ "$CACHE" fi -tail -n +2 $CACHE - +cat "$CACHE"