diff options
author | Anselm R. Garbe <arg@suckless.org> | 2007-05-24 10:34:44 +0200 |
---|---|---|
committer | Anselm R. Garbe <arg@suckless.org> | 2007-05-24 10:34:44 +0200 |
commit | 3a9f3a51ce25717813da7321d4771dca11a25af8 (patch) | |
tree | 5d0f036bcd5236fe8bcd82c5ad73998b11019eac /dmenu_path | |
parent | 53e92b5c1797ae5d259942b0a3f20a63c1a02f1e (diff) | |
download | dmenu-3a9f3a51ce25717813da7321d4771dca11a25af8.tar.gz dmenu-3a9f3a51ce25717813da7321d4771dca11a25af8.tar.bz2 dmenu-3a9f3a51ce25717813da7321d4771dca11a25af8.zip |
I agree with the race fix of JG, but I dislike the SUSV3-breaking find, and I don't care about PATH changes, keep it simple, stupid
Diffstat (limited to 'dmenu_path')
-rwxr-xr-x | dmenu_path | 34 |
1 files changed, 17 insertions, 17 deletions
@@ -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 >/dev/null +uptodate() { + test ! -f $CACHE && return 1 + for dir in $PATH + do + test $dir -nt $CACHE && return 1 + done + return 0 } 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 - } - mv $CACHE.$pid $CACHE + for dir in $PATH + do + for file in "$dir"/* + do + test -x "$file" && echo "${file##*/}" + done + done | sort | uniq > $CACHE.$$ + mv $CACHE.$$ $CACHE fi -tail -n +2 $CACHE - +cat $CACHE |