mirror of
https://github.com/radareorg/radare2.git
synced 2025-01-25 07:15:19 +00:00
105 lines
2.2 KiB
C
105 lines
2.2 KiB
C
/* radare - LGPL - Copyright 2009-2013 - pancake */
|
|
|
|
#include <r_core.h>
|
|
|
|
R_API int r_core_log_list(RCore *core, int n, int nth, char fmt) {
|
|
int printed = 0;
|
|
int count = 0, i, idx, id = core->log->first;
|
|
RStrpool *sp = core->log->sp;
|
|
char *str = sp->str;
|
|
|
|
if (fmt == 'j') {
|
|
r_cons_printf ("[");
|
|
}
|
|
for (i = idx = 0; str && *str; i++, id++) {
|
|
if ((n && n <= id) || !n) {
|
|
switch (fmt) {
|
|
case 'j': r_cons_printf ("%s[%d,\"%s\"]",
|
|
printed? ",": "", id, str); break;
|
|
case 't': r_cons_println (str); break;
|
|
case '*': r_cons_printf ("\"l %s\"\n", str); break;
|
|
default: r_cons_printf ("%d %s\n", id, str); break;
|
|
}
|
|
printed++;
|
|
if (nth && printed >= nth) {
|
|
break;
|
|
}
|
|
}
|
|
str = r_strpool_next (sp, idx);
|
|
if (!str) {
|
|
break;
|
|
}
|
|
idx = r_strpool_get_index (sp, str);
|
|
count++;
|
|
}
|
|
if (fmt == 'j') {
|
|
r_cons_printf ("]\n");
|
|
}
|
|
return count;
|
|
}
|
|
|
|
R_API RCoreLog *r_core_log_new() {
|
|
RCoreLog *log = R_NEW0 (RCoreLog);
|
|
if (!log) {
|
|
return NULL;
|
|
}
|
|
r_core_log_init (log);
|
|
return log;
|
|
}
|
|
|
|
R_API void r_core_log_init(RCoreLog *log) {
|
|
log->first = 1;
|
|
log->last = 1;
|
|
log->sp = r_strpool_new (0);
|
|
}
|
|
|
|
R_API void r_core_log_free(RCoreLog *log) {
|
|
r_strpool_free (log->sp);
|
|
free (log);
|
|
}
|
|
|
|
R_API void r_core_log_add(RCore *core, const char *msg) {
|
|
static bool inProcess = false;
|
|
r_strpool_append (core->log->sp, msg);
|
|
core->log->last++;
|
|
if (core->cmdlog && *core->cmdlog) {
|
|
if (inProcess) {
|
|
// avoid infinite recursive calls
|
|
return;
|
|
}
|
|
inProcess = true;
|
|
r_core_cmd0 (core, core->cmdlog);
|
|
inProcess = false;
|
|
}
|
|
}
|
|
|
|
R_API void r_core_log_del(RCore *core, int n) {
|
|
int idx;
|
|
if (n > 0) {
|
|
if (n + 1 >= core->log->last) {
|
|
core->log->first = core->log->last;
|
|
r_strpool_empty (core->log->sp);
|
|
return;
|
|
}
|
|
if (n < core->log->first) {
|
|
return;
|
|
}
|
|
idx = n - core->log->first;
|
|
if (idx < 0) {
|
|
return;
|
|
}
|
|
core->log->first += idx + 1;
|
|
char *msg = r_strpool_get_i (core->log->sp, idx);
|
|
// if (idx >= core->log->last) {
|
|
if (!msg || !*msg) {
|
|
core->log->first = core->log->last;
|
|
r_strpool_empty (core->log->sp);
|
|
} else {
|
|
r_strpool_slice (core->log->sp, idx);
|
|
}
|
|
} else {
|
|
core->log->first = core->log->last;
|
|
r_strpool_empty (core->log->sp);
|
|
}
|
|
}
|