From: Denis Kenzior Date: Fri, 26 Feb 2010 22:17:10 +0000 (-0600) Subject: Fix: Simplify write-again logic X-Git-Tag: 0.19~26 X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=7be80ef131d15304752e308ee906e1e6671ced86;p=platform%2Fupstream%2Fofono.git Fix: Simplify write-again logic --- diff --git a/gatchat/gatserver.c b/gatchat/gatserver.c index 05392e9..f19d267 100644 --- a/gatchat/gatserver.c +++ b/gatchat/gatserver.c @@ -485,7 +485,6 @@ static gboolean can_write_data(GIOChannel *channel, GIOCondition cond, gsize towrite; struct ring_buffer *write_buf; unsigned char *buf; - gboolean write_again = FALSE; #ifdef WRITE_SCHEDULER_DEBUG int limiter; #endif @@ -502,8 +501,6 @@ static gboolean can_write_data(GIOChannel *channel, GIOCondition cond, buf = ring_buffer_read_ptr(write_buf, 0); towrite = ring_buffer_len_no_wrap(write_buf); - if (towrite < (gsize)ring_buffer_len(write_buf)) - write_again = TRUE; #ifdef WRITE_SCHEDULER_DEBUG limiter = towrite; @@ -535,13 +532,13 @@ static gboolean can_write_data(GIOChannel *channel, GIOCondition cond, * unless it's the last buffer in the queue. */ if ((ring_buffer_len(write_buf) == 0) && - (g_queue_get_length(server->write_queue) != 1)) { + (g_queue_get_length(server->write_queue) > 1)) { write_buf = g_queue_pop_head(server->write_queue); ring_buffer_free(write_buf); - return TRUE; + write_buf = g_queue_peek_head(server->write_queue); } - if (bytes_written < towrite || write_again == TRUE) + if (ring_buffer_len(write_buf) > 0) return TRUE; return FALSE;