Commit Diff


commit - c91cfa9177ba734a4906dce29810845d3557650c
commit + 07494878dc5ae11652cbe221cf9e2a20da94ca96
blob - 4e31d6aef55064a1d64e72fbc4449e8546b471ba
blob + 7af5f6beb89183f01070ebd5edb69c037dc3eefc
--- src/cmd/acme/addr.c
+++ src/cmd/acme/addr.c
@@ -138,7 +138,6 @@ regexp(uint showerr, Text *t, Range lim, Range r, Rune
 			q = Infinity;
 		else
 			q = lim.q1;
-warning(nil, "searching %d-%d\n", r.q1, q);
 		found = rxexecute(t, nil, r.q1, q, &sel);
 	}
 	if(!found && showerr)
blob - 66b935f8e3add1db0e044eb820d233c400653205
blob + 536a3334996d21b0ed2363930f6721f1a2f391c1
--- src/cmd/acme/fsys.c
+++ src/cmd/acme/fsys.c
@@ -160,10 +160,24 @@ fsysproc(void *v)
 		if(fcall[x->fcall.type] == 0)
 			x = respond(x, &t, "bad fcall type");
 		else{
-			if(x->fcall.type==Tversion || x->fcall.type==Tauth)
+			switch(x->fcall.type){
+			case Tversion:
+			case Tauth:
+			case Tflush:
 				f = nil;
-			else
+				break;
+			case Tattach:
+				f = newfid(x->fcall.fid);
+				break;
+			default:
 				f = newfid(x->fcall.fid);
+				if(!f->busy){
+					x->f = f;
+					x = respond(x, &t, "fid not in use");
+					continue;
+				}
+				break;
+			}
 			x->f = f;
 			x  = (*fcall[x->fcall.type])(x, f);
 		}
blob - 13d72957c8000527578ee23ff736cf754c21eff4
blob + 579f19446b12e4b4eb470867e19df3560e4cf350
--- src/cmd/acme/xfid.c
+++ src/cmd/acme/xfid.c
@@ -103,8 +103,14 @@ xfidopen(Xfid *x)
 		q = FILE(x->f->qid);
 		switch(q){
 		case QWaddr:
+			if(w->nopen[q]++ == 0){
+				w->addr = range(0, 0);
+				w->limit = range(-1,-1);
+			}
+			break;
+		case QWdata:
+		case QWxdata:
 			w->nopen[q]++;
-			w->limit = range(-1,-1);
 			break;
 		case QWevent:
 			if(w->nopen[q]++ == 0){