From fc165dcb3eb3f6d5994903ae7f9cb91c9f598cef Mon Sep 17 00:00:00 2001 From: rsc Date: Wed, 19 Oct 2005 03:15:30 +0000 Subject: [PATCH] Autoframework (Jeff Sickel) --- bin/9l | 53 ++++++++++++++++++++++++++++++++++++++++++++++++++--- bin/ps | 18 +++++++++++++++++- bin/psu | 21 ++++++++++++++++++++- 3 files changed, 87 insertions(+), 5 deletions(-) diff --git a/bin/9l b/bin/9l index b3b86531..af8a2317 100755 --- a/bin/9l +++ b/bin/9l @@ -2,14 +2,16 @@ test -f $PLAN9/config && . $PLAN9/config libsl="" - +frameworks="" doautolib=true +doautoframework=true verbose=false if [ "x$1" = "x-l" ] then shift doautolib=false + doautoframework=false elif [ "x$1" = "x-v" ] then shift @@ -162,6 +164,51 @@ then libsl="$libsl -L$X11/lib -lX11" fi fi +if $doautoframework +then + ofiles="" + for i + do + case "$i" in + *.[ao]) + ofiles="$ofiles $i" + ;; + esac + done + + # echo "ofiles $ofiles" + autoframeworks="" + if [ "x$ofiles" != "x" ] + then + a=` + nm $ofiles | + grep '__p9l_autoframework_[a-zA-Z0-9+-]*$' | + sed 's/.*__p9l_autoframework_//' | + sort -u + ` + for i in $a + do + autoframeworks="$autoframeworks $i" + eval "need$i=true" + done + fi + + if $verbose + then + echo "autoframeworks $autoframeworks" + fi + + for i in $autoframeworks + do + eval "have$i() { false; }" + done + + frameworks="" + for i in $autoframeworks + do + frameworks="-framework $i $frameworks" + done +fi extralibs="-lm" tag="${SYSNAME:-`uname`}-${OBJTYPE:-`uname -m`}" @@ -245,7 +292,7 @@ esac if $verbose then - echo $ld -L$PLAN9/lib "$@" $libsl $extralibs + echo $ld -L$PLAN9/lib "$@" $libsl $extralibs $frameworks fi xtmp=/tmp/9l.$$.$USER.out @@ -254,7 +301,7 @@ xxout() { rm -f $xtmp } -if $ld -L$PLAN9/lib "$@" $libsl $extralibs >$xtmp 2>&1 +if $ld -L$PLAN9/lib "$@" $libsl $extralibs $frameworks >$xtmp 2>&1 then xxout exit 0 diff --git a/bin/ps b/bin/ps index 7a8cd4e4..d6f44d9b 100755 --- a/bin/ps +++ b/bin/ps @@ -64,9 +64,25 @@ function statestr(s, wchan) if(start ~ /..:..:../){ # drop :ss sub(/:..$/, "", start); } - printf("%-8s %11d %8s %8s %8dK %-8s %s\n", + sub(/[ ]+$/, "", cmd); + line[0+nline++] = sprintf("%s\001%d\001%s\001%s\001%dK\001%s\001%s", user, pid, start, cputime, mem, statestr(stat, wchan), cmd); } + +END{ + for(i=0; i max[j]) + max[j] = length(a[j]); + } + for(i=0; i