Remove dependencies on TGETENT, SIGINT, SIGKILL, and most terminal configuration logic.

This commit is contained in:
Gregory Nutt 2014-11-03 08:19:14 -06:00
parent d748a6dc92
commit abf3770bb2
7 changed files with 50 additions and 486 deletions

View File

@ -56,18 +56,4 @@ config INTERPRETER_BAS_HAVE_SYSCFG
---help--- ---help---
NuttX does not support the syscfg() function NuttX does not support the syscfg() function
config INTERPRETER_BAS_HAVE_SIGINT
bool
default n
depends on EXPERIMENTAL
---help---
NuttX does not support the SIGINT signal
config INTERPRETER_BAS_HAVE_SIGQUIT
bool
default n
depends on EXPERIMENTAL
---help---
NuttX does not support the SIGQUIT signal
endif endif

View File

@ -1553,7 +1553,6 @@ static struct Value *compileProgram(struct Value *v, int clearGlobals)
lastdata = &stack.begindata; lastdata = &stack.begindata;
} }
optionbase = 0; optionbase = 0;
FS_intr = 0;
stopped = 0; stopped = 0;
program.runnable = 1; program.runnable = 1;
pc = begin; pc = begin;
@ -1614,7 +1613,6 @@ static void runline(struct Token *line)
pc.line = -1; pc.line = -1;
pc.token = line; pc.token = line;
optionbase = 0; optionbase = 0;
FS_intr = 0;
stopped = 0; stopped = 0;
statements(&value); statements(&value);
if (value.type != V_ERROR && pc.token->type != T_EOL) if (value.type != V_ERROR && pc.token->type != T_EOL)
@ -1656,7 +1654,7 @@ static void runline(struct Token *line)
nextdata.line = -1; nextdata.line = -1;
Value_destroy(&value); Value_destroy(&value);
pass = INTERPRET; pass = INTERPRET;
FS_allowIntr(1);
do do
{ {
assert(pass == INTERPRET); assert(pass == INTERPRET);
@ -1698,7 +1696,6 @@ static void runline(struct Token *line)
} }
while (pc.token->type != T_EOL || while (pc.token->type != T_EOL ||
Program_skipEOL(&program, &pc, STDCHANNEL, 1)); Program_skipEOL(&program, &pc, STDCHANNEL, 1));
FS_allowIntr(0);
} }
static struct Value *evalGeometry(struct Value *value, unsigned int *dim, unsigned int geometry[]) static struct Value *evalGeometry(struct Value *value, unsigned int *dim, unsigned int geometry[])
@ -1843,12 +1840,7 @@ more:
else else
return Value_new_ERROR(value, MISSINGSTATEMENT); return Value_new_ERROR(value, MISSINGSTATEMENT);
if (FS_intr) if (pc.token->type == T_COLON && (pc.token + 1)->type == T_ELSE)
{
stopped = 1;
return Value_new_ERROR(value, BREAK);
}
else if (pc.token->type == T_COLON && (pc.token + 1)->type == T_ELSE)
++pc.token; ++pc.token;
else if ((pc.token->type == T_COLON && (pc.token + 1)->type != T_ELSE) || else if ((pc.token->type == T_COLON && (pc.token + 1)->type != T_ELSE) ||
pc.token->type == T_QUOTE) pc.token->type == T_QUOTE)
@ -1951,31 +1943,19 @@ void bas_interpreter(void)
struct Token *line; struct Token *line;
struct String s; struct String s;
FS_intr = 0;
stopped = 0; stopped = 0;
FS_allowIntr(1);
FS_nextline(STDCHANNEL); FS_nextline(STDCHANNEL);
if (FS_istty(STDCHANNEL)) if (FS_istty(STDCHANNEL))
FS_putChars(STDCHANNEL, "> "); FS_putChars(STDCHANNEL, "> ");
FS_flush(STDCHANNEL); FS_flush(STDCHANNEL);
String_new(&s); String_new(&s);
if (FS_appendToString(STDCHANNEL, &s, 1) == -1) if (FS_appendToString(STDCHANNEL, &s, 1) == -1)
{
if (FS_intr)
{
FS_putChars(STDCHANNEL, _("\nBreak\n"));
FS_flush(STDCHANNEL);
String_destroy(&s);
continue;
}
else
{ {
FS_putChars(STDCHANNEL, FS_errmsg); FS_putChars(STDCHANNEL, FS_errmsg);
FS_flush(STDCHANNEL); FS_flush(STDCHANNEL);
String_destroy(&s); String_destroy(&s);
break; break;
} }
}
if (s.length == 0) if (s.length == 0)
{ {
String_destroy(&s); String_destroy(&s);
@ -2029,7 +2009,6 @@ void bas_interpreter(void)
else else
Token_destroy(line); Token_destroy(line);
} }
FS_allowIntr(0);
} }
void bas_exit(void) void bas_exit(void)

