ncurses 6.0 - patch 20160528
[ncurses.git] / ncurses / base / lib_initscr.c
index b2fef0c1d0854651eb01eb9b39941afa3bb84cb0..8ed7aa7dbf2f981fc48942e6b7f443b1974b4b4b 100644 (file)
@@ -1,5 +1,5 @@
 /****************************************************************************
- * Copyright (c) 1998-2007,2008 Free Software Foundation, Inc.              *
+ * Copyright (c) 1998-2014,2016 Free Software Foundation, Inc.              *
  *                                                                          *
  * Permission is hereby granted, free of charge, to any person obtaining a  *
  * copy of this software and associated documentation files (the            *
 #include <sys/termio.h>                /* needed for ISC */
 #endif
 
-MODULE_ID("$Id: lib_initscr.c,v 1.38 2008/08/16 21:20:48 Werner.Fink Exp $")
+MODULE_ID("$Id: lib_initscr.c,v 1.41 2016/05/28 23:11:26 tom Exp $")
 
 NCURSES_EXPORT(WINDOW *)
 initscr(void)
 {
     WINDOW *result;
 
-    NCURSES_CONST char *name;
-
     START_TRACE();
     T((T_CALLED("initscr()")));
 
@@ -62,6 +60,8 @@ initscr(void)
 
     /* Portable applications must not call initscr() more than once */
     if (!_nc_globals.init_screen) {
+       NCURSES_CONST char *name;
+
        _nc_globals.init_screen = TRUE;
 
        if ((name = getenv("TERM")) == 0
@@ -75,9 +75,9 @@ initscr(void)
         * core when attempting to write to stdout.  Opening /dev/tty
         * explicitly seems to fix the problem.
         */
-       if (isatty(fileno(stdout))) {
+       if (NC_ISATTY(fileno(stdout))) {
            FILE *fp = fopen("/dev/tty", "w");
-           if (fp != 0 && isatty(fileno(fp))) {
+           if (fp != 0 && NC_ISATTY(fileno(fp))) {
                fclose(stdout);
                dup2(fileno(fp), STDOUT_FILENO);
                stdout = fdopen(STDOUT_FILENO, "w");
@@ -90,7 +90,11 @@ initscr(void)
        }
 
        /* def_shell_mode - done in newterm/_nc_setupscreen */
+#if NCURSES_SP_FUNCS
+       NCURSES_SP_NAME(def_prog_mode) (CURRENT_SCREEN);
+#else
        def_prog_mode();
+#endif
     }
     result = stdscr;
     _nc_unlock_global(curses);