Improve exit status display. New interface from `doto' project.
[sw-tools] / src / pres_curses.c
index a134eac..44770c6 100644 (file)
@@ -1,6 +1,6 @@
 /* -*-c-*-
  *
- * $Id: pres_curses.c,v 1.1 1999/06/02 16:53:35 mdw Exp $
+ * $Id: pres_curses.c,v 1.3 1999/07/16 12:49:58 mdw Exp $
  *
  * Curses-based output presentation
  *
 /*----- Revision history --------------------------------------------------* 
  *
  * $Log: pres_curses.c,v $
- * Revision 1.1  1999/06/02 16:53:35  mdw
- * Initial revision
+ * Revision 1.3  1999/07/16 12:49:58  mdw
+ * Improve exit status display.  New interface from `doto' project.
+ *
+ * Revision 1.2  1999/06/24 15:51:16  mdw
+ * Fix signal handlers so they don't corrupt `errno'.
+ *
+ * Revision 1.1.1.1  1999/06/02 16:53:35  mdw
+ * Initial import.
  *
  */
 
@@ -121,7 +127,9 @@ static void sizes(void)
 #ifdef SIGTSTP
 static void sig_tstp(int s)
 {
+  int e = errno;
   endwin();
+  errno = e;
   raise(SIGSTOP);
 }
 #endif
@@ -131,7 +139,9 @@ static void sig_tstp(int s)
 #ifdef SIGTSTP
 static void sig_cont(int s)
 {
+  int e = errno;
   wrefresh(curscr);
+  errno = e;
 }
 #endif
 
@@ -142,6 +152,8 @@ static void sig_cont(int s)
 static void sig_winch(int s)
 {
   cwin *c;
+  int e = errno;
+
   endwin();
   refresh();
   sizes();
@@ -153,6 +165,7 @@ static void sig_winch(int s)
     wnoutrefresh(c->s);
   }
   doupdate();
+  errno = e;
 }
 
 #endif
@@ -220,7 +233,7 @@ int curses_init(archcons *a)
     leaveok(c->s, TRUE);
     wbkgdset(c->s, A_STANDOUT);
     werase(c->s);
-    mvwprintw(c->s, 0, 0, "  %s  [running]\n", c->e->arch);
+    mvwprintw(c->s, 0, 0, "  %s [running]\n", c->e->arch);
     wnoutrefresh(c->w);
     wnoutrefresh(c->s);
   }
@@ -265,10 +278,10 @@ void curses_output(archent *e, const char *p, size_t sz)
 
 /* --- @curses_close@ --- */
 
-void curses_close(archent *e, int ok)
+void curses_close(archent *e, int ok, const char *summ)
 {
   cwin *c = e->pres;
-  mvwprintw(c->s, 0, 0, "  %s [%s]\n", e->arch, ok ? "finished" : "failed");
+  mvwprintw(c->s, 0, 0, "  %s [%s]\n", e->arch, summ);
   wrefresh(c->s);
 }