ncurses 5.6 - patch 20070901
[ncurses.git] / ncurses / base / lib_beep.c
index 3428aaf69e1605620f174aa251f79a5e6e3e597b..b478f251a1bbd88a7083f5d332c52eee608eec3a 100644 (file)
@@ -1,5 +1,5 @@
 /****************************************************************************
- * Copyright (c) 1998 Free Software Foundation, Inc.                        *
+ * Copyright (c) 1998-2000,2005 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            *
@@ -29,9 +29,9 @@
 /****************************************************************************
  *  Author: Zeyd M. Ben-Halim <zmbenhal@netcom.com> 1992,1995               *
  *     and: Eric S. Raymond <esr@snark.thyrsus.com>                         *
+ *     and: Thomas E. Dickey                        1996-on                 *
  ****************************************************************************/
 
-
 /*
  *     beep.c
  *
@@ -40,9 +40,9 @@
  */
 
 #include <curses.priv.h>
-#include <term.h>      /* beep, flash */
+#include <term.h>              /* beep, flash */
 
-MODULE_ID("$Id: lib_beep.c,v 1.7 1999/10/22 21:39:09 tom Exp $")
+MODULE_ID("$Id: lib_beep.c,v 1.10 2005/04/09 15:20:04 tom Exp $")
 
 /*
  *     beep()
@@ -52,22 +52,25 @@ MODULE_ID("$Id: lib_beep.c,v 1.7 1999/10/22 21:39:09 tom Exp $")
  *
  */
 
-int beep(void)
+NCURSES_EXPORT(int)
+beep(void)
 {
-       int res = ERR;
+    int res = ERR;
 
-       T((T_CALLED("beep()")));
+    T((T_CALLED("beep()")));
 
-       /* FIXME: should make sure that we are not in altchar mode */
-       if (bell) {
-               TPUTS_TRACE("bell");
-               res = putp(bell);
-               _nc_flush();
-       } else if (flash_screen) {
-               TPUTS_TRACE("flash_screen");
-               res = putp(flash_screen);
-               _nc_flush();
-       }
+    /* FIXME: should make sure that we are not in altchar mode */
+    if (cur_term == 0) {
+       res = ERR;
+    } else if (bell) {
+       TPUTS_TRACE("bell");
+       res = putp(bell);
+       _nc_flush();
+    } else if (flash_screen) {
+       TPUTS_TRACE("flash_screen");
+       res = putp(flash_screen);
+       _nc_flush();
+    }
 
-       returnCode(res);
+    returnCode(res);
 }