--- bpatch.c.orig Wed Jan 17 08:33:33 1990 +++ bpatch.c Sat Sep 18 18:08:04 1999 @@ -90,10 +90,15 @@ /*E*/ /*S includes, globals, and defines */ /*Page Eject*/ -#include +#include #include #include #include +#include +#include +#include +#include +#include #include #include @@ -103,14 +108,8 @@ void icc (); void copyrec (); void schwapp (); - -/* added declarations, mostly for cleanliness */ -extern long lseek(); -extern long atol(); -extern char *strncpy(); -extern void exit(); -extern unsigned sleep(); /* signal problems ??? if sleep called */ -extern void perror(); +void breakp (); +void reset (); /* set up for calls to outstr and errmsg, etc, */ /* by use of sprintf to fill outbuf */ @@ -190,7 +189,7 @@ #ifdef MOD_HAX #else /* use original code... */ /* plus some more for restoring terminal function */ - struct termio asis, aswas; + struct termios asis, aswas; #endif /* MOD_HAX */ /*S main - control all the work from here */ @@ -210,12 +209,10 @@ extern WINDOW *newwin (); register char *cp; /* general purpose char ptr */ - extern char *gets (); /* get string from stdin */ char m = '\017'; /* mask for hex edit */ char response[512]; /* general purpose buffer */ int z; /* character read in */ - int breakp (); /* signal trapping function */ int c; /* current screen column */ int change = 0; /* true if cmd line option toggled */ int fid; /* file descriptor */ @@ -234,8 +231,7 @@ extern char *optarg; /* getopt pointer to opt arg */ extern long getnum (); - extern char *instr (); /* get a string from the cmd line */ - extern int reset (); /* exit function - reset terminal */ + extern char *myinstr (); /* get a string from the cmd line */ /* ------------------------------------------------------------ */ /* set up signal handling */ @@ -333,19 +329,27 @@ alphawin = subwin (stdscr, 16, 16, 4, 57); keypad (alphawin, TRUE); errwin = subwin (stdscr, 1, 80, 23, 0); + if (errwin == NULL) + errwin = stdscr; + if (hexwin == NULL || alphawin == NULL) + { + fprintf(stderr, "Can't create all necessary curses windows.\n"); + reset (0); + exit (2); + } #ifdef MOD_HAX /* This is not exactly what the original code does, but it's good enough. -r$ */ raw(); #else /* use original code... */ - ioctl (0, TCGETA, &asis); + tcgetattr (0, &asis); aswas = asis; /* save termio stuff for later restore */ asis.c_cc[VINTR] = '\0'; asis.c_iflag &= ~IXON; asis.c_iflag &= ~IXOFF; asis.c_iflag &= ~IXANY; - ioctl (0, TCSETA, &asis); + tcsetattr (0, TCSANOW, &asis); #endif /* MOD_HAX */ } @@ -478,7 +482,9 @@ } pbrk = 0; fprintf (stderr, "\007"); - gets (response); + fgets (response, 512, stdin); + if ((cp = strchr (response, '\n'))) + *cp = 0; if (pbrk) status = EOF; } @@ -617,7 +623,7 @@ case '\006': /* new file (^F) */ close (fid); - fid = ckfile (cp = instr (), &size); + fid = ckfile (cp = myinstr (), &size); if (fid < 0) { fid = ckfile (filename, &size); @@ -832,7 +838,8 @@ touchwin (alphawin); wrefresh (alphawin); - while ((z = wgetch (alphawin)) != DEL) + while ((z = wgetch (alphawin)) != KEY_DC && + z != KEY_BACKSPACE) { if (!arrow (z, &r, &c)) { @@ -902,7 +909,8 @@ touchwin (hexwin); wrefresh (hexwin); - while ((z = wgetch (hexwin)) != DEL) + while ((z = wgetch (hexwin)) != KEY_DC + && z != KEY_BACKSPACE) { if (!arrow (z, &r, &c)) { @@ -1281,7 +1289,7 @@ /*S breakp - set pbrk on interrupt */ /*H breakp */ /*E*/ -int breakp (i) +void breakp (i) int i; { int s; @@ -1592,6 +1600,7 @@ /*S reset - reset terminal to original state */ /*H reset */ /*E*/ +void reset (sig) int sig; { @@ -1600,7 +1609,7 @@ move (23, 0); refresh (); #ifndef MOD_HAX - ioctl (0, TCSETA, &aswas); + tcsetattr (0, TCSANOW, &aswas); #endif endwin (); } @@ -1610,7 +1619,6 @@ fprintf (stderr, "killed with signal %d\n", sig); exit (sig); } - return (0); } /*S arrow - determine if current character is a cursor control key */ /*H arrow */ @@ -1683,11 +1691,11 @@ return; } -/*S instr - get a character string from the terminal */ -/*H instr */ +/*S myinstr - get a character string from the terminal */ +/*H myinstr */ /*E*/ char * -instr () +myinstr () { static char buf[512]; @@ -1827,7 +1835,7 @@ register int matched = 0; register int srch_len; - register char *cp = instr (); + register char *cp = myinstr (); register char *rp; int row, col; @@ -1924,8 +1932,8 @@ outstr (fmt) char *fmt; { - if (dump) printf (fmt); - else printw (fmt); + if (dump) printf ("%s", fmt); + else printw ("%s", fmt); return; }