mirror of
https://github.com/radareorg/radare2.git
synced 2025-01-09 23:11:41 +00:00
109 lines
2.7 KiB
C
109 lines
2.7 KiB
C
/* radare - LGPL - Copyright 2007-2019 - pancake */
|
|
|
|
#include <r_util.h>
|
|
#include <r_cons.h>
|
|
|
|
static R_TH_LOCAL RLine r_line_instance;
|
|
#define I r_line_instance
|
|
|
|
R_API RLine *r_line_singleton(void) {
|
|
return &r_line_instance;
|
|
}
|
|
|
|
R_API RLine *r_line_new(void) {
|
|
I.hist_up = NULL;
|
|
I.hist_down = NULL;
|
|
I.prompt = strdup ("> ");
|
|
I.contents = NULL;
|
|
I.enable_vi_mode = false;
|
|
I.clipboard = NULL;
|
|
I.kill_ring = r_list_newf (NULL);
|
|
I.kill_ring_ptr = -1;
|
|
#if __WINDOWS__
|
|
I.vtmode = r_cons_is_vtcompat ();
|
|
#else
|
|
I.vtmode = 2;
|
|
#endif
|
|
if (!r_line_dietline_init ()) {
|
|
R_LOG_ERROR ("r_line_dietline_init has failed");
|
|
}
|
|
r_line_completion_init (&I.completion, 4096);
|
|
return &I;
|
|
}
|
|
|
|
R_API void r_line_free(void) {
|
|
// XXX: prompt out of the heap?
|
|
free ((void *)I.prompt);
|
|
I.prompt = NULL;
|
|
r_list_free (I.kill_ring);
|
|
r_line_hist_free ();
|
|
r_line_completion_fini (&I.completion);
|
|
}
|
|
|
|
R_API void r_line_clipboard_push(const char *str) {
|
|
I.kill_ring_ptr += 1;
|
|
r_list_insert (I.kill_ring, I.kill_ring_ptr, strdup (str));
|
|
}
|
|
|
|
// handle const or dynamic prompts?
|
|
R_API void r_line_set_prompt(const char *prompt) {
|
|
free (I.prompt);
|
|
I.prompt = strdup (prompt);
|
|
RCons *cons = r_cons_singleton ();
|
|
I.cb_fkey = cons->cb_fkey;
|
|
}
|
|
|
|
// handle const or dynamic prompts?
|
|
R_API char *r_line_get_prompt(void) {
|
|
return strdup (I.prompt);
|
|
}
|
|
|
|
R_API void r_line_completion_init(RLineCompletion *completion, size_t args_limit) {
|
|
completion->run = NULL;
|
|
completion->run_user = NULL;
|
|
completion->args_limit = args_limit;
|
|
r_pvector_init (&completion->args, free);
|
|
}
|
|
|
|
R_API void r_line_completion_fini(RLineCompletion *completion) {
|
|
r_line_completion_clear (completion);
|
|
}
|
|
|
|
R_API void r_line_completion_push(RLineCompletion *completion, const char *str) {
|
|
r_return_if_fail (completion && str);
|
|
if (completion->quit) {
|
|
return;
|
|
}
|
|
if (r_pvector_len (&completion->args) < completion->args_limit) {
|
|
char *s = strdup (str);
|
|
if (s) {
|
|
r_pvector_push (&completion->args, (void *)s);
|
|
}
|
|
} else {
|
|
completion->quit = true;
|
|
R_LOG_WARN ("Maximum completion capacity reached, increase scr.maxtab");
|
|
}
|
|
}
|
|
|
|
R_API void r_line_completion_set(RLineCompletion *completion, int argc, const char **argv) {
|
|
r_return_if_fail (completion && (argc >= 0));
|
|
r_line_completion_clear (completion);
|
|
if (argc > completion->args_limit) {
|
|
R_LOG_WARN ("Maximum completion capacity reached, increase scr.maxtab");
|
|
}
|
|
size_t count = R_MIN (argc, completion->args_limit);
|
|
r_pvector_reserve (&completion->args, count);
|
|
int i;
|
|
for (i = 0; i < count; i++) {
|
|
r_line_completion_push (completion, argv[i]);
|
|
}
|
|
}
|
|
|
|
R_API void r_line_completion_clear(RLineCompletion *completion) {
|
|
r_return_if_fail (completion);
|
|
completion->quit = false;
|
|
r_pvector_clear (&completion->args);
|
|
}
|
|
|
|
#include "dietline.c"
|