git: 9front

Download patch

ref: 839b4044d3ba438219701ce029f5e662c27c9387
parent: 22260614d468eef2c4b38a371f4f8b2413ff4e73
author: cinap_lenrek <cinap_lenrek@gmx.de>
date: Wed Jun 6 22:12:04 EDT 2012

mothra: fix "bad ctl message" bug caused by fprint write buffer limit on long urls

--- a/sys/src/cmd/mothra/url.c
+++ b/sys/src/cmd/mothra/url.c
@@ -45,7 +45,7 @@
 static int
 webclone(Url *url, char *buf, int nbuf)
 {
-	int n, fd;
+	int n, conn, fd;
 
 	snprint(buf, nbuf, "%s/clone", mtpt);
 	if((fd = open(buf, ORDWR)) < 0)
@@ -55,16 +55,19 @@
 		return -1;
 	}
 	buf[n] = 0;
-	n = atoi(buf);
-	snprint(buf, nbuf, "%s/%d", mtpt, n);
+	conn = atoi(buf);
 	if(url && url->reltext[0]){
-		if(url->basename[0])
-			fprint(fd, "baseurl %s", url->basename);
-		if(fprint(fd, "url %s", url->reltext) < 0){
+		if(url->basename[0]){
+			n = snprint(buf, nbuf, "baseurl %s", url->basename);
+			write(fd, buf, n);
+		}
+		n = snprint(buf, nbuf, "url %s", url->reltext);
+		if(write(fd, buf, n) < 0){
 			close(fd);
 			return -1;
 		}
 	}
+	snprint(buf, nbuf, "%s/%d", mtpt, conn);
 	return fd;
 }
 
--