Rewrite to get ride of FORTRANish galaxy and newstuff arrays. It's
[super-star-trek.git] / io.c
diff --git a/io.c b/io.c
index 05dd489255287a20eb06bf386b1d5eaaf53c9b74..b3d2438d0b3ed289edd7a92c39790b696c5100da 100644 (file)
--- a/io.c
+++ b/io.c
@@ -5,20 +5,18 @@
 #include <signal.h>
 #include <ctype.h>
 #include <stdarg.h>
-#include <time.h>
 
 #include "sst.h"
 #include "sstlinux.h"
 
 static int linecount;  /* for paging */
-static int curses = TRUE;
 
 WINDOW *curwnd;
 
 static void outro(void)
 /* wrap up, either normally or due to signal */
 {
-    if (curses) {
+    if (game.options & OPTION_CURSES) {
        clear();
        curs_set(1);
        (void)refresh();
@@ -29,9 +27,9 @@ static void outro(void)
     }
 }
 
-void iostart(int usecurses
+void iostart(void
 {
-    if ((curses = usecurses)) {
+    if (game.options & OPTION_CURSES) {
 
        if (atexit(outro)){
            fprintf(stderr,"Unable to register outro(), exiting...\n");
@@ -63,7 +61,7 @@ void iostart(int usecurses)
        report_window     = newwin(10, 0,  1,       25);
        lrscan_window     = newwin(10, 0,  0,       64); 
        message_window    = newwin(0,  0,  12,      0);
-       prompt_window     = newwin(1,  0,  LINES-1, 0); 
+       prompt_window     = newwin(1,  0,  LINES-2, 0); 
        scrollok(message_window, TRUE);
        setwnd(fullscreen_window);
        textcolor(DEFAULT);
@@ -74,7 +72,7 @@ void iostart(int usecurses)
 void waitfor(void)
 /* wait for user action -- OK to do nothing if on a TTY */
 {
-    if (curses)
+    if (game.options & OPTION_CURSES)
        getch();
 }
 
@@ -83,19 +81,19 @@ void pause_game(int i)
     char *prompt;
     char buf[BUFSIZ];
     if (i==1) {
-       if (skill > 2)
+       if (skill > SKILL_FAIR)
            prompt = "[ANOUNCEMENT ARRIVING...]";
        else
            prompt = "[IMPORTANT ANNOUNCEMENT ARRIVING -- PRESS ENTER TO CONTINUE]";
     }
     else {
-       if (skill > 2)
+       if (skill > SKILL_FAIR)
            prompt = "[CONTINUE?]";
        else
            prompt = "[PRESS ENTER TO CONTINUE]";
 
     }
-    if (curses) {
+    if (game.options & OPTION_CURSES) {
        drawmaps(0);
        setwnd(prompt_window);
        wclear(prompt_window);
@@ -121,7 +119,7 @@ void pause_game(int i)
 void skip(int i) 
 {
     while (i-- > 0) {
-       if (curses) {
+       if (game.options & OPTION_CURSES) {
            proutn("\n\r");
        } else {
            linecount++;
@@ -135,7 +133,7 @@ void skip(int i)
 
 static void vproutn(char *fmt, va_list ap) 
 {
-    if (curses) {
+    if (game.options & OPTION_CURSES) {
        vwprintw(curwnd, fmt, ap);
        wrefresh(curwnd);
     }
@@ -163,7 +161,6 @@ void prout(char *fmt, ...)
 void prouts(char *fmt, ...) 
 /* print slowly! */
 {
-    clock_t endTime;
     char *s, buf[BUFSIZ];
     va_list ap;
     va_start(ap, fmt);
@@ -171,9 +168,8 @@ void prouts(char *fmt, ...)
     va_end(ap);
     skip(1);
     for (s = buf; *s; s++) {
-       endTime = clock() + CLOCKS_PER_SEC*0.05;
-       while (clock() < endTime) continue;
-       if (curses) {
+       delay(500);
+       if (game.options & OPTION_CURSES) {
            waddch(curwnd, *s);
            wrefresh(curwnd);
        }
@@ -186,7 +182,7 @@ void prouts(char *fmt, ...)
 
 void cgetline(char *line, int max)
 {
-    if (curses) {
+    if (game.options & OPTION_CURSES) {
        wgetnstr(curwnd, line, max);
        strcat(line, "\n");
        wrefresh(curwnd);
@@ -199,7 +195,7 @@ void cgetline(char *line, int max)
 void setwnd(WINDOW *wnd)
 /* change windows -- OK for this to be a no-op in tty mode */
 {
-    if (curses) {
+    if (game.options & OPTION_CURSES) {
      curwnd=wnd;
      curs_set(wnd == fullscreen_window || wnd == message_window || wnd == prompt_window);
     }
@@ -208,7 +204,7 @@ void setwnd(WINDOW *wnd)
 void clreol (void)
 /* clear to end of line -- can be a no-op in tty mode */
 {
-   if (curses) {
+   if (game.options & OPTION_CURSES) {
        wclrtoeol(curwnd);
        wrefresh(curwnd);
    }
@@ -217,7 +213,7 @@ void clreol (void)
 void clrscr (void)
 /* clear screen -- can be a no-op in tty mode */
 {
-   if (curses) {
+   if (game.options & OPTION_CURSES) {
        wclear(curwnd);
        wmove(curwnd,0,0);
        wrefresh(curwnd);
@@ -227,7 +223,7 @@ void clrscr (void)
 void textcolor (int color)
 {
 #ifdef A_COLOR
-    if (curses) {
+    if (game.options & OPTION_CURSES) {
        switch(color) {
        case DEFAULT: 
            wattrset(curwnd, 0);
@@ -287,7 +283,7 @@ void textcolor (int color)
 
 void highvideo (void)
 {
-    if (curses) {
+    if (game.options & OPTION_CURSES) {
        wattron(curwnd, A_REVERSE);
     }
 }
@@ -302,9 +298,9 @@ void commandhook(char *cmd, int before) {
 void drawmaps(short l)
 /* hook to be called after moving to redraw maps */
 {
-    if (curses) {
-       if (l == 1) 
-           sensor();
+    if (game.options & OPTION_CURSES) {
+       if (l == 1)
+           sensor(FALSE);
        if (l != 2) {
            setwnd(srscan_window);
            wmove(curwnd, 0, 0);
@@ -326,7 +322,7 @@ void drawmaps(short l)
 void boom(int ii, int jj)
 /* enemy fall down, go boom */ 
 {
-    if (curses) {
+    if (game.options & OPTION_CURSES) {
        setwnd(srscan_window);
        drawmaps(2);
        wmove(srscan_window, ii*2+3, jj+2);
@@ -348,7 +344,7 @@ void boom(int ii, int jj)
 void warble(void)
 /* sound and visual effects for teleportation */
 {
-    if (curses) {
+    if (game.options & OPTION_CURSES) {
        drawmaps(1);
        setwnd(message_window);
        sound(50);
@@ -361,7 +357,7 @@ void warble(void)
 void tracktorpedo(int x, int y, int ix, int iy, int wait, int l, int i, int n, int iquad)
 /* torpedo-track animation */
 {
-    if (!curses) {
+    if (!game.options & OPTION_CURSES) {
        if (l == 1) {
            if (n != 1) {
                skip(1);
@@ -403,7 +399,7 @@ void tracktorpedo(int x, int y, int ix, int iy, int wait, int l, int i, int n, i
 
 void makechart(void) 
 {
-    if (curses) {
+    if (game.options & OPTION_CURSES) {
        setwnd(message_window);
        wclear(message_window);
        chart(0);
@@ -412,7 +408,7 @@ void makechart(void)
 
 void setpassword(void) 
 {
-    if (!curses) {
+    if (!(game.options & OPTION_CURSES)) {
        while (TRUE) {
            scan();
            strcpy(game.passwd, citem);