我想从stdin
处理管道/终端,但同时,我希望我的其他操作继续处理,例如 UP / DOWN菜单。
fgets
完成处理管道和屏幕渲染的行,然而,wgetch
变得没有响应,因此我无法在交换机内做任何事情。要关闭应用程序,我必须CTRL+c.
#include <curses.h>
#include <menu.h>
char *choices[] = { "Choice 1", "Exit" };
int main()
{
ITEM **my_items, *cur_item;
MENU *my_menu;
int i, c;
initscr();
cbreak();
noecho();
keypad(stdscr, TRUE);
FILE *fp = stdin;
char line [ 256 ];
while ( fgets ( line, sizeof line, fp) != NULL ) {
printw ( "%s", line);
}
my_items = (ITEM **)calloc(2 + 1, sizeof(ITEM *));
for(i = 0; i < 2; ++i)
my_items[i] = new_item(choices[i], choices[i]);
my_items[2] = (ITEM *)NULL;
my_menu = new_menu((ITEM **)my_items);
mvprintw(LINES - 2, 0, "F1 to Exit");
post_menu(my_menu);
refresh();
timeout(0);
while((c = wgetch(stdscr)) != KEY_F(1))
{ switch(c)
{ case KEY_DOWN:
menu_driver(my_menu, REQ_DOWN_ITEM);
break;
case KEY_UP:
menu_driver(my_menu, REQ_UP_ITEM);
break;
}
}
endwin();
}
答案 0 :(得分:1)
尝试在select
上使用fileno( stdin )
来判断何时可以从stdin读取内容。
查看this链接以获取示例。
还要记住,你必须消费准备从stdin读取的内容,否则select将继续表示准备就绪。
另请注意,这不适用于Windows。请查看使用PeekConsoleInput
。
答案 1 :(得分:1)
有几种方法可以解决这个问题。在我看来,这是更简单的:
以非阻塞方式从您的输入中读取。
使用I / O多路复用。在Unix中,那是select()
,poll()
及其表兄弟。
触发一个线程并让它在读取标准输入时阻止。
谷歌最适合你的是什么,周围有很多好消息。
答案 2 :(得分:1)
您不应该将fgets()
之类的stdio函数与wgetch()
这样的curses函数混合使用。
为内部调用fgets()
的{{1}}写一个替代品,累积字符直到输入换行符。