cu coredumps (fwd)

Mark Cullen mark.cullen at dsl.pipex.com
Wed Oct 27 10:58:55 PDT 2004


Timour Ezeev wrote:
 	Let me say that I wholeheartedly agree. I wrote it more as a joke rather
 	then a practical solution (didn't you notice :) in the end?). And I also
 	concur that malloc() call must be checked. I missed it :/ and should've
 	caught it right away.
 	Regards,

I actually noticed I didn't check malloc() after shortly after the 
second patch post. So I shouldn't worry about freeing it? Suits me :)

It kinda started to get a little messy. I'm sure someone can improve on 
it. So... is the attached patch sort of alright then?
--
Internet Explorer? Try FireFox at http://www.mozilla.org/products/firefox/
Outlook Express? Try ThunderBird at 
http://www.mozilla.org/products/thunderbird/
--- hunt.c.old	2004-10-27 16:44:06.000000000 +0100
+++ hunt.c	2004-10-27 18:58:37.000000000 +0100
@@ -59,16 +59,34 @@
 	char *name;
 {
 	register char *cp;
+	char *tmp_cp;
 	sig_t f;
-	int res;
+	int res, cp_len = 0;
 
 	f = signal(SIGALRM, dead);
 	while ((cp = getremote(name))) {
 		deadfl = 0;
-		if ((uucplock = strrchr(cp, '/')) == NULL)
-			uucplock = cp;
-		else
+
+		if ((uucplock = strrchr(cp, '/')) == NULL) {
+			cp_len = strlen(cp) + strlen("/dev/") + 1;
+			tmp_cp = malloc(sizeof(char) * cp_len);
+			if (tmp_cp == NULL) {
+				uucplock = cp;	
+			} else {
+				strncpy(tmp_cp, "/dev/", 6);
+				strncat(tmp_cp, cp, strlen(cp));
+	
+				if ((uucplock = strrchr(tmp_cp, '/')) == NULL) {
+					uucplock = cp;
+				} else {
+					cp = tmp_cp;
+					++uucplock;
+				}
+			}
+		} else {
 			++uucplock;
+		}
+
 		if ((res = uu_lock(uucplock)) != UU_LOCK_OK) {
 			if (res != UU_LOCK_INUSE)
 				fprintf(stderr, "uu_lock: %s\n", uu_lockerr(res));




More information about the Bugs mailing list