#include <assert.h>
#include <err.h>
#include <errno.h>
#include <locale.h>
#include <stdio.h>
#include <stdlib.h>
#include "read.c"
#include "glue.c"
#define N_KEYS 256
int
main()
{
EditLine el;
struct macros *ma;
int irc;
wchar_t ch;
el_action_t cmdnum;
if (setlocale(LC_CTYPE, "") == NULL)
err(1, "setlocale");
el.el_flags = CHARSET_IS_UTF8;
el.el_infd = STDIN_FILENO;
el.el_state.metanext = 0;
el.el_map.alt = NULL;
if ((el.el_map.key = calloc(N_KEYS, sizeof(el_action_t))) == NULL)
err(1, NULL);
el.el_map.key[(unsigned char)'c'] = ED_SEQUENCE_LEAD_IN;
el.el_map.key[(unsigned char)'i'] = ED_INSERT;
el.el_map.key[(unsigned char)'s'] = ED_SEQUENCE_LEAD_IN;
el.el_map.current = el.el_map.key;
if ((el.el_signal = calloc(1, sizeof(*el.el_signal))) == NULL)
err(1, NULL);
if (read_init(&el) != 0)
err(1, "read_init");
ma = &el.el_read->macros;
el.el_read->read_errno = ENOMSG;
do {
irc = read_getcmd(&el, &cmdnum, &ch);
switch (irc) {
case 0:
fputs("OK ", stdout);
switch (cmdnum) {
case ED_COMMAND:
fputs("command", stdout);
break;
case ED_INSERT:
fputs("insert", stdout);
break;
default:
printf("cmdnum=%u", cmdnum);
break;
}
printf(" L'%lc'", ch);
break;
case -1:
fputs("EOF", stdout);
break;
default:
printf("ret(%d)", irc);
break;
}
if (el.el_read->read_errno != ENOMSG)
printf(" read_errno=%d", el.el_read->read_errno);
if (ma->level > -1)
printf(" macro[%d]=%ls(%d)", ma->level,
*ma->macro, ma->offset);
putchar('\n');
} while (irc == 0);
return 0;
}