From 54c75c47f8df356361a1ecab121d4516652f6dfe Mon Sep 17 00:00:00 2001 From: Denis Kenzior Date: Mon, 16 Aug 2010 13:11:44 -0500 Subject: gatchat: Skip string contents in extract_line --- gatchat/gatchat.c | 9 +++++++-- 1 file changed, 7 insertions(+), 2 deletions(-) (limited to 'gatchat/gatchat.c') diff --git a/gatchat/gatchat.c b/gatchat/gatchat.c index 8f060eeb..e85d9086 100644 --- a/gatchat/gatchat.c +++ b/gatchat/gatchat.c @@ -592,18 +592,23 @@ static char *extract_line(struct at_chat *p, struct ring_buffer *rbuf) unsigned int wrap = ring_buffer_len_no_wrap(rbuf); unsigned int pos = 0; unsigned char *buf = ring_buffer_read_ptr(rbuf, pos); + gboolean in_string = FALSE; int strip_front = 0; int line_length = 0; char *line; while (pos < p->read_so_far) { - if (*buf == '\r' || *buf == '\n') + if (in_string == FALSE && (*buf == '\r' || *buf == '\n')) { if (!line_length) strip_front += 1; else break; - else + } else { + if (*buf == '"') + in_string = !in_string; + line_length += 1; + } buf += 1; pos += 1; -- cgit v1.2.3