[hackers] [dmenu] 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

From: Anselm R. Garbe <arg_AT_suckless.org>
Date: Thu May 24 10:39:40 2007

changeset: 209:f99b690f37c6
tag: tip
user: Anselm R. Garbe <arg_AT_suckless.org>
date: Thu May 24 10:34:44 2007 +0200
summary: 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

diff -r 1fed9410fbc6 -r f99b690f37c6 dmenu_path
--- a/dmenu_path Wed May 23 19:38:23 2007 -0400
+++ b/dmenu_path Thu May 24 10:34:44 2007 +0200
@@ -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
Received on Thu May 24 2007 - 10:39:40 UTC

This archive was generated by hypermail 2.2.0 : Sun Jul 13 2008 - 15:56:48 UTC