]> git.sur5r.net Git - openocd/commitdiff
jim: fix bug in tcl "puts"
authorØyvind Harboe <oyvind.harboe@zylin.com>
Tue, 18 May 2010 10:34:12 +0000 (12:34 +0200)
committerØyvind Harboe <oyvind.harboe@zylin.com>
Tue, 18 May 2010 10:34:12 +0000 (12:34 +0200)
tcl "puts" didn't work because the logging code sensored strings
that did not include a '\n'. The correct thing is to sensor
empty strings, which are used to keep gdb connection alive.

The tcl "puts" code broke apart strings which do contain '\n' in
order to implement the -nonewline argument, which is how it
got hurt by the bug in log.c

Signed-off-by: Øyvind Harboe <oyvind.harboe@zylin.com>
src/helper/log.c

index 7ace93026b7ad50a785298b7635dc1e1062f8028..da227bd72f279c3980c0cc7d9647238a1e83b6c0 100644 (file)
@@ -139,7 +139,7 @@ static void log_puts(enum log_levels level, const char *file, int line, const ch
        if (f != NULL)
                file = f + 1;
 
-       if (strchr(string, '\n') != NULL)
+       if (strlen(string) > 0)
        {
                if (debug_level >= LOG_LVL_DEBUG)
                {
@@ -163,17 +163,12 @@ static void log_puts(enum log_levels level, const char *file, int line, const ch
                {
                        /* if we are using gdb through pipes then we do not want any output
                         * to the pipe otherwise we get repeated strings */
-                       if (strcmp(string, "\n") != 0)
-                       {
-                               /* print human readable output - but skip empty lines */
-                               fprintf(log_output, "%s%s",
-                                               (level > LOG_LVL_USER)?log_strings[level + 1]:"", string);
-                       }
+                       fprintf(log_output, "%s%s",
+                                       (level > LOG_LVL_USER)?log_strings[level + 1]:"", string);
                }
        } else
        {
-               /* only entire lines are logged. Otherwise it's
-                * single chars intended for the log callbacks. */
+               /* Empty strings are sent to log callbacks to keep e.g. gdbserver alive, here we do nothing. */
        }
 
        fflush(log_output);