[Spice-devel] [spice-gtk PATCH v2 14/17] log: use spice logging instead of (f)printf

Victor Toso victortoso at redhat.com
Fri Jan 8 00:51:44 PST 2016


---
 src/channel-cursor.c                   | 16 +++++++----
 src/coroutine_gthread.c                |  4 +--
 src/coroutine_ucontext.c               |  2 +-
 src/coroutine_winfibers.c              |  2 +-
 src/spice-channel.c                    | 50 ++++++++++++++++++++--------------
 src/spice-client-glib-usb-acl-helper.c |  6 ++--
 6 files changed, 47 insertions(+), 33 deletions(-)

diff --git a/src/channel-cursor.c b/src/channel-cursor.c
index 2dbdc90..16ac7b4 100644
--- a/src/channel-cursor.c
+++ b/src/channel-cursor.c
@@ -208,27 +208,31 @@ static void print_cursor(display_cursor *cursor, const guint8 *data)
 {
     int x, y, bpl;
     const guint8 *xor, *and;
+    GString *gstr = g_string_sized_new();
 
     bpl = (cursor->hdr.width + 7) / 8;
     and = data;
     xor = and + bpl * cursor->hdr.height;
 
-    printf("data (%d x %d):\n", cursor->hdr.width, cursor->hdr.height);
+    spice_debug("data (%d x %d):", cursor->hdr.width, cursor->hdr.height);
     for (y = 0 ; y < cursor->hdr.height; ++y) {
         for (x = 0 ; x < cursor->hdr.width / 8; x++) {
-            printf("%02X", and[x]);
+            g_string_append_printf(gstr, "%02X", and[x]);
         }
         and += bpl;
-        printf("\n");
+        spice_debug("%s", gstr->str);
+        gstr = g_string_set_size(gstr, 0);
     }
-    printf("xor:\n");
+    spice_debug("xor:");
     for (y = 0 ; y < cursor->hdr.height; ++y) {
         for (x = 0 ; x < cursor->hdr.width / 8; ++x) {
-            printf("%02X", xor[x]);
+            g_string_append_printf(gstr, "%02X", xor[x]);
         }
         xor += bpl;
-        printf("\n");
+        spice_debug("%s", gstr->str);
+        gstr = g_string_set_size(gstr, 0);
     }
+    g_string_free(gstr, TRUE);
 }
 #endif
 
diff --git a/src/coroutine_gthread.c b/src/coroutine_gthread.c
index abf149b..5c61423 100644
--- a/src/coroutine_gthread.c
+++ b/src/coroutine_gthread.c
@@ -30,7 +30,7 @@ static struct coroutine *current;
 static struct coroutine leader;
 
 #if 0
-#define CO_DEBUG(OP) fprintf(stderr, "%s %p %s %d\n", OP, g_thread_self(), __FUNCTION__, __LINE__)
+#define CO_DEBUG(OP) spice_debug("%s %p", OP, g_thread_self())
 #else
 #define CO_DEBUG(OP)
 #endif
