summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSebastien Helleu <flashcode@flashtux.org>2008-10-31 10:32:53 +0100
committerSebastien Helleu <flashcode@flashtux.org>2008-10-31 10:32:53 +0100
commit72c0321b5475423319a65d45e3bb103e0d2f221c (patch)
treef69e1348b8161d40200aed3f7dc4910d029f110a
parenta0d233bd4ed99b5ef1ba10878cc70f2e725eda74 (diff)
downloadweechat-72c0321b5475423319a65d45e3bb103e0d2f221c.zip
Fix backlog in logger plugin (empty line incorrectly displayed at the end of backlog)
-rw-r--r--src/plugins/logger/logger-tail.c58
1 files changed, 30 insertions, 28 deletions
diff --git a/src/plugins/logger/logger-tail.c b/src/plugins/logger/logger-tail.c
index 2023252b3..30b2adac5 100644
--- a/src/plugins/logger/logger-tail.c
+++ b/src/plugins/logger/logger-tail.c
@@ -30,7 +30,6 @@
#include <fcntl.h>
#include <string.h>
-#include "../weechat-plugin.h"
#include "logger.h"
#include "logger-tail.h"
@@ -123,38 +122,41 @@ logger_tail_file (const char *filename, int n_lines)
pos_eol[0] = '\0';
pos_eol++;
}
- new_line = malloc (sizeof (*new_line));
- if (!new_line)
+ if (part_of_line || pos_eol[0])
{
- logger_tail_free (ptr_line);
- ptr_line = NULL;
- break;
- }
- if (part_of_line)
- {
- new_line->data = malloc ((strlen (pos_eol) +
- strlen (part_of_line) + 1));
- if (!new_line->data)
+ new_line = malloc (sizeof (*new_line));
+ if (!new_line)
{
- free (part_of_line);
logger_tail_free (ptr_line);
- close (fd);
- return NULL;
+ ptr_line = NULL;
+ break;
}
- strcpy (new_line->data, pos_eol);
- strcat (new_line->data, part_of_line);
- free (part_of_line);
- part_of_line = NULL;
- }
- else
- {
- new_line->data = strdup (pos_eol);
+ if (part_of_line)
+ {
+ new_line->data = malloc ((strlen (pos_eol) +
+ strlen (part_of_line) + 1));
+ if (!new_line->data)
+ {
+ free (part_of_line);
+ logger_tail_free (ptr_line);
+ close (fd);
+ return NULL;
+ }
+ strcpy (new_line->data, pos_eol);
+ strcat (new_line->data, part_of_line);
+ free (part_of_line);
+ part_of_line = NULL;
+ }
+ else
+ {
+ new_line->data = strdup (pos_eol);
+ }
+ new_line->next_line = ptr_line;
+ ptr_line = new_line;
+ n_lines--;
+ if (n_lines <= 0)
+ break;
}
- new_line->next_line = ptr_line;
- ptr_line = new_line;
- n_lines--;
- if (n_lines <= 0)
- break;
}
else if (!pos_eol)
{