我的应用程序有一个命令行界面,我正在考虑使用GNU Readline library来提供历史记录,可编辑的命令行等。
遗憾的是,我的命令可能非常冗长和复杂(想想SQL),并且我希望允许用户在多行上传播命令,以使它们在历史记录中更具可读性。
是否可以在readline中执行此操作(可能通过指定换行符和命令结尾之间的差异)?
或者我会更好地实现自己的命令行(但可能使用GNU History library)?
答案 0 :(得分:18)
你确定可以。
您可以使用
定义'\ r'和'\ n'值的选项rl_bind_key('\r', return_func);
您的return_func现在可以决定如何处理这些密钥。
int return_func(int cnt, int key) { ... }
如果您在UNIX终端中执行此操作,则需要了解ANSI终端代码(如果要移动光标)。维基百科上有一个starting reference。
下面是一些使用readline读取多行的示例代码,当您输入分号时我将停止编辑(我将其设置为EOQ或end-or-query)。 Readline非常强大,需要学习很多东西。
#include <stdio.h>
#include <unistd.h>
#include <readline/readline.h>
#include <readline/history.h>
int my_startup(void);
int my_bind_cr(int, int);
int my_bind_eoq(int, int);
char *my_readline(void);
int my_eoq;
int
main(int argc, char *argv[])
{
if (isatty(STDIN_FILENO)) {
rl_readline_name = "my";
rl_startup_hook = my_startup;
my_readline();
}
}
int
my_startup(void)
{
my_eoq = 0;
rl_bind_key('\n', my_bind_cr);
rl_bind_key('\r', my_bind_cr);
rl_bind_key(';', my_bind_eoq);
}
int
my_bind_cr(int count, int key) {
if (my_eoq == 1) {
rl_done = 1;
}
printf("\n");
}
int
my_bind_eoq(int count, int key) {
my_eoq = 1;
printf(";");
}
char *
my_readline(void)
{
char *line;
if ((line = readline("")) == NULL) {
return NULL;
}
printf("LINE : %s\n", line);
}