@@ -155,7 +155,7 @@ void *coroutine_yield(void *arg)
 {
 	struct coroutine *to = coroutine_self()->caller;
 	if (!to) {
-		fprintf(stderr, "Co-routine is yielding to no one\n");
+		spice_warning("Co-routine is yielding to no one");
 		abort();
 	}
 
diff --git a/src/coroutine_ucontext.c b/src/coroutine_ucontext.c
index 84499dc..2ad2465 100644
--- a/src/coroutine_ucontext.c
+++ b/src/coroutine_ucontext.c
@@ -130,7 +130,7 @@ void *coroutine_yield(void *arg)
 {
 	struct coroutine *to = coroutine_self()->caller;
 	if (!to) {
-		fprintf(stderr, "Co-routine is yielding to no one\n");
+		spice_warning("Co-routine is yielding to no one");
 		abort();
 	}
 	coroutine_self()->caller = NULL;
diff --git a/src/coroutine_winfibers.c b/src/coroutine_winfibers.c
index dcd745d..ef07c1c 100644
--- a/src/coroutine_winfibers.c
+++ b/src/coroutine_winfibers.c
@@ -106,7 +106,7 @@ void *coroutine_yield(void *arg)
 {
 	struct coroutine *to = coroutine_self()->caller;
 	if (!to) {
-		fprintf(stderr, "Co-routine is yielding to no one\n");
+		spice_warning("Co-routine is yielding to no one");
 		abort();
 	}
 	coroutine_self()->caller = NULL;
diff --git a/src/spice-channel.c b/src/spice-channel.c
index 6560e3b..8ad6395 100644
--- a/src/spice-channel.c
+++ b/src/spice-channel.c
@@ -551,18 +551,27 @@ void *spice_msg_in_raw(SpiceMsgIn *in, int *len)
 static void hexdump(const char *prefix, unsigned char *data, int len)
 {
     int i;
+    GString *gstr;
 
+    /* Create a GString big enough for each hexdump line */
+    gstr = g_string_sized_new(40);
     for (i = 0; i < len; i++) {
-        if (i % 16 == 0)
-            fprintf(stderr, "%s:", prefix);
-        if (i % 4 == 0)
-            fprintf(stderr, " ");
-        fprintf(stderr, " %02x", data[i]);
-        if (i % 16 == 15)
-            fprintf(stderr, "\n");
+        if (i % 4 == 0) {
+            gstr = g_string_append(gstr, " ");
+        }
+
+        g_string_append_printf(gstr, " %02x", data[i]);
+
+        if (i % 16 == 15) {
+            spice_debug("%s:%s", prefix, gstr->str);
+            gstr = g_string_set_size(gstr, 0);
+        }
+    }
+
+    if (i % 16 != 0) {
+        spice_debug("%s:%s", prefix, gstr->str);
     }
-    if (i % 16 != 0)
-        fprintf(stderr, "\n");
+    g_string_free(gstr, TRUE);
 }
 
 G_GNUC_INTERNAL
@@ -570,11 +579,12 @@ void spice_msg_in_hexdump(SpiceMsgIn *in)
 {
     SpiceChannelPrivate *c = in->channel->priv;
 
-    fprintf(stderr, "--\n<< hdr: %s serial %" PRIu64 " type %d size %d sub-list %d\n",
-            c->name, spice_header_get_in_msg_serial(in),
-            spice_header_get_msg_type(in->header, c->use_mini_header),
-            spice_header_get_msg_size(in->header, c->use_mini_header),
-            spice_header_get_msg_sub_list(in->header, c->use_mini_header));
+    spice_debug("<< hdr: %s serial %" PRIu64 " type %d size %d sub-list %d",
+                c->name,
+                spice_header_get_in_msg_serial(in),
+                spice_header_get_msg_type(in->header, c->use_mini_header),
+                spice_header_get_msg_size(in->header, c->use_mini_header),
+                spice_header_get_msg_sub_list(in->header, c->use_mini_header));
     hexdump("<< msg", in->data, in->dpos);
 }
 
@@ -583,12 +593,12 @@ void spice_msg_out_hexdump(SpiceMsgOut *out, unsigned char *data, int len)
 {
     SpiceChannelPrivate *c = out->channel->priv;
 
-    fprintf(stderr, "--\n>> hdr: %s serial %" PRIu64 " type %d size %d sub-list %d\n",
-            c->name,
-            spice_header_get_out_msg_serial(out),
-            spice_header_get_msg_type(out->header, c->use_mini_header),
-            spice_header_get_msg_size(out->header, c->use_mini_header),
-            spice_header_get_msg_sub_list(out->header, c->use_mini_header));
+    spice_debug(">> hdr: %s serial %" PRIu64 " type %d size %d sub-list %d",
+                c->name,
+                spice_header_get_out_msg_serial(out),
+                spice_header_get_msg_type(out->header, c->use_mini_header),
+                spice_header_get_msg_size(out->header, c->use_mini_header),
+                spice_header_get_msg_sub_list(out->header, c->use_mini_header));
     hexdump(">> msg", data, len);
 }
 
diff --git a/src/spice-client-glib-usb-acl-helper.c b/src/spice-client-glib-usb-acl-helper.c
index bc09776..80cc1cd 100644
--- a/src/spice-client-glib-usb-acl-helper.c
+++ b/src/spice-client-glib-usb-acl-helper.c
@@ -40,15 +40,15 @@
     do { \
         /* We print the error both to stdout, for the app invoking us and \
            stderr for the end user */ \
-        fprintf(stdout, "Error " __VA_ARGS__); \
-        fprintf(stderr, "spice-client-glib-usb-helper: Error " __VA_ARGS__); \
+        spice_warning("Error " __VA_ARGS__); \
+        spice_printerr("spice-client-glib-usb-helper: Error " __VA_ARGS__); \
         exit_status = 1; \
         cleanup(); \
     } while (0)
 
 #define ERROR(...) \
     do { \
-        fprintf(stdout, __VA_ARGS__); \
+        spice_warning(__VA_ARGS__); \
         cleanup(); \
     } while (0)
 
-- 
2.5.0



More information about the Spice-devel mailing list