ncurses 6.0 - patch 20161126
[ncurses.git] / ncurses / tinfo / init_keytry.c
index a720da181e5e53aba49226a255f39e0632bb891e..4853ea1201722f3d1c96a5de82fe911e7cc34684 100644 (file)
@@ -1,5 +1,5 @@
 /****************************************************************************
- * Copyright (c) 1999 Free Software Foundation, Inc.                        *
+ * Copyright (c) 1999-2010,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 <curses.priv.h>
+#include <tic.h>               /* struct tinfo_fkeys */
 
-#include <term.h>      /* keypad_xmit, keypad_local, meta_on, meta_off */
-                       /* cursor_visible,cursor_normal,cursor_invisible */
-#include <tic.h>       /* struct tinfo_fkeys */
-
-MODULE_ID("$Id: init_keytry.c,v 1.2 1999/09/11 17:32:57 Jeffrey.Honig Exp $")
+MODULE_ID("$Id: init_keytry.c,v 1.18 2016/05/28 23:22:52 tom Exp $")
 
 /*
 **      _nc_init_keytry()
@@ -41,7 +38,14 @@ MODULE_ID("$Id: init_keytry.c,v 1.2 1999/09/11 17:32:57 Jeffrey.Honig Exp $")
 **
 */
 
-#ifdef BROKEN_LINKER
+/*
+ * Internal entrypoints use SCREEN* parameter to obtain capabilities rather
+ * than cur_term.
+ */
+#undef CUR
+#define CUR SP_TERMTYPE
+
+#if    BROKEN_LINKER
 #undef _nc_tinfo_fkeys
 #endif
 
@@ -51,28 +55,57 @@ MODULE_ID("$Id: init_keytry.c,v 1.2 1999/09/11 17:32:57 Jeffrey.Honig Exp $")
 /* LINT_PREPRO
 #endif*/
 
-#ifdef BROKEN_LINKER
-struct tinfo_fkeys *_nc_tinfo_fkeysf(void)
+#if    BROKEN_LINKER
+const struct tinfo_fkeys *
+_nc_tinfo_fkeysf(void)
 {
-       return _nc_tinfo_fkeys;
+    return _nc_tinfo_fkeys;
 }
 #endif
 
-void _nc_init_keytry(void)
+NCURSES_EXPORT(void)
+_nc_init_keytry(SCREEN *sp)
 {
-       size_t n;
+    /* The sp->_keytry value is initialized in newterm(), where the sp
+     * structure is created, because we can not tell where keypad() or
+     * mouse_activate() (which will call keyok()) are first called.
+     */
 
-       /* The SP->_keytry value is initialized in newterm(), where the SP
-        * structure is created, because we can not tell where keypad() or
-        * mouse_activate() (which will call keyok()) are first called.
-        */
+    if (sp != 0) {
+       unsigned n;
 
-       for (n = 0; _nc_tinfo_fkeys[n].code; n++)
-               if (_nc_tinfo_fkeys[n].offset < STRCOUNT)
-               _nc_add_to_try(&(SP->_keytry),
-                       CUR Strings[_nc_tinfo_fkeys[n].offset],
-                       _nc_tinfo_fkeys[n].code);
+       for (n = 0; _nc_tinfo_fkeys[n].code; n++) {
+           if (_nc_tinfo_fkeys[n].offset < STRCOUNT) {
+               (void) _nc_add_to_try(&(sp->_keytry),
+                                     CUR Strings[_nc_tinfo_fkeys[n].offset],
+                                     _nc_tinfo_fkeys[n].code);
+           }
+       }
+#if NCURSES_XNAMES
+       /*
+        * Add any of the extended strings to the tries if their name begins
+        * with 'k', i.e., they follow the convention of other terminfo key
+        * names.
+        */
+       {
+           TERMTYPE *tp = &(sp->_term->type);
+           for (n = STRCOUNT; n < NUM_STRINGS(tp); ++n) {
+               const char *name = ExtStrname(tp, (int) n, strnames);
+               char *value = tp->Strings[n];
+               if (name != 0
+                   && *name == 'k'
+                   && value != 0
+                   && NCURSES_SP_NAME(key_defined) (NCURSES_SP_ARGx
+                                                    value) == 0) {
+                   (void) _nc_add_to_try(&(sp->_keytry),
+                                         value,
+                                         n - STRCOUNT + KEY_MAX);
+               }
+           }
+       }
+#endif
 #ifdef TRACE
-       _nc_trace_tries(SP->_keytry);
+       _nc_trace_tries(sp->_keytry);
 #endif
+    }
 }