X-Git-Url: https://git.zerfleddert.de/cgi-bin/gitweb.cgi/proxmark3-svn/blobdiff_plain/7fe9b0b742d7dae9c5af1d292d11840b5c3cbfae..f208c9e281295074e67da04f1527865fae7b2b74:/client/ui.c?ds=sidebyside diff --git a/client/ui.c b/client/ui.c index 9f4377c8..09479620 100644 --- a/client/ui.c +++ b/client/ui.c @@ -1,17 +1,32 @@ +//----------------------------------------------------------------------------- +// Copyright (C) 2009 Michael Gernoth +// Copyright (C) 2010 iZsh +// +// This code is licensed to you under the terms of the GNU GPL, version 2 or, +// at your option, any later version. See the LICENSE.txt file for the text of +// the license. +//----------------------------------------------------------------------------- +// UI utilities +//----------------------------------------------------------------------------- + #include +#include #include #include +#include #include "ui.h" double CursorScaleFactor; -int PlotGridX, PlotGridY; +int PlotGridX, PlotGridY, PlotGridXdefault= 64, PlotGridYdefault= 64; int offline; static char *logfilename = "proxmark3.log"; void PrintAndLog(char *fmt, ...) { + char *saved_line; + int saved_point; va_list argptr, argptr2; static FILE *logfile = NULL; static int logging=1; @@ -23,24 +38,33 @@ void PrintAndLog(char *fmt, ...) logging=0; } } + + int need_hack = (rl_readline_state & RL_STATE_READCMD) > 0; + if (need_hack) { + saved_point = rl_point; + saved_line = rl_copy_text(0, rl_end); + rl_save_prompt(); + rl_replace_line("", 0); + rl_redisplay(); + } + va_start(argptr, fmt); va_copy(argptr2, argptr); vprintf(fmt, argptr); + printf(" "); // cleaning prompt va_end(argptr); printf("\n"); - if (logging && logfile) { -#if 0 - char zeit[25]; - time_t jetzt_t; - struct tm *jetzt; - jetzt_t = time(NULL); - jetzt = localtime(&jetzt_t); - strftime(zeit, 25, "%b %e %T", jetzt); - - fprintf(logfile,"%s ", zeit); -#endif + if (need_hack) { + rl_restore_prompt(); + rl_replace_line(saved_line, 0); + rl_point = saved_point; + rl_redisplay(); + free(saved_line); + } + + if (logging && logfile) { vfprintf(logfile, fmt, argptr2); fprintf(logfile,"\n"); fflush(logfile);