]> jfr.im git - irc/gameservirc.git/blobdiff - gameserv/news.cpp
Fixed a core bug hopefully
[irc/gameservirc.git] / gameserv / news.cpp
index 371ce81f407020fdd179cfdfe3f5ad584e6bac3b..df06e70a59237e5320871e4f3735baff1c83c261 100644 (file)
@@ -6,6 +6,7 @@ using std::ifstream;
 
 List<myString> todaysnews;
 void addNews(List<myString> &news, const char *fmt, ...);
+void clearNews(List<myString> &news) {news.deleteNodes();};
 void showNews(char *nick, List<myString> &news);
 void saveNews(char *filename, List<myString> &news);
 void loadNews(char *filename, List<myString> &news);
@@ -18,6 +19,7 @@ void addNews(List<myString> &news, const char *fmt, ...)
     va_list args;
     char *input;
     input = new char[1024];
+    memset(input, 0, 1024);
     const char *t = fmt;
 
     va_start(args, fmt);
@@ -44,6 +46,7 @@ void addNews(List<myString> &news, const char *fmt, ...)
     #ifdef DEBUGMODE
         log("New News Item: %s", input);
     #endif
+
     myString *nstring;
     nstring = new myString(input);
     news.insertAtBack(nstring);
@@ -73,11 +76,9 @@ void showNews(char *nick, List<myString> &news)
 
 void saveNews(char *filename, List<myString> &news)
 {
-    if (news.isEmpty())
-       return;
-
     ofstream outfile;
     outfile.open(filename);
+
     if (outfile.fail())
     {
        log("Error opening %s", filename);
@@ -96,9 +97,6 @@ void saveNews(char *filename, List<myString> &news)
 
 void loadNews(char *filename, List<myString> &news)
 {
-    if (news.isEmpty())
-       return;
-
     // First clear the old news out
     ListNode<myString> *it, *temp;
     it = news.First();
@@ -125,6 +123,11 @@ void loadNews(char *filename, List<myString> &news)
 
     while (infile.getline(buf, 1024, '\n'))
     {
+       if (buf[0] == '\0' || buf[0] == '\n')
+       {
+           delete [] buf;
+           return;
+       }
        string = new myString(buf);
        news.insertAtBack(string);
        delete string;
@@ -132,3 +135,8 @@ void loadNews(char *filename, List<myString> &news)
 
     delete [] buf;
 }
+
+void do_news(char *u)
+{
+    showNews(u, todaysnews);
+}