devdraw: cleanup, fix macargv
diff --git a/mac/Plumb.app/Contents/MacOS/plumb b/mac/Plumb.app/Contents/MacOS/plumb
index 80918aa..fc5e2c3 100755
--- a/mac/Plumb.app/Contents/MacOS/plumb
+++ b/mac/Plumb.app/Contents/MacOS/plumb
@@ -1,12 +1,21 @@
 #!/bin/bash
+
 . ~/.bashrc
 PLAN9=${PLAN9:-/usr/local/plan9}
-filename="$($PLAN9/bin/macargv)"
-# Blank are problematic in the file name.  Make them go away but keep the content.
-if echo "$filename" | grep -q " "
-then
-	base=$(basename "$filename" | sed 's/ /_/g')
-	cat "$filename" | plumb -i -d edit -a "action=showdata filename=/BadName/$base"
-else
-	$PLAN9/bin/plumb -d edit "$filename"
-fi
+
+bin=$PLAN9/bin
+IFS=$'\n'
+
+for file in $($bin/macargv)
+do
+	# Blanks are problematic in filenames: just plumb
+	# the file's content.
+	if echo "$file" | grep -q " "
+	then
+		base=$(basename "$file" | sed 's/ /_/g')
+		attr="action=showdata filename=/BadName/$base"
+		cat $file | "$bin/plumb" -i -d edit -a "$attr"
+	else
+		"$bin/plumb" -d edit "$file"
+	fi
+done
diff --git a/src/cmd/devdraw/macargv.m b/src/cmd/devdraw/macargv.m
new file mode 100644
index 0000000..cf3e228
--- /dev/null
+++ b/src/cmd/devdraw/macargv.m
@@ -0,0 +1,34 @@
+#import <Cocoa/Cocoa.h>
+
+#include <u.h>
+#include <libc.h>
+
+AUTOFRAMEWORK(Cocoa)
+
+@interface appdelegate : NSObject @end
+
+void
+main(void)
+{
+	if(OSX_VERSION < 100700)
+		[NSAutoreleasePool new];
+
+	[NSApplication sharedApplication];
+	[NSApp setDelegate:[appdelegate new]];
+	[NSApp run];
+}
+
+@implementation appdelegate
+- (void)application:(id)arg openFiles:(NSArray*)file
+{
+	int i,n;
+	NSString *s;
+
+	n = [file count];
+	for(i=0; i<n; i++){
+		s = [file objectAtIndex:i];
+		print("%s\n", [s UTF8String]);
+	}
+	[NSApp terminate:self];
+}
+@end
diff --git a/src/cmd/devdraw/mkfile b/src/cmd/devdraw/mkfile
index 1e7ac0b..1194c79 100644
--- a/src/cmd/devdraw/mkfile
+++ b/src/cmd/devdraw/mkfile
@@ -32,24 +32,20 @@
 latin1.h: $PLAN9/lib/keyboard $O.mklatinkbd
 	./$O.mklatinkbd -r $PLAN9/lib/keyboard | sed 's/, }/ }/' >$target
 
-CLEANFILES=latin1.h $O.mklatinkbd
-
-# Still in progress: Cocoa/Objective C version of devdraw
+$O.macargv: $MACARGV
+	$LD -o $target $prereq
 
 %-objc.$O: %.m
 	$CC $CFLAGS -o $target $stem.m
 
-cocoa: devdraw.o latin1.o mouseswap.o winsize.o osx-draw.o cocoa-screen-objc.o cocoa-srv.o cocoa-thread.o
-	$LD -o $target $prereq
+CLEANFILES=$O.macargv $O.mklatinkbd latin1.h
 
+# old attempt
 devdraw-cocoa: devdraw.o latin1.o mouseswap.o winsize.o osx-screen-objc.o osx-draw.o osx-srv-objc.o osx-delegate-objc.o
 	$LD -o $target $prereq
 
-install-macargv: $O.macargv
-	install $O.macargv $PLAN9/bin/macargv
-
-$O.macargv: macargv.$O
-	$LD -o $target $prereq
-
-install: $MACARGV
 install: mklatinkbd.install
+install:Q: 
+	if [ $MACARGV ]; then
+		mk $MKFLAGS macargv.install
+	fi
diff --git a/src/cmd/devdraw/mkwsysrules.sh b/src/cmd/devdraw/mkwsysrules.sh
index 0554ff8..dde44c8 100644
--- a/src/cmd/devdraw/mkwsysrules.sh
+++ b/src/cmd/devdraw/mkwsysrules.sh
@@ -57,10 +57,10 @@
 		echo 'LDFLAGS=$LDFLAGS -F/System/Library/PrivateFrameworks'
 	fi
 	echo 'WSYSOFILES=$WSYSOFILES osx-screen-carbon-objc.o osx-draw.o osx-srv.o'
-	echo 'MACARGV=install-macargv'
+	echo 'MACARGV=macargv.o'
 elif [ $WSYSTYPE = osx-cocoa ]; then
 	echo 'WSYSOFILES=$WSYSOFILES osx-draw.o cocoa-screen-objc.o cocoa-srv.o cocoa-thread.o'
-	echo 'MACARGV=install-macargv'
+	echo 'MACARGV=macargv-objc.o'
 elif [ $WSYSTYPE = nowsys ]; then
 	echo 'WSYSOFILES=nowsys.o'
 fi
diff --git a/src/mkfile b/src/mkfile
index 8c1f745..103ffe5 100644
--- a/src/mkfile
+++ b/src/mkfile
@@ -16,6 +16,7 @@
 	do
 		(cd $i; echo cd `pwd`';' mk $MKFLAGS $stem; mk $MKFLAGS $stem)
 	done
+	[ "$SYSNAME" != Darwin ] || ranlib ../lib/*.a
 
 MKDIRS=\
 	libbio\