]> ncurses.scripts.mit.edu Git - ncurses.git/blobdiff - ncurses/base/lib_slkatr_set.c
ncurses 6.1 - patch 20180317
[ncurses.git] / ncurses / base / lib_slkatr_set.c
index f83616beaf1735f1dc64703f389452540bad8914..fa701f0b10089a2d6c53ed356bb44f704149f0f7 100644 (file)
@@ -1,5 +1,5 @@
 /****************************************************************************
- * Copyright (c) 1998-2003,2005 Free Software Foundation, Inc.              *
+ * Copyright (c) 1998-2004,2017 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            *
@@ -28,7 +28,7 @@
 
 /****************************************************************************
  *  Author:  Juergen Pfeifer, 1998                                          *
- *     and:  Thomas E. Dickey 2005                                          *
+ *     and:  Thomas E. Dickey 2005-on                                       *
  ****************************************************************************/
 
 /*
  */
 #include <curses.priv.h>
 
-MODULE_ID("$Id: lib_slkatr_set.c,v 1.10 2005/01/28 21:11:53 tom Exp $")
+MODULE_ID("$Id: lib_slkatr_set.c,v 1.16 2017/03/16 23:45:36 tom Exp $")
 
 NCURSES_EXPORT(int)
-slk_attr_set(const attr_t attr, short color_pair_number, void *opts)
+NCURSES_SP_NAME(slk_attr_set) (NCURSES_SP_DCLx
+                              const attr_t attr,
+                              NCURSES_PAIRS_T pair_arg,
+                              void *opts)
 {
-    T((T_CALLED("slk_attr_set(%s,%d)"), _traceattr(attr), color_pair_number));
+    int code = ERR;
+    int color_pair = pair_arg;
 
-    if (SP != 0 && SP->_slk != 0 && !opts &&
-       color_pair_number >= 0 && color_pair_number < COLOR_PAIRS) {
-       TR(TRACE_ATTRS, ("... current %s", _tracech_t(CHREF(SP->_slk->attr))));
-       SetAttr(SP->_slk->attr, attr);
-       if (color_pair_number > 0) {
-           SetPair(SP->_slk->attr, color_pair_number);
+    T((T_CALLED("slk_attr_set(%p,%s,%d)"),
+       (void *) SP_PARM,
+       _traceattr(attr),
+       color_pair));
+
+    set_extended_pair(opts, color_pair);
+    if (SP_PARM != 0
+       && SP_PARM->_slk != 0
+       && color_pair >= 0
+       && color_pair < SP_PARM->_pair_limit) {
+       TR(TRACE_ATTRS, ("... current %s", _tracech_t(CHREF(SP_PARM->_slk->attr))));
+       SetAttr(SP_PARM->_slk->attr, attr);
+       if (color_pair > 0) {
+           SetPair(SP_PARM->_slk->attr, color_pair);
        }
-       TR(TRACE_ATTRS, ("new attribute is %s", _tracech_t(CHREF(SP->_slk->attr))));
-       returnCode(OK);
-    } else
-       returnCode(ERR);
+       TR(TRACE_ATTRS, ("new attribute is %s", _tracech_t(CHREF(SP_PARM->_slk->attr))));
+       code = OK;
+    }
+    returnCode(code);
+}
+
+#if NCURSES_SP_FUNCS
+NCURSES_EXPORT(int)
+slk_attr_set(const attr_t attr, NCURSES_COLOR_T pair_arg, void *opts)
+{
+    return NCURSES_SP_NAME(slk_attr_set) (CURRENT_SCREEN, attr,
+                                         pair_arg, opts);
 }
+#endif