2 * Listener loop for subsystem library libss.a.
7 * Copyright 1987, 1988 by MIT Student Information Processing Board
9 * For copyright information, see copyright.h.
12 #include "copyright.h"
13 #include "ss_internal.h"
17 #include <sys/param.h>
23 static char const rcs_id[] =
27 typedef void sigret_t;
29 static ss_data *current_info;
30 static jmp_buf listen_jmpb;
32 static sigret_t print_prompt()
35 /* put input into a reasonable mode */
37 if (ioctl(fileno(stdin), TIOCGETP, &ttyb) != -1) {
38 if (ttyb.sg_flags & (CBREAK|RAW)) {
39 ttyb.sg_flags &= ~(CBREAK|RAW);
40 (void) ioctl(0, TIOCSETP, &ttyb);
44 (void) fputs(current_info->prompt, stdout);
45 (void) fflush(stdout);
48 static sigret_t listen_int_handler()
51 signal(SIGINT, listen_int_handler);
52 longjmp(listen_jmpb, 1);
55 int ss_listen (sci_idx)
60 sigret_t (*sig_int)(), (*sig_cont)(), (*old_sig_cont)();
67 ss_data *old_info = current_info;
69 current_info = info = ss_info(sci_idx);
70 sig_cont = (sigret_t (*)()) 0;
72 mask = sigblock(sigmask(SIGINT));
73 memcpy(old_jmpb, listen_jmpb, sizeof(jmp_buf));
74 sig_int = signal(SIGINT, listen_int_handler);
76 (void) sigsetmask(mask);
80 old_sig_cont = sig_cont;
81 sig_cont = signal(SIGCONT, print_prompt);
82 if (sig_cont == print_prompt)
83 sig_cont = old_sig_cont;
84 if (fgets(input, BUFSIZ, stdin) != input) {
88 cp = strchr(input, '\n');
94 (void) signal(SIGCONT, sig_cont);
95 for (end = input; *end; end++)
98 code = ss_execute_line (sci_idx, input);
99 if (code == SS_ET_COMMAND_NOT_FOUND) {
100 register char *c = input;
101 while (*c == ' ' || *c == '\t')
103 cp = strchr (c, ' ');
106 cp = strchr (c, '\t');
109 ss_error (sci_idx, 0,
110 "Unknown request \"%s\". Type \"?\" for a request list.",
116 (void) signal(SIGINT, sig_int);
117 memcpy(listen_jmpb, old_jmpb, sizeof(jmp_buf));
118 current_info = old_info;
122 void ss_abort_subsystem(sci_idx, code)
126 ss_info(sci_idx)->abort = 1;
127 ss_info(sci_idx)->exit_status = code;
131 int ss_quit(argc, argv, sci_idx, infop)
137 ss_abort_subsystem(sci_idx, 0);