diff src/request.c @ 124:cfad9678e286 noffle

[svn] Applied patch from M.Nalis: Modify Req_add() to append to requested/news.serv.er file each MsgID (and do not clean dirty flag, because otherwise writeRequestfile() would nuke us when overwriting file!).
author enz
date Sat, 22 Jul 2000 10:04:20 +0100
parents 125d79c9e586
children fed1334d766b
line wrap: on
line diff
--- a/src/request.c	Sat Jul 22 07:21:11 2000 +0100
+++ b/src/request.c	Sat Jul 22 10:04:20 2000 +0100
@@ -3,7 +3,7 @@
 
   Collection of articles that are marked for download.
 
-  $Id: request.c 60 2000-05-09 22:28:38Z uh1763 $
+  $Id: request.c 178 2000-07-22 09:04:20Z enz $
 */
 
 #if HAVE_CONFIG_H
@@ -65,7 +65,7 @@
 static Bool     getReqserv      (const char* serv, Reqserv** rsz);
 static void     fileRequest     (Str file, const char *serv);
 static char**   searchMsgId     (const Reqserv * rs, const char *msgId);
-static void     storeMsgId      (Reqserv* rs, const char* msgId);
+static Bool     storeMsgId      (Reqserv* rs, const char* msgId);
 static Bool     readRequestfile (const char* serv, Reqserv** rsz);
 static time_t   get_mtime       (const char* serv);
 
@@ -178,13 +178,13 @@
 }
 
 
-static void storeMsgId(Reqserv* rs, const char* msgId)
+static Bool storeMsgId(Reqserv* rs, const char* msgId)
 {
   char* msgid;
 
   if (searchMsgId(rs, msgId))
     /* already recorded */
-    return;
+    return FALSE;
 
   msgid = strcpy(malloc(strlen(msgId)+1), msgId);
 
@@ -196,6 +196,34 @@
 
   *(rs->reql + rs->reql_length++) = msgid;
   rs->dirty = TRUE;
+  return TRUE;
+}
+
+static Bool
+appRequest (Reqserv* rs, const char *msgId)
+{
+    Str filename;
+    FILE*  file;
+
+    fileRequest(filename, rs->serv);
+    Log_dbg("appending to request file %s", filename);
+
+    if (Log_check((file = fopen(filename, "a")) != 0,
+            "could not open %s for appending: %s", 
+            filename, strerror(errno)))
+      return FALSE;
+    
+    if (Log_check(    fputs(msgId, file) != EOF
+                  &&  fputs("\n", file) != EOF,
+                  "write error: %s", strerror(errno)))
+      return FALSE;
+
+    if (Log_check(fclose(file) != EOF, 
+                "could not close %s properly: %s\n", 
+                filename, strerror(errno)))
+      return FALSE;
+
+    return TRUE;
 }
 
 
@@ -210,8 +238,9 @@
 
     if (getReqserv(serv, &rs) == FALSE) 
       return FALSE;
-    storeMsgId(rs, msgId);
+    if (storeMsgId(rs, msgId) == FALSE) /* already recorded */
     return TRUE;
+    return appRequest(rs, msgId);
 }
 
 static Bool