У меня есть код, похожий на следующий, используя readline:
#include <errno.h>
#include <error.h>
#include <getopt.h>
#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <signal.h>
#include <readline/readline.h>
#include <readline/history.h>
void handle_signals(int signo) {
if (signo == SIGINT) {
printf("You pressed Ctrl+C\n");
}
}
int main (int argc, char **argv)
{
//printf("path is: %s\n", path_string);
char * input;
char * shell_prompt = "i-shell> ";
if (signal(SIGINT, handle_signals) == SIG_ERR) {
printf("failed to register interrupts with kernel\n");
}
//set up custom completer and associated data strucutres
setup_readline();
while (1)
{
input = readline(shell_prompt);
if (!input)
break;
add_history(input);
//do something with the code
execute_command(input);
}
return 0;
}
Я настроил его на перехват SIGINT
(т.е. нажатие кнопки Ctrl+C
), поэтому я могу сказать, что обработчик сигнала handle_signals()
работает. Однако, когда элемент управления возвращается к readline()
, он использует ту же строку текста, которую он использовал до ввода. Я бы хотел, чтобы readline "отменил" текущую строку текста и дал мне новую строку, подобно оболочке BASH. Что-то вроде этого:
i-shell> bad_command^C
i-shell> _
Есть ли шанс заставить это работать? Что-то в списке рассылки, о котором я читал, упоминается с помощью longjmp(2)
, но это действительно не похоже на хорошую идею.