View File

@ -5,9 +5,6 @@
/* The package name. */ /* The package name. */
#define PACKAGE "bas" #define PACKAGE "bas"
/* Do you have tgetent()? */
/* #undef HAVE_TGETENT */
/* Should we need to include termcap.h? */ /* Should we need to include termcap.h? */
/* #undef HAVE_TERMCAP_H */ /* #undef HAVE_TERMCAP_H */

View File

@ -113,41 +113,10 @@
static struct FileStream **file; static struct FileStream **file;
static int capacity; static int capacity;
static int used; static int used;
#ifdef CONFIG_SERIAL_TERMIOS
static struct termios origMode;
#endif
static struct termios rawMode;
static const int open_mode[4] = { 0, O_RDONLY, O_WRONLY, O_RDWR }; static const int open_mode[4] = { 0, O_RDONLY, O_WRONLY, O_RDWR };
#ifdef CONFIG_INTERPRETER_BAS_HAVE_SIGINT
static struct sigaction old_sigint;
#endif
#ifdef CONFIG_INTERPRETER_BAS_HAVE_SIGQUIT
static struct sigaction old_sigquit;
#endif
#ifdef CONFIG_SERIAL_TERMIOS
static int termchannel;
#endif
const char *FS_errmsg; const char *FS_errmsg;
static char FS_errmsgbuf[80]; static char FS_errmsgbuf[80];
volatile int FS_intr;
#ifdef HAVE_TGETENT
static char *term;
static char entrybuf[2048];
static char *cap;
static char *cl;
static char *cm;
static char *ce;
static char *cr;
static char *md;
static char *me;
static char *AF;
static char *AB;
static int Co;
static int NC;
#endif
/**************************************************************************** /****************************************************************************
* Private Functions * Private Functions
@ -327,24 +296,11 @@ static int edit(int chn, int onl)
return -1; return -1;
} }
if (ch == rawMode.c_cc[VERASE]) #ifdef CONFIG_INTERPREPTER_BAS_VT100
{ /* REVISIT: Use VT100 commands to erase */
if (f->inCapacity) #warning Missing Logic
{ #else
if (f->inBuf[f->inCapacity - 1] >= '\0' && if ((f->inCapacity + 1) < sizeof(f->inBuf))
f->inBuf[f->inCapacity - 1] < ' ')
{
FS_putChars(chn, "\b\b \b\b");
}
else
{
FS_putChars(chn, "\b \b");
}
--f->inCapacity;
}
}
else if ((f->inCapacity + 1) < sizeof(f->inBuf))
{ {
if (ch != '\n') if (ch != '\n')
{ {
@ -365,273 +321,52 @@ static int edit(int chn, int onl)
f->inBuf[f->inCapacity++] = ch; f->inBuf[f->inCapacity++] = ch;
} }
#endif
} }
while (ch != '\n'); while (ch != '\n');
return 0; return 0;
} }
#if defined(HAVE_TGETENT) || defined(CONFIG_SERIAL_TERMIOS)
static int outc(int ch)
{
struct FileStream *f;
if (opened(termchannel, 0) == -1)
{
return -1;
}
f = file[termchannel];
if (f->outSize + 1 >= f->outCapacity && FS_flush(termchannel) == -1)
{
return -1;
}
f->outBuf[f->outSize++] = ch;
FS_errmsg = (const char *)0;
return ch;
}
#endif
#ifdef HAVE_TGETENT
static int mytputs(const char *str, int affcnt, int (*out) (int))
{
# ifdef TPUTS_RETURNS_VOID
tputs(str, affcnt, out);
return 0;
# else
return tputs(str, affcnt, out);
# endif
}
#ifdef CONFIG_SERIAL_TERMIOS
static int initTerminal(int chn)
{
static int init = 0;
if (!init)
{
termchannel = chn;
if ((term = getenv("TERM")) == (char *)0)
{
FS_errmsg = _("environment variable TERM is not set");
return -1;
}
switch (tgetent(entrybuf, term))
{
case -1:
{
FS_errmsg = _("reading terminal description failed");
return -1;
}
case 0:
{
sprintf(FS_errmsgbuf, _("unknown terminal type %s"), term);
FS_errmsg = FS_errmsgbuf;
return -1;
}
case 1:
{
cl = tgetstr("cl", &cap);
cm = tgetstr("cm", &cap);
ce = tgetstr("ce", &cap);
cr = tgetstr("cr", &cap);
md = tgetstr("md", &cap);
me = tgetstr("me", &cap);
AF = tgetstr("AF", &cap);
AB = tgetstr("AB", &cap);
Co = tgetnum("Co");
if ((NC = tgetnum("NC")) == -1)
{
NC = 0;
}
return 0;
}
}
init = 1;
}
return 0;
}
#endif /* CONFIG_SERIAL_TERMIOS */
static int cls(int chn) static int cls(int chn)
{ {
if (cl == (char *)0) #ifdef CONFIG_INTERPREPTER_BAS_VT100
{ /* REVISIT: Use VT100 commands to clear the screen */
sprintf(FS_errmsgbuf, #warning Missing Logic
_("terminal type %s can not clear the screen"), term); #endif
FS_errmsg = FS_errmsgbuf; FS_errmsg = _("Clear screen operation not implemented");
return -1;
}
if (mytputs(cl, 0, outc) == -1)
{
return -1;
}
return 0;
}
static int locate(int chn, int line, int column)
{
termchannel = chn;
if (cm == (char *)0)
{
sprintf(FS_errmsgbuf,
_("terminal type %s can not position the cursor"), term);
FS_errmsg = FS_errmsgbuf;
return -1;
}
if (mytputs(tgoto(cm, column - 1, line - 1), 0, outc) == -1)
{
return -1;
}
return 0;
}
static int colour(int chn, int foreground, int background)
{
if (AF && AB && Co >= 8)
{
static int map[8] = { 0, 4, 2, 6, 1, 5, 3, 7 };
if (foreground != -1)
{
if (md && me && !(NC & 32))
{
if (foreground > 7 && file[chn]->outforeground <= 7)
{
if (mytputs(md, 0, outc) == -1)
{
return -1;
}
/* all attributes are gone now, need to set background
* again */
if (background == -1)
{
background = file[chn]->outbackground;
}
}
else if (foreground <= 7 && file[chn]->outforeground > 7)
{
if (mytputs(me, 0, outc) == -1)
{
return -1;
}
}
}
if (mytputs(tgoto(AF, 0, map[foreground & 7]), 0, outc) == -1)
{
return -1;
}
}
if (background != -1)
{
if (mytputs(tgoto(AB, 0, map[background & 7]), 0, outc) == -1)
{
return -1;
}
}
}
return 0;
}
static int resetcolour(int chn)
{
if (me)
{
mytputs(me, 0, outc);
}
if (ce)
{
mytputs(ce, 0, outc);
}
return 0;
}
#ifdef CONFIG_SERIAL_TERMIOS
static void carriage_return(int chn)
{
if (cr)
{
mytputs(cr, 0, outc);
}
else
{
outc('\r');
}
outc('\n');
}
#endif /* CONFIG_SERIAL_TERMIOS */
#else /* HAVE_TGETENT */
#ifdef CONFIG_SERIAL_TERMIOS
static int initTerminal(int chn)
{
termchannel = chn;
return 0;
}
#endif /* CONFIG_SERIAL_TERMIOS */
static int cls(int chn)
{
FS_errmsg = _("This installation does not support terminal handling");
return -1; return -1;
} }
static int locate(int chn, int line, int column) static int locate(int chn, int line, int column)
{ {
FS_errmsg = _("This installation does not support terminal handling"); #ifdef CONFIG_INTERPREPTER_BAS_VT100
/* REVISIT: Use VT100 commands to set the cursor position */
#warning Missing Logic
#endif
FS_errmsg = _("Set cursor position operation not implement");
return -1; return -1;
} }
static int colour(int chn, int foreground, int background) static int colour(int chn, int foreground, int background)
{ {
FS_errmsg = _("This installation does not support terminal handling"); #ifdef CONFIG_INTERPREPTER_BAS_VT100
/* REVISIT: Use VT100 commands to color */
#warning Missing Logic
#endif
FS_errmsg = _("Set color operation no implemented");
return -1; return -1;
} }
static int resetcolour(int chn) static int resetcolour(int chn)
{ {
#ifdef CONFIG_INTERPREPTER_BAS_VT100
/* REVISIT: Use VT100 commands to reset color */
#warning Missing Logic
#endif
return 0; return 0;
} }
#ifdef CONFIG_SERIAL_TERMIOS
static void carriage_return(int chn)
{
outc('\r');
outc('\n');
}
#endif /* CONFIG_SERIAL_TERMIOS */
#endif /* HAVE_TGETENT */
#ifdef CONFIG_INTERPRETER_BAS_HAVE_SIGINT
static void sigintr(int sig)
{
FS_intr = 1;
FS_allowIntr(0);
}
#endif
/**************************************************************************** /****************************************************************************
* Public Functions * Public Functions
****************************************************************************/ ****************************************************************************/
@ -651,38 +386,11 @@ int FS_opendev(int chn, int infd, int outfd)
file[chn] = malloc(sizeof(struct FileStream)); file[chn] = malloc(sizeof(struct FileStream));
file[chn]->dev = 1; file[chn]->dev = 1;
#ifdef CONFIG_SERIAL_TERMIOS #ifdef CONFIG_SERIAL_TERMIOS
if ((file[chn]->tty = (infd == 0 ? isatty(infd) && isatty(outfd) : 0))) file[chn]->tty = (infd == 0 ? isatty(infd) && isatty(outfd) : 0);
{
if (tcgetattr(infd, &origMode) == -1)
{
FS_errmsg = strerror(errno);
free(file[chn]);
file[chn] = (struct FileStream *)0;
return -1;
}
rawMode = origMode;
rawMode.c_lflag &= ~(ICANON | ECHO); /* IEXTEN would disable IUCLC,
* breaking UC only terminals */
rawMode.c_cc[VMIN] = 1;
rawMode.c_cc[VTIME] = 0;
rawMode.c_oflag &= ~ONLCR;
if (tcsetattr(infd, TCSADRAIN, &rawMode) == -1)
{
FS_errmsg = strerror(errno);
free(file[chn]);
file[chn] = (struct FileStream *)0;
return -1;
}
initTerminal(chn);
}
#else #else
file[chn]->tty = 1; file[chn]->tty = 1;
#endif #endif
file[chn]->recLength = 1; file[chn]->recLength = 1;
file[chn]->infd = infd; file[chn]->infd = infd;
file[chn]->inSize = 0; file[chn]->inSize = 0;
@ -1043,13 +751,6 @@ int FS_close(int dev)
close(file[dev]->binaryfd); close(file[dev]->binaryfd);
} }
#ifdef CONFIG_SERIAL_TERMIOS
if (file[dev]->tty)
{
tcsetattr(file[dev]->infd, TCSADRAIN, &origMode);
}
#endif
if (file[dev]->infd >= 0) if (file[dev]->infd >= 0)
{ {
close(file[dev]->infd); close(file[dev]->infd);
@ -1163,64 +864,15 @@ int FS_truncate(int chn)
void FS_shellmode(int dev) void FS_shellmode(int dev)
{ {
#if defined(CONFIG_INTERPRETER_BAS_HAVE_SIGINT) || defined(CONFIG_INTERPRETER_BAS_HAVE_SIGQUIT)
struct sigaction interrupt;
#endif
#ifdef CONFIG_SERIAL_TERMIOS
if (file[dev]->tty)
{
tcsetattr(file[dev]->infd, TCSADRAIN, &origMode);
}
#endif
#if defined(CONFIG_INTERPRETER_BAS_HAVE_SIGINT) || defined(CONFIG_INTERPRETER_BAS_HAVE_SIGQUIT)
interrupt.sa_flags = 0;
sigemptyset(&interrupt.sa_mask);
interrupt.sa_handler = SIG_IGN;
# ifdef CONFIG_INTERPRETER_BAS_HAVE_SIGINT
sigaction(SIGINT, &interrupt, &old_sigint);
# endif
# ifdef CONFIG_INTERPRETER_BAS_HAVE_SIGQUIT
sigaction(SIGQUIT, &interrupt, &old_sigquit);
# endif
#endif
} }
void FS_fsmode(int chn) void FS_fsmode(int chn)
{ {
#ifdef CONFIG_SERIAL_TERMIOS
if (file[chn]->tty)
{
tcsetattr(file[chn]->infd, TCSADRAIN, &rawMode);
}
#endif
#ifdef CONFIG_INTERPRETER_BAS_HAVE_SIGINT
sigaction(SIGINT, &old_sigint, (struct sigaction *)0);
#endif
#ifdef CONFIG_INTERPRETER_BAS_HAVE_SIGQUIT
sigaction(SIGQUIT, &old_sigquit, (struct sigaction *)0);
#endif
} }
void FS_xonxoff(int chn, int on) void FS_xonxoff(int chn, int on)
{ {
#ifdef CONFIG_SERIAL_TERMIOS /* Not implemented */
if (file[chn]->tty)
{
if (on)
{
rawMode.c_iflag |= (IXON | IXOFF);
}
else
{
rawMode.c_iflag &= ~(IXON | IXOFF);
}
tcsetattr(file[chn]->infd, TCSADRAIN, &rawMode);
}
#endif
} }
int FS_put(int chn) int FS_put(int chn)
@ -1280,30 +932,11 @@ int FS_putChar(int dev, char ch)
if (f->outLineWidth && f->outPos == f->outLineWidth) if (f->outLineWidth && f->outPos == f->outLineWidth)
{ {
#ifdef CONFIG_SERIAL_TERMIOS
if (FS_istty(dev))
{
carriage_return(dev);
}
else
#endif
{
f->outBuf[f->outSize++] = '\n'; f->outBuf[f->outSize++] = '\n';
}
f->outPos = 0; f->outPos = 0;
} }
#ifdef CONFIG_SERIAL_TERMIOS
if (FS_istty(dev) && ch == '\n')
{
carriage_return(dev);
}
else
#endif
{
f->outBuf[f->outSize++] = ch; f->outBuf[f->outSize++] = ch;
}
if (ch != '\n' && ch != '\b') if (ch != '\n' && ch != '\b')
{ {
@ -1767,8 +1400,6 @@ int FS_inkeyChar(int dev, int ms)
#ifdef USE_SELECT #ifdef USE_SELECT
fd_set just_infd; fd_set just_infd;
struct timeval timeout; struct timeval timeout;
#elif defined(CONFIG_SERIAL_TERMIOS)
struct termios timedread;
#endif #endif
if (opened(dev, 1) == -1) if (opened(dev, 1) == -1)
@ -1815,24 +1446,9 @@ int FS_inkeyChar(int dev, int ms)
return 0; return 0;
#else #else
#ifdef CONFIG_SERIAL_TERMIOS
timedread = rawMode;
timedread.c_cc[VMIN] = 0;
timedread.c_cc[VTIME] = (ms ? ms : 100) / 100;
if (tcsetattr(f->infd, TCSADRAIN, &timedread) == -1)
{
FS_errmsg = strerror(errno);
return -1;
}
#endif
FS_errmsg = (const char *)0; FS_errmsg = (const char *)0;
len = read(f->infd, &c, 1); len = read(f->infd, &c, 1);
#ifdef CONFIG_SERIAL_TERMIOS
tcsetattr(f->infd, TCSADRAIN, &rawMode);
#endif
if (len == -1) if (len == -1)
{ {
FS_errmsg = strerror(errno); FS_errmsg = strerror(errno);
@ -2223,16 +1839,3 @@ int FS_memOutput(int address, int value)
FS_errmsg = _("Direct memory access not available"); FS_errmsg = _("Direct memory access not available");
return -1; return -1;
} }
void FS_allowIntr(int on)
{
#ifdef CONFIG_INTERPRETER_BAS_HAVE_SIGINT
struct sigaction breakact;
breakact.sa_handler = on ? sigintr : SIG_IGN;
sigemptyset(&breakact.sa_mask);
sigaddset(&breakact.sa_mask, SIGINT);
breakact.sa_flags = 0;
sigaction(SIGINT, &breakact, (struct sigaction *)0);
#endif
}

View File

@ -55,7 +55,6 @@ struct FileStream
#define FS_LOCK_EXCLUSIVE 2 #define FS_LOCK_EXCLUSIVE 2
extern const char *FS_errmsg; extern const char *FS_errmsg;
extern volatile int FS_intr;
extern int FS_opendev(int dev, int infd, int outfd); extern int FS_opendev(int dev, int infd, int outfd);
extern int FS_openin(const char *name); extern int FS_openin(const char *name);
@ -116,6 +115,5 @@ extern int FS_portInput(int address);
extern int FS_memInput(int address); extern int FS_memInput(int address);
extern int FS_portOutput(int address, int value); extern int FS_portOutput(int address, int value);
extern int FS_memOutput(int address, int value); extern int FS_memOutput(int address, int value);
extern void FS_allowIntr(int on);
#endif #endif

View File

@ -749,7 +749,8 @@ struct Value *Program_list(struct Program *this, int dev, int watchIntr,
{ {
return Value_new_ERROR(value, IOERROR, FS_errmsg); return Value_new_ERROR(value, IOERROR, FS_errmsg);
} }
if (watchIntr && FS_intr)
if (watchIntr)
{ {
return Value_new_ERROR(value, BREAK); return Value_new_ERROR(value, BREAK);
} }

View File

@ -2973,9 +2973,9 @@ struct Value *stmt_OPTIONRUN(struct Value *value)
++pc.token; ++pc.token;
if (pass==INTERPRET) if (pass==INTERPRET)
{ {
FS_allowIntr(0);
FS_xonxoff(STDCHANNEL,0); FS_xonxoff(STDCHANNEL,0);
} }
return (struct Value*)0; return (struct Value*)0;
} }
@ -2984,9 +2984,9 @@ struct Value *stmt_OPTIONSTOP(struct Value *value)
++pc.token; ++pc.token;
if (pass==INTERPRET) if (pass==INTERPRET)
{ {
FS_allowIntr(1);
FS_xonxoff(STDCHANNEL,1); FS_xonxoff(STDCHANNEL,1);
} }
return (struct Value*)0; return (struct Value*)0;
} }
@ -3706,11 +3706,11 @@ struct Value *stmt_SLEEP(struct Value *value)
struct Value *stmt_STOP(struct Value *value) struct Value *stmt_STOP(struct Value *value)
{ {
if (pass==INTERPRET) FS_intr=1; if (pass!=INTERPRET)
else
{ {
++pc.token; ++pc.token;
} }
return (struct Value*)0; return (struct Value*)0;
} }