Changeset e92465d for patches


Ignore:
Timestamp:
Sep 13, 2009, 8:25:05 PM (15 years ago)
Author:
Chris Staub <chris@…>
Branches:
clfs-1.2, clfs-2.1, clfs-3.0.0-systemd, clfs-3.0.0-sysvinit, master, systemd, sysvinit
Children:
0a81d23
Parents:
dca5b7b (diff), 32cb8ca (diff)
Note: this is a merge changeset, the changes displayed below correspond to the merge itself.
Use the (diff) links above to see all the changes relative to each parent.
Message:

Merge branch 'master' of git://git.cross-lfs.org/cross-lfs

Location:
patches
Files:
2 added
1 deleted
4 moved

Legend:

Unmodified
Added
Removed
  • patches/bash-4.0-branch_update-7.patch

    rdca5b7b re92465d  
    11Submitted By: Jim Gifford (jim at cross-lfs dot org)
    2 Date: 07-22-2009
     2Date: 09-12-2009
    33Initial Package Version: 4.0
    44Origin: Upstream
    55Upstream Status: Applied
    6 Description: Contains all upstream patches up to 4.0-028
     6Description: Contains all upstream patches up to 4.0-033
    77
    88diff -Naur bash-4.0.orig/arrayfunc.c bash-4.0/arrayfunc.c
    99--- bash-4.0.orig/arrayfunc.c   2009-01-04 11:32:21.000000000 -0800
    10 +++ bash-4.0/arrayfunc.c        2009-07-22 15:31:16.000000000 -0700
     10+++ bash-4.0/arrayfunc.c        2009-09-12 08:23:47.000000000 -0700
     11@@ -98,7 +98,7 @@
     12   oldval = value_cell (var);
     13   hash = assoc_create (0);
     14   if (oldval)
     15-    assoc_insert (hash, "0", oldval);
     16+    assoc_insert (hash, savestring ("0"), oldval);
     17 
     18   FREE (value_cell (var));
     19   var_setassoc (var, hash);
    1120@@ -604,64 +604,7 @@
    1221     }
     
    7584 /* This function is called with SUB pointing to just after the beginning
    7685    `[' of an array subscript and removes the array element to which SUB
     86diff -Naur bash-4.0.orig/bashline.c bash-4.0/bashline.c
     87--- bash-4.0.orig/bashline.c    2009-01-08 06:29:24.000000000 -0800
     88+++ bash-4.0/bashline.c 2009-09-12 08:23:46.000000000 -0700
     89@@ -3388,7 +3388,6 @@
     90   Keymap xkmap;                /* unix command executing keymap */
     91   register int i;
     92   intmax_t mi;
     93-  int save_point;
     94   sh_parser_state_t ps;
     95   char *cmd, *value, *l;
     96   SHELL_VAR *v;
     97@@ -3432,7 +3431,6 @@
     98   if (v)
     99     VSETATTR (v, att_exported);
     100   l = value_cell (v);
     101-  save_point = rl_point;
     102   value = inttostr (rl_point, ibuf, sizeof (ibuf));
     103   v = bind_int_variable ("READLINE_POINT", value);
     104   if (v)
     105@@ -3450,7 +3448,7 @@
     106   if (v && legal_number (value_cell (v), &mi))
     107     {
     108       i = mi;
     109-      if (i != save_point)
     110+      if (i != rl_point)
     111        {
     112          rl_point = i;
     113          if (rl_point > rl_end)
    77114diff -Naur bash-4.0.orig/builtins/declare.def bash-4.0/builtins/declare.def
    78115--- bash-4.0.orig/builtins/declare.def  2009-01-04 11:32:22.000000000 -0800
    79 +++ bash-4.0/builtins/declare.def       2009-07-22 15:31:12.000000000 -0700
     116+++ bash-4.0/builtins/declare.def       2009-09-12 08:23:07.000000000 -0700
    80117@@ -295,6 +295,13 @@
    81118       subscript_start = (char *)NULL;
     
    103140diff -Naur bash-4.0.orig/builtins/exit.def bash-4.0/builtins/exit.def
    104141--- bash-4.0.orig/builtins/exit.def     2009-01-04 11:32:22.000000000 -0800
    105 +++ bash-4.0/builtins/exit.def  2009-07-22 15:31:11.000000000 -0700
     142+++ bash-4.0/builtins/exit.def  2009-09-12 08:23:05.000000000 -0700
    106143@@ -113,7 +113,7 @@
    107144       for (i = stopmsg = 0; i < js.j_jobslots; i++)
     
    115152diff -Naur bash-4.0.orig/builtins/fc.def bash-4.0/builtins/fc.def
    116153--- bash-4.0.orig/builtins/fc.def       2009-01-04 11:32:22.000000000 -0800
    117 +++ bash-4.0/builtins/fc.def    2009-07-22 15:31:26.000000000 -0700
     154+++ bash-4.0/builtins/fc.def    2009-09-12 08:23:21.000000000 -0700
    118155@@ -88,6 +88,7 @@
    119156 extern int current_command_line_count;
     
    181218diff -Naur bash-4.0.orig/builtins/read.def bash-4.0/builtins/read.def
    182219--- bash-4.0.orig/builtins/read.def     2009-01-15 20:11:21.000000000 -0800
    183 +++ bash-4.0/builtins/read.def  2009-07-22 15:31:19.000000000 -0700
     220+++ bash-4.0/builtins/read.def  2009-09-12 08:23:50.000000000 -0700
    184221@@ -369,14 +369,14 @@
    185222       code = setjmp (alrmbuf);
     
    202239       old_alrm = set_signal_handler (SIGALRM, sigalrm);
    203240       add_unwind_protect (reset_alarm, (char *)NULL);
     241@@ -763,7 +763,10 @@
     242       if (*input_string == 0)
     243        tofree = input_string = t;
     244       else
     245-       input_string = strip_trailing_ifs_whitespace (t1, ifs_chars, saw_escape);
     246+       {
     247+         input_string = strip_trailing_ifs_whitespace (t1, ifs_chars, saw_escape);
     248+         tofree = t;
     249+       }
     250     }
     251 #endif
     252 
    204253diff -Naur bash-4.0.orig/doc/bash.1 bash-4.0/doc/bash.1
    205254--- bash-4.0.orig/doc/bash.1    2009-02-18 12:13:56.000000000 -0800
    206 +++ bash-4.0/doc/bash.1 2009-07-22 15:31:48.000000000 -0700
     255+++ bash-4.0/doc/bash.1 2009-09-12 08:23:43.000000000 -0700
    207256@@ -8257,9 +8257,10 @@
    208257 Exit after reading and executing one command.
     
    220269diff -Naur bash-4.0.orig/doc/bashref.texi bash-4.0/doc/bashref.texi
    221270--- bash-4.0.orig/doc/bashref.texi      2009-02-18 12:14:43.000000000 -0800
    222 +++ bash-4.0/doc/bashref.texi   2009-07-22 15:31:48.000000000 -0700
     271+++ bash-4.0/doc/bashref.texi   2009-09-12 08:23:43.000000000 -0700
    223272@@ -4138,7 +4138,8 @@
    224273 Exit after reading and executing one command.
     
    233282diff -Naur bash-4.0.orig/execute_cmd.c bash-4.0/execute_cmd.c
    234283--- bash-4.0.orig/execute_cmd.c 2009-02-13 13:41:41.000000000 -0800
    235 +++ bash-4.0/execute_cmd.c      2009-07-22 15:31:29.000000000 -0700
     284+++ bash-4.0/execute_cmd.c      2009-09-12 08:23:24.000000000 -0700
    236285@@ -568,6 +568,7 @@
    237286 
     
    299348diff -Naur bash-4.0.orig/externs.h bash-4.0/externs.h
    300349--- bash-4.0.orig/externs.h     2009-01-18 15:29:29.000000000 -0800
    301 +++ bash-4.0/externs.h  2009-07-22 15:31:45.000000000 -0700
     350+++ bash-4.0/externs.h  2009-09-12 08:23:39.000000000 -0700
    302351@@ -192,6 +192,8 @@
    303352 extern char *fmtumax __P((uintmax_t, int, char *, size_t, int));
     
    320369diff -Naur bash-4.0.orig/jobs.c bash-4.0/jobs.c
    321370--- bash-4.0.orig/jobs.c        2009-01-29 14:09:49.000000000 -0800
    322 +++ bash-4.0/jobs.c     2009-07-22 15:31:34.000000000 -0700
     371+++ bash-4.0/jobs.c     2009-09-12 08:23:29.000000000 -0700
    323372@@ -442,7 +442,7 @@
    324373   old_pipeline = the_pipeline;
     
    356405diff -Naur bash-4.0.orig/jobs.h bash-4.0/jobs.h
    357406--- bash-4.0.orig/jobs.h        2009-01-04 11:32:29.000000000 -0800
    358 +++ bash-4.0/jobs.h     2009-07-22 15:31:34.000000000 -0700
     407+++ bash-4.0/jobs.h     2009-09-12 08:23:29.000000000 -0700
    359408@@ -235,6 +235,8 @@
    360409 extern void init_job_stats __P((void));
     
    368417diff -Naur bash-4.0.orig/lib/glob/glob.c bash-4.0/lib/glob/glob.c
    369418--- bash-4.0.orig/lib/glob/glob.c       2009-01-04 11:32:30.000000000 -0800
    370 +++ bash-4.0/lib/glob/glob.c    2009-07-22 15:31:43.000000000 -0700
     419+++ bash-4.0/lib/glob/glob.c    2009-09-12 08:23:38.000000000 -0700
    371420@@ -356,7 +356,7 @@
    372421        *np = 0;
     
    441490diff -Naur bash-4.0.orig/lib/readline/display.c bash-4.0/lib/readline/display.c
    442491--- bash-4.0.orig/lib/readline/display.c        2009-01-04 11:32:32.000000000 -0800
    443 +++ bash-4.0/lib/readline/display.c     2009-07-22 15:31:46.000000000 -0700
     492+++ bash-4.0/lib/readline/display.c     2009-09-12 08:23:41.000000000 -0700
    444493@@ -512,6 +512,7 @@
    445494   /* Block keyboard interrupts because this function manipulates global
     
    519568diff -Naur bash-4.0.orig/lib/readline/readline.h bash-4.0/lib/readline/readline.h
    520569--- bash-4.0.orig/lib/readline/readline.h       2009-01-04 11:32:33.000000000 -0800
    521 +++ bash-4.0/lib/readline/readline.h    2009-07-22 15:31:36.000000000 -0700
     570+++ bash-4.0/lib/readline/readline.h    2009-09-12 08:23:30.000000000 -0700
    522571@@ -814,8 +814,9 @@
    523572 #define RL_STATE_VIMOTION      0x100000        /* reading vi motion arg */
     
    533582diff -Naur bash-4.0.orig/lib/readline/terminal.c bash-4.0/lib/readline/terminal.c
    534583--- bash-4.0.orig/lib/readline/terminal.c       2009-01-04 11:32:34.000000000 -0800
    535 +++ bash-4.0/lib/readline/terminal.c    2009-07-22 15:31:36.000000000 -0700
     584+++ bash-4.0/lib/readline/terminal.c    2009-09-12 08:23:30.000000000 -0700
    536585@@ -355,7 +355,7 @@
    537586       _rl_get_screen_size (fileno (rl_instream), 1);
     
    545594diff -Naur bash-4.0.orig/lib/sh/winsize.c bash-4.0/lib/sh/winsize.c
    546595--- bash-4.0.orig/lib/sh/winsize.c      2008-08-12 10:53:51.000000000 -0700
    547 +++ bash-4.0/lib/sh/winsize.c   2009-07-22 15:31:33.000000000 -0700
     596+++ bash-4.0/lib/sh/winsize.c   2009-09-12 08:23:27.000000000 -0700
    548597@@ -30,16 +30,29 @@
    549598 
     
    587636diff -Naur bash-4.0.orig/parse.y bash-4.0/parse.y
    588637--- bash-4.0.orig/parse.y       2009-01-08 05:29:12.000000000 -0800
    589 +++ bash-4.0/parse.y    2009-07-22 15:31:39.000000000 -0700
     638+++ bash-4.0/parse.y    2009-09-12 08:23:33.000000000 -0700
    590639@@ -1122,7 +1122,7 @@
    591640                          REDIRECTEE rd;
     
    833882diff -Naur bash-4.0.orig/patchlevel.h bash-4.0/patchlevel.h
    834883--- bash-4.0.orig/patchlevel.h  2009-01-04 11:32:40.000000000 -0800
    835 +++ bash-4.0/patchlevel.h       2009-07-22 15:31:48.000000000 -0700
     884+++ bash-4.0/patchlevel.h       2009-09-12 08:23:50.000000000 -0700
    836885@@ -25,6 +25,6 @@
    837886    regexp `^#define[   ]*PATCHLEVEL', since that's what support/mkversion.sh
     
    839888 
    840889-#define PATCHLEVEL 0
    841 +#define PATCHLEVEL 28
     890+#define PATCHLEVEL 33
    842891 
    843892 #endif /* _PATCHLEVEL_H_ */
    844893diff -Naur bash-4.0.orig/pcomplete.c bash-4.0/pcomplete.c
    845894--- bash-4.0.orig/pcomplete.c   2009-02-01 14:12:31.000000000 -0800
    846 +++ bash-4.0/pcomplete.c        2009-07-22 15:31:08.000000000 -0700
     895+++ bash-4.0/pcomplete.c        2009-09-12 08:23:02.000000000 -0700
    847896@@ -1032,6 +1032,7 @@
    848897   cmdlist = build_arg_list (funcname, text, lwords, cw);
     
    855904diff -Naur bash-4.0.orig/sig.c bash-4.0/sig.c
    856905--- bash-4.0.orig/sig.c 2009-01-04 11:32:41.000000000 -0800
    857 +++ bash-4.0/sig.c      2009-07-22 15:31:28.000000000 -0700
     906+++ bash-4.0/sig.c      2009-09-12 08:23:22.000000000 -0700
    858907@@ -448,6 +448,48 @@
    859908 termsig_sighandler (sig)
     
    907956diff -Naur bash-4.0.orig/subst.c bash-4.0/subst.c
    908957--- bash-4.0.orig/subst.c       2009-01-28 11:34:12.000000000 -0800
    909 +++ bash-4.0/subst.c    2009-07-22 15:31:48.000000000 -0700
     958+++ bash-4.0/subst.c    2009-09-12 08:23:49.000000000 -0700
    910959@@ -85,6 +85,7 @@
    911960 
     
    10801129 
    10811130   return w;
     1131@@ -6503,7 +6606,7 @@
     1132            *contains_dollar_at = 1;
     1133        }
     1134       free (x);
     1135-      free (xlist);
     1136+      dispose_words (xlist);
     1137       free (temp1);
     1138       *indexp = sindex;
     1139 
    10821140@@ -6556,7 +6659,7 @@
    10831141   if (want_indir)
     
    11631221diff -Naur bash-4.0.orig/trap.c bash-4.0/trap.c
    11641222--- bash-4.0.orig/trap.c        2009-01-16 14:07:53.000000000 -0800
    1165 +++ bash-4.0/trap.c     2009-07-22 15:31:34.000000000 -0700
     1223+++ bash-4.0/trap.c     2009-09-12 08:23:29.000000000 -0700
    11661224@@ -755,7 +755,7 @@
    11671225        }
     
    12101268 #if defined (DEBUGGER)
    12111269       /* If we're in the debugger and the DEBUG trap returns 2 while we're in
     1270diff -Naur bash-4.0.orig/variables.c bash-4.0/variables.c
     1271--- bash-4.0.orig/variables.c   2009-01-04 11:32:46.000000000 -0800
     1272+++ bash-4.0/variables.c        2009-09-12 08:23:47.000000000 -0700
     1273@@ -252,6 +252,7 @@
     1274 
     1275 static int visible_var __P((SHELL_VAR *));
     1276 static int visible_and_exported __P((SHELL_VAR *));
     1277+static int export_environment_candidate __P((SHELL_VAR *));
     1278 static int local_and_exported __P((SHELL_VAR *));
     1279 static int variable_in_context __P((SHELL_VAR *));
     1280 #if defined (ARRAY_VARS)
     1281@@ -375,10 +376,17 @@
     1282        }
     1283 #  endif
     1284 #endif
     1285+#if 0
     1286       else if (legal_identifier (name))
     1287+#else
     1288+      else
     1289+#endif
     1290        {
     1291          temp_var = bind_variable (name, string, 0);
     1292-         VSETATTR (temp_var, (att_exported | att_imported));
     1293+         if (legal_identifier (name))
     1294+           VSETATTR (temp_var, (att_exported | att_imported));
     1295+         else
     1296+           VSETATTR (temp_var, (att_exported | att_imported | att_invisible));
     1297          array_needs_making = 1;
     1298        }
     1299 
     1300@@ -2209,7 +2217,7 @@
     1301        }
     1302       else if (assoc_p (entry))
     1303        {
     1304-         assoc_insert (assoc_cell (entry), "0", newval);
     1305+         assoc_insert (assoc_cell (entry), savestring ("0"), newval);
     1306          free (newval);
     1307        }
     1308       else
     1309@@ -3082,6 +3090,16 @@
     1310   return (invisible_p (var) == 0 && exported_p (var));
     1311 }
     1312 
     1313+/* Candidate variables for the export environment are either valid variables
     1314+   with the export attribute or invalid variables inherited from the initial
     1315+   environment and simply passed through. */
     1316+static int
     1317+export_environment_candidate (var)
     1318+     SHELL_VAR *var;
     1319+{
     1320+  return (exported_p (var) && (invisible_p (var) == 0 || imported_p (var)));
     1321+}
     1322+
     1323 /* Return non-zero if VAR is a local variable in the current context and
     1324    is exported. */
     1325 static int
     1326@@ -3438,7 +3456,11 @@
     1327   char **list;
     1328   SHELL_VAR **vars;
     1329 
     1330+#if 0
     1331   vars = map_over (visible_and_exported, vcxt);
     1332+#else
     1333+  vars = map_over (export_environment_candidate, vcxt);
     1334+#endif
     1335 
     1336   if (vars == 0)
     1337     return (char **)NULL;
  • patches/coreutils-7.6-uname-1.patch

    rdca5b7b re92465d  
    11Submitted By: Jim Gifford <jim at cross-lfs dot org>
    2 Date: 2009-02-21
    3 Initial Package Version: 7.1
     2Date: 2009-09-12
     3Initial Package Version: 7.6
    44Upstream Status: Not Accepted
    55Origin: Gentoo - http://sources.gentoo.org/viewcvs.py/gentoo/src/patchsets/coreutils
     
    77
    88Rediffed for 7.1 by Jim Gifford
    9 Original Patch by - Matthew Burgess and Scot McPherson
     9Rediffed for 7.5 by Jim Gifford
    1010
    11 diff -Naur coreutils-7.1.orig/src/uname.c coreutils-7.1/src/uname.c
    12 --- coreutils-7.1.orig/src/uname.c      2008-09-18 00:06:57.000000000 -0700
    13 +++ coreutils-7.1/src/uname.c   2009-02-21 21:48:22.417139823 -0800
     11diff -Naur coreutils-7.6.orig/src/uname.c coreutils-7.6/src/uname.c
     12--- coreutils-7.6.orig/src/uname.c      2009-09-01 04:01:16.000000000 -0700
     13+++ coreutils-7.6/src/uname.c   2009-09-12 01:32:54.000000000 -0700
    1414@@ -50,6 +50,11 @@
    1515 # include <mach-o/arch.h>
     
    149149+#if ( HAVE_SYSINFO && defined SI_ARCHITECTURE ) || defined(USE_PROCINFO)
    150150       {
    151         static char processor[257];
     151         static char processor[257];
    152152+#if defined(USE_PROCINFO)
    153 +       if (0 <= __linux_procinfo (PROCINFO_PROCESSOR, processor, sizeof processor))
     153+        if (0 <= __linux_procinfo (PROCINFO_PROCESSOR, processor, sizeof processor))
    154154+#else
    155         if (0 <= sysinfo (SI_ARCHITECTURE, processor, sizeof processor))
     155         if (0 <= sysinfo (SI_ARCHITECTURE, processor, sizeof processor))
    156156+#endif
    157           element = processor;
     157           element = processor;
    158158       }
    159159 #endif
    160160@@ -358,9 +478,13 @@
    161161       if (element == unknown)
    162         {
    163           static char hardware_platform[257];
     162         {
     163           static char hardware_platform[257];
    164164+#if defined(USE_PROCINFO)
    165 +         if (0 <= __linux_procinfo (PROCINFO_HARDWARE_PLATFORM, hardware_platform, sizeof hardware_platform))
     165+        if (0 <= __linux_procinfo (PROCINFO_HARDWARE_PLATFORM, hardware_platform, sizeof hardware_platform))
    166166+#else
    167           size_t s = sizeof hardware_platform;
    168           static int mib[] = { CTL_HW, UNAME_HARDWARE_PLATFORM };
    169           if (sysctl (mib, 2, hardware_platform, &s, 0, 0) >= 0)
     167           size_t s = sizeof hardware_platform;
     168           static int mib[] = { CTL_HW, UNAME_HARDWARE_PLATFORM };
     169           if (sysctl (mib, 2, hardware_platform, &s, 0, 0) >= 0)
    170170+#endif
    171             element = hardware_platform;
    172         }
     171             element = hardware_platform;
     172         }
    173173 #endif
  • patches/ncurses-5.7-branch_update-20.patch

    rdca5b7b re92465d  
    11Submitted By: Jim Gifford (jim at cross-lfs dot org)
    2 Date: 07-19-2009
     2Date: 09-12-2009
    33Initial Package Version: 5.7
    44Origin: Upstream
    55Upstream Status: Applied
    66Description: This is a branch update for NCurses-5.7, and should be
    7              rechecked periodically. This patch covers up to 5.7-20090718.
     7             rechecked periodically. This patch covers up to 5.7-20090906.
    88
    99diff -Naur ncurses-5.7.orig/aclocal.m4 ncurses-5.7/aclocal.m4
    1010--- ncurses-5.7.orig/aclocal.m4 2008-10-25 15:15:32.000000000 -0700
    11 +++ ncurses-5.7/aclocal.m4      2009-07-19 15:04:17.000000000 -0700
     11+++ ncurses-5.7/aclocal.m4      2009-09-12 08:51:54.000000000 -0700
    1212@@ -1,5 +1,5 @@
    1313 dnl***************************************************************************
     
    966966diff -Naur ncurses-5.7.orig/Ada95/gen/adacurses-config.in ncurses-5.7/Ada95/gen/adacurses-config.in
    967967--- ncurses-5.7.orig/Ada95/gen/adacurses-config.in      2007-04-07 14:06:50.000000000 -0700
    968 +++ ncurses-5.7/Ada95/gen/adacurses-config.in   2009-07-19 15:02:13.000000000 -0700
     968+++ ncurses-5.7/Ada95/gen/adacurses-config.in   2009-09-12 08:51:08.000000000 -0700
    969969@@ -1,18 +1,47 @@
    970970 #! /bin/sh
     
    10401040diff -Naur ncurses-5.7.orig/Ada95/gen/gen.c ncurses-5.7/Ada95/gen/gen.c
    10411041--- ncurses-5.7.orig/Ada95/gen/gen.c    2008-10-04 14:59:37.000000000 -0700
    1042 +++ ncurses-5.7/Ada95/gen/gen.c 2009-07-19 15:03:45.000000000 -0700
     1042+++ ncurses-5.7/Ada95/gen/gen.c 2009-09-12 08:51:23.000000000 -0700
    10431043@@ -1,5 +1,5 @@
    10441044 /****************************************************************************
     
    10791079diff -Naur ncurses-5.7.orig/Ada95/gen/Makefile.in ncurses-5.7/Ada95/gen/Makefile.in
    10801080--- ncurses-5.7.orig/Ada95/gen/Makefile.in      2008-10-04 15:58:31.000000000 -0700
    1081 +++ ncurses-5.7/Ada95/gen/Makefile.in   2009-07-19 15:02:13.000000000 -0700
     1081+++ ncurses-5.7/Ada95/gen/Makefile.in   2009-09-12 08:51:08.000000000 -0700
    10821082@@ -1,5 +1,5 @@
    10831083 ##############################################################################
     
    11351135diff -Naur ncurses-5.7.orig/Ada95/samples/Makefile.in ncurses-5.7/Ada95/samples/Makefile.in
    11361136--- ncurses-5.7.orig/Ada95/samples/Makefile.in  2006-12-17 08:45:02.000000000 -0800
    1137 +++ ncurses-5.7/Ada95/samples/Makefile.in       2009-07-19 15:02:13.000000000 -0700
     1137+++ ncurses-5.7/Ada95/samples/Makefile.in       2009-09-12 08:51:08.000000000 -0700
    11381138@@ -1,5 +1,5 @@
    11391139 ##############################################################################
     
    11741174diff -Naur ncurses-5.7.orig/Ada95/src/Makefile.in ncurses-5.7/Ada95/src/Makefile.in
    11751175--- ncurses-5.7.orig/Ada95/src/Makefile.in      2007-09-15 11:22:24.000000000 -0700
    1176 +++ ncurses-5.7/Ada95/src/Makefile.in   2009-07-19 15:02:13.000000000 -0700
     1176+++ ncurses-5.7/Ada95/src/Makefile.in   2009-09-12 08:51:08.000000000 -0700
    11771177@@ -1,5 +1,5 @@
    11781178 ##############################################################################
     
    12661266diff -Naur ncurses-5.7.orig/Ada95/src/terminal_interface-curses-mouse.adb ncurses-5.7/Ada95/src/terminal_interface-curses-mouse.adb
    12671267--- ncurses-5.7.orig/Ada95/src/terminal_interface-curses-mouse.adb      2008-07-26 11:51:11.000000000 -0700
    1268 +++ ncurses-5.7/Ada95/src/terminal_interface-curses-mouse.adb   2009-07-19 15:01:57.000000000 -0700
     1268+++ ncurses-5.7/Ada95/src/terminal_interface-curses-mouse.adb   2009-09-12 08:50:52.000000000 -0700
    12691269@@ -35,8 +35,8 @@
    12701270 ------------------------------------------------------------------------------
     
    12891289diff -Naur ncurses-5.7.orig/c++/cursesw.cc ncurses-5.7/c++/cursesw.cc
    12901290--- ncurses-5.7.orig/c++/cursesw.cc     2007-12-15 15:01:57.000000000 -0800
    1291 +++ ncurses-5.7/c++/cursesw.cc  2009-07-19 15:03:48.000000000 -0700
     1291+++ ncurses-5.7/c++/cursesw.cc  2009-09-12 08:51:25.000000000 -0700
    12921292@@ -1,6 +1,6 @@
    12931293 // * this is for making emacs happy: -*-Mode: C++;-*-
     
    13361336diff -Naur ncurses-5.7.orig/c++/demo.cc ncurses-5.7/c++/demo.cc
    13371337--- ncurses-5.7.orig/c++/demo.cc        2008-08-04 10:16:57.000000000 -0700
    1338 +++ ncurses-5.7/c++/demo.cc     2009-07-19 15:03:58.000000000 -0700
     1338+++ ncurses-5.7/c++/demo.cc     2009-09-12 08:51:35.000000000 -0700
    13391339@@ -35,7 +35,7 @@
    13401340  *   Demo code for NCursesMenu and NCursesForm written by
     
    13621362diff -Naur ncurses-5.7.orig/c++/internal.h ncurses-5.7/c++/internal.h
    13631363--- ncurses-5.7.orig/c++/internal.h     2008-10-25 14:35:44.000000000 -0700
    1364 +++ ncurses-5.7/c++/internal.h  2009-07-19 15:03:58.000000000 -0700
     1364+++ ncurses-5.7/c++/internal.h  2009-09-12 08:51:35.000000000 -0700
    13651365@@ -31,7 +31,7 @@
    13661366  *   Author: Juergen Pfeifer, 1997                                          *
     
    13861386diff -Naur ncurses-5.7.orig/c++/Makefile.in ncurses-5.7/c++/Makefile.in
    13871387--- ncurses-5.7.orig/c++/Makefile.in    2007-04-28 08:29:12.000000000 -0700
    1388 +++ ncurses-5.7/c++/Makefile.in 2009-07-19 15:03:48.000000000 -0700
     1388+++ ncurses-5.7/c++/Makefile.in 2009-09-12 08:51:25.000000000 -0700
    13891389@@ -1,6 +1,6 @@
    13901390-# $Id: Makefile.in,v 1.84 2007/04/28 15:29:12 tom Exp $
     
    14441444diff -Naur ncurses-5.7.orig/config.guess ncurses-5.7/config.guess
    14451445--- ncurses-5.7.orig/config.guess       2008-08-30 13:25:07.000000000 -0700
    1446 +++ ncurses-5.7/config.guess    2009-07-19 15:02:08.000000000 -0700
     1446+++ ncurses-5.7/config.guess    2009-09-12 08:51:04.000000000 -0700
    14471447@@ -4,7 +4,7 @@
    14481448 #   2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008
     
    15141514diff -Naur ncurses-5.7.orig/config.sub ncurses-5.7/config.sub
    15151515--- ncurses-5.7.orig/config.sub 2008-08-30 13:25:02.000000000 -0700
    1516 +++ ncurses-5.7/config.sub      2009-07-19 15:02:08.000000000 -0700
     1516+++ ncurses-5.7/config.sub      2009-09-12 08:51:04.000000000 -0700
    15171517@@ -4,7 +4,7 @@
    15181518 #   2000, 2001, 2002, 2003, 2004, 2005, 2006, 2007, 2008
     
    15981598diff -Naur ncurses-5.7.orig/configure ncurses-5.7/configure
    15991599--- ncurses-5.7.orig/configure  2008-10-25 17:04:38.000000000 -0700
    1600 +++ ncurses-5.7/configure       2009-07-19 15:04:17.000000000 -0700
     1600+++ ncurses-5.7/configure       2009-09-12 08:52:04.000000000 -0700
    16011601@@ -1,7 +1,7 @@
    16021602 #! /bin/sh
    16031603-# From configure.in Revision: 1.454 .
    1604 +# From configure.in Revision: 1.472 .
     1604+# From configure.in Revision: 1.473 .
    16051605 # Guess values for system-dependent variables and create Makefiles.
    16061606-# Generated by Autoconf 2.52.20080325.
     
    39043904+break
    39053905+done
    3906  
    3907 -echo "$as_me:3831: checking for archiver options (symbol AR_OPTS)" >&5
    3908 -echo $ECHO_N "checking for archiver options (symbol AR_OPTS)... $ECHO_C" >&6
     3906+
    39093907+fi
    39103908+fi
     
    39183916+fi
    39193917 
    3920 -if test -z "$AR_OPTS" ; then
    3921 -       AR_OPTS=rv
     3918-echo "$as_me:3831: checking for archiver options (symbol AR_OPTS)" >&5
     3919-echo $ECHO_N "checking for archiver options (symbol AR_OPTS)... $ECHO_C" >&6
    39223920+fi
    39233921+if test -z "$ac_cv_prog_AR"; then
     
    39443942+done
    39453943 
     3944-if test -z "$AR_OPTS" ; then
     3945-       AR_OPTS=rv
    39463946+  test -z "$ac_cv_prog_ac_ct_AR" && ac_cv_prog_ac_ct_AR="ar"
    39473947+fi
    3948  fi
     3948+fi
    39493949+ac_ct_AR=$ac_cv_prog_ac_ct_AR
    39503950+if test -n "$ac_ct_AR"; then
     
    39553955+echo "${ECHO_T}no" >&6
    39563956+fi
    3957 +
     3957 
    39583958+  AR=$ac_ct_AR
    39593959+else
    39603960+  AR="$ac_cv_prog_AR"
    3961 +fi
    3962 +
     3961 fi
     3962 
     3963-cf_cv_subst_AR_OPTS=$AR_OPTS
     3964-echo "$as_me:3840: result: $AR_OPTS" >&5
     3965-echo "${ECHO_T}$AR_OPTS" >&6
    39633966+echo "$as_me:4049: checking for options to update archives" >&5
    39643967+echo $ECHO_N "checking for options to update archives... $ECHO_C" >&6
     
    39893992+               else
    39903993+                       test -n "$verbose" && echo "    cannot compile test-program" 1>&6
    3991  
    3992 -cf_cv_subst_AR_OPTS=$AR_OPTS
    3993 -echo "$as_me:3840: result: $AR_OPTS" >&5
    3994 -echo "${ECHO_T}$AR_OPTS" >&6
     3994+
    39953995+echo "${as_me-configure}:4078: testing cannot compile test-program ..." 1>&5
    39963996+
     
    52655265 
    52665266 if test "$use_database" != no ; then
    5267 @@ -5393,7 +5690,7 @@
     5267@@ -5393,18 +5690,18 @@
    52685268 #define USE_DATABASE 1
    52695269 EOF
     
    52735273 echo $ECHO_N "checking which terminfo source-file will be installed... $ECHO_C" >&6
    52745274 
    5275  # Check whether --enable-database or --disable-database was given.
    5276 @@ -5401,10 +5698,10 @@
    5277    enableval="$enable_database"
     5275-# Check whether --enable-database or --disable-database was given.
     5276-if test "${enable_database+set}" = set; then
     5277-  enableval="$enable_database"
     5278+# Check whether --with-database or --without-database was given.
     5279+if test "${with_database+set}" = set; then
     5280+  withval="$with_database"
    52785281   TERMINFO_SRC=$withval
    52795282 fi;
     
    1342013423 s,@USE_CXX_BOOL@,$USE_CXX_BOOL,;t t
    1342113424 s,@gnat_exists@,$gnat_exists,;t t
    13422 @@ -17493,6 +17964,7 @@
     13425@@ -17493,6 +17964,8 @@
    1342313426 s,@HAVE_TCGETATTR@,$HAVE_TCGETATTR,;t t
    1342413427 s,@HAVE_TERMIO_H@,$HAVE_TERMIO_H,;t t
    1342513428 s,@HAVE_TERMIOS_H@,$HAVE_TERMIOS_H,;t t
    1342613429+s,@MAKE_PC_FILES@,$MAKE_PC_FILES,;t t
     13430+s,@cross_compiling@,$cross_compiling,;t t
    1342713431 CEOF
    1342813432 
    1342913433 EOF
    13430 @@ -17607,7 +18079,7 @@
     13434@@ -17607,7 +18080,7 @@
    1343113435   esac
    1343213436 
    1343313437   if test x"$ac_file" != x-; then
    1343413438-    { echo "$as_me:17610: creating $ac_file" >&5
    13435 +    { echo "$as_me:18082: creating $ac_file" >&5
     13439+    { echo "$as_me:18083: creating $ac_file" >&5
    1343613440 echo "$as_me: creating $ac_file" >&6;}
    1343713441     rm -f "$ac_file"
    1343813442   fi
    13439 @@ -17625,7 +18097,7 @@
     13443@@ -17625,7 +18098,7 @@
    1344013444       -) echo $tmp/stdin ;;
    1344113445       [\\/$]*)
    1344213446          # Absolute (can't be DOS-style, as IFS=:)
    1344313447-         test -f "$f" || { { echo "$as_me:17628: error: cannot find input file: $f" >&5
    13444 +         test -f "$f" || { { echo "$as_me:18100: error: cannot find input file: $f" >&5
     13448+         test -f "$f" || { { echo "$as_me:18101: error: cannot find input file: $f" >&5
    1344513449 echo "$as_me: error: cannot find input file: $f" >&2;}
    1344613450    { (exit 1); exit 1; }; }
    1344713451          echo $f;;
    13448 @@ -17638,7 +18110,7 @@
     13452@@ -17638,7 +18111,7 @@
    1344913453            echo $srcdir/$f
    1345013454          else
    1345113455            # /dev/null tree
    1345213456-           { { echo "$as_me:17641: error: cannot find input file: $f" >&5
    13453 +           { { echo "$as_me:18113: error: cannot find input file: $f" >&5
     13457+           { { echo "$as_me:18114: error: cannot find input file: $f" >&5
    1345413458 echo "$as_me: error: cannot find input file: $f" >&2;}
    1345513459    { (exit 1); exit 1; }; }
    1345613460          fi;;
    13457 @@ -17704,7 +18176,7 @@
     13461@@ -17704,7 +18177,7 @@
    1345813462   * )   ac_file_in=$ac_file.in ;;
    1345913463   esac
    1346013464 
    1346113465-  test x"$ac_file" != x- && { echo "$as_me:17707: creating $ac_file" >&5
    13462 +  test x"$ac_file" != x- && { echo "$as_me:18179: creating $ac_file" >&5
     13466+  test x"$ac_file" != x- && { echo "$as_me:18180: creating $ac_file" >&5
    1346313467 echo "$as_me: creating $ac_file" >&6;}
    1346413468 
    1346513469   # First look for the input files in the build tree, otherwise in the
    13466 @@ -17715,7 +18187,7 @@
     13470@@ -17715,7 +18188,7 @@
    1346713471       -) echo $tmp/stdin ;;
    1346813472       [\\/$]*)
    1346913473          # Absolute (can't be DOS-style, as IFS=:)
    1347013474-         test -f "$f" || { { echo "$as_me:17718: error: cannot find input file: $f" >&5
    13471 +         test -f "$f" || { { echo "$as_me:18190: error: cannot find input file: $f" >&5
     13475+         test -f "$f" || { { echo "$as_me:18191: error: cannot find input file: $f" >&5
    1347213476 echo "$as_me: error: cannot find input file: $f" >&2;}
    1347313477    { (exit 1); exit 1; }; }
    1347413478          echo $f;;
    13475 @@ -17728,7 +18200,7 @@
     13479@@ -17728,7 +18201,7 @@
    1347613480            echo $srcdir/$f
    1347713481          else
    1347813482            # /dev/null tree
    1347913483-           { { echo "$as_me:17731: error: cannot find input file: $f" >&5
    13480 +           { { echo "$as_me:18203: error: cannot find input file: $f" >&5
     13484+           { { echo "$as_me:18204: error: cannot find input file: $f" >&5
    1348113485 echo "$as_me: error: cannot find input file: $f" >&2;}
    1348213486    { (exit 1); exit 1; }; }
    1348313487          fi;;
    13484 @@ -17786,7 +18258,7 @@
     13488@@ -17786,7 +18259,7 @@
    1348513489   rm -f $tmp/in
    1348613490   if test x"$ac_file" != x-; then
    1348713491     if cmp -s $ac_file $tmp/config.h 2>/dev/null; then
    1348813492-      { echo "$as_me:17789: $ac_file is unchanged" >&5
    13489 +      { echo "$as_me:18261: $ac_file is unchanged" >&5
     13493+      { echo "$as_me:18262: $ac_file is unchanged" >&5
    1349013494 echo "$as_me: $ac_file is unchanged" >&6;}
    1349113495     else
    1349213496       ac_dir=`$as_expr X"$ac_file" : 'X\(.*[^/]\)//*[^/][^/]*/*$' \| \
    13493 @@ -17873,40 +18345,44 @@
     13497@@ -17873,40 +18346,44 @@
    1349413498                for cf_item in $cf_LIST_MODELS
    1349513499                do
     
    1354713551                                cf_depsuf=$cf_suffix
    1354813552                                ;;
    13549 @@ -18020,40 +18496,44 @@
     13553@@ -18020,40 +18497,44 @@
    1355013554 
    1355113555 cf_ITEM=`echo "$cf_item" | sed y%abcdefghijklmnopqrstuvwxyz./-%ABCDEFGHIJKLMNOPQRSTUVWXYZ___%`
     
    1360313607                                cf_depsuf=$cf_suffix
    1360413608                                ;;
    13605 @@ -18234,18 +18714,28 @@
     13609@@ -18234,18 +18715,28 @@
    1360613610 install.libs uninstall.libs \\
    1360713611 install.data uninstall.data ::
     
    1363213636 if test -f $srcdir/$tack.h; then
    1363313637 cat >> Makefile <<CF_EOF
    13634 @@ -18256,6 +18746,7 @@
     13638@@ -18256,6 +18747,7 @@
    1363513639 CF_EOF
    1363613640 fi
     
    1364213646diff -Naur ncurses-5.7.orig/configure.in ncurses-5.7/configure.in
    1364313647--- ncurses-5.7.orig/configure.in       2008-10-18 07:53:32.000000000 -0700
    13644 +++ ncurses-5.7/configure.in    2009-07-19 15:04:17.000000000 -0700
     13648+++ ncurses-5.7/configure.in    2009-09-12 08:52:04.000000000 -0700
    1364513649@@ -1,5 +1,5 @@
    1364613650 dnl***************************************************************************
     
    1365513659 dnl
    1365613660-dnl $Id: configure.in,v 1.454 2008/10/18 14:53:32 tom Exp $
    13657 +dnl $Id: configure.in,v 1.472 2009/07/18 16:18:30 tom Exp $
     13661+dnl $Id: configure.in,v 1.473 2009/08/15 16:28:00 tom Exp $
    1365813662 dnl Process this file with autoconf to produce a configure script.
    1365913663 dnl
     
    1366313667 AC_PREREQ(2.13.20020210)
    1366413668-AC_REVISION($Revision: 1.454 $)
    13665 +AC_REVISION($Revision: 1.472 $)
     13669+AC_REVISION($Revision: 1.473 $)
    1366613670 AC_INIT(ncurses/base/lib_initscr.c)
    1366713671 AC_CONFIG_HEADER(include/ncurses_cfg.h:include/ncurses_cfg.hin)
     
    1372213726 dnl Special option for use by system-builders: the install-prefix is used to
    1372313727 dnl adjust the location into which the actual install is done, so that an
     13728@@ -413,7 +445,7 @@
     13729        AC_DEFINE(USE_DATABASE)
     13730 
     13731        AC_MSG_CHECKING(which terminfo source-file will be installed)
     13732-       AC_ARG_ENABLE(database,
     13733+       AC_ARG_WITH(database,
     13734                [  --with-database=XXX     specify terminfo source to install],
     13735                [TERMINFO_SRC=$withval])
     13736        AC_MSG_RESULT($TERMINFO_SRC)
    1372413737@@ -797,6 +829,15 @@
    1372513738        [NCURSES_MMASK_T=auto])
     
    1392513938 AC_DEFINE_UNQUOTED(NCURSES_VERSION_STRING, "${NCURSES_MAJOR}.${NCURSES_MINOR}.${NCURSES_PATCH}")
    1392613939 
    13927 @@ -1765,11 +1860,23 @@
     13940@@ -1765,11 +1860,24 @@
    1392813941 CF_SUBST_IF(["$ac_cv_header_termios_h" = yes], HAVE_TERMIOS_H, 1, 0)
    1392913942 
     
    1394213955+fi
    1394313956+AC_SUBST(MAKE_PC_FILES)
     13957+AC_SUBST(cross_compiling)
    1394413958+
    1394513959 AC_OUTPUT( \
     
    1395013964        include/unctrl.h \
    1395113965        $SUB_MAKEFILES \
    13952 @@ -1796,13 +1903,13 @@
     13966@@ -1796,13 +1904,13 @@
    1395313967 NCURSES_PATCH="$NCURSES_PATCH"
    1395413968 SRC_SUBDIRS="$SRC_SUBDIRS"
     
    1396713981 WITH_ECHO="$with_echo"
    1396813982 WITH_OVERWRITE="$with_overwrite"
    13969 @@ -1821,6 +1928,7 @@
     13983@@ -1821,6 +1929,7 @@
    1397013984 cf_cv_shlib_version_infix="$cf_cv_shlib_version_infix"
    1397113985 cf_cv_system_name="$cf_cv_system_name"
     
    1397713991diff -Naur ncurses-5.7.orig/dist.mk ncurses-5.7/dist.mk
    1397813992--- ncurses-5.7.orig/dist.mk    2008-11-01 17:58:38.000000000 -0700
    13979 +++ ncurses-5.7/dist.mk 2009-07-19 15:04:17.000000000 -0700
     13993+++ ncurses-5.7/dist.mk 2009-09-12 08:52:10.000000000 -0700
    1398013994@@ -25,7 +25,7 @@
    1398113995 # use or other dealings in this Software without prior written               #
     
    1398313997 ##############################################################################
    1398413998-# $Id: dist.mk,v 1.671 2008/11/02 00:58:38 tom Exp $
    13985 +# $Id: dist.mk,v 1.709 2009/07/15 23:12:22 tom Exp $
     13999+# $Id: dist.mk,v 1.719 2009/09/06 14:11:10 tom Exp $
    1398614000 # Makefile for creating ncurses distributions.
    1398714001 #
     
    1399214006 NCURSES_MINOR = 7
    1399314007-NCURSES_PATCH = 20081102
    13994 +NCURSES_PATCH = 20090718
     14008+NCURSES_PATCH = 20090906
    1399514009 
    1399614010 # We don't append the patch to the version, since this only applies to releases
     
    1399814012diff -Naur ncurses-5.7.orig/form/fld_def.c ncurses-5.7/form/fld_def.c
    1399914013--- ncurses-5.7.orig/form/fld_def.c     2007-10-13 12:29:58.000000000 -0700
    14000 +++ ncurses-5.7/form/fld_def.c  2009-07-19 15:02:23.000000000 -0700
     14014+++ ncurses-5.7/form/fld_def.c  2009-09-12 08:51:19.000000000 -0700
    1400114015@@ -32,7 +32,7 @@
    1400214016 
     
    1402014034diff -Naur ncurses-5.7.orig/form/fld_newftyp.c ncurses-5.7/form/fld_newftyp.c
    1402114035--- ncurses-5.7.orig/form/fld_newftyp.c 2007-10-13 12:30:55.000000000 -0700
    14022 +++ ncurses-5.7/form/fld_newftyp.c      2009-07-19 15:03:51.000000000 -0700
     14036+++ ncurses-5.7/form/fld_newftyp.c      2009-09-12 08:51:28.000000000 -0700
    1402314037@@ -1,5 +1,5 @@
    1402414038 /****************************************************************************
     
    1405114065diff -Naur ncurses-5.7.orig/form/form.priv.h ncurses-5.7/form/form.priv.h
    1405214066--- ncurses-5.7.orig/form/form.priv.h   2008-09-08 13:29:05.000000000 -0700
    14053 +++ ncurses-5.7/form/form.priv.h        2009-07-19 15:03:51.000000000 -0700
     14067+++ ncurses-5.7/form/form.priv.h        2009-09-12 08:51:28.000000000 -0700
    1405414068@@ -1,5 +1,5 @@
    1405514069 /****************************************************************************
     
    1411614130diff -Naur ncurses-5.7.orig/form/frm_driver.c ncurses-5.7/form/frm_driver.c
    1411714131--- ncurses-5.7.orig/form/frm_driver.c  2008-10-18 09:25:00.000000000 -0700
    14118 +++ ncurses-5.7/form/frm_driver.c       2009-07-19 15:02:00.000000000 -0700
     14132+++ ncurses-5.7/form/frm_driver.c       2009-09-12 08:52:07.000000000 -0700
     14133@@ -1,5 +1,5 @@
     14134 /****************************************************************************
     14135- * Copyright (c) 1998-2007,2008 Free Software Foundation, Inc.              *
     14136+ * Copyright (c) 1998-2008,2009 Free Software Foundation, Inc.              *
     14137  *                                                                          *
     14138  * Permission is hereby granted, free of charge, to any person obtaining a  *
     14139  * copy of this software and associated documentation files (the            *
    1411914140@@ -32,7 +32,7 @@
    1412014141 
     
    1412214143 
    1412314144-MODULE_ID("$Id: frm_driver.c,v 1.88 2008/10/18 16:25:00 tom Exp $")
    14124 +MODULE_ID("$Id: frm_driver.c,v 1.89 2008/12/06 23:08:12 tom Exp $")
     14145+MODULE_ID("$Id: frm_driver.c,v 1.90 2009/08/29 19:02:25 tom Exp $")
    1412514146 
    1412614147 /*----------------------------------------------------------------------------
    1412714148   This is the core module of the form library. It contains the majority
    14128 @@ -4366,6 +4366,7 @@
     14149@@ -188,7 +188,7 @@
     14150 /* Macro to set the attributes for a fields window */
     14151 #define Set_Field_Window_Attributes(field,win) \
     14152 (  wbkgdset((win),(chtype)((field)->pad | (field)->back)), \
     14153-   wattrset((win),(field)->fore) )
     14154+   (void) wattrset((win),(field)->fore) )
     14155 
     14156 /* Logic to decide whether or not a field really appears on the form */
     14157 #define Field_Really_Appears(field)         \
     14158@@ -1073,9 +1073,13 @@
     14159   else
     14160     {
     14161       if (field->opts & O_VISIBLE)
     14162-       Set_Field_Window_Attributes(field, win);
     14163+       {
     14164+         Set_Field_Window_Attributes(field, win);
     14165+       }
     14166       else
     14167-       wattrset(win, WINDOW_ATTRS(fwin));
     14168+       {
     14169+         (void)wattrset(win, WINDOW_ATTRS(fwin));
     14170+       }
     14171       werase(win);
     14172     }
     14173 
     14174@@ -4366,6 +4370,7 @@
    1412914175       delwin(field->working);
    1413014176       field->working = newpad(field->drows, field->dcols);
     
    1413614182diff -Naur ncurses-5.7.orig/form/frm_sub.c ncurses-5.7/form/frm_sub.c
    1413714183--- ncurses-5.7.orig/form/frm_sub.c     2004-12-11 14:13:39.000000000 -0800
    14138 +++ ncurses-5.7/form/frm_sub.c  2009-07-19 15:03:51.000000000 -0700
     14184+++ ncurses-5.7/form/frm_sub.c  2009-09-12 08:51:28.000000000 -0700
    1413914185@@ -1,5 +1,5 @@
    1414014186 /****************************************************************************
     
    1418314229diff -Naur ncurses-5.7.orig/form/frm_win.c ncurses-5.7/form/frm_win.c
    1418414230--- ncurses-5.7.orig/form/frm_win.c     2004-12-11 14:15:27.000000000 -0800
    14185 +++ ncurses-5.7/form/frm_win.c  2009-07-19 15:03:53.000000000 -0700
     14231+++ ncurses-5.7/form/frm_win.c  2009-09-12 08:51:30.000000000 -0700
    1418614232@@ -1,5 +1,5 @@
    1418714233 /****************************************************************************
     
    1424414290diff -Naur ncurses-5.7.orig/form/fty_generic.c ncurses-5.7/form/fty_generic.c
    1424514291--- ncurses-5.7.orig/form/fty_generic.c 1969-12-31 16:00:00.000000000 -0800
    14246 +++ ncurses-5.7/form/fty_generic.c      2009-07-19 15:04:11.000000000 -0700
     14292+++ ncurses-5.7/form/fty_generic.c      2009-09-12 08:51:49.000000000 -0700
    1424714293@@ -0,0 +1,287 @@
    1424814294+/****************************************************************************
     
    1453514581diff -Naur ncurses-5.7.orig/form/Makefile.in ncurses-5.7/form/Makefile.in
    1453614582--- ncurses-5.7.orig/form/Makefile.in   2007-04-28 07:56:11.000000000 -0700
    14537 +++ ncurses-5.7/form/Makefile.in        2009-07-19 15:03:48.000000000 -0700
     14583+++ ncurses-5.7/form/Makefile.in        2009-09-12 08:51:25.000000000 -0700
    1453814584@@ -1,6 +1,6 @@
    1453914585-# $Id: Makefile.in,v 1.47 2007/04/28 14:56:11 tom Exp $
     
    1456414610diff -Naur ncurses-5.7.orig/include/capdefaults.c ncurses-5.7/include/capdefaults.c
    1456514611--- ncurses-5.7.orig/include/capdefaults.c      2008-08-04 05:33:42.000000000 -0700
    14566 +++ ncurses-5.7/include/capdefaults.c   2009-07-19 15:02:22.000000000 -0700
     14612+++ ncurses-5.7/include/capdefaults.c   2009-09-12 08:51:17.000000000 -0700
    1456714613@@ -32,7 +32,7 @@
    1456814614  *     and: Thomas E. Dickey                        1996-on                 *
     
    1459014636diff -Naur ncurses-5.7.orig/include/curses.h.in ncurses-5.7/include/curses.h.in
    1459114637--- ncurses-5.7.orig/include/curses.h.in        2008-08-30 13:11:29.000000000 -0700
    14592 +++ ncurses-5.7/include/curses.h.in     2009-07-19 15:04:17.000000000 -0700
     14638+++ ncurses-5.7/include/curses.h.in     2009-09-12 08:52:10.000000000 -0700
    1459314639@@ -1,5 +1,5 @@
    1459414640 /****************************************************************************
     
    1460314649 
    1460414650-/* $Id: curses.h.in,v 1.187 2008/08/30 20:11:29 tom Exp $ */
    14605 +/* $Id: curses.h.in,v 1.204 2009/07/18 16:02:07 tom Exp $ */
     14651+/* $Id: curses.h.in,v 1.206 2009/09/06 15:55:10 tom Exp $ */
    1460614652 
    1460714653 #ifndef __NCURSES_H
     
    1472914775 extern NCURSES_EXPORT(int) keyok (int, bool);
    1473014776 extern NCURSES_EXPORT(int) resize_term (int, int);
    14731 @@ -856,23 +869,133 @@
     14777@@ -856,23 +869,135 @@
    1473214778  * These extensions provide access to information stored in the WINDOW even
    1473314779  * when NCURSES_OPAQUE is set:
     
    1475414800+extern NCURSES_EXPORT(bool) is_nodelay (const WINDOW *);       /* @GENERATED_EXT_FUNCS@ */
    1475514801+extern NCURSES_EXPORT(bool) is_notimeout (const WINDOW *);     /* @GENERATED_EXT_FUNCS@ */
     14802+extern NCURSES_EXPORT(bool) is_pad (const WINDOW *);           /* @GENERATED_EXT_FUNCS@ */
    1475614803+extern NCURSES_EXPORT(bool) is_scrollok (const WINDOW *);      /* @GENERATED_EXT_FUNCS@ */
     14804+extern NCURSES_EXPORT(bool) is_subwin (const WINDOW *);                /* @GENERATED_EXT_FUNCS@ */
    1475714805+extern NCURSES_EXPORT(bool) is_syncok (const WINDOW *);                /* @GENERATED_EXT_FUNCS@ */
    1475814806+extern NCURSES_EXPORT(int) wgetscrreg (const WINDOW *, int *, int *); /* @GENERATED_EXT_FUNCS@ */
     
    1487514923 
    1487614924 #define NCURSES_ATTR_SHIFT       8
    14877 @@ -971,9 +1094,9 @@
     14925@@ -971,9 +1096,11 @@
    1487814926 #if !NCURSES_OPAQUE
    1487914927 #if defined(_XOPEN_SOURCE_EXTENDED) && @NCURSES_EXT_COLORS@
    1488014928 #define wattrset(win,at)       ((win)->_color = PAIR_NUMBER(at), \
    1488114929-                                (win)->_attrs = (at))
    14882 +                                 NCURSES_CAST(int, (win)->_attrs = (at)))
     14930+                                 (win)->_attrs = (at), \
     14931+                                 NCURSES_CAST(int, (win)->_attrs))
    1488314932 #else
    1488414933-#define wattrset(win,at)       ((win)->_attrs = (at))
    14885 +#define wattrset(win,at)        NCURSES_CAST(int, (win)->_attrs = (at))
     14934+#define wattrset(win,at)        ((win)->_attrs = (at), \
     14935+                                NCURSES_CAST(int, (win)->_attrs))
    1488614936 #endif
    1488714937 #endif /* NCURSES_OPAQUE */
    1488814938 
    14889 @@ -1173,7 +1296,7 @@
     14939@@ -1148,16 +1275,18 @@
     14940  */
     14941 #if @NCURSES_EXT_FUNCS@
     14942 #if !NCURSES_OPAQUE
     14943-#define is_cleared(win)                ((win)->_clear)
     14944-#define is_idcok(win)          ((win)->_idcok)
     14945-#define is_idlok(win)          ((win)->_idlok)
     14946-#define is_immedok(win)                ((win)->_immed)
     14947-#define is_keypad(win)         ((win)->_use_keypad)
     14948-#define is_leaveok(win)                ((win)->_leaveok)
     14949-#define is_nodelay(win)                ((win)->_delay == 0)
     14950-#define is_notimeout(win)      ((win)->_notimeout)
     14951-#define is_scrollok(win)       ((win)->_scroll)
     14952-#define is_syncok(win)         ((win)->_sync)
     14953+#define is_cleared(win)                ((win) ? (win)->_clear : FALSE)
     14954+#define is_idcok(win)          ((win) ? (win)->_idcok : FALSE)
     14955+#define is_idlok(win)          ((win) ? (win)->_idlok : FALSE)
     14956+#define is_immedok(win)                ((win) ? (win)->_immed : FALSE)
     14957+#define is_keypad(win)         ((win) ? (win)->_use_keypad : FALSE)
     14958+#define is_leaveok(win)                ((win) ? (win)->_leaveok : FALSE)
     14959+#define is_nodelay(win)                ((win) ? ((win)->_delay == 0) : FALSE)
     14960+#define is_notimeout(win)      ((win) ? (win)->_notimeout : FALSE)
     14961+#define is_pad(win)            ((win) ? ((win)->_flags & _ISPAD) != 0 : FALSE)
     14962+#define is_scrollok(win)       ((win) ? (win)->_scroll : FALSE)
     14963+#define is_subwin(win)         ((win) ? ((win)->_flags & _SUBWIN) != 0 : FALSE)
     14964+#define is_syncok(win)         ((win) ? (win)->_sync : FALSE)
     14965 #define wgetparent(win)                ((win) ? (win)->_parent : 0)
     14966 #define wgetscrreg(win,t,b)    ((win) ? (*(t) = (win)->_regtop, *(b) = (win)->_regbottom, OK) : ERR)
     14967 #endif
     14968@@ -1173,7 +1302,7 @@
    1489014969  *        It gives the ESC expire time in milliseconds.
    1489114970  *     b. ttytype is needed for backward compatibility
     
    1489814977diff -Naur ncurses-5.7.orig/include/curses.tail ncurses-5.7/include/curses.tail
    1489914978--- ncurses-5.7.orig/include/curses.tail        2008-07-05 13:20:38.000000000 -0700
    14900 +++ ncurses-5.7/include/curses.tail     2009-07-19 15:04:03.000000000 -0700
     14979+++ ncurses-5.7/include/curses.tail     2009-09-12 08:51:40.000000000 -0700
    1490114980@@ -1,4 +1,4 @@
    1490214981-/* $Id: curses.tail,v 1.16 2008/07/05 20:20:38 tom Exp $ */
     
    1495715036diff -Naur ncurses-5.7.orig/include/curses.wide ncurses-5.7/include/curses.wide
    1495815037--- ncurses-5.7.orig/include/curses.wide        2007-03-10 09:52:23.000000000 -0800
    14959 +++ ncurses-5.7/include/curses.wide     2009-07-19 15:03:59.000000000 -0700
     15038+++ ncurses-5.7/include/curses.wide     2009-09-12 08:51:37.000000000 -0700
    1496015039@@ -1,9 +1,11 @@
    1496115040-/* $Id: curses.wide,v 1.34 2007/03/10 17:52:23 tom Exp $ */
     
    1499515074 
    1499615075 /*
     15076diff -Naur ncurses-5.7.orig/include/headers ncurses-5.7/include/headers
     15077--- ncurses-5.7.orig/include/headers    2007-01-20 11:57:04.000000000 -0800
     15078+++ ncurses-5.7/include/headers 2009-09-12 08:52:09.000000000 -0700
     15079@@ -1,6 +1,6 @@
     15080-# $Id: headers,v 1.9 2007/01/20 19:57:04 Miroslav.Lichvar Exp $
     15081+# $Id: headers,v 1.10 2009/09/05 17:46:30 tom Exp $
     15082 ##############################################################################
     15083-# Copyright (c) 1998-2006,2007 Free Software Foundation, Inc.                #
     15084+# Copyright (c) 1998-2007,2009 Free Software Foundation, Inc.                #
     15085 #                                                                            #
     15086 # Permission is hereby granted, free of charge, to any person obtaining a    #
     15087 # copy of this software and associated documentation files (the "Software"), #
     15088@@ -33,7 +33,7 @@
     15089 curses.h
     15090 unctrl.h
     15091 termcap.h
     15092-$(srcdir)/ncurses_dll.h
     15093+ncurses_dll.h
     15094 @ ticlib
     15095 $(srcdir)/tic.h
     15096 $(srcdir)/term_entry.h
    1499715097diff -Naur ncurses-5.7.orig/include/Makefile.in ncurses-5.7/include/Makefile.in
    1499815098--- ncurses-5.7.orig/include/Makefile.in        2001-12-08 10:50:06.000000000 -0800
    14999 +++ ncurses-5.7/include/Makefile.in     2009-07-19 15:04:09.000000000 -0700
    15000 @@ -1,4 +1,4 @@
     15099+++ ncurses-5.7/include/Makefile.in     2009-09-12 08:52:04.000000000 -0700
     15100@@ -1,6 +1,6 @@
    1500115101-# $Id: Makefile.in,v 1.35 2001/12/08 18:50:06 tom Exp $
    15002 +# $Id: Makefile.in,v 1.36 2009/06/13 21:42:45 tom Exp $
     15102+# $Id: Makefile.in,v 1.37 2009/08/10 20:50:04 tom Exp $
    1500315103 ##############################################################################
    15004  # Copyright (c) 1998,2000,2001 Free Software Foundation, Inc.                #
     15104-# Copyright (c) 1998,2000,2001 Free Software Foundation, Inc.                #
     15105+# Copyright (c) 1998,2001,2009 Free Software Foundation, Inc.                #
    1500515106 #                                                                            #
    15006 @@ -72,6 +72,7 @@
    15007         curses.h \
    15008         hashsize.h \
    15009         ncurses_def.h \
     15107 # Permission is hereby granted, free of charge, to any person obtaining a    #
     15108 # copy of this software and associated documentation files (the "Software"), #
     15109@@ -64,6 +64,7 @@
     15110 CONFIG_SRC = \
     15111        MKterm.h.awk \
     15112        curses.head \
    1501015113+       ncurses_dll.h \
    15011         parametrized.h \
    15012         term.h
     15114        termcap.h \
     15115        unctrl.h
    1501315116 
    1501415117diff -Naur ncurses-5.7.orig/include/MKterm.h.awk.in ncurses-5.7/include/MKterm.h.awk.in
    1501515118--- ncurses-5.7.orig/include/MKterm.h.awk.in    2008-05-24 16:13:59.000000000 -0700
    15016 +++ ncurses-5.7/include/MKterm.h.awk.in 2009-07-19 15:03:59.000000000 -0700
     15119+++ ncurses-5.7/include/MKterm.h.awk.in 2009-09-12 08:51:37.000000000 -0700
    1501715120@@ -1,7 +1,7 @@
    1501815121 # vile:awkmode
     
    1512515228diff -Naur ncurses-5.7.orig/include/nc_alloc.h ncurses-5.7/include/nc_alloc.h
    1512615229--- ncurses-5.7.orig/include/nc_alloc.h 2008-09-27 15:30:33.000000000 -0700
    15127 +++ ncurses-5.7/include/nc_alloc.h      2009-07-19 15:03:53.000000000 -0700
     15230+++ ncurses-5.7/include/nc_alloc.h      2009-09-12 08:51:30.000000000 -0700
    1512815231@@ -1,5 +1,5 @@
    1512915232 /****************************************************************************
     
    1516115264diff -Naur ncurses-5.7.orig/include/nc_mingw.h ncurses-5.7/include/nc_mingw.h
    1516215265--- ncurses-5.7.orig/include/nc_mingw.h 1969-12-31 16:00:00.000000000 -0800
    15163 +++ ncurses-5.7/include/nc_mingw.h      2009-07-19 15:04:11.000000000 -0700
     15266+++ ncurses-5.7/include/nc_mingw.h      2009-09-12 08:51:49.000000000 -0700
    1516415267@@ -0,0 +1,59 @@
    1516515268+/****************************************************************************
     
    1522415327diff -Naur ncurses-5.7.orig/include/nc_panel.h ncurses-5.7/include/nc_panel.h
    1522515328--- ncurses-5.7.orig/include/nc_panel.h 2008-08-04 11:26:46.000000000 -0700
    15226 +++ ncurses-5.7/include/nc_panel.h      2009-07-19 15:04:13.000000000 -0700
     15329+++ ncurses-5.7/include/nc_panel.h      2009-09-12 08:51:50.000000000 -0700
    1522715330@@ -1,5 +1,5 @@
    1522815331 /****************************************************************************
     
    1529015393diff -Naur ncurses-5.7.orig/include/ncurses_defs ncurses-5.7/include/ncurses_defs
    1529115394--- ncurses-5.7.orig/include/ncurses_defs       2008-09-06 08:57:41.000000000 -0700
    15292 +++ ncurses-5.7/include/ncurses_defs    2009-07-19 15:03:58.000000000 -0700
     15395+++ ncurses-5.7/include/ncurses_defs    2009-09-12 08:51:35.000000000 -0700
    1529315396@@ -1,4 +1,4 @@
    1529415397-# $Id: ncurses_defs,v 1.40 2008/09/06 15:57:41 tom Exp $
     
    1530715410diff -Naur ncurses-5.7.orig/include/ncurses_dll.h ncurses-5.7/include/ncurses_dll.h
    1530815411--- ncurses-5.7.orig/include/ncurses_dll.h      2007-03-10 11:21:49.000000000 -0800
    15309 +++ ncurses-5.7/include/ncurses_dll.h   2009-07-19 15:03:53.000000000 -0700
     15412+++ ncurses-5.7/include/ncurses_dll.h   2009-09-12 08:51:30.000000000 -0700
    1531015413@@ -1,5 +1,5 @@
    1531115414 /****************************************************************************
     
    1534715450diff -Naur ncurses-5.7.orig/include/ncurses_dll.h.in ncurses-5.7/include/ncurses_dll.h.in
    1534815451--- ncurses-5.7.orig/include/ncurses_dll.h.in   1969-12-31 16:00:00.000000000 -0800
    15349 +++ ncurses-5.7/include/ncurses_dll.h.in        2009-07-19 15:04:09.000000000 -0700
     15452+++ ncurses-5.7/include/ncurses_dll.h.in        2009-09-12 08:51:47.000000000 -0700
    1535015453@@ -0,0 +1,86 @@
    1535115454+/****************************************************************************
     
    1543715540diff -Naur ncurses-5.7.orig/include/ncurses_mingw.h ncurses-5.7/include/ncurses_mingw.h
    1543815541--- ncurses-5.7.orig/include/ncurses_mingw.h    1969-12-31 16:00:00.000000000 -0800
    15439 +++ ncurses-5.7/include/ncurses_mingw.h 2009-07-19 15:04:11.000000000 -0700
     15542+++ ncurses-5.7/include/ncurses_mingw.h 2009-09-12 08:51:49.000000000 -0700
    1544015543@@ -0,0 +1,164 @@
    1544115544+/****************************************************************************
     
    1560515708diff -Naur ncurses-5.7.orig/include/term_entry.h ncurses-5.7/include/term_entry.h
    1560615709--- ncurses-5.7.orig/include/term_entry.h       2008-08-16 09:16:03.000000000 -0700
    15607 +++ ncurses-5.7/include/term_entry.h    2009-07-19 15:04:15.000000000 -0700
     15710+++ ncurses-5.7/include/term_entry.h    2009-09-12 08:51:52.000000000 -0700
    1560815711@@ -1,5 +1,5 @@
    1560915712 /****************************************************************************
     
    1564415747diff -Naur ncurses-5.7.orig/include/tic.h ncurses-5.7/include/tic.h
    1564515748--- ncurses-5.7.orig/include/tic.h      2007-08-11 09:12:43.000000000 -0700
    15646 +++ ncurses-5.7/include/tic.h   2009-07-19 15:04:15.000000000 -0700
     15749+++ ncurses-5.7/include/tic.h   2009-09-12 08:52:02.000000000 -0700
    1564715750@@ -1,5 +1,5 @@
    1564815751 /****************************************************************************
     
    1565715760 /*
    1565815761- * $Id: tic.h,v 1.62 2007/08/11 16:12:43 tom Exp $
    15659 + * $Id: tic.h,v 1.63 2009/07/11 18:11:15 tom Exp $
     15762+ * $Id: tic.h,v 1.65 2009/08/08 17:52:46 tom Exp $
    1566015763  *     tic.h - Global variables and structures for the terminfo
    1566115764  *                     compiler.
    1566215765  */
    15663 @@ -246,7 +246,7 @@
     15766@@ -183,6 +183,8 @@
     15767 
     15768 #endif
     15769 
     15770+typedef short HashValue;
     15771+
     15772        /*
     15773         * The file comp_captab.c contains an array of these structures, one
     15774         * per possible capability.  These are indexed by a hash table array of
     15775@@ -193,10 +195,21 @@
     15776 {
     15777        const char *nte_name;   /* name to hash on */
     15778        int     nte_type;       /* BOOLEAN, NUMBER or STRING */
     15779-       short   nte_index;      /* index of associated variable in its array */
     15780-       short   nte_link;       /* index in table of next hash, or -1 */
     15781+       HashValue nte_index;    /* index of associated variable in its array */
     15782+       HashValue nte_link;     /* index in table of next hash, or -1 */
     15783 };
     15784 
     15785+       /*
     15786+        * Use this structure to hide differences between terminfo and termcap
     15787+        * tables.
     15788+        */
     15789+typedef struct {
     15790+       unsigned table_size;
     15791+       const HashValue *table_data;
     15792+       HashValue (*hash_of)(const char *);
     15793+       int (*compare_names)(const char *, const char *);
     15794+} HashData;
     15795+
     15796 struct alias
     15797 {
     15798        const char      *from;
     15799@@ -205,7 +218,8 @@
     15800 };
     15801 
     15802 extern NCURSES_EXPORT(const struct name_table_entry *) _nc_get_table (bool);
     15803-extern NCURSES_EXPORT(const short *) _nc_get_hash_table (bool);
     15804+extern NCURSES_EXPORT(const HashData *) _nc_get_hash_info (bool);
     15805+extern NCURSES_EXPORT(const HashValue *) _nc_get_hash_table (bool);
     15806 extern NCURSES_EXPORT(const struct alias *) _nc_get_alias_table (bool);
     15807 
     15808 #define NOTFOUND       ((struct name_table_entry *) 0)
     15809@@ -244,9 +258,9 @@
     15810 
     15811 /* comp_hash.c: name lookup */
    1566415812 extern NCURSES_EXPORT(struct name_table_entry const *) _nc_find_entry
    15665         (const char *, const short *);
     15813-       (const char *, const short *);
     15814+       (const char *, const HashValue *);
    1566615815 extern NCURSES_EXPORT(struct name_table_entry const *) _nc_find_type_entry
    1566715816-       (const char *, int, const struct name_table_entry *);
     
    1567215821diff -Naur ncurses-5.7.orig/include/unctrl.h.in ncurses-5.7/include/unctrl.h.in
    1567315822--- ncurses-5.7.orig/include/unctrl.h.in        2001-03-24 13:53:25.000000000 -0800
    15674 +++ ncurses-5.7/include/unctrl.h.in     2009-07-19 15:03:53.000000000 -0700
     15823+++ ncurses-5.7/include/unctrl.h.in     2009-09-12 08:51:30.000000000 -0700
    1567515824@@ -1,5 +1,5 @@
    1567615825 /****************************************************************************
     
    1570215851diff -Naur ncurses-5.7.orig/INSTALL ncurses-5.7/INSTALL
    1570315852--- ncurses-5.7.orig/INSTALL    2008-11-02 13:13:51.000000000 -0800
    15704 +++ ncurses-5.7/INSTALL 2009-07-19 15:04:17.000000000 -0700
     15853+++ ncurses-5.7/INSTALL 2009-09-12 08:51:59.000000000 -0700
    1570515854@@ -1,5 +1,5 @@
    1570615855 -------------------------------------------------------------------------------
     
    1571515864 -------------------------------------------------------------------------------
    1571615865--- $Id: INSTALL,v 1.135 2008/11/02 21:13:51 tom Exp $
    15717 +-- $Id: INSTALL,v 1.139 2009/07/18 20:50:08 tom Exp $
     15866+-- $Id: INSTALL,v 1.140 2009/08/01 19:32:04 tom Exp $
    1571815867 ---------------------------------------------------------------------
    1571915868              How to install Ncurses/Terminfo on your system
     
    1578015929        Tell the configure script to suppress the build of ncurses' application
    1578115930        programs (e.g., tic).  The test applications will still be built if you
     15931@@ -1584,7 +1610,8 @@
     15932        tree is accessible (that is, in single-user mode or at OS installation
     15933        time) the ncurses library can be compiled to include an array of
     15934        pre-fetched fallback entries.  This must be done on a machine which
     15935-       has ncurses' infocmp and terminfo database installed.
     15936+       has ncurses' infocmp and terminfo database installed (as well as
     15937+       ncurses' tic and infocmp programs).
     15938 
     15939        These entries are checked by setupterm() only when the conventional
     15940        fetches from the terminfo tree and the termcap fallback (if configured)
     15941@@ -1735,6 +1762,10 @@
     15942        option), ncurses uses the development platform's tic to do the
     15943        "make install.data" portion.
     15944 
     15945+       The system's tic program is used to install the terminal database,
     15946+       even for cross-compiles.  For best results, the tic program should
     15947+       be from the most current version of ncurses.
     15948+
     15949 BUGS:
     15950        Send any feedback to the ncurses mailing list at
     15951        bug-ncurses@gnu.org. To subscribe send mail to
    1578215952diff -Naur ncurses-5.7.orig/Makefile.in ncurses-5.7/Makefile.in
    1578315953--- ncurses-5.7.orig/Makefile.in        2005-01-29 11:30:06.000000000 -0800
    15784 +++ ncurses-5.7/Makefile.in     2009-07-19 15:04:11.000000000 -0700
     15954+++ ncurses-5.7/Makefile.in     2009-09-12 08:51:49.000000000 -0700
    1578515955@@ -1,4 +1,4 @@
    1578615956-# $Id: Makefile.in,v 1.24 2005/01/29 19:30:06 tom Exp $
     
    1580615976diff -Naur ncurses-5.7.orig/man/curs_color.3x ncurses-5.7/man/curs_color.3x
    1580715977--- ncurses-5.7.orig/man/curs_color.3x  2005-12-17 16:00:37.000000000 -0800
    15808 +++ ncurses-5.7/man/curs_color.3x       2009-07-19 15:02:16.000000000 -0700
     15978+++ ncurses-5.7/man/curs_color.3x       2009-09-12 08:51:11.000000000 -0700
    1580915979@@ -1,5 +1,5 @@
    1581015980 .\"***************************************************************************
     
    1583716007diff -Naur ncurses-5.7.orig/man/curs_getcchar.3x ncurses-5.7/man/curs_getcchar.3x
    1583816008--- ncurses-5.7.orig/man/curs_getcchar.3x       2008-05-17 12:37:05.000000000 -0700
    15839 +++ ncurses-5.7/man/curs_getcchar.3x    2009-07-19 15:04:17.000000000 -0700
     16009+++ ncurses-5.7/man/curs_getcchar.3x    2009-09-12 08:51:54.000000000 -0700
    1584016010@@ -1,5 +1,5 @@
    1584116011 .\"***************************************************************************
     
    1586616036diff -Naur ncurses-5.7.orig/man/curs_mouse.3x ncurses-5.7/man/curs_mouse.3x
    1586716037--- ncurses-5.7.orig/man/curs_mouse.3x  2006-12-30 15:43:34.000000000 -0800
    15868 +++ ncurses-5.7/man/curs_mouse.3x       2009-07-19 15:01:57.000000000 -0700
     16038+++ ncurses-5.7/man/curs_mouse.3x       2009-09-12 08:52:07.000000000 -0700
    1586916039@@ -1,6 +1,6 @@
    1587016040 '\" t
    1587116041 .\"***************************************************************************
    1587216042-.\" Copyright (c) 1998-2005,2006 Free Software Foundation, Inc.              *
    15873 +.\" Copyright (c) 1998-2006,2008 Free Software Foundation, Inc.              *
     16043+.\" Copyright (c) 1998-2008,2009 Free Software Foundation, Inc.              *
    1587416044 .\"                                                                          *
    1587516045 .\" Permission is hereby granted, free of charge, to any person obtaining a  *
     
    1588016050 .\"
    1588116051-.\" $Id: curs_mouse.3x,v 1.30 2006/12/30 23:43:34 tom Exp $
    15882 +.\" $Id: curs_mouse.3x,v 1.31 2008/11/23 00:09:53 tom Exp $
     16052+.\" $Id: curs_mouse.3x,v 1.32 2009/08/29 18:11:58 tom Exp $
    1588316053 .TH curs_mouse 3X ""
    1588416054 .na
     
    1591016080 cause an error beep when cooked mode is being simulated in a window by a
    1591116081 function such as \fBgetstr\fR that expects a linefeed for input-loop
     16082@@ -256,7 +262,7 @@
     16083 xterm's built-in mouse-tracking API or
     16084 platform-specific drivers including
     16085 .RS
     16086-Alessandro Rubini's gpm server.
     16087+Alessandro Rubini's gpm server
     16088 .br
     16089 FreeBSD sysmouse
     16090 .br
     16091diff -Naur ncurses-5.7.orig/man/curs_opaque.3x ncurses-5.7/man/curs_opaque.3x
     16092--- ncurses-5.7.orig/man/curs_opaque.3x 2007-09-08 11:49:13.000000000 -0700
     16093+++ ncurses-5.7/man/curs_opaque.3x      2009-09-12 08:52:10.000000000 -0700
     16094@@ -1,5 +1,5 @@
     16095 .\"***************************************************************************
     16096-.\" Copyright (c) 2007 Free Software Foundation, Inc.                        *
     16097+.\" Copyright (c) 2007,2009 Free Software Foundation, Inc.                   *
     16098 .\"                                                                          *
     16099 .\" Permission is hereby granted, free of charge, to any person obtaining a  *
     16100 .\" copy of this software and associated documentation files (the            *
     16101@@ -26,7 +26,7 @@
     16102 .\" authorization.                                                           *
     16103 .\"***************************************************************************
     16104 .\"
     16105-.\" $Id: curs_opaque.3x,v 1.6 2007/09/08 18:49:13 tom Exp $
     16106+.\" $Id: curs_opaque.3x,v 1.7 2009/09/06 16:01:55 tom Exp $
     16107 .TH curs_opaque 3X ""
     16108 .na
     16109 .hy 0
     16110@@ -38,8 +38,10 @@
     16111 \fBis_keypad\fR,
     16112 \fBis_leaveok\fR,
     16113 \fBis_nodelay\fR,
     16114-\fBis_timeout\fR,
     16115+\fBis_notimeout\fR,
     16116+\fBis_pad\fR,
     16117 \fBis_scrollok\fR,
     16118+\fBis_subwin\fR,
     16119 \fBis_syncok\fR - \fBcurses\fR window properties
     16120 .ad
     16121 .hy
     16122@@ -62,8 +64,12 @@
     16123 .br
     16124 \fBbool is_notimeout(const WINDOW *win);\fR
     16125 .br
     16126+\fBbool is_pad(const WINDOW *win);\fR
     16127+.br
     16128 \fBbool is_scrollok(const WINDOW *win);\fR
     16129 .br
     16130+\fBbool is_subwin(const WINDOW *win);\fR
     16131+.br
     16132 \fBbool is_syncok(const WINDOW *win);\fR
     16133 .br
     16134 \fBWINDOW * wgetparent(const WINDOW *win);\fR
     16135@@ -99,9 +105,17 @@
     16136 \fBis_notimeout\fR
     16137 returns the value set in \fBnotimeout\fR
     16138 .TP 5
     16139+\fBis_pad\fR
     16140+returns TRUE if the window is a pad
     16141+i.e., created by \fBnewpad\fP
     16142+.TP 5
     16143 \fBis_scrollok\fR
     16144 returns the value set in \fBscrollok\fR
     16145 .TP 5
     16146+\fBis_subwin\fR
     16147+returns TRUE if the window is a subwindow,
     16148+i.e., created by \fBsubwin\fP or \fBderwin\fP
     16149+.TP 5
     16150 \fBis_syncok\fR
     16151 returns the value set in \fBsyncok\fR
     16152 .TP 5
    1591216153diff -Naur ncurses-5.7.orig/man/form_field_validation.3x ncurses-5.7/man/form_field_validation.3x
    1591316154--- ncurses-5.7.orig/man/form_field_validation.3x       2006-12-24 08:08:08.000000000 -0800
    15914 +++ ncurses-5.7/man/form_field_validation.3x    2009-07-19 15:03:51.000000000 -0700
     16155+++ ncurses-5.7/man/form_field_validation.3x    2009-09-12 08:51:28.000000000 -0700
    1591516156@@ -26,7 +26,7 @@
    1591616157 .\" authorization.                                                           *
     
    1593516176diff -Naur ncurses-5.7.orig/man/keybound.3x ncurses-5.7/man/keybound.3x
    1593616177--- ncurses-5.7.orig/man/keybound.3x    2006-02-25 13:47:06.000000000 -0800
    15937 +++ ncurses-5.7/man/keybound.3x 2009-07-19 15:02:02.000000000 -0700
     16178+++ ncurses-5.7/man/keybound.3x 2009-09-12 08:50:57.000000000 -0700
    1593816179@@ -1,5 +1,5 @@
    1593916180 .\"***************************************************************************
     
    1595416195 \fBkeybound\fP \- return definition of keycode
    1595516196 .SH SYNOPSIS
     16197diff -Naur ncurses-5.7.orig/man/man_db.renames ncurses-5.7/man/man_db.renames
     16198--- ncurses-5.7.orig/man/man_db.renames 2008-10-25 16:24:03.000000000 -0700
     16199+++ ncurses-5.7/man/man_db.renames      2009-09-12 08:52:01.000000000 -0700
     16200@@ -1,5 +1,5 @@
     16201 ##############################################################################
     16202-# Copyright (c) 1998-2007,2008 Free Software Foundation, Inc.                #
     16203+# Copyright (c) 1998-2008,2009 Free Software Foundation, Inc.                #
     16204 #                                                                            #
     16205 # Permission is hereby granted, free of charge, to any person obtaining a    #
     16206 # copy of this software and associated documentation files (the "Software"), #
     16207@@ -25,7 +25,7 @@
     16208 # use or other dealings in this Software without prior written               #
     16209 # authorization.                                                             #
     16210 ##############################################################################
     16211-# $Id: man_db.renames,v 0.41 2008/10/25 23:24:03 tom Exp $
     16212+# $Id: man_db.renames,v 0.43 2009/08/04 00:30:32 tom Exp $
     16213 # Manual-page renamings for the man_db program
     16214 #
     16215 # Files:
     16216@@ -152,6 +152,7 @@
     16217 resizeterm.3x                  resizeterm.3ncurses
     16218 scanf.3s                       scanf.3
     16219 system.3s                      system.3
     16220+tabs.1                         tabs.1
     16221 term.5                         term.5
     16222 term.7                         term.7
     16223 terminfo.5                     terminfo.5
    1595616224diff -Naur ncurses-5.7.orig/man/tabs.1 ncurses-5.7/man/tabs.1
    1595716225--- ncurses-5.7.orig/man/tabs.1 1969-12-31 16:00:00.000000000 -0800
    15958 +++ ncurses-5.7/man/tabs.1      2009-07-19 15:01:56.000000000 -0700
     16226+++ ncurses-5.7/man/tabs.1      2009-09-12 08:52:09.000000000 -0700
    1595916227@@ -0,0 +1,143 @@
    1596016228+.\"***************************************************************************
    15961 +.\" Copyright (c) 2008 Free Software Foundation, Inc.                        *
     16229+.\" Copyright (c) 2008,2009 Free Software Foundation, Inc.                   *
    1596216230+.\"                                                                          *
    1596316231+.\" Permission is hereby granted, free of charge, to any person obtaining a  *
     
    1598616254+.\"***************************************************************************
    1598716255+.\"
    15988 +.\" $Id: tabs.1,v 1.2 2008/11/15 23:03:45 tom Exp $
    15989 +.TH @TABS@ 1M ""
     16256+.\" $Id: tabs.1,v 1.3 2009/09/05 17:06:08 tom Exp $
     16257+.TH @TABS@ 1 ""
    1599016258+.ds n 5
    1599116259+.SH NAME
     
    1610316371diff -Naur ncurses-5.7.orig/man/tset.1 ncurses-5.7/man/tset.1
    1610416372--- ncurses-5.7.orig/man/tset.1 2006-12-24 07:00:30.000000000 -0800
    16105 +++ ncurses-5.7/man/tset.1      2009-07-19 15:01:56.000000000 -0700
     16373+++ ncurses-5.7/man/tset.1      2009-09-12 08:50:51.000000000 -0700
    1610616374@@ -1,5 +1,5 @@
    1610716375 .\"***************************************************************************
     
    1612416392diff -Naur ncurses-5.7.orig/MANIFEST ncurses-5.7/MANIFEST
    1612516393--- ncurses-5.7.orig/MANIFEST   2008-10-25 16:47:24.000000000 -0700
    16126 +++ ncurses-5.7/MANIFEST        2009-07-19 15:04:15.000000000 -0700
     16394+++ ncurses-5.7/MANIFEST        2009-09-12 08:52:02.000000000 -0700
    1612716395@@ -172,6 +172,7 @@
    1612816396 ./Makefile.os2
     
    1619616464 ./ncurses/modules
    1619716465 ./ncurses/tinfo/MKcaptab.awk
    16198 @@ -870,6 +879,7 @@
     16466@@ -863,6 +872,7 @@
     16467 ./ncurses/tinfo/lib_tparm.c
     16468 ./ncurses/tinfo/lib_tputs.c
     16469 ./ncurses/tinfo/lib_ttyflags.c
     16470+./ncurses/tinfo/make_hash.c
     16471 ./ncurses/tinfo/make_keys.c
     16472 ./ncurses/tinfo/name_match.c
     16473 ./ncurses/tinfo/parse_entry.c
     16474@@ -870,6 +880,7 @@
    1619916475 ./ncurses/tinfo/read_termcap.c
    1620016476 ./ncurses/tinfo/setbuf.c
     
    1620416480 ./ncurses/tinfo/use_screen.c
    1620516481 ./ncurses/tinfo/write_entry.c
    16206 @@ -915,6 +925,8 @@
     16482@@ -915,6 +926,8 @@
    1620716483 ./ncurses/widechar/lib_vline_set.c
    1620816484 ./ncurses/widechar/lib_wacs.c
     
    1621316489 ./panel/headers
    1621416490 ./panel/llib-lpanel
    16215 @@ -947,9 +959,11 @@
     16491@@ -947,9 +960,11 @@
    1621616492 ./progs/infocmp.c
    1621716493 ./progs/modules
     
    1622516501 ./tar-copy.sh
    1622616502 ./test/Makefile.in
    16227 @@ -963,6 +977,7 @@
     16503@@ -963,6 +978,7 @@
    1622816504 ./test/cardfile.c
    1622916505 ./test/cardfile.dat
     
    1623316509 ./test/configure
    1623416510 ./test/configure.in
    16235 @@ -973,6 +988,7 @@
     16511@@ -973,6 +989,7 @@
    1623616512 ./test/demo_menus.c
    1623716513 ./test/demo_panels.c
     
    1624116517 ./test/dots.c
    1624216518 ./test/dots_mvcur.c
    16243 @@ -990,6 +1006,7 @@
     16519@@ -990,6 +1007,7 @@
    1624416520 ./test/inch_wide.c
    1624516521 ./test/inchs.c
     
    1625116527diff -Naur ncurses-5.7.orig/menu/Makefile.in ncurses-5.7/menu/Makefile.in
    1625216528--- ncurses-5.7.orig/menu/Makefile.in   2007-04-28 07:56:11.000000000 -0700
    16253 +++ ncurses-5.7/menu/Makefile.in        2009-07-19 15:03:48.000000000 -0700
     16529+++ ncurses-5.7/menu/Makefile.in        2009-09-12 08:51:25.000000000 -0700
    1625416530@@ -1,6 +1,6 @@
    1625516531-# $Id: Makefile.in,v 1.48 2007/04/28 14:56:11 tom Exp $
     
    1628016556diff -Naur ncurses-5.7.orig/menu/m_attribs.c ncurses-5.7/menu/m_attribs.c
    1628116557--- ncurses-5.7.orig/menu/m_attribs.c   2004-12-11 15:29:12.000000000 -0800
    16282 +++ ncurses-5.7/menu/m_attribs.c        2009-07-19 15:03:51.000000000 -0700
     16558+++ ncurses-5.7/menu/m_attribs.c        2009-09-12 08:51:28.000000000 -0700
    1628316559@@ -37,7 +37,7 @@
    1628416560 
     
    1631016586diff -Naur ncurses-5.7.orig/menu/m_cursor.c ncurses-5.7/menu/m_cursor.c
    1631116587--- ncurses-5.7.orig/menu/m_cursor.c    2005-10-22 16:03:32.000000000 -0700
    16312 +++ ncurses-5.7/menu/m_cursor.c 2009-07-19 15:02:23.000000000 -0700
     16588+++ ncurses-5.7/menu/m_cursor.c 2009-09-12 08:51:19.000000000 -0700
    1631316589@@ -1,5 +1,5 @@
    1631416590 /****************************************************************************
     
    1633816614diff -Naur ncurses-5.7.orig/menu/m_driver.c ncurses-5.7/menu/m_driver.c
    1633916615--- ncurses-5.7.orig/menu/m_driver.c    2008-08-03 15:08:22.000000000 -0700
    16340 +++ ncurses-5.7/menu/m_driver.c 2009-07-19 15:02:23.000000000 -0700
     16616+++ ncurses-5.7/menu/m_driver.c 2009-09-12 08:51:19.000000000 -0700
    1634116617@@ -1,5 +1,5 @@
    1634216618 /****************************************************************************
     
    1636616642diff -Naur ncurses-5.7.orig/menu/menu.h ncurses-5.7/menu/menu.h
    1636716643--- ncurses-5.7.orig/menu/menu.h        2007-02-24 09:32:13.000000000 -0800
    16368 +++ ncurses-5.7/menu/menu.h     2009-07-19 15:03:51.000000000 -0700
     16644+++ ncurses-5.7/menu/menu.h     2009-09-12 08:51:28.000000000 -0700
    1636916645@@ -1,5 +1,5 @@
    1637016646 /****************************************************************************
     
    1639616672diff -Naur ncurses-5.7.orig/menu/menu.priv.h ncurses-5.7/menu/menu.priv.h
    1639716673--- ncurses-5.7.orig/menu/menu.priv.h   2005-01-15 17:02:23.000000000 -0800
    16398 +++ ncurses-5.7/menu/menu.priv.h        2009-07-19 15:02:23.000000000 -0700
     16674+++ ncurses-5.7/menu/menu.priv.h        2009-09-12 08:51:19.000000000 -0700
    1639916675@@ -1,5 +1,5 @@
    1640016676 /****************************************************************************
     
    1642916705diff -Naur ncurses-5.7.orig/menu/m_global.c ncurses-5.7/menu/m_global.c
    1643016706--- ncurses-5.7.orig/menu/m_global.c    2005-12-31 13:51:52.000000000 -0800
    16431 +++ ncurses-5.7/menu/m_global.c 2009-07-19 15:02:23.000000000 -0700
     16707+++ ncurses-5.7/menu/m_global.c 2009-09-12 08:51:19.000000000 -0700
    1643216708@@ -1,5 +1,5 @@
    1643316709 /****************************************************************************
     
    1647016746diff -Naur ncurses-5.7.orig/menu/m_new.c ncurses-5.7/menu/m_new.c
    1647116747--- ncurses-5.7.orig/menu/m_new.c       2006-11-04 11:04:06.000000000 -0800
    16472 +++ ncurses-5.7/menu/m_new.c    2009-07-19 15:03:51.000000000 -0700
     16748+++ ncurses-5.7/menu/m_new.c    2009-09-12 08:51:28.000000000 -0700
    1647316749@@ -1,5 +1,5 @@
    1647416750 /****************************************************************************
     
    1655716833diff -Naur ncurses-5.7.orig/menu/m_pad.c ncurses-5.7/menu/m_pad.c
    1655816834--- ncurses-5.7.orig/menu/m_pad.c       2004-12-25 13:40:58.000000000 -0800
    16559 +++ ncurses-5.7/menu/m_pad.c    2009-07-19 15:03:51.000000000 -0700
     16835+++ ncurses-5.7/menu/m_pad.c    2009-09-12 08:51:28.000000000 -0700
    1656016836@@ -37,19 +37,19 @@
    1656116837 
     
    1658316859diff -Naur ncurses-5.7.orig/menu/m_post.c ncurses-5.7/menu/m_post.c
    1658416860--- ncurses-5.7.orig/menu/m_post.c      2004-12-25 15:57:04.000000000 -0800
    16585 +++ ncurses-5.7/menu/m_post.c   2009-07-19 15:02:23.000000000 -0700
     16861+++ ncurses-5.7/menu/m_post.c   2009-09-12 08:51:19.000000000 -0700
    1658616862@@ -1,5 +1,5 @@
    1658716863 /****************************************************************************
     
    1662016896diff -Naur ncurses-5.7.orig/menu/m_sub.c ncurses-5.7/menu/m_sub.c
    1662116897--- ncurses-5.7.orig/menu/m_sub.c       2004-12-25 13:38:31.000000000 -0800
    16622 +++ ncurses-5.7/menu/m_sub.c    2009-07-19 15:03:51.000000000 -0700
     16898+++ ncurses-5.7/menu/m_sub.c    2009-09-12 08:51:28.000000000 -0700
    1662316899@@ -37,7 +37,7 @@
    1662416900 
     
    1666616942diff -Naur ncurses-5.7.orig/menu/m_win.c ncurses-5.7/menu/m_win.c
    1666716943--- ncurses-5.7.orig/menu/m_win.c       2004-12-25 13:39:20.000000000 -0800
    16668 +++ ncurses-5.7/menu/m_win.c    2009-07-19 15:03:51.000000000 -0700
     16944+++ ncurses-5.7/menu/m_win.c    2009-09-12 08:51:28.000000000 -0700
    1666916945@@ -37,7 +37,7 @@
    1667016946 
     
    1672116997diff -Naur ncurses-5.7.orig/misc/gen-pkgconfig.in ncurses-5.7/misc/gen-pkgconfig.in
    1672216998--- ncurses-5.7.orig/misc/gen-pkgconfig.in      1969-12-31 16:00:00.000000000 -0800
    16723 +++ ncurses-5.7/misc/gen-pkgconfig.in   2009-07-19 15:03:43.000000000 -0700
     16999+++ ncurses-5.7/misc/gen-pkgconfig.in   2009-09-12 08:51:21.000000000 -0700
    1672417000@@ -0,0 +1,140 @@
    1672517001+#!@SHELL@
     
    1686517141diff -Naur ncurses-5.7.orig/misc/Makefile.in ncurses-5.7/misc/Makefile.in
    1686617142--- ncurses-5.7.orig/misc/Makefile.in   2007-03-31 08:54:17.000000000 -0700
    16867 +++ ncurses-5.7/misc/Makefile.in        2009-07-19 15:02:18.000000000 -0700
     17143+++ ncurses-5.7/misc/Makefile.in        2009-09-12 08:52:04.000000000 -0700
    1686817144@@ -1,6 +1,6 @@
    1686917145-# $Id: Makefile.in,v 1.43 2007/03/31 15:54:17 tom Exp $
    16870 +# $Id: Makefile.in,v 1.51 2009/02/07 18:17:17 Miroslav.Lichvar Exp $
     17146+# $Id: Makefile.in,v 1.52 2009/08/15 17:13:49 tom Exp $
    1687117147 ##############################################################################
    1687217148-# Copyright (c) 1998-2006,2007 Free Software Foundation, Inc.                #
     
    1687517151 # Permission is hereby granted, free of charge, to any person obtaining a    #
    1687617152 # copy of this software and associated documentation files (the "Software"), #
    16877 @@ -66,15 +66,17 @@
     17153@@ -57,24 +57,23 @@
     17154 libdir         = @libdir@
     17155 datadir                = @datadir@
     17156 
     17157-CC             = @CC@
     17158-HOSTCC         = @BUILD_CC@
     17159-
     17160 tabsetdir      = $(datadir)/tabset
     17161 ticdir         = @TERMINFO@
     17162 ticfile                = $(ticdir).db
    1687817163 source         = @TERMINFO_SRC@
    1687917164 
     
    1689517180 install : install.data install.libs
    1689617181 
    16897 @@ -103,9 +105,17 @@
     17182@@ -91,8 +90,7 @@
     17183        datadir=${datadir} \
     17184        ticdir=${ticdir} \
     17185        source=terminfo.tmp \
     17186-       THIS_CC="$(CC)" \
     17187-       THAT_CC="$(HOSTCC)" \
     17188+       cross_compiling=@cross_compiling@ \
     17189        $(SHELL) ./run_tic.sh
     17190        @cd $(srcdir)/tabset && \
     17191                $(SHELL) -c 'for i in * ; do \
     17192@@ -103,9 +101,17 @@
    1689817193 
    1689917194 NCURSES_CONFIG = ncurses@DFT_ARG_SUFFIX@@cf_cv_abi_version@-config
     
    1691417209        echo '** adjusting tabset paths'
    1691517210        sed -f run_tic.sed $(source) >terminfo.tmp
    16916 @@ -118,7 +128,8 @@
     17211@@ -118,7 +124,8 @@
    1691717212 $(DESTDIR)$(bindir) \
    1691817213 $(DESTDIR)$(libdir) \
     
    1692417219 
    1692517220 uninstall : uninstall.data uninstall.libs
    16926 @@ -130,6 +141,7 @@
     17221@@ -130,6 +137,7 @@
    1692717222 
    1692817223 uninstall.libs :
     
    1693217227 tags :
    1693317228 
    16934 @@ -138,11 +150,13 @@
     17229@@ -138,11 +146,13 @@
    1693517230 mostlyclean :
    1693617231        -rm -f terminfo.tmp
     
    1694817243diff -Naur ncurses-5.7.orig/misc/ncu-indent ncurses-5.7/misc/ncu-indent
    1694917244--- ncurses-5.7.orig/misc/ncu-indent    2008-08-03 08:46:44.000000000 -0700
    16950 +++ ncurses-5.7/misc/ncu-indent 2009-07-19 15:02:23.000000000 -0700
     17245+++ ncurses-5.7/misc/ncu-indent 2009-09-12 08:51:19.000000000 -0700
    1695117246@@ -26,7 +26,7 @@
    1695217247 #* sale, use or other dealings in this Software without prior written       *
     
    1699717292diff -Naur ncurses-5.7.orig/misc/ncurses-config.in ncurses-5.7/misc/ncurses-config.in
    1699817293--- ncurses-5.7.orig/misc/ncurses-config.in     2007-03-17 13:02:19.000000000 -0700
    16999 +++ ncurses-5.7/misc/ncurses-config.in  2009-07-19 15:03:43.000000000 -0700
     17294+++ ncurses-5.7/misc/ncurses-config.in  2009-09-12 08:51:21.000000000 -0700
    1700017295@@ -1,7 +1,7 @@
    1700117296 #!@SHELL@
     
    1713017425   --mandir           echos the directory containing ${THIS} manpages
    1713117426   --terminfo         echos the \$TERMINFO terminfo database path
     17427diff -Naur ncurses-5.7.orig/misc/run_tic.in ncurses-5.7/misc/run_tic.in
     17428--- ncurses-5.7.orig/misc/run_tic.in    2006-10-28 12:43:30.000000000 -0700
     17429+++ ncurses-5.7/misc/run_tic.in 2009-09-12 08:52:04.000000000 -0700
     17430@@ -1,7 +1,7 @@
     17431 #!@SHELL@
     17432-# $Id: run_tic.in,v 1.23 2006/10/28 19:43:30 tom Exp $
     17433+# $Id: run_tic.in,v 1.24 2009/08/15 17:19:36 tom Exp $
     17434 ##############################################################################
     17435-# Copyright (c) 1998-2005,2006 Free Software Foundation, Inc.                #
     17436+# Copyright (c) 1998-2006,2009 Free Software Foundation, Inc.                #
     17437 #                                                                            #
     17438 # Permission is hereby granted, free of charge, to any person obtaining a    #
     17439 # copy of this software and associated documentation files (the "Software"), #
     17440@@ -28,7 +28,7 @@
     17441 # authorization.                                                             #
     17442 ##############################################################################
     17443 #
     17444-# Author: Thomas E. Dickey 1996,2000
     17445+# Author: Thomas E. Dickey 1996-on
     17446 #
     17447 # This script is used to install terminfo.src using tic.  We use a script
     17448 # because the path checking is too awkward to do in a makefile.
     17449@@ -52,8 +52,7 @@
     17450 : ${ticdir=@TERMINFO@}
     17451 : ${source=@TERMINFO_SRC@}
     17452 : ${LN_S="@LN_S@"}
     17453-: ${THAT_CC=cc}
     17454-: ${THIS_CC=cc}
     17455+: ${cross_compiling=no}
     17456 : ${ext_funcs=@NCURSES_EXT_FUNCS@}
     17457 
     17458 test -z "${DESTDIR}" && DESTDIR=
     17459@@ -61,10 +60,10 @@
     17460 # Allow tic to run either from the install-path, or from the build-directory.
     17461 # Do not do this if we appear to be cross-compiling.  In that case, we rely
     17462 # on the host's copy of tic to compile the terminfo database.
     17463-if test "$THAT_CC" = "$THIS_CC" ; then
     17464+if test "x$cross_compiling" = "xno" ; then
     17465 case "$PATH" in
     17466-:*) PATH=../progs:../lib:${DESTDIR}$bindir$PATH ;;
     17467-*) PATH=../progs:../lib:${DESTDIR}$bindir:$PATH ;;
     17468+@PATH_SEPARATOR@*) PATH=../progs@PATH_SEPARATOR@../lib@PATH_SEPARATOR@${DESTDIR}$bindir$PATH ;;
     17469+*) PATH=../progs@PATH_SEPARATOR@../lib@PATH_SEPARATOR@${DESTDIR}$bindir@PATH_SEPARATOR@$PATH ;;
     17470 esac
     17471 export PATH
     17472 SHLIB="sh $srcdir/shlib"
    1713217473diff -Naur ncurses-5.7.orig/misc/terminfo.src ncurses-5.7/misc/terminfo.src
    1713317474--- ncurses-5.7.orig/misc/terminfo.src  2008-10-12 16:03:54.000000000 -0700
    17134 +++ ncurses-5.7/misc/terminfo.src       2009-07-19 15:03:58.000000000 -0700
     17475+++ ncurses-5.7/misc/terminfo.src       2009-09-12 08:51:35.000000000 -0700
    1713517476@@ -6,8 +6,8 @@
    1713617477 # Report bugs and new terminal descriptions to
     
    1743217773diff -Naur ncurses-5.7.orig/mk-1st.awk ncurses-5.7/mk-1st.awk
    1743317774--- ncurses-5.7.orig/mk-1st.awk 2007-03-24 15:10:55.000000000 -0700
    17434 +++ ncurses-5.7/mk-1st.awk      2009-07-19 15:03:48.000000000 -0700
     17775+++ ncurses-5.7/mk-1st.awk      2009-09-12 08:51:25.000000000 -0700
    1743517776@@ -1,6 +1,6 @@
    1743617777-# $Id: mk-1st.awk,v 1.78 2007/03/24 22:10:55 tom Exp $
     
    1747717818diff -Naur ncurses-5.7.orig/mk-dlls.sh ncurses-5.7/mk-dlls.sh
    1747817819--- ncurses-5.7.orig/mk-dlls.sh 1969-12-31 16:00:00.000000000 -0800
    17479 +++ ncurses-5.7/mk-dlls.sh      2009-07-19 15:04:11.000000000 -0700
     17820+++ ncurses-5.7/mk-dlls.sh      2009-09-12 08:51:49.000000000 -0700
    1748017821@@ -0,0 +1,93 @@
    1748117822+#!/bin/sh
     
    1757417915diff -Naur ncurses-5.7.orig/ncurses/base/define_key.c ncurses-5.7/ncurses/base/define_key.c
    1757517916--- ncurses-5.7.orig/ncurses/base/define_key.c  2006-12-30 15:23:31.000000000 -0800
    17576 +++ ncurses-5.7/ncurses/base/define_key.c       2009-07-19 15:03:59.000000000 -0700
     17917+++ ncurses-5.7/ncurses/base/define_key.c       2009-09-12 08:51:37.000000000 -0700
    1757717918@@ -1,5 +1,5 @@
    1757817919 /****************************************************************************
     
    1764717988diff -Naur ncurses-5.7.orig/ncurses/base/keybound.c ncurses-5.7/ncurses/base/keybound.c
    1764817989--- ncurses-5.7.orig/ncurses/base/keybound.c    2006-06-17 11:19:24.000000000 -0700
    17649 +++ ncurses-5.7/ncurses/base/keybound.c 2009-07-19 15:02:22.000000000 -0700
     17990+++ ncurses-5.7/ncurses/base/keybound.c 2009-09-12 08:51:17.000000000 -0700
    1765017991@@ -1,5 +1,5 @@
    1765117992 /****************************************************************************
     
    1769818039diff -Naur ncurses-5.7.orig/ncurses/base/key_defined.c ncurses-5.7/ncurses/base/key_defined.c
    1769918040--- ncurses-5.7.orig/ncurses/base/key_defined.c 2006-12-30 15:22:55.000000000 -0800
    17700 +++ ncurses-5.7/ncurses/base/key_defined.c      2009-07-19 15:02:22.000000000 -0700
     18041+++ ncurses-5.7/ncurses/base/key_defined.c      2009-09-12 08:51:17.000000000 -0700
    1770118042@@ -1,5 +1,5 @@
    1770218043 /****************************************************************************
     
    1774418085diff -Naur ncurses-5.7.orig/ncurses/base/keyok.c ncurses-5.7/ncurses/base/keyok.c
    1774518086--- ncurses-5.7.orig/ncurses/base/keyok.c       2006-12-30 08:22:33.000000000 -0800
    17746 +++ ncurses-5.7/ncurses/base/keyok.c    2009-07-19 15:04:06.000000000 -0700
     18087+++ ncurses-5.7/ncurses/base/keyok.c    2009-09-12 08:51:43.000000000 -0700
    1774718088@@ -1,5 +1,5 @@
    1774818089 /****************************************************************************
     
    1782818169diff -Naur ncurses-5.7.orig/ncurses/base/legacy_coding.c ncurses-5.7/ncurses/base/legacy_coding.c
    1782918170--- ncurses-5.7.orig/ncurses/base/legacy_coding.c       2005-12-17 15:38:17.000000000 -0800
    17830 +++ ncurses-5.7/ncurses/base/legacy_coding.c    2009-07-19 15:02:22.000000000 -0700
     18171+++ ncurses-5.7/ncurses/base/legacy_coding.c    2009-09-12 08:51:17.000000000 -0700
    1783118172@@ -1,5 +1,5 @@
    1783218173 /****************************************************************************
     
    1787718218diff -Naur ncurses-5.7.orig/ncurses/base/lib_addch.c ncurses-5.7/ncurses/base/lib_addch.c
    1787818219--- ncurses-5.7.orig/ncurses/base/lib_addch.c   2008-08-16 12:20:04.000000000 -0700
    17879 +++ ncurses-5.7/ncurses/base/lib_addch.c        2009-07-19 15:04:01.000000000 -0700
     18220+++ ncurses-5.7/ncurses/base/lib_addch.c        2009-09-12 08:52:01.000000000 -0700
    1788018221@@ -1,5 +1,5 @@
    1788118222 /****************************************************************************
     
    1789018231 
    1789118232-MODULE_ID("$Id: lib_addch.c,v 1.113 2008/08/16 19:20:04 tom Exp $")
    17892 +MODULE_ID("$Id: lib_addch.c,v 1.119 2009/05/15 23:47:26 tom Exp $")
     18233+MODULE_ID("$Id: lib_addch.c,v 1.121 2009/08/04 00:20:09 tom Exp $")
    1789318234 
    1789418235 static const NCURSES_CH_T blankchar = NewChar(BLANK_TEXT);
     
    1790118242+#define DeriveSP() SCREEN *sp = _nc_screen_of(win);
    1790218243+#else
    17903 +#define DeriveSP() /*nothing*/
     18244+#define DeriveSP()             /*nothing */
    1790418245+#endif
    1790518246     if_WIDEC({
     
    1791018251            if (len >= -1) {
    1791118252-               /* handle EILSEQ */
    17912 +               attr_t attr = AttrOf(ch);
    17913 +
    17914 +               /* handle EILSEQ (i.e., when len >= -1) */
    17915                 if (is8bits(CharOf(ch))) {
     18253-               if (is8bits(CharOf(ch))) {
    1791618254-                   const char *s = unctrl((chtype) CharOf(ch));
    1791718255-                   if (s[1] != 0) {
    1791818256-                       return waddstr(win, s);
     18257+               attr_t attr = AttrOf(ch);
     18258+
     18259+               /* handle EILSEQ (i.e., when len >= -1) */
     18260+               if (len == -1 && is8bits(CharOf(ch))) {
    1791918261+                   int rc = OK;
    1792018262+                   const char *s = NCURSES_SP_NAME(unctrl)
     
    1798318325-
    1798418326+#if USE_REENTRANT
    17985 +       tabsize = sp->_TABSIZE;
     18327+       tabsize = *ptrTabsize(sp);
    1798618328+#else
    1798718329+       tabsize = TABSIZE;
     
    1799318335diff -Naur ncurses-5.7.orig/ncurses/base/lib_beep.c ncurses-5.7/ncurses/base/lib_beep.c
    1799418336--- ncurses-5.7.orig/ncurses/base/lib_beep.c    2005-04-09 08:20:04.000000000 -0700
    17995 +++ ncurses-5.7/ncurses/base/lib_beep.c 2009-07-19 15:04:03.000000000 -0700
     18337+++ ncurses-5.7/ncurses/base/lib_beep.c 2009-09-12 08:51:40.000000000 -0700
    1799618338@@ -1,5 +1,5 @@
    1799718339 /****************************************************************************
     
    1805918401+}
    1806018402+#endif
     18403diff -Naur ncurses-5.7.orig/ncurses/base/lib_bkgd.c ncurses-5.7/ncurses/base/lib_bkgd.c
     18404--- ncurses-5.7.orig/ncurses/base/lib_bkgd.c    2008-03-22 17:09:14.000000000 -0700
     18405+++ ncurses-5.7/ncurses/base/lib_bkgd.c 2009-09-12 08:52:07.000000000 -0700
     18406@@ -1,5 +1,5 @@
     18407 /****************************************************************************
     18408- * Copyright (c) 1998-2006,2008 Free Software Foundation, Inc.              *
     18409+ * Copyright (c) 1998-2008,2009 Free Software Foundation, Inc.              *
     18410  *                                                                          *
     18411  * Permission is hereby granted, free of charge, to any person obtaining a  *
     18412  * copy of this software and associated documentation files (the            *
     18413@@ -36,7 +36,7 @@
     18414 
     18415 #include <curses.priv.h>
     18416 
     18417-MODULE_ID("$Id: lib_bkgd.c,v 1.36 2008/03/23 00:09:14 tom Exp $")
     18418+MODULE_ID("$Id: lib_bkgd.c,v 1.37 2009/08/29 19:02:25 tom Exp $")
     18419 
     18420 /*
     18421  * Set the window's background information.
     18422@@ -126,8 +126,8 @@
     18423        NCURSES_CH_T old_bkgrnd;
     18424        wgetbkgrnd(win, &old_bkgrnd);
     18425 
     18426-       wbkgrndset(win, CHREF(new_bkgd));
     18427-       wattrset(win, AttrOf(win->_nc_bkgd));
     18428+       (void) wbkgrndset(win, CHREF(new_bkgd));
     18429+       (void) wattrset(win, AttrOf(win->_nc_bkgd));
     18430 
     18431        for (y = 0; y <= win->_maxy; y++) {
     18432            for (x = 0; x <= win->_maxx; x++) {
    1806118433diff -Naur ncurses-5.7.orig/ncurses/base/lib_color.c ncurses-5.7/ncurses/base/lib_color.c
    1806218434--- ncurses-5.7.orig/ncurses/base/lib_color.c   2007-04-07 10:07:28.000000000 -0700
    18063 +++ ncurses-5.7/ncurses/base/lib_color.c        2009-07-19 15:04:06.000000000 -0700
     18435+++ ncurses-5.7/ncurses/base/lib_color.c        2009-09-12 08:52:05.000000000 -0700
    1806418436@@ -1,5 +1,5 @@
    1806518437 /****************************************************************************
    1806618438- * Copyright (c) 1998-2006,2007 Free Software Foundation, Inc.              *
    18067 + * Copyright (c) 1998-2007,2009 Free Software Foundation, Inc.              *
     18439+ * Copyright (c) 1998-2008,2009 Free Software Foundation, Inc.              *
    1806818440  *                                                                          *
    1806918441  * Permission is hereby granted, free of charge, to any person obtaining a  *
     
    1807718449 
    1807818450 /* lib_color.c
    18079 @@ -42,7 +43,11 @@
    18080  #include <term.h>
     18451@@ -38,12 +39,33 @@
     18452  */
     18453 
     18454 #include <curses.priv.h>
     18455-
     18456-#include <term.h>
    1808118457 #include <tic.h>
    1808218458 
     
    1808618462+#endif
    1808718463+
    18088 +MODULE_ID("$Id: lib_color.c,v 1.92 2009/06/06 20:26:16 tom Exp $")
    18089  
     18464+MODULE_ID("$Id: lib_color.c,v 1.95 2009/08/22 19:04:36 tom Exp $")
     18465+
     18466+#ifdef USE_TERM_DRIVER
     18467+#define CanChange      InfoOf(SP_PARM).canchange
     18468+#define DefaultPalette InfoOf(SP_PARM).defaultPalette
     18469+#define HasColor       InfoOf(SP_PARM).hascolor
     18470+#define InitColor      InfoOf(SP_PARM).initcolor
     18471+#define MaxColors      InfoOf(SP_PARM).maxcolors
     18472+#define MaxPairs       InfoOf(SP_PARM).maxpairs
     18473+#define UseHlsPalette  (DefaultPalette == _nc_hls_palette)
     18474+#else
     18475+#define CanChange      can_change
     18476+#define DefaultPalette (hue_lightness_saturation ? hls_palette : cga_palette)
     18477+#define HasColor       has_color
     18478+#define InitColor      initialize_color
     18479+#define MaxColors      max_colors
     18480+#define MaxPairs       max_pairs
     18481+#define UseHlsPalette  (hue_lightness_saturation)
     18482+#endif
     18483 
     18484+#ifndef USE_TERM_DRIVER
    1809018485 /*
    1809118486  * These should be screen structure members.  They need to be globals for
    18092 @@ -108,6 +113,13 @@
     18487  * historical reasons.  So we assign them in start_color() and also in
     18488@@ -64,6 +86,7 @@
     18489 NCURSES_EXPORT_VAR(int) COLOR_PAIRS = 0;
     18490 NCURSES_EXPORT_VAR(int) COLORS = 0;
     18491 #endif
     18492+#endif /* !USE_TERM_DRIVER */
     18493 
     18494 #define DATA(r,g,b) {r,g,b, 0,0,0, 0}
     18495 
     18496@@ -71,7 +94,7 @@
     18497 
     18498 #define MAX_PALETTE    8
     18499 
     18500-#define OkColorHi(n)   (((n) < COLORS) && ((n) < max_colors))
     18501+#define OkColorHi(n)   (((n) < COLORS) && ((n) < maxcolors))
     18502 #define InPalette(n)   ((n) >= 0 && (n) < MAX_PALETTE)
     18503 
     18504 /*
     18505@@ -106,29 +129,43 @@
     18506     DATA(      300,    50,     100),           /* COLOR_CYAN */
     18507     DATA(      0,      50,     100),           /* COLOR_WHITE */
    1809318508 };
     18509+
     18510+#ifdef USE_TERM_DRIVER
     18511+NCURSES_EXPORT_VAR(const color_t*) _nc_cga_palette = cga_palette;
     18512+NCURSES_EXPORT_VAR(const color_t*) _nc_hls_palette = hls_palette;
     18513+#endif
     18514+
    1809418515 /* *INDENT-ON* */
    1809518516 
     
    1809918520+ */
    1810018521+#define ValidPair(pair) \
    18101 +    ((SP != 0) && (pair >= 0) && (pair < SP->_pair_limit) && SP->_coloron)
     18522+    ((SP_PARM != 0) && (pair >= 0) && (pair < SP_PARM->_pair_limit) && SP_PARM->_coloron)
    1810218523+
    1810318524 #if NCURSES_EXT_FUNCS
    1810418525 /*
    1810518526  * These are called from _nc_do_color(), which in turn is called from
    18106 @@ -147,31 +159,39 @@
     18527- * vidattr - so we have to assume that SP may be null.
     18528+ * vidattr - so we have to assume that sp may be null.
     18529  */
     18530 static int
     18531-default_fg(void)
     18532+default_fg(NCURSES_SP_DCL0)
     18533 {
     18534-    return (SP != 0) ? SP->_default_fg : COLOR_WHITE;
     18535+    return (SP_PARM != 0) ? SP_PARM->_default_fg : COLOR_WHITE;
    1810718536 }
     18537 
     18538 static int
     18539-default_bg(void)
     18540+default_bg(NCURSES_SP_DCL0)
     18541 {
     18542-    return SP != 0 ? SP->_default_bg : COLOR_BLACK;
     18543+    return SP_PARM != 0 ? SP_PARM->_default_bg : COLOR_BLACK;
     18544 }
     18545 #else
     18546-#define default_fg() COLOR_WHITE
     18547-#define default_bg() COLOR_BLACK
     18548+#define default_fg(sp) COLOR_WHITE
     18549+#define default_bg(sp) COLOR_BLACK
     18550 #endif
     18551 
     18552+#ifndef USE_TERM_DRIVER
     18553 /*
     18554  * SVr4 curses is known to interchange color codes (1,4) and (3,6), possibly
     18555  * to maintain compatibility with a pre-ANSI scheme.  The same scheme is
     18556@@ -145,52 +182,70 @@
     18557     }
     18558     return c;
     18559 }
     18560+#endif
    1810818561 
    1810918562 static void
     
    1811118564+set_background_color(NCURSES_SP_DCLx int bg, NCURSES_SP_OUTC outc)
    1811218565 {
     18566+#ifdef USE_TERM_DRIVER
     18567+    CallDriver_3(SP_PARM, color, FALSE, bg, outc);
     18568+#else
    1811318569     if (set_a_background) {
    1811418570        TPUTS_TRACE("set_a_background");
     
    1812418580+                               1, outc);
    1812518581     }
     18582+#endif
    1812618583 }
    1812718584 
     
    1813018587+set_foreground_color(NCURSES_SP_DCLx int fg, NCURSES_SP_OUTC outc)
    1813118588 {
     18589+#ifdef USE_TERM_DRIVER
     18590+    CallDriver_3(SP_PARM, color, TRUE, fg, outc);
     18591+#else
    1813218592     if (set_a_foreground) {
    1813318593        TPUTS_TRACE("set_a_foreground");
     
    1814318603+                               1, outc);
    1814418604     }
     18605+#endif
    1814518606 }
    1814618607 
     
    1814918610+init_color_table(NCURSES_SP_DCL0)
    1815018611 {
    18151      const color_t *tp;
     18612-    const color_t *tp;
     18613+    const color_t *tp = DefaultPalette;
    1815218614     int n;
    18153 @@ -179,18 +199,18 @@
    18154      tp = (hue_lightness_saturation) ? hls_palette : cga_palette;
     18615 
     18616-    tp = (hue_lightness_saturation) ? hls_palette : cga_palette;
     18617+    assert(tp != 0);
     18618+
    1815518619     for (n = 0; n < COLORS; n++) {
    1815618620        if (InPalette(n)) {
     
    1815918623        } else {
    1816018624-           SP->_color_table[n] = tp[n % MAX_PALETTE];
     18625-           if (hue_lightness_saturation) {
     18626-               SP->_color_table[n].green = 100;
    1816118627+           SP_PARM->_color_table[n] = tp[n % MAX_PALETTE];
    18162             if (hue_lightness_saturation) {
    18163 -               SP->_color_table[n].green = 100;
     18628+           if (UseHlsPalette) {
    1816418629+               SP_PARM->_color_table[n].green = 100;
    1816518630            } else {
     
    1817918644        }
    1818018645     }
    18181 @@ -200,7 +220,7 @@
     18646@@ -200,8 +255,11 @@
    1818218647  * Reset the color pair, e.g., to whatever color pair 0 is.
    1818318648  */
     
    1818618651+reset_color_pair(NCURSES_SP_DCL0)
    1818718652 {
     18653+#ifdef USE_TERM_DRIVER
     18654+    return CallDriver(SP_PARM, rescol);
     18655+#else
    1818818656     bool result = FALSE;
    1818918657 
    18190 @@ -218,15 +238,14 @@
     18658     if (orig_pair != 0) {
     18659@@ -210,6 +268,7 @@
     18660        result = TRUE;
     18661     }
     18662     return result;
     18663+#endif
     18664 }
     18665 
     18666 /*
     18667@@ -217,65 +276,93 @@
     18668  * badly-written terminal descriptions than for the relatively rare case where
    1819118669  * someone has changed the color definitions.
    1819218670  */
    18193  bool
     18671-bool
    1819418672-_nc_reset_colors(void)
    18195 -{
    18196 +NCURSES_SP_NAME(_nc_reset_colors) (NCURSES_SP_DCL0) {
     18673+NCURSES_EXPORT(bool)
     18674+NCURSES_SP_NAME(_nc_reset_colors) (NCURSES_SP_DCL0)
     18675 {
    1819718676     int result = FALSE;
    1819818677 
    18199      T((T_CALLED("_nc_reset_colors()")));
     18678-    T((T_CALLED("_nc_reset_colors()")));
    1820018679-    if (SP->_color_defs > 0)
    1820118680-       SP->_color_defs = -(SP->_color_defs);
     18681-
     18682-    if (reset_color_pair())
     18683+    T((T_CALLED("_nc_reset_colors(%p)"), SP_PARM));
    1820218684+    if (SP_PARM->_color_defs > 0)
    1820318685+       SP_PARM->_color_defs = -(SP_PARM->_color_defs);
    18204  
    18205 -    if (reset_color_pair())
    1820618686+    if (reset_color_pair(NCURSES_SP_ARG))
    1820718687        result = TRUE;
     18688+
     18689+#ifdef USE_TERM_DRIVER
     18690+    result = CallDriver(SP_PARM, rescolors);
     18691+#else
    1820818692     if (orig_colors != 0) {
    1820918693        TPUTS_TRACE("orig_colors");
    18210 @@ -236,46 +255,69 @@
     18694        putp(orig_colors);
     18695        result = TRUE;
     18696     }
     18697+#endif
    1821118698     returnBool(result);
    1821218699 }
    1821318700 
    1821418701+#if NCURSES_SP_FUNCS
    18215 +bool
     18702+NCURSES_EXPORT(bool)
    1821618703+_nc_reset_colors(void)
    1821718704+{
     
    1822518712 {
    1822618713     int result = ERR;
    18227  
    18228      T((T_CALLED("start_color()")));
     18714+    int maxpairs = 0, maxcolors = 0;
     18715 
     18716-    T((T_CALLED("start_color()")));
     18717+    T((T_CALLED("start_color(%p)"), SP_PARM));
    1822918718 
    1823018719-    if (SP == 0) {
     
    1823518724        result = OK;
    1823618725     } else {
    18237  
     18726-
    1823818727-       if (reset_color_pair() != TRUE) {
    1823918728-           set_foreground_color(default_fg(), _nc_outch);
    1824018729-           set_background_color(default_bg(), _nc_outch);
     18730+       maxpairs = MaxPairs;
     18731+       maxcolors = MaxColors;
    1824118732+       if (reset_color_pair(NCURSES_SP_ARG) != TRUE) {
    1824218733+           set_foreground_color(NCURSES_SP_ARGx
    18243 +                                default_fg(),
     18734+                                default_fg(NCURSES_SP_ARG),
    1824418735+                                NCURSES_SP_NAME(_nc_outch));
    1824518736+           set_background_color(NCURSES_SP_ARGx
    18246 +                                default_bg(),
     18737+                                default_bg(NCURSES_SP_ARG),
    1824718738+                                NCURSES_SP_NAME(_nc_outch));
    1824818739        }
    1824918740 
    18250         if (max_pairs > 0 && max_colors > 0) {
     18741-       if (max_pairs > 0 && max_colors > 0) {
    1825118742-           SP->_pair_count = max_pairs;
    1825218743-           SP->_color_count = max_colors;
    18253 +           SP_PARM->_pair_limit = max_pairs;
     18744+       if (maxpairs > 0 && maxcolors > 0) {
     18745+           SP_PARM->_pair_limit = maxpairs;
    1825418746+
    1825518747+#if NCURSES_EXT_FUNCS
     
    1825818750+            * allow for default-color as a component of a color-pair.
    1825918751+            */
    18260 +           SP_PARM->_pair_limit += (1 + (2 * max_colors));
     18752+           SP_PARM->_pair_limit += (1 + (2 * maxcolors));
    1826118753+#endif
    18262 +           SP_PARM->_pair_count = max_pairs;
    18263 +           SP_PARM->_color_count = max_colors;
     18754+           SP_PARM->_pair_count = maxpairs;
     18755+           SP_PARM->_color_count = maxcolors;
    1826418756 #if !USE_REENTRANT
    18265             COLOR_PAIRS = max_pairs;
    18266             COLORS = max_colors;
     18757-           COLOR_PAIRS = max_pairs;
     18758-           COLORS = max_colors;
     18759+           COLOR_PAIRS = maxpairs;
     18760+           COLORS = maxcolors;
    1826718761 #endif
    1826818762 
     
    1827318767-                   SP->_color_pairs[0] = PAIR_OF(default_fg(), default_bg());
    1827418768-                   init_color_table();
    18275 +           SP_PARM->_color_pairs = TYPE_CALLOC(colorpair_t,
    18276 +                                               SP_PARM->_pair_limit);
     18769+           SP_PARM->_color_pairs = TYPE_CALLOC(colorpair_t, SP_PARM->_pair_limit);
    1827718770+           if (SP_PARM->_color_pairs != 0) {
    18278 +               SP_PARM->_color_table = TYPE_CALLOC(color_t, max_colors);
     18771+               SP_PARM->_color_table = TYPE_CALLOC(color_t, maxcolors);
    1827918772+               if (SP_PARM->_color_table != 0) {
    18280 +                   SP_PARM->_color_pairs[0] = PAIR_OF(default_fg(),
    18281 +                                                      default_bg());
     18773+                   SP_PARM->_color_pairs[0] = PAIR_OF(default_fg(NCURSES_SP_ARG),
     18774+                                                      default_bg(NCURSES_SP_ARG));
    1828218775+                   init_color_table(NCURSES_SP_ARG);
    1828318776 
     
    1829518788            }
    1829618789        } else {
    18297 @@ -285,6 +327,14 @@
     18790@@ -285,6 +372,14 @@
    1829818791     returnCode(result);
    1829918792 }
     
    1831018803 static void
    1831118804 rgb2hls(short r, short g, short b, short *h, short *l, short *s)
    18312 @@ -328,24 +378,72 @@
     18805@@ -328,24 +423,75 @@
    1831318806  * values.
    1831418807  */
     
    1831918812     colorpair_t result;
    1832018813+    colorpair_t previous;
    18321  
    18322      T((T_CALLED("init_pair(%d,%d,%d)"), pair, f, b));
     18814+    int maxcolors;
     18815 
     18816-    T((T_CALLED("init_pair(%d,%d,%d)"), pair, f, b));
     18817+    T((T_CALLED("init_pair(%p,%d,%d,%d)"), SP_PARM, pair, f, b));
    1832318818 
    1832418819-    if ((pair < 0) || (pair >= COLOR_PAIRS) || SP == 0 || !SP->_coloron)
    1832518820+    if (!ValidPair(pair))
    1832618821        returnCode(ERR);
     18822+
     18823+    maxcolors = MaxColors;
    1832718824+
    1832818825+    previous = SP_PARM->_color_pairs[pair];
     
    1839018887 #endif
    1839118888     {
    18392 @@ -361,8 +459,8 @@
     18889@@ -361,14 +507,14 @@
    1839318890      * pair colors with the new ones).
    1839418891      */
     
    1840018897        int y, x;
    1840118898 
    18402         for (y = 0; y <= curscr->_maxy; y++) {
    18403 @@ -381,9 +479,9 @@
    18404                 _nc_make_oldhash(y);
     18899-       for (y = 0; y <= curscr->_maxy; y++) {
     18900-           struct ldat *ptr = &(curscr->_line[y]);
     18901+       for (y = 0; y <= CurScreen(SP_PARM)->_maxy; y++) {
     18902+           struct ldat *ptr = &(CurScreen(SP_PARM)->_line[y]);
     18903            bool changed = FALSE;
     18904-           for (x = 0; x <= curscr->_maxx; x++) {
     18905+           for (x = 0; x <= CurScreen(SP_PARM)->_maxx; x++) {
     18906                if (GetPair(ptr->text[x]) == pair) {
     18907                    /* Set the old cell to zero to ensure it will be
     18908                       updated on the next doupdate() */
     18909@@ -378,15 +524,19 @@
     18910                }
     18911            }
     18912            if (changed)
     18913-               _nc_make_oldhash(y);
     18914+               NCURSES_SP_NAME(_nc_make_oldhash) (NCURSES_SP_ARGx y);
    1840518915        }
    1840618916     }
     
    1840818918-    if (GET_SCREEN_PAIR(SP) == pair)
    1840918919-       SET_SCREEN_PAIR(SP, (chtype) (~0));     /* force attribute update */
     18920 
    1841018921+    SP_PARM->_color_pairs[pair] = result;
    1841118922+    if (GET_SCREEN_PAIR(SP_PARM) == pair)
    1841218923+       SET_SCREEN_PAIR(SP_PARM, (chtype) (~0));        /* force attribute update */
    18413  
     18924+
     18925+#ifdef USE_TERM_DRIVER
     18926+    CallDriver_3(SP_PARM, initpair, pair, f, b);
     18927+#else
    1841418928     if (initialize_pair && InPalette(f) && InPalette(b)) {
    18415         const color_t *tp = hue_lightness_saturation ? hls_palette : cga_palette;
    18416 @@ -404,54 +502,79 @@
     18929-       const color_t *tp = hue_lightness_saturation ? hls_palette : cga_palette;
     18930+       const color_t *tp = DefaultPalette;
     18931 
     18932        TR(TRACE_ATTRS,
     18933           ("initializing pair: pair = %d, fg=(%d,%d,%d), bg=(%d,%d,%d)",
     18934@@ -400,80 +550,139 @@
     18935                     tp[f].red, tp[f].green, tp[f].blue,
     18936                     tp[b].red, tp[b].green, tp[b].blue));
     18937     }
     18938+#endif
     18939 
    1841718940     returnCode(OK);
    1841818941 }
     
    1843418957 {
    1843518958     int result = ERR;
    18436  
    18437      T((T_CALLED("init_color(%d,%d,%d,%d)"), color, r, g, b));
    18438  
    18439      if (initialize_color != NULL
     18959+    int maxcolors;
     18960+
     18961+    T((T_CALLED("init_color(%p,%d,%d,%d,%d)"), SP_PARM, color, r, g, b));
     18962 
     18963-    T((T_CALLED("init_color(%d,%d,%d,%d)"), color, r, g, b));
     18964+    if (SP_PARM == 0)
     18965+       returnCode(result);
     18966 
     18967-    if (initialize_color != NULL
    1844018968-       && SP != 0
    1844118969-       && SP->_coloron
    18442 +       && SP_PARM != 0
     18970+    maxcolors = MaxColors;
     18971+
     18972+    if (InitColor
    1844318973+       && SP_PARM->_coloron
    1844418974        && (color >= 0 && OkColorHi(color))
     
    1845418984+       SP_PARM->_color_table[color].b = b;
    1845518985 
    18456         if (hue_lightness_saturation) {
     18986-       if (hue_lightness_saturation) {
     18987+       if (UseHlsPalette) {
    1845718988            rgb2hls(r, g, b,
    1845818989-                   &SP->_color_table[color].red,
     
    1847119002        }
    1847219003 
     19004+#ifdef USE_TERM_DRIVER
     19005+       CallDriver_4(SP_PARM, initcolor, color, r, g, b);
     19006+#else
    1847319007        TPUTS_TRACE("initialize_color");
    1847419008        putp(TPARM_4(initialize_color, color, r, g, b));
    1847519009-       SP->_color_defs = max(color + 1, SP->_color_defs);
     19010+#endif
    1847619011+       SP_PARM->_color_defs = max(color + 1, SP_PARM->_color_defs);
     19012+
    1847719013        result = OK;
    1847819014     }
     
    1848819024+#endif
    1848919025+
    18490  NCURSES_EXPORT(bool)
    18491 -can_change_color(void)
    18492 +NCURSES_SP_NAME(can_change_color) (NCURSES_SP_DCL0)
    18493  {
    18494      T((T_CALLED("can_change_color()")));
    18495      returnCode((can_change != 0) ? TRUE : FALSE);
    18496  }
    18497  
     19026+NCURSES_EXPORT(bool)
     19027+NCURSES_SP_NAME(can_change_color) (NCURSES_SP_DCL)
     19028+{
     19029+    T((T_CALLED("can_change_color(%p)"), SP_PARM));
     19030+    returnCode((CanChange != 0) ? TRUE : FALSE);
     19031+}
     19032+
    1849819033+#if NCURSES_SP_FUNCS
    1849919034 NCURSES_EXPORT(bool)
     19035 can_change_color(void)
     19036 {
     19037-    T((T_CALLED("can_change_color()")));
     19038-    returnCode((can_change != 0) ? TRUE : FALSE);
     19039+    return NCURSES_SP_NAME(can_change_color) (CURRENT_SCREEN);
     19040 }
     19041+#endif
     19042 
     19043 NCURSES_EXPORT(bool)
    1850019044-has_colors(void)
    18501 +can_change_color(void)
    18502 +{
    18503 +    return NCURSES_SP_NAME(can_change_color) (CURRENT_SCREEN);
    18504 +}
    18505 +#endif
    18506 +
    18507 +NCURSES_EXPORT(bool)
    1850819045+NCURSES_SP_NAME(has_colors) (NCURSES_SP_DCL0)
    1850919046 {
     19047+    int code;
     19048+
    1851019049     T((T_CALLED("has_colors()")));
    18511      returnCode((VALID_NUMERIC(max_colors) && VALID_NUMERIC(max_pairs)
    18512 @@ -462,18 +585,27 @@
    18513                     || set_color_pair)) ? TRUE : FALSE);
     19050-    returnCode((VALID_NUMERIC(max_colors) && VALID_NUMERIC(max_pairs)
     19051-               && (((set_foreground != NULL)
     19052-                    && (set_background != NULL))
     19053-                   || ((set_a_foreground != NULL)
     19054-                       && (set_a_background != NULL))
     19055-                   || set_color_pair)) ? TRUE : FALSE);
     19056+#ifdef USE_TERM_DRIVER
     19057+    code = HasColor;
     19058+#else
     19059+    code = ((VALID_NUMERIC(max_colors) && VALID_NUMERIC(max_pairs)
     19060+            && (((set_foreground != NULL)
     19061+                 && (set_background != NULL))
     19062+                || ((set_a_foreground != NULL)
     19063+                    && (set_a_background != NULL))
     19064+                || set_color_pair)) ? TRUE : FALSE);
     19065+#endif
     19066+    returnCode(code);
    1851419067 }
    1851519068 
     
    1852419077 NCURSES_EXPORT(int)
    1852519078-color_content(short color, short *r, short *g, short *b)
    18526 +NCURSES_SP_NAME(color_content) (NCURSES_SP_DCLx short color, short *r,
    18527 +                               short *g, short *b)
     19079+NCURSES_SP_NAME(color_content) (NCURSES_SP_DCLx
     19080+                               short color, short *r, short *g, short *b)
    1852819081 {
    18529      int result;
    18530  
    18531      T((T_CALLED("color_content(%d,%p,%p,%p)"), color, r, g, b));
     19082-    int result;
     19083+    int result = ERR;
     19084+    int maxcolors;
     19085+
     19086+    T((T_CALLED("color_content(%p,%d,%p,%p,%p)"), SP_PARM, color, r, g, b));
     19087+
     19088+    if (SP_PARM == 0)
     19089+       returnCode(result);
     19090 
     19091-    T((T_CALLED("color_content(%d,%p,%p,%p)"), color, r, g, b));
    1853219092-    if (color < 0 || !OkColorHi(color) || SP == 0 || !SP->_coloron) {
    18533 +    if (color < 0 || !OkColorHi(color) || SP_PARM == 0 || !SP_PARM->_coloron) {
     19093+    maxcolors = MaxColors;
     19094+
     19095+    if (color < 0 || !OkColorHi(color) || !SP_PARM->_coloron) {
    1853419096        result = ERR;
    1853519097     } else {
     
    1854319105        if (r)
    1854419106            *r = c_r;
    18545 @@ -489,18 +621,27 @@
     19107@@ -489,18 +698,27 @@
    1854619108     returnCode(result);
    1854719109 }
     
    1855719119+
    1855819120+NCURSES_EXPORT(int)
    18559 +NCURSES_SP_NAME(pair_content) (NCURSES_SP_DCLx short pair, short *f,
    18560 +                              short *b)
     19121+NCURSES_SP_NAME(pair_content) (NCURSES_SP_DCLx
     19122+                              short pair, short *f, short *b)
    1856119123 {
    1856219124     int result;
    1856319125 
    18564      T((T_CALLED("pair_content(%d,%p,%p)"), pair, f, b));
     19126-    T((T_CALLED("pair_content(%d,%p,%p)"), pair, f, b));
     19127+    T((T_CALLED("pair_content(%p,%d,%p,%p)"), SP_PARM, pair, f, b));
    1856519128 
    1856619129-    if ((pair < 0) || (pair >= COLOR_PAIRS) || SP == 0 || !SP->_coloron) {
     
    1857519138 #if NCURSES_EXT_FUNCS
    1857619139        if (fg == COLOR_DEFAULT)
    18577 @@ -520,27 +661,41 @@
     19140@@ -514,33 +732,50 @@
     19141        if (b)
     19142            *b = bg;
     19143 
     19144-       TR(TRACE_ATTRS, ("...pair_content(%d,%d,%d)", pair, fg, bg));
     19145+       TR(TRACE_ATTRS, ("...pair_content(%p,%d,%d,%d)", SP_PARM, pair, fg, bg));
     19146        result = OK;
     19147     }
    1857819148     returnCode(result);
    1857919149 }
     
    1859519165+                              NCURSES_SP_OUTC outc)
    1859619166 {
     19167+#ifdef USE_TERM_DRIVER
     19168+    CallDriver_4(SP_PARM, docolor, old_pair, pair, reverse, outc);
     19169+#else
    1859719170     NCURSES_COLOR_T fg = COLOR_DEFAULT;
    1859819171     NCURSES_COLOR_T bg = COLOR_DEFAULT;
     
    1862219195        if ((isDefaultColor(fg) && !isDefaultColor(old_fg))
    1862319196            || (isDefaultColor(bg) && !isDefaultColor(old_bg))) {
    18624 @@ -550,20 +705,20 @@
     19197@@ -550,29 +785,29 @@
    1862519198             * the terminal description, treat it as screen's indicator of ECMA
    1862619199             * SGR 39 and SGR 49, and assume the two sequences are independent.
     
    1864919222            return;
    1865019223     }
    18651 @@ -585,9 +740,22 @@
     19224 
     19225 #if NCURSES_EXT_FUNCS
     19226     if (isDefaultColor(fg))
     19227-       fg = default_fg();
     19228+       fg = default_fg(NCURSES_SP_ARG);
     19229     if (isDefaultColor(bg))
     19230-       bg = default_bg();
     19231+       bg = default_bg(NCURSES_SP_ARG);
     19232 #endif
     19233 
     19234     if (reverse) {
     19235@@ -585,9 +820,23 @@
    1865219236                     fg, bg));
    1865319237 
     
    1866019244+       set_background_color(NCURSES_SP_ARGx bg, outc);
    1866119245     }
     19246+#endif
    1866219247 }
    1866319248+
     
    1867619261diff -Naur ncurses-5.7.orig/ncurses/base/lib_colorset.c ncurses-5.7/ncurses/base/lib_colorset.c
    1867719262--- ncurses-5.7.orig/ncurses/base/lib_colorset.c        2005-01-29 13:40:51.000000000 -0800
    18678 +++ ncurses-5.7/ncurses/base/lib_colorset.c     2009-07-19 15:02:16.000000000 -0700
     19263+++ ncurses-5.7/ncurses/base/lib_colorset.c     2009-09-12 08:51:11.000000000 -0700
    1867919264@@ -1,5 +1,5 @@
    1868019265 /****************************************************************************
     
    1872419309diff -Naur ncurses-5.7.orig/ncurses/base/lib_delwin.c ncurses-5.7/ncurses/base/lib_delwin.c
    1872519310--- ncurses-5.7.orig/ncurses/base/lib_delwin.c  2008-06-07 07:10:56.000000000 -0700
    18726 +++ ncurses-5.7/ncurses/base/lib_delwin.c       2009-07-19 15:04:03.000000000 -0700
     19311+++ ncurses-5.7/ncurses/base/lib_delwin.c       2009-09-12 08:51:40.000000000 -0700
    1872719312@@ -1,5 +1,5 @@
    1872819313 /****************************************************************************
     
    1878119366diff -Naur ncurses-5.7.orig/ncurses/base/lib_dft_fgbg.c ncurses-5.7/ncurses/base/lib_dft_fgbg.c
    1878219367--- ncurses-5.7.orig/ncurses/base/lib_dft_fgbg.c        2005-11-26 12:03:38.000000000 -0800
    18783 +++ ncurses-5.7/ncurses/base/lib_dft_fgbg.c     2009-07-19 15:04:04.000000000 -0700
     19368+++ ncurses-5.7/ncurses/base/lib_dft_fgbg.c     2009-09-12 08:51:42.000000000 -0700
    1878419369@@ -1,5 +1,5 @@
    1878519370 /****************************************************************************
     
    1888819473diff -Naur ncurses-5.7.orig/ncurses/base/lib_driver.c ncurses-5.7/ncurses/base/lib_driver.c
    1888919474--- ncurses-5.7.orig/ncurses/base/lib_driver.c  1969-12-31 16:00:00.000000000 -0800
    18890 +++ ncurses-5.7/ncurses/base/lib_driver.c       2009-07-19 15:04:11.000000000 -0700
     19475+++ ncurses-5.7/ncurses/base/lib_driver.c       2009-09-12 08:51:49.000000000 -0700
    1889119476@@ -0,0 +1,142 @@
    1889219477+/****************************************************************************
     
    1903419619diff -Naur ncurses-5.7.orig/ncurses/base/lib_echo.c ncurses-5.7/ncurses/base/lib_echo.c
    1903519620--- ncurses-5.7.orig/ncurses/base/lib_echo.c    2000-12-09 18:43:27.000000000 -0800
    19036 +++ ncurses-5.7/ncurses/base/lib_echo.c 2009-07-19 15:02:22.000000000 -0700
     19621+++ ncurses-5.7/ncurses/base/lib_echo.c 2009-09-12 08:51:17.000000000 -0700
    1903719622@@ -1,5 +1,5 @@
    1903819623 /****************************************************************************
     
    1910019685diff -Naur ncurses-5.7.orig/ncurses/base/lib_endwin.c ncurses-5.7/ncurses/base/lib_endwin.c
    1910119686--- ncurses-5.7.orig/ncurses/base/lib_endwin.c  2000-12-09 18:43:27.000000000 -0800
    19102 +++ ncurses-5.7/ncurses/base/lib_endwin.c       2009-07-19 15:04:13.000000000 -0700
     19687+++ ncurses-5.7/ncurses/base/lib_endwin.c       2009-09-12 08:51:50.000000000 -0700
    1910319688@@ -1,5 +1,5 @@
    1910419689 /****************************************************************************
     
    1916819753diff -Naur ncurses-5.7.orig/ncurses/base/lib_flash.c ncurses-5.7/ncurses/base/lib_flash.c
    1916919754--- ncurses-5.7.orig/ncurses/base/lib_flash.c   2000-12-09 18:43:27.000000000 -0800
    19170 +++ ncurses-5.7/ncurses/base/lib_flash.c        2009-07-19 15:04:03.000000000 -0700
     19755+++ ncurses-5.7/ncurses/base/lib_flash.c        2009-09-12 08:51:40.000000000 -0700
    1917119756@@ -1,5 +1,5 @@
    1917219757 /****************************************************************************
     
    1923719822diff -Naur ncurses-5.7.orig/ncurses/base/lib_freeall.c ncurses-5.7/ncurses/base/lib_freeall.c
    1923819823--- ncurses-5.7.orig/ncurses/base/lib_freeall.c 2008-09-27 06:09:57.000000000 -0700
    19239 +++ ncurses-5.7/ncurses/base/lib_freeall.c      2009-07-19 15:03:59.000000000 -0700
     19824+++ ncurses-5.7/ncurses/base/lib_freeall.c      2009-09-12 08:51:37.000000000 -0700
    1924019825@@ -1,5 +1,5 @@
    1924119826 /****************************************************************************
     
    1936319948diff -Naur ncurses-5.7.orig/ncurses/base/lib_getch.c ncurses-5.7/ncurses/base/lib_getch.c
    1936419949--- ncurses-5.7.orig/ncurses/base/lib_getch.c   2008-09-20 12:46:13.000000000 -0700
    19365 +++ ncurses-5.7/ncurses/base/lib_getch.c        2009-07-19 15:04:13.000000000 -0700
     19950+++ ncurses-5.7/ncurses/base/lib_getch.c        2009-09-12 08:52:04.000000000 -0700
    1936619951@@ -1,5 +1,5 @@
    1936719952 /****************************************************************************
     
    1938419969 
    1938519970-MODULE_ID("$Id: lib_getch.c,v 1.99 2008/09/20 19:46:13 tom Exp $")
    19386 +MODULE_ID("$Id: lib_getch.c,v 1.104 2009/07/04 20:41:13 tom Exp $")
     19971+MODULE_ID("$Id: lib_getch.c,v 1.107 2009/08/15 20:41:24 Clemens.Ladisch Exp $")
    1938719972 
    1938819973 #include <fifo_defs.h>
     
    1939119976-#define GetEscdelay(sp) (sp)->_ESCDELAY
    1939219977+#define GetEscdelay(sp) *_nc_ptr_Escdelay(sp)
    19393 +NCURSES_EXPORT(int *)
    19394 +_nc_ptr_Escdelay(SCREEN *sp)
    19395 +{
    19396 +    return ptrEscdelay(sp);
    19397 +}
    1939819978 NCURSES_EXPORT(int)
    1939919979 NCURSES_PUBLIC_VAR(ESCDELAY) (void)
     
    1940119981-    return SP ? GetEscdelay(SP) : 1000;
    1940219982+    return *(_nc_ptr_Escdelay(CURRENT_SCREEN));
     19983+}
     19984+
     19985+NCURSES_EXPORT(int *)
     19986+_nc_ptr_Escdelay(SCREEN *sp)
     19987+{
     19988+    return ptrEscdelay(sp);
    1940319989 }
    1940419990 #else
     
    1940619992-NCURSES_EXPORT_VAR(int)
    1940719993-ESCDELAY = 1000;               /* max interval betw. chars in funkeys, in millisecs */
    19408 +NCURSES_EXPORT_VAR (int)
    19409 +  ESCDELAY = 1000;             /* max interval betw. chars in funkeys, in millisecs */
     19994+NCURSES_EXPORT_VAR(int) ESCDELAY = 1000;
    1941019995 #endif
    1941119996 
     
    1942620011 #else
    1942720012+    (void) SP_PARM;
    19428      ESCDELAY = value;
    19429  #endif
    19430      return code;
    19431  }
     20013+    ESCDELAY = value;
     20014+#endif
     20015+    return code;
     20016+}
    1943220017+
    1943320018+#if NCURSES_SP_FUNCS
     
    1943920024+    code = NCURSES_SP_NAME(set_escdelay) (CURRENT_SCREEN, value);
    1944020025+#else
    19441 +    ESCDELAY = value;
     20026     ESCDELAY = value;
    1944220027+    code = OK;
    19443 +#endif
    19444 +    return code;
    19445 +}
    19446 +#endif
     20028 #endif
     20029     return code;
     20030 }
     20031 #endif
    1944720032+#endif /* NCURSES_EXT_FUNCS */
    1944820033+
     
    1945920044+#if NCURSES_SP_FUNCS
    1946020045+NCURSES_EXPORT(int)
    19461 +get_escdelay (void)
     20046+get_escdelay(void)
    1946220047+{
    19463 +    return NCURSES_SP_NAME(get_escdelay)(CURRENT_SCREEN);
     20048+    return NCURSES_SP_NAME(get_escdelay) (CURRENT_SCREEN);
    1946420049+}
    19465  #endif
     20050+#endif
    1946620051+#endif /* NCURSES_EXT_FUNCS */
    1946720052 
     
    1959120176 #ifdef NCURSES_WGETCH_EVENTS
    1959220177        /* Return it first */
    19593 @@ -402,7 +461,7 @@
     20178@@ -402,13 +461,13 @@
    1959420179            rc = check_mouse_activity(sp, delay EVENTLIST_2nd(evl));
    1959520180 
     
    1960020185                returnCode(KEY_CODE_YES);
    1960120186            }
     20187 #endif
     20188            if (!rc) {
     20189-               returnCode(ERR);
     20190+               goto check_sigwinch;
     20191            }
     20192        }
     20193        /* else go on to read data available */
    1960220194@@ -427,7 +486,7 @@
    1960320195         * increase the wait with mouseinterval().
     
    1963920231            }
    1964020232        }
    19641 @@ -645,7 +704,7 @@
     20233@@ -470,6 +529,7 @@
     20234     }
     20235 
     20236     if (ch == ERR) {
     20237+      check_sigwinch:
     20238 #if USE_SIZECHANGE
     20239        if (_nc_handle_sigwinch(sp)) {
     20240            _nc_update_screensize(sp);
     20241@@ -645,7 +705,7 @@
    1964220242            TR(TRACE_IEVENT, ("waiting for rest of sequence"));
    1964320243            rc = check_mouse_activity(sp, timeleft EVENTLIST_2nd(evl));
     
    1965020250diff -Naur ncurses-5.7.orig/ncurses/base/lib_getstr.c ncurses-5.7/ncurses/base/lib_getstr.c
    1965120251--- ncurses-5.7.orig/ncurses/base/lib_getstr.c  2008-08-16 12:20:04.000000000 -0700
    19652 +++ ncurses-5.7/ncurses/base/lib_getstr.c       2009-07-19 15:03:59.000000000 -0700
     20252+++ ncurses-5.7/ncurses/base/lib_getstr.c       2009-09-12 08:51:37.000000000 -0700
    1965320253@@ -1,5 +1,5 @@
    1965420254 /****************************************************************************
     
    1971620316diff -Naur ncurses-5.7.orig/ncurses/base/lib_initscr.c ncurses-5.7/ncurses/base/lib_initscr.c
    1971720317--- ncurses-5.7.orig/ncurses/base/lib_initscr.c 2008-08-16 14:20:48.000000000 -0700
    19718 +++ ncurses-5.7/ncurses/base/lib_initscr.c      2009-07-19 15:03:51.000000000 -0700
     20318+++ ncurses-5.7/ncurses/base/lib_initscr.c      2009-09-12 08:51:28.000000000 -0700
    1971920319@@ -1,5 +1,5 @@
    1972020320 /****************************************************************************
     
    1974720347diff -Naur ncurses-5.7.orig/ncurses/base/lib_insch.c ncurses-5.7/ncurses/base/lib_insch.c
    1974820348--- ncurses-5.7.orig/ncurses/base/lib_insch.c   2008-02-02 16:14:37.000000000 -0800
    19749 +++ ncurses-5.7/ncurses/base/lib_insch.c        2009-07-19 15:04:04.000000000 -0700
     20349+++ ncurses-5.7/ncurses/base/lib_insch.c        2009-09-12 08:51:42.000000000 -0700
    1975020350@@ -1,5 +1,5 @@
    1975120351 /****************************************************************************
     
    1984920449diff -Naur ncurses-5.7.orig/ncurses/base/lib_insnstr.c ncurses-5.7/ncurses/base/lib_insnstr.c
    1985020450--- ncurses-5.7.orig/ncurses/base/lib_insnstr.c 2004-02-28 15:44:56.000000000 -0800
    19851 +++ ncurses-5.7/ncurses/base/lib_insnstr.c      2009-07-19 15:04:04.000000000 -0700
     20451+++ ncurses-5.7/ncurses/base/lib_insnstr.c      2009-09-12 08:51:42.000000000 -0700
    1985220452@@ -1,5 +1,5 @@
    1985320453 /****************************************************************************
     
    1988220482diff -Naur ncurses-5.7.orig/ncurses/base/lib_isendwin.c ncurses-5.7/ncurses/base/lib_isendwin.c
    1988320483--- ncurses-5.7.orig/ncurses/base/lib_isendwin.c        2000-12-09 18:43:27.000000000 -0800
    19884 +++ ncurses-5.7/ncurses/base/lib_isendwin.c     2009-07-19 15:02:20.000000000 -0700
     20484+++ ncurses-5.7/ncurses/base/lib_isendwin.c     2009-09-12 08:51:16.000000000 -0700
    1988520485@@ -1,5 +1,5 @@
    1988620486 /****************************************************************************
     
    1992620526diff -Naur ncurses-5.7.orig/ncurses/base/lib_mouse.c ncurses-5.7/ncurses/base/lib_mouse.c
    1992720527--- ncurses-5.7.orig/ncurses/base/lib_mouse.c   2008-10-18 14:48:55.000000000 -0700
    19928 +++ ncurses-5.7/ncurses/base/lib_mouse.c        2009-07-19 15:04:13.000000000 -0700
     20528+++ ncurses-5.7/ncurses/base/lib_mouse.c        2009-09-12 08:51:50.000000000 -0700
    1992920529@@ -1,5 +1,5 @@
    1993020530 /****************************************************************************
     
    2031320913diff -Naur ncurses-5.7.orig/ncurses/base/lib_mvwin.c ncurses-5.7/ncurses/base/lib_mvwin.c
    2031420914--- ncurses-5.7.orig/ncurses/base/lib_mvwin.c   2006-02-25 14:53:46.000000000 -0800
    20315 +++ ncurses-5.7/ncurses/base/lib_mvwin.c        2009-07-19 15:04:06.000000000 -0700
     20915+++ ncurses-5.7/ncurses/base/lib_mvwin.c        2009-09-12 08:51:43.000000000 -0700
    2031620916@@ -1,5 +1,5 @@
    2031720917 /****************************************************************************
     
    2036020960diff -Naur ncurses-5.7.orig/ncurses/base/lib_newterm.c ncurses-5.7/ncurses/base/lib_newterm.c
    2036120961--- ncurses-5.7.orig/ncurses/base/lib_newterm.c 2008-08-16 14:20:48.000000000 -0700
    20362 +++ ncurses-5.7/ncurses/base/lib_newterm.c      2009-07-19 15:03:59.000000000 -0700
     20962+++ ncurses-5.7/ncurses/base/lib_newterm.c      2009-09-12 08:52:10.000000000 -0700
    2036320963@@ -1,5 +1,5 @@
    2036420964 /****************************************************************************
     
    2037620976 
    2037720977 /*
    20378 @@ -45,10 +46,14 @@
     20978@@ -45,10 +46,19 @@
    2037920979 #define _POSIX_SOURCE
    2038020980 #endif
    2038120981 
     20982-#include <term.h>              /* clear_screen, cup & friends, cur_term */
    2038220983+#ifndef CUR
    20383 +#define CUR SP_TERMTYPE 
     20984+#define CUR SP_TERMTYPE
    2038420985+#endif
    2038520986+
    20386  #include <term.h>              /* clear_screen, cup & friends, cur_term */
    2038720987 #include <tic.h>
    2038820988 
    2038920989-MODULE_ID("$Id: lib_newterm.c,v 1.73 2008/08/16 21:20:48 Werner.Fink Exp $")
    20390 +MODULE_ID("$Id: lib_newterm.c,v 1.77 2009/05/10 00:48:29 tom Exp $")
     20990+MODULE_ID("$Id: lib_newterm.c,v 1.79 2009/09/06 15:13:41 tom Exp $")
     20991+
     20992+#ifdef USE_TERM_DRIVER
     20993+#define NumLabels      InfoOf(SP_PARM).numlabels
     20994+#else
     20995+#define NumLabels      num_labels
     20996+#endif
    2039120997 
    2039220998 #ifndef ONLCR                  /* Allows compilation under the QNX 4.2 OS */
    2039320999 #define ONLCR 0
    20394 @@ -95,7 +100,7 @@
     21000@@ -63,16 +73,17 @@
     21001  * is supposed to behave as if it calls newterm, we do it here.
     21002  */
     21003 static NCURSES_INLINE int
     21004-_nc_initscr(void)
     21005+_nc_initscr(NCURSES_SP_DCL0)
     21006 {
     21007     int result = ERR;
     21008+    TERMINAL *term = TerminalOf(SP_PARM);
     21009 
     21010     /* for extended XPG4 conformance requires cbreak() at this point */
     21011     /* (SVr4 curses does this anyway) */
     21012-    if (cbreak() == OK) {
     21013+    if (NCURSES_SP_NAME(cbreak) (NCURSES_SP_ARG) == OK) {
     21014        TTY buf;
     21015 
     21016-       buf = cur_term->Nttyb;
     21017+       buf = term->Nttyb;
     21018 #ifdef TERMIOS
     21019        buf.c_lflag &= ~(ECHO | ECHONL);
     21020        buf.c_iflag &= ~(ICRNL | INLCR | IGNCR);
     21021@@ -82,8 +93,9 @@
     21022 #else
     21023        memset(&buf, 0, sizeof(buf));
     21024 #endif
     21025-       if ((result = _nc_set_tty_mode(&buf)) == OK)
     21026-           cur_term->Nttyb = buf;
     21027+       result = NCURSES_SP_NAME(_nc_set_tty_mode) (NCURSES_SP_ARGx &buf);
     21028+       if (result == OK)
     21029+           term->Nttyb = buf;
     21030     }
     21031     return result;
     21032 }
     21033@@ -95,13 +107,30 @@
    2039521034  * initialized.
    2039621035  */
    2039721036 NCURSES_EXPORT(void)
    20398 -filter(void)
    2039921037+NCURSES_SP_NAME(filter) (NCURSES_SP_DCL0)
     21038+{
     21039+    START_TRACE();
     21040+    T((T_CALLED("filter(%p)"), SP_PARM));
     21041+#if NCURSES_SP_FUNCS
     21042+    if (IsPreScreen(SP_PARM)) {
     21043+       SP_PARM->_filtered = TRUE;
     21044+    }
     21045+#else
     21046+    _nc_prescreen.filter_mode = TRUE;
     21047+#endif
     21048+    returnVoid;
     21049+}
     21050+
     21051+#if NCURSES_SP_FUNCS
     21052+NCURSES_EXPORT(void)
     21053 filter(void)
    2040021054 {
    2040121055     START_TRACE();
    20402      T((T_CALLED("filter")));
    20403 @@ -103,23 +108,42 @@
     21056-    T((T_CALLED("filter")));
     21057+    T((T_CALLED("filter()")));
     21058     _nc_prescreen.filter_mode = TRUE;
    2040421059     returnVoid;
    2040521060 }
    20406  
    20407 +#if NCURSES_SP_FUNCS
    20408 +NCURSES_EXPORT(void)
    20409 +filter(void)
    20410 +{
    20411 +    NCURSES_SP_NAME(filter) (CURRENT_SCREEN);
    20412 +}
    2041321061+#endif
    20414 +
     21062 
    2041521063 #if NCURSES_EXT_FUNCS
    2041621064 /*
    20417   * An extension, allowing the application to open a new screen without
     21065@@ -109,62 +138,105 @@
    2041821066  * requiring it to also be filtered.
    2041921067  */
    2042021068 NCURSES_EXPORT(void)
    20421 -nofilter(void)
    2042221069+NCURSES_SP_NAME(nofilter) (NCURSES_SP_DCL0)
     21070+{
     21071+    START_TRACE();
     21072+    T((T_CALLED("nofilter(%p)"), SP_PARM));
     21073+#if NCURSES_SP_FUNCS
     21074+    if (IsPreScreen(SP_PARM)) {
     21075+       SP_PARM->_filtered = FALSE;
     21076+    }
     21077+#else
     21078+    _nc_prescreen.filter_mode = FALSE;
     21079+#endif
     21080+    returnVoid;
     21081+}
     21082+
     21083+#if NCURSES_SP_FUNCS
     21084+NCURSES_EXPORT(void)
     21085 nofilter(void)
    2042321086 {
    2042421087     START_TRACE();
    20425      T((T_CALLED("nofilter")));
     21088-    T((T_CALLED("nofilter")));
     21089+    T((T_CALLED("nofilter()")));
    2042621090     _nc_prescreen.filter_mode = FALSE;
    2042721091     returnVoid;
    2042821092 }
    20429 +
    20430 +#if NCURSES_SP_FUNCS
    20431 +NCURSES_EXPORT(void)
    20432 +nofilter(void)
    20433 +{
    20434 +    NCURSES_SP_NAME(nofilter) (CURRENT_SCREEN);
    20435 +}
    2043621093 #endif
    2043721094+#endif /* NCURSES_EXT_FUNCS */
     
    2044621103     int value;
    2044721104     int errret;
    20448 @@ -133,8 +157,8 @@
     21105-    SCREEN *current;
     21106     SCREEN *result = 0;
     21107+    SCREEN *current;
     21108     TERMINAL *its_term;
     21109+    FILE *_ofp = ofp ? ofp : stdout;
     21110+    FILE *_ifp = ifp ? ifp : stdin;
     21111+    int cols;
     21112+    int numlab;
     21113+#ifdef USE_TERM_DRIVER
     21114+    TERMINAL *new_term;
     21115+#endif
     21116 
     21117     START_TRACE();
     21118-    T((T_CALLED("newterm(\"%s\",%p,%p)"), name, ofp, ifp));
     21119+    T((T_CALLED("newterm(%p, \"%s\", %p,%p)"), SP_PARM, name, ofp, ifp));
     21120 
    2044921121     _nc_init_pthreads();
    2045021122     _nc_lock_global(curses);
     
    2045621128 
    2045721129     /* this loads the capability entry, then sets LINES and COLS */
    20458      if (setupterm(name, fileno(ofp), &errret) != ERR) {
    20459 @@ -159,7 +183,7 @@
     21130-    if (setupterm(name, fileno(ofp), &errret) != ERR) {
     21131+    if (setupterm(name, fileno(_ofp), &errret) != ERR) {
     21132        int slk_format = _nc_globals.slk_format;
     21133 
     21134-       /*
     21135-        * This actually allocates the screen structure, and saves the original
     21136-        * terminal settings.
     21137-        */
     21138        _nc_set_screen(0);
     21139+#ifdef USE_TERM_DRIVER
     21140+       assert(new_term != 0);
     21141+#endif
     21142 
     21143        /* allow user to set maximum escape delay from the environment */
     21144        if ((value = _nc_getenv_num("ESCDELAY")) >= 0) {
     21145            set_escdelay(value);
     21146        }
     21147 
     21148+       /*
     21149+        * This actually allocates the screen structure, and saves the original
     21150+        * terminal settings.
     21151+        */
     21152        if (_nc_setupscreen(LINES,
     21153                            COLS,
     21154-                           ofp,
     21155+                           _ofp,
     21156                            _nc_prescreen.filter_mode,
     21157                            slk_format) == ERR) {
    2046021158            _nc_set_screen(current);
    2046121159            result = 0;
    2046221160        } else {
    2046321161-           assert(SP != 0);
     21162+#ifdef USE_TERM_DRIVER
     21163+           TERMINAL_CONTROL_BLOCK *TCB;
     21164+#else
     21165+           SP_PARM = CURRENT_SCREEN;
     21166+#endif
    2046421167+           assert(SP_PARM != 0);
     21168+           cols = *(ptrCols(SP_PARM));
     21169+#ifdef USE_TERM_DRIVER
     21170+           TCB = (TERMINAL_CONTROL_BLOCK *) new_term;
     21171+           TCB->csp = SP_PARM;
     21172+#endif
     21173+           numlab = NumLabels;
     21174+
    2046521175            /*
    2046621176             * In setupterm() we did a set_curterm(), but it was before we set
    20467              * SP.  So the "current" screen's terminal pointer was overwritten
    20468 @@ -233,3 +257,11 @@
     21177-            * SP.  So the "current" screen's terminal pointer was overwritten
     21178-            * with a different terminal.  Later, in _nc_setupscreen(), we set
     21179-            * SP and the terminal pointer in the new screen.
     21180+            * CURRENT_SCREEN.  So the "current" screen's terminal pointer was
     21181+            * overwritten with a different terminal.  Later, in
     21182+            * _nc_setupscreen(), we set CURRENT_SCREEN and the terminal
     21183+            * pointer in the new screen.
     21184             *
     21185             * Restore the terminal-pointer for the pre-existing screen, if
     21186             * any.
     21187@@ -173,36 +245,41 @@
     21188                current->_term = its_term;
     21189 
     21190            /* if the terminal type has real soft labels, set those up */
     21191-           if (slk_format && num_labels > 0 && SLK_STDFMT(slk_format))
     21192+           if (slk_format && NumLabels > 0 && SLK_STDFMT(slk_format))
     21193                _nc_slk_initialize(stdscr, COLS);
     21194 
     21195-           SP->_ifd = fileno(ifp);
     21196-           typeahead(fileno(ifp));
     21197+           SP_PARM->_ifd = fileno(_ifp);
     21198+           NCURSES_SP_NAME(typeahead) (NCURSES_SP_ARGx fileno(_ifp));
     21199 #ifdef TERMIOS
     21200-           SP->_use_meta = ((cur_term->Ottyb.c_cflag & CSIZE) == CS8 &&
     21201-                            !(cur_term->Ottyb.c_iflag & ISTRIP));
     21202+           SP_PARM->_use_meta = ((cur_term->Ottyb.c_cflag & CSIZE) == CS8 &&
     21203+                                 !(cur_term->Ottyb.c_iflag & ISTRIP));
     21204 #else
     21205-           SP->_use_meta = FALSE;
     21206+           SP_PARM->_use_meta = FALSE;
     21207 #endif
     21208-           SP->_endwin = FALSE;
     21209-
     21210+           SP_PARM->_endwin = FALSE;
     21211+#ifndef USE_TERM_DRIVER
     21212            /*
     21213             * Check whether we can optimize scrolling under dumb terminals in
     21214             * case we do not have any of these capabilities, scrolling
     21215             * optimization will be useless.
     21216             */
     21217-           SP->_scrolling = ((scroll_forward && scroll_reverse) ||
     21218-                             ((parm_rindex ||
     21219-                               parm_insert_line ||
     21220-                               insert_line) &&
     21221-                              (parm_index ||
     21222-                               parm_delete_line ||
     21223-                               delete_line)));
     21224+           SP_PARM->_scrolling = ((scroll_forward && scroll_reverse) ||
     21225+                                  ((parm_rindex ||
     21226+                                    parm_insert_line ||
     21227+                                    insert_line) &&
     21228+                                   (parm_index ||
     21229+                                    parm_delete_line ||
     21230+                                    delete_line)));
     21231+#endif
     21232 
     21233-           baudrate();         /* sets a field in the SP structure */
     21234+           NCURSES_SP_NAME(baudrate) (NCURSES_SP_ARG);         /* sets a field in the screen structure */
     21235 
     21236-           SP->_keytry = 0;
     21237+           SP_PARM->_keytry = 0;
     21238 
     21239+           /* compute movement costs so we can do better move optimization */
     21240+#ifdef USE_TERM_DRIVER
     21241+           TCBOf(SP_PARM)->drv->scinit(SP_PARM);
     21242+#else
     21243            /*
     21244             * Check for mismatched graphic-rendition capabilities.  Most SVr4
     21245             * terminfo trees contain entries that have rmul or rmso equated to
     21246@@ -213,23 +290,31 @@
     21247             * shouldn't be looking at this detail.
     21248             */
     21249 #define SGR0_TEST(mode) (mode != 0) && (exit_attribute_mode == 0 || strcmp(mode, exit_attribute_mode))
     21250-           SP->_use_rmso = SGR0_TEST(exit_standout_mode);
     21251-           SP->_use_rmul = SGR0_TEST(exit_underline_mode);
     21252+           SP_PARM->_use_rmso = SGR0_TEST(exit_standout_mode);
     21253+           SP_PARM->_use_rmul = SGR0_TEST(exit_underline_mode);
     21254 
     21255            /* compute movement costs so we can do better move optimization */
     21256            _nc_mvcur_init();
     21257 
     21258            /* initialize terminal to a sane state */
     21259            _nc_screen_init();
     21260+#endif
     21261 
     21262            /* Initialize the terminal line settings. */
     21263-           _nc_initscr();
     21264+           _nc_initscr(NCURSES_SP_ARG);
     21265 
     21266            _nc_signal_handler(TRUE);
     21267-
     21268-           result = SP;
     21269+           result = SP_PARM;
     21270        }
     21271     }
    2046921272     _nc_unlock_global(curses);
    2047021273     returnSP(result);
     
    2048021283diff -Naur ncurses-5.7.orig/ncurses/base/lib_newwin.c ncurses-5.7/ncurses/base/lib_newwin.c
    2048121284--- ncurses-5.7.orig/ncurses/base/lib_newwin.c  2008-06-07 06:58:09.000000000 -0700
    20482 +++ ncurses-5.7/ncurses/base/lib_newwin.c       2009-07-19 15:04:06.000000000 -0700
     21285+++ ncurses-5.7/ncurses/base/lib_newwin.c       2009-09-12 08:52:10.000000000 -0700
    2048321286@@ -1,5 +1,5 @@
    2048421287 /****************************************************************************
     
    2050121304 
    2050221305-MODULE_ID("$Id: lib_newwin.c,v 1.52 2008/06/07 13:58:09 tom Exp $")
    20503 +MODULE_ID("$Id: lib_newwin.c,v 1.58 2009/06/06 17:53:11 tom Exp $")
     21306+MODULE_ID("$Id: lib_newwin.c,v 1.60 2009/09/06 16:32:48 tom Exp $")
    2050421307 
    2050521308 #define window_is(name) ((sp)->_##name == win)
    2050621309 
    20507 @@ -87,11 +88,11 @@
     21310@@ -61,6 +62,17 @@
     21311 {
     21312     SCREEN *sp;
     21313 
     21314+#ifdef USE_SP_WINDOWLIST
     21315+    if ((sp = _nc_screen_of(win)) != 0) {
     21316+       if (window_is(curscr)) {
     21317+           remove_window(curscr);
     21318+       } else if (window_is(stdscr)) {
     21319+           remove_window(stdscr);
     21320+       } else if (window_is(newscr)) {
     21321+           remove_window(newscr);
     21322+       }
     21323+    }
     21324+#else
     21325     for (each_screen(sp)) {
     21326        if (window_is(curscr)) {
     21327            remove_window(curscr);
     21328@@ -73,6 +85,7 @@
     21329            break;
     21330        }
     21331     }
     21332+#endif
     21333 }
     21334 
     21335 NCURSES_EXPORT(int)
     21336@@ -81,17 +94,20 @@
     21337     WINDOWLIST *p, *q;
     21338     int i;
     21339     int result = ERR;
     21340+#ifdef USE_SP_WINDOWLIST
     21341+    SCREEN *sp = _nc_screen_of(win);   /* pretend this is parameter */
     21342+#endif
     21343 
     21344     T((T_CALLED("_nc_freewin(%p)"), win));
     21345 
    2050821346     if (win != 0) {
    20509         if (_nc_try_global(curses) == 0) {
     21347-       if (_nc_try_global(curses) == 0) {
     21348+       if (_nc_nonsp_try_global(curses) == 0) {
    2051021349            q = 0;
    2051121350-           for (each_window(p)) {
    20512 +           for (each_window(SP, p)) {
     21351+           for (each_window(SP_PARM, p)) {
    2051321352                if (&(p->win) == win) {
    2051421353                    remove_window_from_screen(win);
    2051521354                    if (q == 0)
    2051621355-                       _nc_windows = p->next;
    20517 +                       WindowList(SP) = p->next;
     21356+                       WindowList(SP_PARM) = p->next;
    2051821357                    else
    2051921358                        q->next = p->next;
    2052021359 
    20521 @@ -115,7 +116,8 @@
     21360@@ -108,30 +124,34 @@
     21361                }
     21362                q = p;
     21363            }
     21364-           _nc_unlock_global(curses);
     21365+           _nc_nonsp_unlock_global(curses);
     21366        }
     21367     }
     21368     returnCode(result);
    2052221369 }
    2052321370 
     
    2052921376     WINDOW *win;
    2053021377     NCURSES_CH_T *ptr;
    20531 @@ -127,11 +129,13 @@
     21378     int i;
     21379 
     21380-    T((T_CALLED("newwin(%d,%d,%d,%d)"), num_lines, num_columns, begy, begx));
     21381+    T((T_CALLED("newwin(%p, %d,%d,%d,%d)"), SP_PARM, num_lines, num_columns,
     21382+       begy, begx));
     21383 
     21384     if (begy < 0 || begx < 0 || num_lines < 0 || num_columns < 0)
    2053221385        returnWin(0);
    2053321386 
     
    2054621399 
    2054721400     for (i = 0; i < num_lines; i++) {
    20548 @@ -149,9 +153,22 @@
     21401@@ -149,12 +169,28 @@
    2054921402     returnWin(win);
    2055021403 }
     
    2055421407+newwin(int num_lines, int num_columns, int begy, int begx)
    2055521408+{
    20556 +    return NCURSES_SP_NAME(newwin) (CURRENT_SCREEN,
    20557 +                                   num_lines, num_columns,
    20558 +                                   begy, begx);
     21409+    WINDOW *win;
     21410+    _nc_sp_lock_global(curses);
     21411+    win = NCURSES_SP_NAME(newwin) (CURRENT_SCREEN,
     21412+                                  num_lines, num_columns, begy, begx);
     21413+    _nc_sp_unlock_global(curses);
     21414+    return (win);
    2055921415+}
    2056021416+#endif
     
    2056321419 derwin(WINDOW *orig, int num_lines, int num_columns, int begy, int begx)
    2056421420 {
    20565 +#if NCURSES_SP_FUNCS
    20566 +    SCREEN *sp = CURRENT_SCREEN;
    20567 +#endif
    2056821421     WINDOW *win;
    2056921422     int i;
    2057021423     int flags = _SUBWIN;
    20571 @@ -177,8 +194,10 @@
     21424+#if NCURSES_SP_FUNCS
     21425+    SCREEN *sp = _nc_screen_of(orig);
     21426+#endif
     21427 
     21428     T((T_CALLED("derwin(%p,%d,%d,%d,%d)"), orig, num_lines, num_columns,
     21429        begy, begx));
     21430@@ -177,8 +213,10 @@
    2057221431     if (orig->_flags & _ISPAD)
    2057321432        flags |= _ISPAD;
     
    2058221441 
    2058321442     win->_pary = begy;
    20584 @@ -211,16 +230,22 @@
     21443@@ -211,16 +249,22 @@
    2058521444 }
    2058621445 
     
    2059721456     WINDOWLIST *wp;
    2059821457     WINDOW *win;
    20599      bool is_pad = (flags & _ISPAD);
     21458-    bool is_pad = (flags & _ISPAD);
     21459+    bool is_padwin = (flags & _ISPAD);
    2060021460 
    2060121461-    T((T_CALLED("_nc_makenew(%d,%d,%d,%d)"), num_lines, num_columns, begy, begx));
     
    2060821468 
    2060921469     if (!dimension_limit(num_lines) || !dimension_limit(num_columns))
    20610 @@ -244,14 +269,16 @@
     21470@@ -236,7 +280,7 @@
     21471        returnWin(0);
     21472     }
     21473 
     21474-    _nc_lock_global(curses);
     21475+    _nc_nonsp_lock_global(curses);
     21476 
     21477     win->_curx = 0;
     21478     win->_cury = 0;
     21479@@ -244,14 +288,16 @@
    2061121480     win->_maxx = num_columns - 1;
    2061221481     win->_begy = begy;
     
    2062121490-    win->_clear = is_pad ? FALSE : (num_lines == screen_lines
    2062221491-                                   && num_columns == screen_columns);
    20623 +    win->_clear = (is_pad
     21492+    win->_clear = (is_padwin
    2062421493+                  ? FALSE
    2062521494+                  : (num_lines == screen_lines(SP_PARM)
     
    2062821497     win->_idcok = TRUE;
    2062921498     win->_scroll = FALSE;
    20630 @@ -300,19 +327,19 @@
     21499@@ -300,23 +346,23 @@
    2063121500        if_USE_SCROLL_HINTS(win->_line[i].oldindex = i);
    2063221501     }
    2063321502 
    2063421503-    if (!is_pad && (begx + num_columns == screen_columns)) {
    20635 +    if (!is_pad && (begx + num_columns == screen_columns(SP_PARM))) {
     21504+    if (!is_padwin && (begx + num_columns == screen_columns(SP_PARM))) {
    2063621505        win->_flags |= _ENDLINE;
    2063721506 
     
    2065421523     T((T_CREATE("window %p"), win));
    2065521524 
    20656 @@ -320,19 +347,37 @@
     21525-    _nc_unlock_global(curses);
     21526+    _nc_nonsp_unlock_global(curses);
    2065721527     returnWin(win);
    2065821528 }
    2065921529 
    20660 +#if NCURSES_SP_FUNCS
    20661 +NCURSES_EXPORT(WINDOW *)
    20662 +_nc_makenew(int num_lines, int num_columns, int begy, int begx, int flags)
    20663 +{
    20664 +    return NCURSES_SP_NAME(_nc_makenew) (CURRENT_SCREEN,
    20665 +                                        num_lines, num_columns,
    20666 +                                        begy, begx, flags);
    20667 +}
    20668 +#endif
    20669 +
    20670  /*
    20671   * wgetch() and other functions with a WINDOW* parameter may use a SCREEN*
     21530@@ -325,14 +371,22 @@
    2067221531  * internally, and it is useful to allow those to be invoked without switching
    2067321532  * SCREEN's, e.g., for multi-threaded applications.
     
    2070221561diff -Naur ncurses-5.7.orig/ncurses/base/lib_nl.c ncurses-5.7/ncurses/base/lib_nl.c
    2070321562--- ncurses-5.7.orig/ncurses/base/lib_nl.c      2000-12-09 18:43:27.000000000 -0800
    20704 +++ ncurses-5.7/ncurses/base/lib_nl.c   2009-07-19 15:04:13.000000000 -0700
     21563+++ ncurses-5.7/ncurses/base/lib_nl.c   2009-09-12 08:51:50.000000000 -0700
    2070521564@@ -1,5 +1,5 @@
    2070621565 /****************************************************************************
     
    2078821647diff -Naur ncurses-5.7.orig/ncurses/base/lib_pad.c ncurses-5.7/ncurses/base/lib_pad.c
    2078921648--- ncurses-5.7.orig/ncurses/base/lib_pad.c     2006-10-14 13:47:13.000000000 -0700
    20790 +++ ncurses-5.7/ncurses/base/lib_pad.c  2009-07-19 15:04:13.000000000 -0700
     21649+++ ncurses-5.7/ncurses/base/lib_pad.c  2009-09-12 08:51:50.000000000 -0700
    2079121650@@ -1,5 +1,5 @@
    2079221651 /****************************************************************************
     
    2094521804diff -Naur ncurses-5.7.orig/ncurses/base/lib_printw.c ncurses-5.7/ncurses/base/lib_printw.c
    2094621805--- ncurses-5.7.orig/ncurses/base/lib_printw.c  2006-12-17 11:21:39.000000000 -0800
    20947 +++ ncurses-5.7/ncurses/base/lib_printw.c       2009-07-19 15:03:53.000000000 -0700
     21806+++ ncurses-5.7/ncurses/base/lib_printw.c       2009-09-12 08:51:30.000000000 -0700
    2094821807@@ -1,5 +1,5 @@
    2094921808 /****************************************************************************
     
    2098021839diff -Naur ncurses-5.7.orig/ncurses/base/lib_redrawln.c ncurses-5.7/ncurses/base/lib_redrawln.c
    2098121840--- ncurses-5.7.orig/ncurses/base/lib_redrawln.c        2007-10-13 13:08:56.000000000 -0700
    20982 +++ ncurses-5.7/ncurses/base/lib_redrawln.c     2009-07-19 15:03:53.000000000 -0700
     21841+++ ncurses-5.7/ncurses/base/lib_redrawln.c     2009-09-12 08:51:30.000000000 -0700
    2098321842@@ -1,5 +1,5 @@
    2098421843 /****************************************************************************
     
    2104821907diff -Naur ncurses-5.7.orig/ncurses/base/lib_refresh.c ncurses-5.7/ncurses/base/lib_refresh.c
    2104921908--- ncurses-5.7.orig/ncurses/base/lib_refresh.c 2007-09-29 13:39:34.000000000 -0700
    21050 +++ ncurses-5.7/ncurses/base/lib_refresh.c      2009-07-19 15:04:06.000000000 -0700
     21909+++ ncurses-5.7/ncurses/base/lib_refresh.c      2009-09-12 08:51:43.000000000 -0700
    2105121910@@ -1,5 +1,5 @@
    2105221911 /****************************************************************************
     
    2118222041diff -Naur ncurses-5.7.orig/ncurses/base/lib_restart.c ncurses-5.7/ncurses/base/lib_restart.c
    2118322042--- ncurses-5.7.orig/ncurses/base/lib_restart.c 2008-06-21 10:31:22.000000000 -0700
    21184 +++ ncurses-5.7/ncurses/base/lib_restart.c      2009-07-19 15:03:58.000000000 -0700
     22043+++ ncurses-5.7/ncurses/base/lib_restart.c      2009-09-12 08:52:09.000000000 -0700
    2118522044@@ -1,5 +1,5 @@
    2118622045 /****************************************************************************
     
    2119822057 
    2119922058 /*
    21200 @@ -44,49 +45,52 @@
     22059@@ -44,49 +45,58 @@
    2120122060 #define _POSIX_SOURCE
    2120222061 #endif
     
    2120522064-
    2120622065-MODULE_ID("$Id: lib_restart.c,v 1.10 2008/06/21 17:31:22 tom Exp $")
    21207 +MODULE_ID("$Id: lib_restart.c,v 1.11 2009/05/02 20:47:42 tom Exp $")
     22066+MODULE_ID("$Id: lib_restart.c,v 1.12 2009/08/30 17:59:13 tom Exp $")
    2120822067 
    2120922068 NCURSES_EXPORT(int)
     
    2121522074 {
    2121622075     int result;
     22076+#ifdef USE_TERM_DRIVER
     22077+    TERMINAL *new_term;
     22078+#endif
    2121722079 
    2121822080-    T((T_CALLED("restartterm(%s,%d,%p)"), termp, filenum, errret));
    2121922081+    T((T_CALLED("restartterm(%p,%s,%d,%p)"), SP_PARM, termp, filenum, errret));
    2122022082 
    21221      if (setupterm(termp, filenum, errret) != OK) {
     22083-    if (setupterm(termp, filenum, errret) != OK) {
     22084+    if (TINFO_SETUP_TERM(&new_term, termp, filenum, errret, FALSE) != OK) {
    2122222085        result = ERR;
    2122322086-    } else if (SP != 0) {
     
    2123722100+       int savenl = SP_PARM->_nl;
    2123822101+
     22102+#ifdef USE_TERM_DRIVER
     22103+       SP_PARM->_term = new_term;
     22104+#endif
    2123922105+       if (saveecho) {
    2124022106+           NCURSES_SP_NAME(echo) (NCURSES_SP_ARG);
     
    2125322119+           NCURSES_SP_NAME(nocbreak) (NCURSES_SP_ARG);
    2125422120+           NCURSES_SP_NAME(raw) (NCURSES_SP_ARG);
    21255 +       } else {
     22121        } else {
     22122-           nocbreak();
     22123-           noraw();
    2125622124+           NCURSES_SP_NAME(nocbreak) (NCURSES_SP_ARG);
    2125722125+           NCURSES_SP_NAME(noraw) (NCURSES_SP_ARG);
     
    2125922127+       if (savenl) {
    2126022128+           NCURSES_SP_NAME(nl) (NCURSES_SP_ARG);
    21261         } else {
    21262 -           nocbreak();
    21263 -           noraw();
     22129+       } else {
    2126422130+           NCURSES_SP_NAME(nonl) (NCURSES_SP_ARG);
    2126522131        }
     
    2127822144 
    2127922145        result = OK;
    21280 @@ -95,3 +99,11 @@
     22146@@ -95,3 +105,11 @@
    2128122147     }
    2128222148     returnCode(result);
     
    2129222158diff -Naur ncurses-5.7.orig/ncurses/base/lib_screen.c ncurses-5.7/ncurses/base/lib_screen.c
    2129322159--- ncurses-5.7.orig/ncurses/base/lib_screen.c  2008-08-16 12:05:37.000000000 -0700
    21294 +++ ncurses-5.7/ncurses/base/lib_screen.c       2009-07-19 15:04:06.000000000 -0700
     22160+++ ncurses-5.7/ncurses/base/lib_screen.c       2009-09-12 08:51:43.000000000 -0700
    2129522161@@ -1,5 +1,5 @@
    2129622162 /****************************************************************************
     
    2148022346diff -Naur ncurses-5.7.orig/ncurses/base/lib_set_term.c ncurses-5.7/ncurses/base/lib_set_term.c
    2148122347--- ncurses-5.7.orig/ncurses/base/lib_set_term.c        2008-08-04 11:11:12.000000000 -0700
    21482 +++ ncurses-5.7/ncurses/base/lib_set_term.c     2009-07-19 15:04:11.000000000 -0700
     22348+++ ncurses-5.7/ncurses/base/lib_set_term.c     2009-09-12 08:52:09.000000000 -0700
    2148322349@@ -1,5 +1,5 @@
    2148422350 /****************************************************************************
     
    2149622362 
    2149722363 /*
    21498 @@ -44,7 +45,11 @@
    21499  #include <term.h>              /* cur_term */
     22364@@ -41,10 +42,21 @@
     22365 
     22366 #include <curses.priv.h>
     22367 
     22368-#include <term.h>              /* cur_term */
    2150022369 #include <tic.h>
    2150122370 
     
    2150522374+#endif
    2150622375+
    21507 +MODULE_ID("$Id: lib_set_term.c,v 1.124 2009/06/27 21:36:14 tom Exp $")
     22376+MODULE_ID("$Id: lib_set_term.c,v 1.126 2009/09/05 18:18:10 tom Exp $")
     22377+
     22378+#ifdef USE_TERM_DRIVER
     22379+#define MaxColors      InfoOf(sp).maxcolors
     22380+#define NumLabels      InfoOf(sp).numlabels
     22381+#else
     22382+#define MaxColors      max_colors
     22383+#define NumLabels      num_labels
     22384+#endif
    2150822385 
    2150922386 NCURSES_EXPORT(SCREEN *)
    2151022387 set_term(SCREEN *screenp)
    21511 @@ -256,6 +261,9 @@
     22388@@ -61,7 +73,7 @@
     22389     newSP = SP;
     22390 
     22391     if (newSP != 0) {
     22392-       set_curterm(newSP->_term);
     22393+       TINFO_SET_CURTERM(newSP, newSP->_term);
     22394 #if !USE_REENTRANT
     22395        curscr = newSP->_curscr;
     22396        newscr = newSP->_newscr;
     22397@@ -70,7 +82,7 @@
     22398        COLOR_PAIRS = newSP->_pair_count;
     22399 #endif
     22400     } else {
     22401-       set_curterm(0);
     22402+       TINFO_SET_CURTERM(oldSP, 0);
     22403 #if !USE_REENTRANT
     22404        curscr = 0;
     22405        newscr = 0;
     22406@@ -129,6 +141,19 @@
     22407 
     22408     _nc_lock_global(curses);
     22409     if (delink_screen(sp)) {
     22410+#ifdef USE_SP_RIPOFF
     22411+       ripoff_t *rop;
     22412+       if (safe_ripoff_sp && safe_ripoff_sp != safe_ripoff_stack) {
     22413+           for (rop = safe_ripoff_stack;
     22414+                rop != safe_ripoff_sp && (rop - safe_ripoff_stack) < N_RIPS;
     22415+                rop++) {
     22416+               if (rop->win) {
     22417+                   (void) delwin(rop->win);
     22418+                   rop->win = 0;
     22419+               }
     22420+           }
     22421+       }
     22422+#endif
     22423 
     22424        (void) _nc_freewin(sp->_curscr);
     22425        (void) _nc_freewin(sp->_newscr);
     22426@@ -176,7 +201,7 @@
     22427            free(sp->_setbuf);
     22428        }
     22429 
     22430-       del_curterm(sp->_term);
     22431+       NCURSES_SP_NAME(del_curterm) (NCURSES_SP_ARGx sp->_term);
     22432        free(sp);
     22433 
     22434        /*
     22435@@ -248,6 +273,41 @@
     22436 }
     22437 #endif
     22438 
     22439+#if NCURSES_SP_FUNCS
     22440+/*
     22441+ * In case of handling multiple screens, we need to have a screen before
     22442+ * initialization in setupscreen takes place.  This is to extend the substitute
     22443+ * for some of the stuff in _nc_prescreen, especially for slk and ripoff
     22444+ * handling which should be done per screen.
     22445+ */
     22446+NCURSES_EXPORT(SCREEN *)
     22447+new_prescr(void)
     22448+{
     22449+    SCREEN *sp = _nc_alloc_screen_sp();
     22450+    if (sp) {
     22451+       sp->rsp = sp->rippedoff;
     22452+       sp->_filtered = _nc_prescreen.filter_mode;
     22453+       sp->_use_env = _nc_prescreen.use_env;
     22454+#if NCURSES_NO_PADDING
     22455+       sp->_no_padding = _nc_prescreen._no_padding;
     22456+#endif
     22457+       sp->slk_format = 0;
     22458+       sp->_slk = 0;
     22459+       sp->_prescreen = TRUE;
     22460+       SP_PRE_INIT(sp);
     22461+#if USE_REENTRANT
     22462+       sp->_TABSIZE = _nc_prescreen._TABSIZE;
     22463+       sp->_ESCDELAY = _nc_prescreen._ESCDELAY;
     22464+#endif
     22465+       _nc_set_screen(sp);
     22466+    }
     22467+    return sp;
     22468+}
     22469+#endif
     22470+
     22471+#define ReturnScreenError() _nc_set_screen(0); \
     22472+                            returnCode(ERR)
     22473+
     22474 /* OS-independent screen initializations */
     22475 NCURSES_EXPORT(int)
     22476 _nc_setupscreen(int slines GCC_UNUSED,
     22477@@ -256,6 +316,9 @@
    2151222478                bool filtered,
    2151322479                int slk_format)
     
    2151922485     int bottom_stolen = 0;
    2152022486     bool support_cookies = USE_XMC_SUPPORT;
    21521 @@ -272,6 +280,9 @@
     22487@@ -272,6 +335,9 @@
    2152222488     }
    2152322489 
     
    2152922495     _nc_screen_chain = SP;
    2153022496 
    21531 @@ -546,7 +557,7 @@
     22497@@ -292,6 +358,9 @@
     22498     if (filtered) {
     22499        slines = 1;
     22500        SET_LINES(slines);
     22501+#ifdef USE_TERM_DRIVER
     22502+       CallDriver(sp, setfilter);
     22503+#else
     22504        clear_screen = 0;
     22505        cursor_down = parm_down_cursor = 0;
     22506        cursor_address = 0;
     22507@@ -299,6 +368,7 @@
     22508        row_address = 0;
     22509 
     22510        cursor_home = carriage_return;
     22511+#endif
     22512        T(("filter screensize %dx%d", LINES, COLS));
     22513     }
     22514 #ifdef __DJGPP__
     22515@@ -364,9 +434,9 @@
     22516        char sep1, sep2;
     22517        int count = sscanf(env, "%d%c%d%c", &fg, &sep1, &bg, &sep2);
     22518        if (count >= 1) {
     22519-           SP->_default_fg = (fg >= 0 && fg < max_colors) ? fg : C_MASK;
     22520+           SP->_default_fg = (fg >= 0 && fg < MaxColors) ? fg : C_MASK;
     22521            if (count >= 3) {
     22522-               SP->_default_bg = (bg >= 0 && bg < max_colors) ? bg : C_MASK;
     22523+               SP->_default_bg = (bg >= 0 && bg < MaxColors) ? bg : C_MASK;
     22524            }
     22525            TR(TRACE_CHARPUT | TRACE_MOVE,
     22526               ("from environment assumed fg=%d, bg=%d",
     22527@@ -390,20 +460,20 @@
     22528            p = extract_fgbg(p, &(SP->_default_bg));
     22529        TR(TRACE_CHARPUT | TRACE_MOVE, ("decoded fg=%d, bg=%d",
     22530                                        SP->_default_fg, SP->_default_bg));
     22531-       if (SP->_default_fg >= max_colors) {
     22532+       if (SP->_default_fg >= MaxColors) {
     22533            if (set_a_foreground != ABSENT_STRING
     22534                && !strcmp(set_a_foreground, "\033[3%p1%dm")) {
     22535                set_a_foreground = "\033[3%?%p1%{8}%>%t9%e%p1%d%;m";
     22536            } else {
     22537-               SP->_default_fg %= max_colors;
     22538+               SP->_default_fg %= MaxColors;
     22539            }
     22540        }
     22541-       if (SP->_default_bg >= max_colors) {
     22542+       if (SP->_default_bg >= MaxColors) {
     22543            if (set_a_background != ABSENT_STRING
     22544                && !strcmp(set_a_background, "\033[4%p1%dm")) {
     22545                set_a_background = "\033[4%?%p1%{8}%>%t9%e%p1%d%;m";
     22546            } else {
     22547-               SP->_default_bg %= max_colors;
     22548+               SP->_default_bg %= MaxColors;
     22549            }
     22550        }
     22551     }
     22552@@ -546,7 +616,7 @@
    2153222553     curscr = SP->_curscr;
    2153322554 #endif
     
    2153822559 
    2153922560     newscr->_clear = TRUE;
    21540 @@ -555,8 +566,8 @@
     22561@@ -555,8 +625,8 @@
    2154122562     def_shell_mode();
    2154222563     def_prog_mode();
     
    2154922570 
    2155022571        /* If we must simulate soft labels, grab off the line to be used.
    21551 @@ -595,7 +606,7 @@
     22572@@ -564,7 +634,7 @@
     22573           formats (4-4 or 3-2-3) for which there may be some hardware
     22574           support. */
     22575        if (rop->hook == _nc_slk_initialize)
     22576-           if (!(num_labels <= 0 || !SLK_STDFMT(slk_format)))
     22577+           if (!(NumLabels <= 0 || !SLK_STDFMT(slk_format)))
     22578                continue;
     22579        if (rop->hook) {
     22580            int count;
     22581@@ -595,7 +665,7 @@
    2155222582        }
    2155322583     }
     
    2155822588     T(("creating stdscr"));
    2155922589     assert((SP->_lines_avail + SP->_topstolen + bottom_stolen) == slines);
    21560 @@ -615,27 +626,39 @@
     22590@@ -615,27 +685,39 @@
    2156122591  * off from the top or bottom.
    2156222592  */
     
    2160622636     START_TRACE();
    2160722637     T((T_CALLED("ripoffline(%d,%p)"), line, init));
    21608 @@ -643,5 +666,15 @@
     22638@@ -643,5 +725,15 @@
    2160922639     if (line == 0)
    2161022640        returnCode(OK);
     
    2162522655diff -Naur ncurses-5.7.orig/ncurses/base/lib_slkatrof.c ncurses-5.7/ncurses/base/lib_slkatrof.c
    2162622656--- ncurses-5.7.orig/ncurses/base/lib_slkatrof.c        2005-01-08 15:01:32.000000000 -0800
    21627 +++ ncurses-5.7/ncurses/base/lib_slkatrof.c     2009-07-19 15:02:22.000000000 -0700
     22657+++ ncurses-5.7/ncurses/base/lib_slkatrof.c     2009-09-12 08:51:17.000000000 -0700
    2162822658@@ -1,5 +1,5 @@
    2162922659 /****************************************************************************
     
    2167322703diff -Naur ncurses-5.7.orig/ncurses/base/lib_slkatron.c ncurses-5.7/ncurses/base/lib_slkatron.c
    2167422704--- ncurses-5.7.orig/ncurses/base/lib_slkatron.c        2005-01-08 15:02:01.000000000 -0800
    21675 +++ ncurses-5.7/ncurses/base/lib_slkatron.c     2009-07-19 15:02:22.000000000 -0700
     22705+++ ncurses-5.7/ncurses/base/lib_slkatron.c     2009-09-12 08:51:17.000000000 -0700
    2167622706@@ -1,5 +1,5 @@
    2167722707 /****************************************************************************
     
    2172122751diff -Naur ncurses-5.7.orig/ncurses/base/lib_slkatr_set.c ncurses-5.7/ncurses/base/lib_slkatr_set.c
    2172222752--- ncurses-5.7.orig/ncurses/base/lib_slkatr_set.c      2005-01-28 13:11:53.000000000 -0800
    21723 +++ ncurses-5.7/ncurses/base/lib_slkatr_set.c   2009-07-19 15:02:22.000000000 -0700
     22753+++ ncurses-5.7/ncurses/base/lib_slkatr_set.c   2009-09-12 08:51:17.000000000 -0700
    2172422754@@ -1,5 +1,5 @@
    2172522755 /****************************************************************************
     
    2179222822diff -Naur ncurses-5.7.orig/ncurses/base/lib_slkatrset.c ncurses-5.7/ncurses/base/lib_slkatrset.c
    2179322823--- ncurses-5.7.orig/ncurses/base/lib_slkatrset.c       2005-01-08 13:46:47.000000000 -0800
    21794 +++ ncurses-5.7/ncurses/base/lib_slkatrset.c    2009-07-19 15:02:22.000000000 -0700
     22824+++ ncurses-5.7/ncurses/base/lib_slkatrset.c    2009-09-12 08:51:17.000000000 -0700
    2179522825@@ -1,5 +1,5 @@
    2179622826 /****************************************************************************
     
    2183222862diff -Naur ncurses-5.7.orig/ncurses/base/lib_slkattr.c ncurses-5.7/ncurses/base/lib_slkattr.c
    2183322863--- ncurses-5.7.orig/ncurses/base/lib_slkattr.c 2005-01-08 13:44:28.000000000 -0800
    21834 +++ ncurses-5.7/ncurses/base/lib_slkattr.c      2009-07-19 15:02:22.000000000 -0700
     22864+++ ncurses-5.7/ncurses/base/lib_slkattr.c      2009-09-12 08:51:17.000000000 -0700
    2183522865@@ -1,5 +1,5 @@
    2183622866 /****************************************************************************
     
    2187622906diff -Naur ncurses-5.7.orig/ncurses/base/lib_slk.c ncurses-5.7/ncurses/base/lib_slk.c
    2187722907--- ncurses-5.7.orig/ncurses/base/lib_slk.c     2008-09-27 07:07:33.000000000 -0700
    21878 +++ ncurses-5.7/ncurses/base/lib_slk.c  2009-07-19 15:04:17.000000000 -0700
     22908+++ ncurses-5.7/ncurses/base/lib_slk.c  2009-09-12 08:52:04.000000000 -0700
    2187922909@@ -1,5 +1,5 @@
    2188022910 /****************************************************************************
     
    2188422914  * Permission is hereby granted, free of charge, to any person obtaining a  *
    2188522915  * copy of this software and associated documentation files (the            *
    21886 @@ -41,26 +41,81 @@
     22916@@ -41,26 +41,94 @@
    2188722917  */
    2188822918 
     
    2189722927+#endif
    2189822928+
    21899 +MODULE_ID("$Id: lib_slk.c,v 1.40 2009/07/19 00:34:07 tom Exp $")
     22929+MODULE_ID("$Id: lib_slk.c,v 1.42 2009/08/15 23:05:02 tom Exp $")
     22930+
     22931+#ifdef USE_TERM_DRIVER
     22932+#define NumLabels    InfoOf(SP_PARM).numlabels
     22933+#define NoColorVideo InfoOf(SP_PARM).nocolorvideo
     22934+#define LabelWidth   InfoOf(SP_PARM).labelwidth
     22935+#define LabelHeight  InfoOf(SP_PARM).labelheight
     22936+#else
     22937+#define NumLabels    num_labels
     22938+#define NoColorVideo no_color_video
     22939+#define LabelWidth   label_width
     22940+#define LabelHeight  label_height
     22941+#endif
    2190022942 
    2190122943 /*
     
    2196223004+                   x += (i == 2 || i == 4) ? gap : 1;
    2196323005+               }
    21964 +           } else
    21965 +               returnCode(slk_failed(NCURSES_SP_ARG));
     23006+           } else {
     23007+               return slk_failed(NCURSES_SP_ARG);
     23008+           }
    2196623009+       }
    2196723010+    }
     
    2197423017  * Initialize soft labels.
    2197523018  * Called from newterm()
    21976 @@ -68,108 +123,91 @@
     23019@@ -68,108 +136,91 @@
    2197723020 NCURSES_EXPORT(int)
    2197823021 _nc_slk_initialize(WINDOW *stwin, int cols)
     
    2199823041+    assert(term);
    2199923042+
    22000 +    numlab = InfoOf(SP_PARM).numlabels;
     23043+    numlab = NumLabels;
    2200123044+
    2200223045+    if (SP_PARM->_slk) {       /* we did this already, so simply return */
     
    2201923062-    if ((no_color_video & 1) == 0)
    2202023063-       SetAttr(SP->_slk->attr, A_STANDOUT);
    22021 +    if ((InfoOf(SP_PARM).nocolorvideo & 1) == 0)
     23064+    if ((NoColorVideo & 1) == 0)
    2202223065+       SetAttr(SP_PARM->_slk->attr, A_STANDOUT);
    2202323066     else
     
    2204423087+                            : MAX_SKEY(SP_PARM->slk_format));
    2204523088+    SP_PARM->_slk->maxlen = ((numlab > 0)
    22046 +                            ? InfoOf(SP_PARM).labelwidth * InfoOf(SP_PARM).labelheight
     23089+                            ? LabelWidth * LabelHeight
    2204723090+                            : MAX_SKEY_LEN(SP_PARM->slk_format));
    2204823091+    SP_PARM->_slk->labcnt = ((SP_PARM->_slk->maxlab < MAX_SKEY(SP_PARM->slk_format))
     
    2209023133-       if (gap < 1)
    2209123134-           gap = 1;
    22092 -
     23135+    res = _nc_format_slks(NCURSES_SP_ARGx cols);
     23136 
    2209323137-       for (i = x = 0; i < SP->_slk->maxlab; i++) {
    2209423138-           SP->_slk->ent[i].ent_x = x;
     
    2211123155-               int gap = (cols - (SP->_slk->maxlab * max_length) - 5)
    2211223156-               / 2;
    22113 +    res = _nc_format_slks(NCURSES_SP_ARGx cols);
    22114  
     23157-
    2211523158-               if (gap < 1)
    2211623159-                   gap = 1;
     
    2213923182     returnCode(res);
    2214023183 }
    22141 @@ -178,14 +216,24 @@
     23184@@ -178,14 +229,24 @@
    2214223185  * Restore the soft labels on the screen.
    2214323186  */
     
    2217323216diff -Naur ncurses-5.7.orig/ncurses/base/lib_slkclear.c ncurses-5.7/ncurses/base/lib_slkclear.c
    2217423217--- ncurses-5.7.orig/ncurses/base/lib_slkclear.c        2007-12-29 09:51:47.000000000 -0800
    22175 +++ ncurses-5.7/ncurses/base/lib_slkclear.c     2009-07-19 15:02:22.000000000 -0700
     23218+++ ncurses-5.7/ncurses/base/lib_slkclear.c     2009-09-12 08:51:17.000000000 -0700
    2217623219@@ -1,5 +1,5 @@
    2217723220 /****************************************************************************
     
    2222923272diff -Naur ncurses-5.7.orig/ncurses/base/lib_slkcolor.c ncurses-5.7/ncurses/base/lib_slkcolor.c
    2223023273--- ncurses-5.7.orig/ncurses/base/lib_slkcolor.c        2005-01-28 13:11:53.000000000 -0800
    22231 +++ ncurses-5.7/ncurses/base/lib_slkcolor.c     2009-07-19 15:02:22.000000000 -0700
     23274+++ ncurses-5.7/ncurses/base/lib_slkcolor.c     2009-09-12 08:51:17.000000000 -0700
    2223223275@@ -1,5 +1,5 @@
    2223323276 /****************************************************************************
     
    2229323336diff -Naur ncurses-5.7.orig/ncurses/base/lib_slkinit.c ncurses-5.7/ncurses/base/lib_slkinit.c
    2229423337--- ncurses-5.7.orig/ncurses/base/lib_slkinit.c 2008-01-12 12:23:39.000000000 -0800
    22295 +++ ncurses-5.7/ncurses/base/lib_slkinit.c      2009-07-19 15:04:03.000000000 -0700
     23338+++ ncurses-5.7/ncurses/base/lib_slkinit.c      2009-09-12 08:51:40.000000000 -0700
    2229623339@@ -1,5 +1,5 @@
    2229723340 /****************************************************************************
     
    2235823401diff -Naur ncurses-5.7.orig/ncurses/base/lib_slklab.c ncurses-5.7/ncurses/base/lib_slklab.c
    2235923402--- ncurses-5.7.orig/ncurses/base/lib_slklab.c  2003-03-29 14:53:48.000000000 -0800
    22360 +++ ncurses-5.7/ncurses/base/lib_slklab.c       2009-07-19 15:02:22.000000000 -0700
     23403+++ ncurses-5.7/ncurses/base/lib_slklab.c       2009-09-12 08:51:17.000000000 -0700
    2236123404@@ -1,5 +1,5 @@
    2236223405 /****************************************************************************
     
    2240523448diff -Naur ncurses-5.7.orig/ncurses/base/lib_slkrefr.c ncurses-5.7/ncurses/base/lib_slkrefr.c
    2240623449--- ncurses-5.7.orig/ncurses/base/lib_slkrefr.c 2008-09-27 07:07:53.000000000 -0700
    22407 +++ ncurses-5.7/ncurses/base/lib_slkrefr.c      2009-07-19 15:04:06.000000000 -0700
     23450+++ ncurses-5.7/ncurses/base/lib_slkrefr.c      2009-09-12 08:52:07.000000000 -0700
    2240823451@@ -1,5 +1,5 @@
    2240923452 /****************************************************************************
     
    2241323456  * Permission is hereby granted, free of charge, to any person obtaining a  *
    2241423457  * copy of this software and associated documentation files (the            *
    22415 @@ -38,9 +38,12 @@
     23458@@ -38,9 +38,18 @@
    2241623459  *     Write SLK window to the (virtual) screen.
    2241723460  */
     
    2242423467+#endif
    2242523468+
    22426 +MODULE_ID("$Id: lib_slkrefr.c,v 1.21 2009/06/06 20:26:17 tom Exp $")
     23469+MODULE_ID("$Id: lib_slkrefr.c,v 1.24 2009/08/29 18:43:13 tom Exp $")
     23470+
     23471+#ifdef USE_TERM_DRIVER
     23472+#define NumLabels    InfoOf(SP_PARM).numlabels
     23473+#else
     23474+#define NumLabels    num_labels
     23475+#endif
    2242723476 
    2242823477 /*
    2242923478  * Paint the info line for the PC style SLK emulation.
    22430 @@ -66,31 +69,47 @@
     23479@@ -66,31 +75,47 @@
    2243123480  * Write the soft labels to the soft-key window.
    2243223481  */
     
    2244623495+    slk = sp->_slk;
    2244723496+    fmt = sp->slk_format;
    22448 +    numlab = InfoOf(sp).numlabels;
     23497+    numlab = NumLabels;
    2244923498+
    2245023499+    if (slk->hidden)
     
    2247123520-                       wattrset(slk->win, AttrOf(SP->_slk->attr));
    2247223521+                   if (sp->_slk) {
    22473 +                       wattrset(slk->win, AttrOf(sp->_slk->attr));
     23522+                       (void) wattrset(slk->win, AttrOf(sp->_slk->attr));
    2247423523                    }
    2247523524                    waddstr(slk->win, slk->ent[i].form_text);
     
    2247823527                       for the label window */
    2247923528-                   wattrset(slk->win, WINDOW_ATTRS(stdscr));
    22480 +                   wattrset(slk->win, WINDOW_ATTRS(StdScreen(sp)));
     23529+                   (void) wattrset(slk->win, WINDOW_ATTRS(StdScreen(sp)));
    2248123530                }
    2248223531            }
    2248323532            slk->ent[i].dirty = FALSE;
    22484 @@ -98,7 +117,10 @@
     23533@@ -98,7 +123,10 @@
    2248523534     }
    2248623535     slk->dirty = FALSE;
     
    2249423543            TPUTS_TRACE("label_off");
    2249523544            putp(label_off);
    22496 @@ -106,6 +128,7 @@
     23545@@ -106,6 +134,7 @@
    2249723546            TPUTS_TRACE("label_on");
    2249823547            putp(label_on);
     
    2250223551 }
    2250323552 
    22504 @@ -113,32 +136,48 @@
     23553@@ -113,32 +142,48 @@
    2250523554  * Refresh the soft labels.
    2250623555  */
     
    2252023569-    slk_intern_refresh(SP->_slk);
    2252123570+    slk_intern_refresh(SP_PARM);
    22522  
    22523 -    returnCode(wnoutrefresh(SP->_slk->win));
     23571+
    2252423572+    returnCode(wnoutrefresh(SP_PARM->_slk->win));
    2252523573+}
    22526 +
     23574 
     23575-    returnCode(wnoutrefresh(SP->_slk->win));
    2252723576+#if NCURSES_SP_FUNCS
    2252823577+NCURSES_EXPORT(int)
     
    2256523614diff -Naur ncurses-5.7.orig/ncurses/base/lib_slkset.c ncurses-5.7/ncurses/base/lib_slkset.c
    2256623615--- ncurses-5.7.orig/ncurses/base/lib_slkset.c  2007-10-13 13:08:46.000000000 -0700
    22567 +++ ncurses-5.7/ncurses/base/lib_slkset.c       2009-07-19 15:02:22.000000000 -0700
     23616+++ ncurses-5.7/ncurses/base/lib_slkset.c       2009-09-12 08:51:17.000000000 -0700
    2256823617@@ -1,5 +1,5 @@
    2256923618 /****************************************************************************
     
    2262623675diff -Naur ncurses-5.7.orig/ncurses/base/lib_slktouch.c ncurses-5.7/ncurses/base/lib_slktouch.c
    2262723676--- ncurses-5.7.orig/ncurses/base/lib_slktouch.c        2000-12-09 18:43:27.000000000 -0800
    22628 +++ ncurses-5.7/ncurses/base/lib_slktouch.c     2009-07-19 15:02:22.000000000 -0700
     23677+++ ncurses-5.7/ncurses/base/lib_slktouch.c     2009-09-12 08:51:17.000000000 -0700
    2262923678@@ -1,5 +1,5 @@
    2263023679 /****************************************************************************
     
    2267723726diff -Naur ncurses-5.7.orig/ncurses/base/lib_ungetch.c ncurses-5.7/ncurses/base/lib_ungetch.c
    2267823727--- ncurses-5.7.orig/ncurses/base/lib_ungetch.c 2008-05-31 09:44:54.000000000 -0700
    22679 +++ ncurses-5.7/ncurses/base/lib_ungetch.c      2009-07-19 15:03:53.000000000 -0700
     23728+++ ncurses-5.7/ncurses/base/lib_ungetch.c      2009-09-12 08:51:30.000000000 -0700
    2268023729@@ -1,5 +1,5 @@
    2268123730 /****************************************************************************
     
    2273323782diff -Naur ncurses-5.7.orig/ncurses/base/lib_winch.c ncurses-5.7/ncurses/base/lib_winch.c
    2273423783--- ncurses-5.7.orig/ncurses/base/lib_winch.c   2001-06-02 16:42:08.000000000 -0700
    22735 +++ ncurses-5.7/ncurses/base/lib_winch.c        2009-07-19 15:02:22.000000000 -0700
     23784+++ ncurses-5.7/ncurses/base/lib_winch.c        2009-09-12 08:51:17.000000000 -0700
    2273623785@@ -39,16 +39,16 @@
    2273723786 
     
    2275723806diff -Naur ncurses-5.7.orig/ncurses/base/lib_window.c ncurses-5.7/ncurses/base/lib_window.c
    2275823807--- ncurses-5.7.orig/ncurses/base/lib_window.c  2008-06-07 07:12:56.000000000 -0700
    22759 +++ ncurses-5.7/ncurses/base/lib_window.c       2009-07-19 15:03:53.000000000 -0700
     23808+++ ncurses-5.7/ncurses/base/lib_window.c       2009-09-12 08:51:30.000000000 -0700
    2276023809@@ -1,5 +1,5 @@
    2276123810 /****************************************************************************
     
    2280423853diff -Naur ncurses-5.7.orig/ncurses/base/MKkeyname.awk ncurses-5.7/ncurses/base/MKkeyname.awk
    2280523854--- ncurses-5.7.orig/ncurses/base/MKkeyname.awk 2008-07-12 11:40:00.000000000 -0700
    22806 +++ ncurses-5.7/ncurses/base/MKkeyname.awk      2009-07-19 15:03:59.000000000 -0700
     23855+++ ncurses-5.7/ncurses/base/MKkeyname.awk      2009-09-12 08:51:37.000000000 -0700
    2280723856@@ -1,6 +1,6 @@
    2280823857-# $Id: MKkeyname.awk,v 1.40 2008/07/12 18:40:00 tom Exp $
     
    2285723906diff -Naur ncurses-5.7.orig/ncurses/base/MKlib_gen.sh ncurses-5.7/ncurses/base/MKlib_gen.sh
    2285823907--- ncurses-5.7.orig/ncurses/base/MKlib_gen.sh  2008-08-30 12:20:50.000000000 -0700
    22859 +++ ncurses-5.7/ncurses/base/MKlib_gen.sh       2009-07-19 15:02:22.000000000 -0700
     23908+++ ncurses-5.7/ncurses/base/MKlib_gen.sh       2009-09-12 08:51:17.000000000 -0700
    2286023909@@ -2,7 +2,7 @@
    2286123910 #
     
    2287823927diff -Naur ncurses-5.7.orig/ncurses/base/MKunctrl.awk ncurses-5.7/ncurses/base/MKunctrl.awk
    2287923928--- ncurses-5.7.orig/ncurses/base/MKunctrl.awk  2008-10-04 14:40:24.000000000 -0700
    22880 +++ ncurses-5.7/ncurses/base/MKunctrl.awk       2009-07-19 15:04:13.000000000 -0700
     23929+++ ncurses-5.7/ncurses/base/MKunctrl.awk       2009-09-12 08:51:50.000000000 -0700
    2288123930@@ -1,6 +1,6 @@
    2288223931-# $Id: MKunctrl.awk,v 1.23 2008/10/04 21:40:24 tom Exp $
     
    2294423993diff -Naur ncurses-5.7.orig/ncurses/base/nc_panel.c ncurses-5.7/ncurses/base/nc_panel.c
    2294523994--- ncurses-5.7.orig/ncurses/base/nc_panel.c    2000-12-09 18:43:28.000000000 -0800
    22946 +++ ncurses-5.7/ncurses/base/nc_panel.c 2009-07-19 15:03:51.000000000 -0700
     23995+++ ncurses-5.7/ncurses/base/nc_panel.c 2009-09-12 08:51:28.000000000 -0700
    2294723996@@ -1,5 +1,5 @@
    2294823997 /****************************************************************************
     
    2297924028diff -Naur ncurses-5.7.orig/ncurses/base/resizeterm.c ncurses-5.7/ncurses/base/resizeterm.c
    2298024029--- ncurses-5.7.orig/ncurses/base/resizeterm.c  2008-06-07 06:58:40.000000000 -0700
    22981 +++ ncurses-5.7/ncurses/base/resizeterm.c       2009-07-19 15:04:13.000000000 -0700
     24030+++ ncurses-5.7/ncurses/base/resizeterm.c       2009-09-12 08:52:09.000000000 -0700
    2298224031@@ -1,5 +1,5 @@
    2298324032 /****************************************************************************
     
    2300724056 
    2300824057-#define stolen_lines (screen_lines - SP->_lines_avail)
    23009 +MODULE_ID("$Id: resizeterm.c,v 1.40 2009/07/04 18:38:49 tom Exp $")
     24058+MODULE_ID("$Id: resizeterm.c,v 1.41 2009/08/30 16:18:58 tom Exp $")
    2301024059 
    2301124060 /*
     
    2312224171+           _nc_format_slks(
    2312324172+#if NCURSES_SP_FUNCS
    23124 +               _nc_screen_of(win),
     24173+                              _nc_screen_of(win),
    2312524174+#endif
    23126 +               ToCols);
     24175+                              ToCols);
    2312724176     } else if (win->_begy >= bottom) {
    2312824177        /*
     
    2319724246     }
    2319824247 
    23199      _nc_lock_global(curses);
     24248-    _nc_lock_global(curses);
     24249+    _nc_nonsp_lock_global(curses);
    2320024250 
    2320124251-    was_stolen = (screen_lines - SP->_lines_avail);
     
    2324224292+       screen_lines(SP_PARM) = ToLines;
    2324324293+       screen_columns(SP_PARM) = ToCols;
    23244 +
     24294 
     24295-       SP->_lines_avail = lines - was_stolen;
    2324524296+#ifdef USE_TERM_DRIVER
    2324624297+       CallDriver_2(SP_PARM, setsize, ToLines, ToCols);
     
    2325024301+#endif
    2325124302 
    23252 -       SP->_lines_avail = lines - was_stolen;
    23253 +       SP_PARM->_lines_avail = ToLines - was_stolen;
    23254  
    2325524303-       if (SP->oldhash) {
    2325624304-           FreeAndNull(SP->oldhash);
     24305+       SP_PARM->_lines_avail = ToLines - was_stolen;
     24306+
    2325724307+       if (SP_PARM->oldhash) {
    2325824308+           FreeAndNull(SP_PARM->oldhash);
     
    2326524315 #ifdef TRACE
    2326624316        if (USE_TRACEF(TRACE_UPDATE)) {
    23267 @@ -383,6 +423,18 @@
     24317@@ -378,11 +418,23 @@
     24318     SET_LINES(ToLines - was_stolen);
     24319     SET_COLS(ToCols);
     24320 
     24321-    _nc_unlock_global(curses);
     24322+    _nc_nonsp_unlock_global(curses);
     24323 
    2326824324     returnCode(result);
    2326924325 }
     
    2327424330+{
    2327524331+    int res = ERR;
    23276 +    _nc_lock_global(curses);
     24332+    _nc_sp_lock_global(curses);
    2327724333+    res = NCURSES_SP_NAME(resize_term) (CURRENT_SCREEN, ToLines, ToCols);
    23278 +    _nc_unlock_global(curses);
     24334+    _nc_sp_unlock_global(curses);
    2327924335+    return (res);
    2328024336+}
     
    2336924425diff -Naur ncurses-5.7.orig/ncurses/base/safe_sprintf.c ncurses-5.7/ncurses/base/safe_sprintf.c
    2337024426--- ncurses-5.7.orig/ncurses/base/safe_sprintf.c        2007-04-21 15:28:06.000000000 -0700
    23371 +++ ncurses-5.7/ncurses/base/safe_sprintf.c     2009-07-19 15:03:53.000000000 -0700
     24427+++ ncurses-5.7/ncurses/base/safe_sprintf.c     2009-09-12 08:51:30.000000000 -0700
    2337224428@@ -1,5 +1,5 @@
    2337324429 /****************************************************************************
     
    2343724493diff -Naur ncurses-5.7.orig/ncurses/base/tries.c ncurses-5.7/ncurses/base/tries.c
    2343824494--- ncurses-5.7.orig/ncurses/base/tries.c       2008-08-16 12:22:55.000000000 -0700
    23439 +++ ncurses-5.7/ncurses/base/tries.c    2009-07-19 15:02:22.000000000 -0700
     24495+++ ncurses-5.7/ncurses/base/tries.c    2009-09-12 08:51:17.000000000 -0700
    2344024496@@ -39,7 +39,7 @@
    2344124497 
     
    2346024516diff -Naur ncurses-5.7.orig/ncurses/base/wresize.c ncurses-5.7/ncurses/base/wresize.c
    2346124517--- ncurses-5.7.orig/ncurses/base/wresize.c     2008-06-07 06:59:01.000000000 -0700
    23462 +++ ncurses-5.7/ncurses/base/wresize.c  2009-07-19 15:04:03.000000000 -0700
     24518+++ ncurses-5.7/ncurses/base/wresize.c  2009-09-12 08:51:40.000000000 -0700
    2346324519@@ -1,5 +1,5 @@
    2346424520 /****************************************************************************
     
    2350124557diff -Naur ncurses-5.7.orig/ncurses/curses.priv.h ncurses-5.7/ncurses/curses.priv.h
    2350224558--- ncurses-5.7.orig/ncurses/curses.priv.h      2008-10-04 14:37:45.000000000 -0700
    23503 +++ ncurses-5.7/ncurses/curses.priv.h   2009-07-19 15:04:13.000000000 -0700
     24559+++ ncurses-5.7/ncurses/curses.priv.h   2009-09-12 08:52:09.000000000 -0700
    2350424560@@ -1,5 +1,5 @@
    2350524561 /****************************************************************************
     
    2351924575 /*
    2352024576- * $Id: curses.priv.h,v 1.394 2008/10/04 21:37:45 tom Exp $
    23521 + * $Id: curses.priv.h,v 1.430 2009/07/04 20:40:42 tom Exp $
     24577+ * $Id: curses.priv.h,v 1.436 2009/08/30 18:13:54 tom Exp $
    2352224578  *
    2352324579  *     curses.priv.h
     
    2364824704 #define GetNoPadding(sp)       FALSE
    2364924705 #define SetNoPadding(sp)       /*nothing*/
    23650 @@ -302,17 +375,34 @@
     24706@@ -301,18 +374,37 @@
     24707 #define GET_SCREEN_PAIR(s)     GetPair(SCREEN_ATTRS(s))
    2365124708 #define SET_SCREEN_PAIR(s,p)   SetPair(SCREEN_ATTRS(s), p)
    2365224709 
     24710+#if USE_REENTRANT || NCURSES_SP_FUNCS
     24711+NCURSES_EXPORT(int *)        _nc_ptr_Lines (SCREEN *);
     24712+NCURSES_EXPORT(int *)        _nc_ptr_Cols (SCREEN *);
     24713+NCURSES_EXPORT(int *)        _nc_ptr_Tabsize (SCREEN *);
     24714+NCURSES_EXPORT(int *)        _nc_ptr_Escdelay (SCREEN *);
     24715+#endif
     24716+
    2365324717 #if USE_REENTRANT
    2365424718-NCURSES_EXPORT(int *) _nc_ptr_Lines (void);
     
    2366424728-#define SET_COLS(value)  COLS = value
    2366524729+
    23666 +NCURSES_EXPORT(int *)        _nc_ptr_Lines (SCREEN *);
    23667 +NCURSES_EXPORT(int *)        _nc_ptr_Cols (SCREEN *);
    23668 +NCURSES_EXPORT(int *)        _nc_ptr_Tabsize (SCREEN *);
    23669 +NCURSES_EXPORT(int *)        _nc_ptr_Escdelay (SCREEN *);
    23670 +
    2367124730+#define ptrLines(sp)         (sp ? &(sp->_LINES) : &(_nc_prescreen._LINES))
    2367224731+#define ptrCols(sp)          (sp ? &(sp->_COLS) : &(_nc_prescreen._COLS))
     
    2369424753 
    2369524754 #define TR_MUTEX(data) _tracef("%s@%d: me:%08lX COUNT:%2u/%2d/%6d/%2d/%s%9u: " #data, \
    23696 @@ -404,6 +494,8 @@
     24755@@ -389,6 +481,36 @@
     24756 
     24757 #endif /* USE_PTHREADS */
     24758 
     24759+/*
     24760+ * When using sp-funcs, locks are targeted to SCREEN-level granularity.
     24761+ * So the locking is done in the non-sp-func (which calls the sp-func) rather
     24762+ * than in the sp-func itself.
     24763+ *
     24764+ * Use the _nc_nonsp_XXX functions in the function using "NCURSES_SP_NAME()".
     24765+ * Use the _nc_sp_XXX functions in the function using "#if NCURSES_SP_FUNCS".
     24766+ */
     24767+#if NCURSES_SP_FUNCS
     24768+
     24769+#define _nc_nonsp_lock_global(name)    /* nothing */
     24770+#define _nc_nonsp_try_global(name)    0
     24771+#define _nc_nonsp_unlock_global(name)  /* nothing */
     24772+
     24773+#define _nc_sp_lock_global(name)       _nc_lock_global(name)
     24774+#define _nc_sp_try_global(name)         _nc_try_global(name)
     24775+#define _nc_sp_unlock_global(name)     _nc_unlock_global(name)
     24776+
     24777+#else
     24778+
     24779+#define _nc_nonsp_lock_global(name)    _nc_lock_global(name)
     24780+#define _nc_nonsp_try_global(name)      _nc_try_global(name)
     24781+#define _nc_nonsp_unlock_global(name)  _nc_unlock_global(name)
     24782+
     24783+#define _nc_sp_lock_global(name)       /* nothing */
     24784+#define _nc_sp_try_global(name)    0
     24785+#define _nc_sp_unlock_global(name)     /* nothing */
     24786+
     24787+#endif
     24788+
     24789 #if HAVE_GETTIMEOFDAY
     24790 # define PRECISE_GETTIME 1
     24791 # define TimeType struct timeval
     24792@@ -404,6 +526,8 @@
    2369724793 #define C_SHIFT 9              /* we need more bits than there are colors */
    2369824794 #define C_MASK                 ((1 << C_SHIFT) - 1)
     
    2370324799 
    2370424800 #define COLOR_DEFAULT          C_MASK
    23705 @@ -464,13 +556,13 @@
     24801@@ -464,13 +588,13 @@
    2370624802 } slk_ent;
    2370724803 
     
    2372324819 } SLK;
    2372424820 
    23725 @@ -493,10 +585,10 @@
     24821@@ -493,10 +617,10 @@
    2372624822 typedef int (*TYPE_Gpm_Close) (void);
    2372724823 typedef int (*TYPE_Gpm_GetEvent) (Gpm_Event *);
     
    2373824834 /* link statically to GPM */
    2373924835 #define my_gpm_fd       &gpm_fd
    23740 @@ -609,8 +701,10 @@
     24836@@ -609,8 +733,10 @@
    2374124837        int             tgetent_index;
    2374224838        long            tgetent_sequence;
     
    2375024846 #if USE_HOME_TERMINFO
    2375124847        char            *home_terminfo;
    23752 @@ -644,7 +738,9 @@
     24848@@ -644,7 +770,9 @@
    2375324849        char            traceatr_color_buf[2][80];
    2375424850        int             traceatr_color_sel;
     
    2376124857 
    2376224858 #ifdef USE_PTHREADS
    23763 @@ -669,8 +765,10 @@
     24859@@ -669,8 +797,10 @@
    2376424860        bool            use_env;
    2376524861        bool            filter_mode;
     
    2377224868        TTY             *saved_tty;     /* savetty/resetty information      */
    2377324869 #if NCURSES_NO_PADDING
    23774 @@ -680,6 +778,8 @@
     24870@@ -680,6 +810,8 @@
    2377524871        chtype          *real_acs_map;
    2377624872        int             _LINES;
     
    2378124877 #ifdef TRACE
    2378224878        long            _outchars;
    23783 @@ -688,8 +788,16 @@
     24879@@ -688,8 +820,16 @@
    2378424880 #endif
    2378524881 } NCURSES_PRESCREEN;
     
    2380024896 extern NCURSES_EXPORT_VAR(NCURSES_PRESCREEN) _nc_prescreen;
    2380124897 
    23802 @@ -703,6 +811,8 @@
     24898@@ -703,6 +843,8 @@
    2380324899        char            *_setbuf;       /* buffered I/O for output          */
    2380424900        bool            _filtered;      /* filter() was called              */
     
    2380924905        TERMINAL        *_term;         /* terminal type information        */
    2381024906        TTY             _saved_tty;     /* savetty/resetty information      */
    23811 @@ -716,6 +826,10 @@
     24907@@ -716,6 +858,10 @@
    2381224908        WINDOW          *_newscr;       /* virtual screen to be updated to  */
    2381324909        WINDOW          *_stdscr;       /* screen's full-window context     */
     
    2382024916        TRIES           *_key_ok;       /* Disabled keys via keyok(,FALSE)  */
    2382124917        bool            _tried;         /* keypad mode was initialized      */
    23822 @@ -794,11 +908,13 @@
     24918@@ -794,11 +940,13 @@
    2382324919        int             _color_count;   /* count of colors in palette        */
    2382424920        colorpair_t     *_color_pairs;  /* screen's color pair list          */
     
    2383424930        chtype          _ok_attributes; /* valid attributes for terminal     */
    2383524931        chtype          _xmc_suppress;  /* attributes to suppress if xmc     */
    23836 @@ -820,8 +936,9 @@
     24932@@ -820,8 +968,9 @@
    2383724933         */
    2383824934        bool            _nc_sp_idlok;
     
    2384624942        /*
    2384724943         * These are the data that support the mouse interface.
    23848 @@ -875,7 +992,7 @@
     24944@@ -875,7 +1024,7 @@
    2384924945         * This supports automatic resizing
    2385024946         */
     
    2385524951 
    2385624952        /*
    23857 @@ -895,7 +1012,7 @@
     24953@@ -895,7 +1044,7 @@
    2385824954        int             _oldnum_size;
    2385924955 
     
    2386424960        int             _legacy_coding; /* see use_legacy_coding() */
    2386524961 
    23866 @@ -915,6 +1032,15 @@
     24962@@ -915,6 +1064,15 @@
    2386724963        char            tracechr_buf[40];
    2386824964        char            tracemse_buf[TRACEMSE_MAX];
     
    2388024976         * ncurses/ncursesw are the same up to this point.
    2388124977         */
    23882 @@ -943,6 +1069,20 @@
     24978@@ -943,6 +1101,20 @@
    2388324979 
    2388424980 #define WINDOW_EXT(win,field) (((WINDOWLIST *)(win))->field)
     
    2390124997 #ifndef UCHAR_MAX
    2390224998 #define UCHAR_MAX 255
    23903 @@ -1112,7 +1252,7 @@
     24999@@ -1112,7 +1284,7 @@
    2390425000                                AttrOf(dst) |= (ext + 1)
    2390525001 
     
    2391025006                         || (!isWidecExt(ch) &&                         \
    2391125007                             (ch).chars[1] == L'\0' &&                  \
    23912 @@ -1214,8 +1354,8 @@
     25008@@ -1214,8 +1386,8 @@
    2391325009  * Standardize/simplify common loops
    2391425010  */
     
    2392125017 /*
    2392225018  * Prefixes for call/return points of library function traces.  We use these to
    23923 @@ -1263,7 +1403,7 @@
     25019@@ -1263,7 +1435,7 @@
    2392425020 #define returnBool(code)       TRACE_RETURN(code,bool)
    2392525021 #define returnCPtr(code)       TRACE_RETURN(code,cptr)
     
    2393025026 #define returnPtr(code)                TRACE_RETURN(code,ptr)
    2393125027 #define returnSP(code)         TRACE_RETURN(code,sp)
    23932 @@ -1322,7 +1462,7 @@
     25028@@ -1322,7 +1494,7 @@
    2393325029 #define returnBool(code)       return code
    2393425030 #define returnCPtr(code)       return code
     
    2393925035 #define returnPtr(code)                return code
    2394025036 #define returnSP(code)         return code
    23941 @@ -1348,7 +1488,7 @@
     25037@@ -1348,7 +1520,7 @@
    2394225038 
    2394325039 #define ALL_BUT_COLOR ((chtype)~(A_COLOR))
     
    2394825044 #define toggle_attr_on(S,at) {\
    2394925045    if (PAIR_NUMBER(at) > 0) {\
    23950 @@ -1367,38 +1507,38 @@
     25046@@ -1367,38 +1539,38 @@
    2395125047    }\
    2395225048    TR(TRACE_ATTRS, ("new attribute is %s", _traceattr((S))));}
     
    2400325099 
    2400425100 /*
    24005 @@ -1425,16 +1565,28 @@
     25101@@ -1425,16 +1597,28 @@
    2400625102 extern NCURSES_EXPORT(void) _nc_toggle_attr_off (attr_t *, attr_t);
    2400725103 
     
    2403825134 #else
    2403925135 
    24040 @@ -1483,8 +1635,8 @@
     25136@@ -1483,8 +1667,8 @@
    2404125137 #endif
    2404225138 
     
    2404925145 /* lib_addch.c */
    2405025146 #if USE_WIDEC_SUPPORT
    24051 @@ -1503,7 +1655,7 @@
     25147@@ -1503,7 +1687,7 @@
    2405225148 extern NCURSES_EXPORT(int) _nc_wgetch(WINDOW *, unsigned long *, int EVENTLIST_2nd(_nc_eventlist *));
    2405325149 
     
    2405825154 /* lib_mvcur.c */
    2405925155 #define INFINITY       1000000 /* cost: too high to use */
    24060 @@ -1519,7 +1671,7 @@
     25156@@ -1519,7 +1703,7 @@
    2406125157 extern NCURSES_EXPORT(void) _nc_screen_wrap (void);
    2406225158 
     
    2406725163 /* lib_mvcur.c */
    2406825164 #define INFINITY       1000000 /* cost: too high to use */
    24069 @@ -1527,10 +1679,13 @@
     25165@@ -1527,10 +1711,12 @@
    2407025166 
    2407125167 /* lib_setup.c */
     
    2407825174+extern NCURSES_EXPORT(int)    _nc_locale_breaks_acs(TERMINAL *);
    2407925175+extern NCURSES_EXPORT(int)    _nc_setupterm(NCURSES_CONST char *, int, int *, bool);
    24080 +extern NCURSES_EXPORT(void)   _nc_get_screensize(SCREEN *, int *, int *);
    2408125176+
    2408225177+/* lib_set_term.c */
     
    2408525180 /* lib_tstp.c */
    2408625181 #if USE_SIGWINCH
    24087 @@ -1539,9 +1694,6 @@
     25182@@ -1539,9 +1725,6 @@
    2408825183 #define _nc_handle_sigwinch(a) /* nothing */
    2408925184 #endif
     
    2409525190 #if USE_WIDEC_SUPPORT
    2409625191 extern NCURSES_EXPORT(void) _nc_init_wacs(void);
    24097 @@ -1577,8 +1729,6 @@
     25192@@ -1577,9 +1760,8 @@
    2409825193 
    2409925194 /* elsewhere ... */
     
    2410225197-extern NCURSES_EXPORT(NCURSES_CONST char *) _nc_unctrl (SCREEN *, chtype);
    2410325198 extern NCURSES_EXPORT(SCREEN *) _nc_screen_of (WINDOW *);
     25199+extern NCURSES_EXPORT(TERMINAL*) _nc_get_cur_term (void);
    2410425200 extern NCURSES_EXPORT(WINDOW *) _nc_makenew (int, int, int, int, int);
    2410525201 extern NCURSES_EXPORT(char *) _nc_trace_buf (int, size_t);
    24106 @@ -1592,12 +1742,14 @@
     25202 extern NCURSES_EXPORT(char *) _nc_trace_bufcat (int, const char *);
     25203@@ -1592,12 +1774,14 @@
    2410725204 extern NCURSES_EXPORT(int) _nc_keypad (SCREEN *, bool);
    2410825205 extern NCURSES_EXPORT(int) _nc_ospeed (int);
     
    2412125218 extern NCURSES_EXPORT(void) _nc_freeall (void);
    2412225219 extern NCURSES_EXPORT(void) _nc_hash_map (void);
    24123 @@ -1661,24 +1813,33 @@
     25220@@ -1661,24 +1845,33 @@
    2412425221 
    2412525222 #define USE_SETBUF_0 0
     
    2416225259 
    2416325260 /*
    24164 @@ -1686,10 +1847,11 @@
     25261@@ -1686,10 +1879,11 @@
    2416525262  * if the application is running multiple screens under X, it's quite possible
    2416625263  * they could all have type xterm but have different sizes!  So...
     
    2417625273 /*
    2417725274  * Some constants related to SLK's
    24178 @@ -1707,14 +1869,240 @@
     25275@@ -1707,14 +1901,277 @@
    2417925276 #define MAX_SKEY(fmt)     (SLK_STDFMT(fmt)? MAX_SKEY_OLD : MAX_SKEY_PC)
    2418025277 #define MAX_SKEY_LEN(fmt) (SLK_STDFMT(fmt)? MAX_SKEY_LEN_OLD : MAX_SKEY_LEN_PC)
     
    2420825305+    sp->jump = outc
    2420925306+
     25307+#ifdef USE_TERM_DRIVER
    2421025308+struct DriverTCB; /* Terminal Control Block forward declaration */
    2421125309+typedef void* TERM_HANDLE;
     
    2426925367+} TERM_DRIVER;
    2427025368+
    24271 +
    2427225369+typedef struct DriverTCB
    2427325370+{
     
    2429825395+extern NCURSES_EXPORT_VAR(const color_t*) _nc_hls_palette;
    2429925396+
     25397+extern NCURSES_EXPORT(int)      _nc_get_driver(TERMINAL_CONTROL_BLOCK*, const char*, int*);
     25398+extern NCURSES_EXPORT(void)     _nc_get_screensize_ex(SCREEN *, TERMINAL *, int *, int *);
     25399+#endif /* USE_TERM_DRIVER */
     25400+
     25401+/*
     25402+ * Entrypoints which are actually provided in the terminal driver, which would
     25403+ * be an sp-name otherwise.
     25404+ */
    2430025405+#ifdef USE_TERM_DRIVER
    24301 +extern NCURSES_EXPORT(int)      _nc_tinfo_has_key(SCREEN*, int);
    24302 +extern NCURSES_EXPORT(int)      _nc_tinfo_doupdate(SCREEN *sp);
    24303 +extern NCURSES_EXPORT(int)      _nc_tinfo_mvcur(SCREEN*,int,int,int,int);
    24304 +extern NCURSES_EXPORT(int)      _nc_get_driver(TERMINAL_CONTROL_BLOCK*, const char*, int*);
     25406+#define TINFO_HAS_KEY           _nc_tinfo_has_key
     25407+#define TINFO_DOUPDATE          _nc_tinfo_doupdate
     25408+#define TINFO_MVCUR             _nc_tinfo_mvcur
     25409+extern NCURSES_EXPORT(int)      TINFO_HAS_KEY(SCREEN*, int);
     25410+extern NCURSES_EXPORT(int)      TINFO_DOUPDATE(SCREEN *);
     25411+extern NCURSES_EXPORT(int)      TINFO_MVCUR(SCREEN*, int, int, int, int);
     25412+#else
     25413+#define TINFO_HAS_KEY           NCURSES_SP_NAME(has_key)
     25414+#define TINFO_DOUPDATE          NCURSES_SP_NAME(doupdate)
     25415+#define TINFO_MVCUR             NCURSES_SP_NAME(mvcur)
    2430525416+#endif
    2430625417+
     25418+/*
     25419+ * Entrypoints using an extra parameter with the terminal driver.
     25420+ */
     25421+#ifdef USE_TERM_DRIVER
     25422+extern NCURSES_EXPORT(void)   _nc_get_screensize(SCREEN *, TERMINAL *, int *, int *);
     25423+extern NCURSES_EXPORT(int)    _nc_setupterm_ex(TERMINAL **, NCURSES_CONST char *, int , int *, bool);
     25424+#define TINFO_GET_SIZE(sp, tp, lp, cp) \
     25425+       _nc_get_screensize(sp, tp, lp, cp)
     25426+#define TINFO_SET_CURTERM(sp, tp) \
     25427+       NCURSES_SP_NAME(set_curterm)(sp, tp)
     25428+#define TINFO_SETUP_TERM(tpp, name, fd, err, reuse) \
     25429+       _nc_setupterm_ex(tpp, name, fd, err, reuse)
     25430+#else /* !USE_TERM_DRIVER */
     25431+extern NCURSES_EXPORT(void)   _nc_get_screensize(SCREEN *, int *, int *);
     25432+#define TINFO_GET_SIZE(sp, tp, lp, cp) \
     25433+       _nc_get_screensize(sp, lp, cp)
     25434+#define TINFO_SET_CURTERM(sp, tp) \
     25435+       set_curterm(tp)
     25436+#define TINFO_SETUP_TERM(tpp, name, fd, err, reuse) \
     25437+       _nc_setupterm(name, fd, err, reuse)
     25438+#endif /* !USE_TERM_DRIVER */
     25439+
     25440+#ifdef USE_TERM_DRIVER
    2430725441+#ifdef __MINGW32__
    2430825442+#include <nc_mingw.h>
     
    2431025444+#endif
    2431125445+extern NCURSES_EXPORT_VAR(TERM_DRIVER) _nc_TINFO_DRIVER;
     25446+#endif
    2431225447+
    2431325448+#ifdef USE_TERM_DRIVER
     
    2433025465+
    2433125466+#if USE_REENTRANT
    24332 +extern NCURSES_EXPORT(char *)    NCURSES_SP_NAME(_nc_ttytype)(SCREEN*);
    2433325467+extern NCURSES_EXPORT(int)       NCURSES_SP_NAME(_nc_TABSIZE)(SCREEN*);
    2433425468+extern NCURSES_EXPORT(char *)    NCURSES_SP_NAME(longname)(SCREEN*);
     
    2434325477+ * part of the API up to now
    2434425478+ */
    24345 +extern NCURSES_EXPORT(TERMINAL*) NCURSES_SP_NAME(cur_term)(SCREEN *sp);
     25479+extern NCURSES_EXPORT(TERMINAL*) NCURSES_SP_NAME(_nc_get_cur_term) (SCREEN *sp);
    2434625480+extern NCURSES_EXPORT(WINDOW *) NCURSES_SP_NAME(_nc_makenew) (SCREEN*, int, int, int, int, int);
    2434725481+extern NCURSES_EXPORT(bool)     NCURSES_SP_NAME(_nc_reset_colors)(SCREEN*);
     
    2442125555diff -Naur ncurses-5.7.orig/ncurses/llib-lncurses ncurses-5.7/ncurses/llib-lncurses
    2442225556--- ncurses-5.7.orig/ncurses/llib-lncurses      2008-10-11 13:57:29.000000000 -0700
    24423 +++ ncurses-5.7/ncurses/llib-lncurses   2009-07-19 15:04:11.000000000 -0700
     25557+++ ncurses-5.7/ncurses/llib-lncurses   2009-09-12 08:51:49.000000000 -0700
    2442425558@@ -1,5 +1,5 @@
    2442525559 /****************************************************************************
     
    2611327247diff -Naur ncurses-5.7.orig/ncurses/llib-lncursest ncurses-5.7/ncurses/llib-lncursest
    2611427248--- ncurses-5.7.orig/ncurses/llib-lncursest     2008-10-11 14:13:13.000000000 -0700
    26115 +++ ncurses-5.7/ncurses/llib-lncursest  2009-07-19 15:04:11.000000000 -0700
     27249+++ ncurses-5.7/ncurses/llib-lncursest  2009-09-12 08:51:49.000000000 -0700
    2611627250@@ -1,5 +1,5 @@
    2611727251 /****************************************************************************
     
    2785928993diff -Naur ncurses-5.7.orig/ncurses/llib-lncursestw ncurses-5.7/ncurses/llib-lncursestw
    2786028994--- ncurses-5.7.orig/ncurses/llib-lncursestw    1969-12-31 16:00:00.000000000 -0800
    27861 +++ ncurses-5.7/ncurses/llib-lncursestw 2009-07-19 15:04:11.000000000 -0700
     28995+++ ncurses-5.7/ncurses/llib-lncursestw 2009-09-12 08:51:49.000000000 -0700
    2786228996@@ -0,0 +1,5192 @@
    2786328997+/****************************************************************************
     
    3305534189diff -Naur ncurses-5.7.orig/ncurses/llib-lncursesw ncurses-5.7/ncurses/llib-lncursesw
    3305634190--- ncurses-5.7.orig/ncurses/llib-lncursesw     2008-10-11 14:03:02.000000000 -0700
    33057 +++ ncurses-5.7/ncurses/llib-lncursesw  2009-07-19 15:04:11.000000000 -0700
     34191+++ ncurses-5.7/ncurses/llib-lncursesw  2009-09-12 08:51:49.000000000 -0700
    3305834192@@ -1,5 +1,5 @@
    3305934193 /****************************************************************************
     
    3482435958diff -Naur ncurses-5.7.orig/ncurses/Makefile.in ncurses-5.7/ncurses/Makefile.in
    3482535959--- ncurses-5.7.orig/ncurses/Makefile.in        2008-10-18 07:11:54.000000000 -0700
    34826 +++ ncurses-5.7/ncurses/Makefile.in     2009-07-19 15:04:13.000000000 -0700
     35960+++ ncurses-5.7/ncurses/Makefile.in     2009-09-12 08:52:04.000000000 -0700
    3482735961@@ -1,6 +1,6 @@
    3482835962-# $Id: Makefile.in,v 1.113 2008/10/18 14:11:54 tom Exp $
    34829 +# $Id: Makefile.in,v 1.117 2009/07/04 16:36:11 tom Exp $
     35963+# $Id: Makefile.in,v 1.119 2009/08/10 09:06:37 tom Exp $
    3483035964 ##############################################################################
    3483135965-# Copyright (c) 1998-2007,2008 Free Software Foundation, Inc.                #
     
    3486936003 ################################################################################
    3487036004 all \
    34871 @@ -204,7 +206,7 @@
     36005@@ -200,11 +202,11 @@
     36006        $(BUILD_CC) -o $@ $(BUILD_CCFLAGS) $(tinfo)/make_keys.c $(BUILD_LDFLAGS) $(BUILD_LIBS)
     36007 
     36008 make_hash$(BUILD_EXEEXT) : \
     36009-               $(tinfo)/comp_hash.c \
     36010+               $(tinfo)/make_hash.c \
    3487236011                ../include/hashsize.h
    34873         $(BUILD_CC) -o $@ $(BUILD_CCFLAGS) -DMAIN_PROGRAM $(tinfo)/comp_hash.c $(BUILD_LDFLAGS) $(BUILD_LIBS)
     36012-       $(BUILD_CC) -o $@ $(BUILD_CCFLAGS) -DMAIN_PROGRAM $(tinfo)/comp_hash.c $(BUILD_LDFLAGS) $(BUILD_LIBS)
     36013+       $(BUILD_CC) -o $@ $(BUILD_CCFLAGS) $(tinfo)/make_hash.c $(BUILD_LDFLAGS) $(BUILD_LIBS)
    3487436014 
    3487536015-./expanded.c : $(serial)/MKexpanded.sh
    34876 +./expanded.c : curses.priv.h $(serial)/MKexpanded.sh
     36016+./expanded.c : $(srcdir)/curses.priv.h $(serial)/MKexpanded.sh
    3487736017        sh -e $(serial)/MKexpanded.sh "$(CPP)" $(CPPFLAGS) > $@
    3487836018 
     
    3488036020diff -Naur ncurses-5.7.orig/ncurses/modules ncurses-5.7/ncurses/modules
    3488136021--- ncurses-5.7.orig/ncurses/modules    2007-09-08 15:03:34.000000000 -0700
    34882 +++ ncurses-5.7/ncurses/modules 2009-07-19 15:04:15.000000000 -0700
     36022+++ ncurses-5.7/ncurses/modules 2009-09-12 08:51:52.000000000 -0700
    3488336023@@ -1,6 +1,6 @@
    3488436024-# $Id: modules,v 1.112 2007/09/08 22:03:34 tom Exp $
     
    3491236052diff -Naur ncurses-5.7.orig/ncurses/README ncurses-5.7/ncurses/README
    3491336053--- ncurses-5.7.orig/ncurses/README     2006-04-22 15:19:37.000000000 -0700
    34914 +++ ncurses-5.7/ncurses/README  2009-07-19 15:04:11.000000000 -0700
     36054+++ ncurses-5.7/ncurses/README  2009-09-12 08:51:49.000000000 -0700
    3491536055@@ -1,5 +1,5 @@
    3491636056 -------------------------------------------------------------------------------
     
    3495036090diff -Naur ncurses-5.7.orig/ncurses/tinfo/access.c ncurses-5.7/ncurses/tinfo/access.c
    3495136091--- ncurses-5.7.orig/ncurses/tinfo/access.c     2007-11-17 16:57:53.000000000 -0800
    34952 +++ ncurses-5.7/ncurses/tinfo/access.c  2009-07-19 15:03:51.000000000 -0700
     36092+++ ncurses-5.7/ncurses/tinfo/access.c  2009-09-12 08:51:28.000000000 -0700
    3495336093@@ -1,5 +1,5 @@
    3495436094 /****************************************************************************
     
    3497836118diff -Naur ncurses-5.7.orig/ncurses/tinfo/alloc_ttype.c ncurses-5.7/ncurses/tinfo/alloc_ttype.c
    3497936119--- ncurses-5.7.orig/ncurses/tinfo/alloc_ttype.c        2008-10-12 09:12:00.000000000 -0700
    34980 +++ ncurses-5.7/ncurses/tinfo/alloc_ttype.c     2009-07-19 15:03:53.000000000 -0700
     36120+++ ncurses-5.7/ncurses/tinfo/alloc_ttype.c     2009-09-12 08:51:30.000000000 -0700
    3498136121@@ -1,5 +1,5 @@
    3498236122 /****************************************************************************
     
    3512536265diff -Naur ncurses-5.7.orig/ncurses/tinfo/captoinfo.c ncurses-5.7/ncurses/tinfo/captoinfo.c
    3512636266--- ncurses-5.7.orig/ncurses/tinfo/captoinfo.c  2008-08-16 12:24:51.000000000 -0700
    35127 +++ ncurses-5.7/ncurses/tinfo/captoinfo.c       2009-07-19 15:03:48.000000000 -0700
     36267+++ ncurses-5.7/ncurses/tinfo/captoinfo.c       2009-09-12 08:51:25.000000000 -0700
    3512836268@@ -1,5 +1,5 @@
    3512936269 /****************************************************************************
     
    3515336293diff -Naur ncurses-5.7.orig/ncurses/tinfo/comp_hash.c ncurses-5.7/ncurses/tinfo/comp_hash.c
    3515436294--- ncurses-5.7.orig/ncurses/tinfo/comp_hash.c  2008-08-16 10:06:53.000000000 -0700
    35155 +++ ncurses-5.7/ncurses/tinfo/comp_hash.c       2009-07-19 15:04:17.000000000 -0700
     36295+++ ncurses-5.7/ncurses/tinfo/comp_hash.c       2009-09-12 08:52:02.000000000 -0700
    3515636296@@ -1,5 +1,5 @@
    3515736297 /****************************************************************************
     
    3516136301  * Permission is hereby granted, free of charge, to any person obtaining a  *
    3516236302  * copy of this software and associated documentation files (the            *
    35163 @@ -50,7 +50,7 @@
    35164  #define DEBUG(level, params)   /*nothing */
    35165  #endif
    35166  
     36303@@ -44,110 +44,36 @@
     36304 #include <tic.h>
     36305 #include <hashsize.h>
     36306 
     36307-#ifdef MAIN_PROGRAM
     36308-#include <ctype.h>
     36309-#undef  DEBUG
     36310-#define DEBUG(level, params)   /*nothing */
     36311-#endif
     36312-
    3516736313-MODULE_ID("$Id: comp_hash.c,v 1.36 2008/08/16 17:06:53 tom Exp $")
    35168 +MODULE_ID("$Id: comp_hash.c,v 1.45 2009/07/18 20:30:21 tom Exp $")
    35169  
    35170  static int hash_function(const char *);
    35171  
    35172 @@ -91,8 +91,7 @@
    35173         hash_table[hashvalue] = i;
    35174      }
    35175  
     36314-
     36315-static int hash_function(const char *);
     36316-
     36317-/*
     36318- *     _nc_make_hash_table()
     36319- *
     36320- *     Takes the entries in table[] and hashes them into hash_table[]
     36321- *     by name.  There are CAPTABSIZE entries in table[] and HASHTABSIZE
     36322- *     slots in hash_table[].
     36323- *
     36324- */
     36325-
     36326-#ifdef MAIN_PROGRAM
     36327-
     36328-#undef MODULE_ID
     36329-#define MODULE_ID(id)          /*nothing */
     36330-#include <tinfo/doalloc.c>
     36331-
     36332-static void
     36333-_nc_make_hash_table(struct name_table_entry *table,
     36334-                   short *hash_table)
     36335-{
     36336-    short i;
     36337-    int hashvalue;
     36338-    int collisions = 0;
     36339-
     36340-    for (i = 0; i < HASHTABSIZE; i++) {
     36341-       hash_table[i] = -1;
     36342-    }
     36343-    for (i = 0; i < CAPTABSIZE; i++) {
     36344-       hashvalue = hash_function(table[i].nte_name);
     36345-
     36346-       if (hash_table[hashvalue] >= 0)
     36347-           collisions++;
     36348-
     36349-       if (hash_table[hashvalue] != 0)
     36350-           table[i].nte_link = hash_table[hashvalue];
     36351-       hash_table[hashvalue] = i;
     36352-    }
     36353-
    3517636354-    DEBUG(4, ("Hash table complete: %d collisions out of %d entries",
    3517736355-             collisions, CAPTABSIZE));
    35178 +    printf("/* %d collisions out of %d entries */\n", collisions, CAPTABSIZE);
    35179  }
    35180  #endif
    35181  
    35182 @@ -121,16 +120,24 @@
    35183      return (int) (sum % HASHTABSIZE);
    35184  }
    35185  
    35186 +#ifndef MAIN_PROGRAM
    35187 +
    35188 +#define SameName(a,b,termcap) (termcap ? !strncmp(a,b,2) : !strcmp(a,b))
    35189 +#if 0
    35190 +static bool
    35191 +same_name(const char *a, const char *b, bool termcap)
    35192 +{
    35193 +    fprintf(stderr, "compare(%s,%s)\n", a, b);
    35194 +    return SameName(a, b, termcap);
    35195 +}
    35196 +#else
    35197 +#define same_name(a,b,termcap) SameName(a,b,termcap)
    35198 +#endif
    35199 +
     36356-}
     36357-#endif
     36358+MODULE_ID("$Id: comp_hash.c,v 1.48 2009/08/08 17:36:21 tom Exp $")
     36359 
    3520036360 /*
     36361- *     int hash_function(string)
     36362- *
     36363- *     Computes the hashing function on the given string.
     36364- *
     36365- *     The current hash function is the sum of each consectutive pair
     36366- *     of characters, taken as two-byte integers, mod HASHTABSIZE.
     36367- *
     36368+ * Finds the entry for the given string in the hash table if present.
     36369+ * Returns a pointer to the entry in the table or 0 if not found.
     36370  */
     36371-
     36372-static int
     36373-hash_function(const char *string)
     36374-{
     36375-    long sum = 0;
     36376-
     36377-    DEBUG(9, ("hashing %s", string));
     36378-    while (*string) {
     36379-       sum += (long) (*string + (*(string + 1) << 8));
     36380-       string++;
     36381-    }
     36382-
     36383-    DEBUG(9, ("sum is %ld", sum));
     36384-    return (int) (sum % HASHTABSIZE);
     36385-}
     36386-
     36387-/*
    3520136388- *     struct name_table_entry *
    3520236389- *     find_entry(string)
     
    3520536392- *     Returns a pointer to the entry in the table or 0 if not found.
    3520636393- *
    35207 + * Finds the entry for the given string in the hash table if present.
    35208 + * Returns a pointer to the entry in the table or 0 if not found.
    35209   */
     36394- */
    3521036395-
    3521136396-#ifndef MAIN_PROGRAM
     36397+/* entrypoint used by tack (do not alter) */
    3521236398 NCURSES_EXPORT(struct name_table_entry const *)
    3521336399 _nc_find_entry(const char *string,
    35214                const short *hash_table)
    35215 @@ -142,11 +149,15 @@
    35216      hashvalue = hash_function(string);
    35217  
    35218      if (hash_table[hashvalue] >= 0) {
     36400-              const short *hash_table)
     36401+              const HashValue * hash_table)
     36402 {
     36403+    bool termcap = (hash_table != _nc_get_hash_table(FALSE));
     36404+    const HashData *data = _nc_get_hash_info(termcap);
     36405     int hashvalue;
     36406     struct name_table_entry const *ptr = 0;
     36407     struct name_table_entry const *real_table;
     36408 
     36409-    hashvalue = hash_function(string);
     36410+    hashvalue = data->hash_of(string);
     36411+
     36412+    if (data->table_data[hashvalue] >= 0) {
     36413 
     36414-    if (hash_table[hashvalue] >= 0) {
    3521936415-       real_table = _nc_get_table(hash_table != _nc_get_hash_table(FALSE));
    35220 +       bool termcap = (hash_table != _nc_get_hash_table(FALSE));
    35221 +
    35222 +       real_table = _nc_get_table(termcap);
    35223         ptr = real_table + hash_table[hashvalue];
     36416-       ptr = real_table + hash_table[hashvalue];
    3522436417-       while (strcmp(ptr->nte_name, string) != 0) {
    3522536418-           if (ptr->nte_link < 0)
    3522636419-               return 0;
    35227 +       while (!same_name(ptr->nte_name, string, termcap)) {
     36420-           ptr = real_table + (ptr->nte_link + hash_table[HASHTABSIZE]);
     36421+       real_table = _nc_get_table(termcap);
     36422+       ptr = real_table + data->table_data[hashvalue];
     36423+       while (!data->compare_names(ptr->nte_name, string)) {
    3522836424+           if (ptr->nte_link < 0) {
    3522936425+               ptr = 0;
    3523036426+               break;
    3523136427+           }
    35232             ptr = real_table + (ptr->nte_link + hash_table[HASHTABSIZE]);
     36428+           ptr = real_table + (ptr->nte_link
     36429+                               + data->table_data[data->table_size]);
    3523336430        }
    3523436431     }
    35235 @@ -155,29 +166,36 @@
     36432 
     36433@@ -155,216 +81,34 @@
    3523636434 }
    3523736435 
     
    3525836456 {
    3525936457-    struct name_table_entry const *ptr;
    35260 +    struct name_table_entry const *ptr = NULL;
    35261 +    const short *hash_table = _nc_get_hash_table(termcap);
    35262 +    int hashvalue = hash_function(string);
    35263  
     36458-
    3526436459-    for (ptr = table; ptr < table + CAPTABSIZE; ptr++) {
    3526536460-       if (ptr->nte_type == type && strcmp(string, ptr->nte_name) == 0)
    3526636461-           return (ptr);
    35267 +    if (hash_table[hashvalue] >= 0) {
     36462-    }
     36463-
     36464-    return ((struct name_table_entry *) NULL);
     36465-}
     36466-#endif
     36467-
     36468-#ifdef MAIN_PROGRAM
     36469-/*
     36470- * This filter reads from standard input a list of tab-delimited columns,
     36471- * (e.g., from Caps.filtered) computes the hash-value of a specified column and
     36472- * writes the hashed tables to standard output.
     36473- *
     36474- * By compiling the hash table at build time, we're able to make the entire
     36475- * set of terminfo and termcap tables readonly (and also provide some runtime
     36476- * performance enhancement).
     36477- */
     36478-
     36479-#define MAX_COLUMNS BUFSIZ     /* this _has_ to be worst-case */
     36480-
     36481-static char **
     36482-parse_columns(char *buffer)
     36483-{
     36484-    static char **list;
     36485-
     36486-    int col = 0;
     36487-
     36488-    if (list == 0 && (list = typeCalloc(char *, MAX_COLUMNS)) == 0)
     36489-         return (0);
     36490-
     36491-    if (*buffer != '#') {
     36492-       while (*buffer != '\0') {
     36493-           char *s;
     36494-           for (s = buffer; (*s != '\0') && !isspace(UChar(*s)); s++)
     36495-               /*EMPTY */ ;
     36496-           if (s != buffer) {
     36497-               char mark = *s;
     36498-               *s = '\0';
     36499-               if ((s - buffer) > 1
     36500-                   && (*buffer == '"')
     36501-                   && (s[-1] == '"')) {        /* strip the quotes */
     36502-                   assert(s > buffer + 1);
     36503-                   s[-1] = '\0';
     36504-                   buffer++;
     36505-               }
     36506-               list[col] = buffer;
     36507-               col++;
     36508-               if (mark == '\0')
     36509-                   break;
     36510-               while (*++s && isspace(UChar(*s)))
     36511-                   /*EMPTY */ ;
     36512-               buffer = s;
     36513-           } else
     36514+    struct name_table_entry const *ptr = NULL;
     36515+    const HashData *data = _nc_get_hash_info(termcap);
     36516+    int hashvalue = data->hash_of(string);
     36517+
     36518+    if (data->table_data[hashvalue] >= 0) {
    3526836519+       const struct name_table_entry *const table = _nc_get_table(termcap);
    3526936520+
    35270 +       ptr = table + hash_table[hashvalue];
     36521+       ptr = table + data->table_data[hashvalue];
    3527136522+       while (ptr->nte_type != type
    35272 +              || !same_name(ptr->nte_name, string, termcap)) {
     36523+              || !data->compare_names(ptr->nte_name, string)) {
    3527336524+           if (ptr->nte_link < 0) {
    3527436525+               ptr = 0;
    35275 +               break;
    35276 +           }
    35277 +           ptr = table + (ptr->nte_link + hash_table[HASHTABSIZE]);
    35278 +       }
     36526                break;
     36527-       }
     36528-    }
     36529-    return col ? list : 0;
     36530-}
     36531-
     36532-int
     36533-main(int argc, char **argv)
     36534-{
     36535-    struct name_table_entry *name_table = typeCalloc(struct
     36536-                                                    name_table_entry, CAPTABSIZE);
     36537-    short *hash_table = typeCalloc(short, HASHTABSIZE);
     36538-    const char *root_name = "";
     36539-    int column = 0;
     36540-    int bigstring = 0;
     36541-    int n;
     36542-    char buffer[BUFSIZ];
     36543-
     36544-    static const char *typenames[] =
     36545-    {"BOOLEAN", "NUMBER", "STRING"};
     36546-
     36547-    short BoolCount = 0;
     36548-    short NumCount = 0;
     36549-    short StrCount = 0;
     36550-
     36551-    /* The first argument is the column-number (starting with 0).
     36552-     * The second is the root name of the tables to generate.
     36553-     */
     36554-    if (argc <= 3
     36555-       || (column = atoi(argv[1])) <= 0
     36556-       || (column >= MAX_COLUMNS)
     36557-       || *(root_name = argv[2]) == 0
     36558-       || (bigstring = atoi(argv[3])) < 0
     36559-       || name_table == 0
     36560-       || hash_table == 0) {
     36561-       fprintf(stderr, "usage: make_hash column root_name bigstring\n");
     36562-       exit(EXIT_FAILURE);
     36563-    }
     36564-
     36565-    /*
     36566-     * Read the table into our arrays.
     36567-     */
     36568-    for (n = 0; (n < CAPTABSIZE) && fgets(buffer, BUFSIZ, stdin);) {
     36569-       char **list, *nlp = strchr(buffer, '\n');
     36570-       if (nlp)
     36571-           *nlp = '\0';
     36572-       list = parse_columns(buffer);
     36573-       if (list == 0)          /* blank or comment */
     36574-           continue;
     36575-       name_table[n].nte_link = -1;    /* end-of-hash */
     36576-       name_table[n].nte_name = strdup(list[column]);
     36577-       if (!strcmp(list[2], "bool")) {
     36578-           name_table[n].nte_type = BOOLEAN;
     36579-           name_table[n].nte_index = BoolCount++;
     36580-       } else if (!strcmp(list[2], "num")) {
     36581-           name_table[n].nte_type = NUMBER;
     36582-           name_table[n].nte_index = NumCount++;
     36583-       } else if (!strcmp(list[2], "str")) {
     36584-           name_table[n].nte_type = STRING;
     36585-           name_table[n].nte_index = StrCount++;
     36586-       } else {
     36587-           fprintf(stderr, "Unknown type: %s\n", list[2]);
     36588-           exit(EXIT_FAILURE);
     36589-       }
     36590-       n++;
     36591-    }
     36592-    _nc_make_hash_table(name_table, hash_table);
     36593-
     36594-    /*
     36595-     * Write the compiled tables to standard output
     36596-     */
     36597-    if (bigstring) {
     36598-       int len = 0;
     36599-       int nxt;
     36600-
     36601-       printf("static const char %s_names_text[] = \\\n", root_name);
     36602-       for (n = 0; n < CAPTABSIZE; n++) {
     36603-           nxt = (int) strlen(name_table[n].nte_name) + 5;
     36604-           if (nxt + len > 72) {
     36605-               printf("\\\n");
     36606-               len = 0;
     36607            }
     36608-           printf("\"%s\\0\" ", name_table[n].nte_name);
     36609-           len += nxt;
     36610-       }
     36611-       printf(";\n\n");
     36612-
     36613-       len = 0;
     36614-       printf("static name_table_data const %s_names_data[] =\n",
     36615-              root_name);
     36616-       printf("{\n");
     36617-       for (n = 0; n < CAPTABSIZE; n++) {
     36618-           printf("\t{ %15d,\t%10s,\t%3d, %3d }%c\n",
     36619-                  len,
     36620-                  typenames[name_table[n].nte_type],
     36621-                  name_table[n].nte_index,
     36622-                  name_table[n].nte_link,
     36623-                  n < CAPTABSIZE - 1 ? ',' : ' ');
     36624-           len += (int) strlen(name_table[n].nte_name) + 1;
     36625+           ptr = table + (ptr->nte_link + data->table_data[data->table_size]);
     36626        }
     36627-       printf("};\n\n");
     36628-       printf("static struct name_table_entry *_nc_%s_table = 0;\n\n", root_name);
     36629-    } else {
     36630-
     36631-       printf("static struct name_table_entry %s _nc_%s_table[] =\n",
     36632-              bigstring ? "" : "const",
     36633-              root_name);
     36634-       printf("{\n");
     36635-       for (n = 0; n < CAPTABSIZE; n++) {
     36636-           sprintf(buffer, "\"%s\"",
     36637-                   name_table[n].nte_name);
     36638-           printf("\t{ %15s,\t%10s,\t%3d, %3d }%c\n",
     36639-                  buffer,
     36640-                  typenames[name_table[n].nte_type],
     36641-                  name_table[n].nte_index,
     36642-                  name_table[n].nte_link,
     36643-                  n < CAPTABSIZE - 1 ? ',' : ' ');
     36644-       }
     36645-       printf("};\n\n");
     36646-    }
     36647-
     36648-    printf("static const short _nc_%s_hash_table[%d] =\n",
     36649-          root_name,
     36650-          HASHTABSIZE + 1);
     36651-    printf("{\n");
     36652-    for (n = 0; n < HASHTABSIZE; n++) {
     36653-       printf("\t%3d,\n", hash_table[n]);
    3527936654     }
    35280  
    35281 -    return ((struct name_table_entry *) NULL);
     36655-    printf("\t0\t/* base-of-table */\n");
     36656-    printf("};\n\n");
     36657-
     36658-    printf("#if (BOOLCOUNT!=%d)||(NUMCOUNT!=%d)||(STRCOUNT!=%d)\n",
     36659-          BoolCount, NumCount, StrCount);
     36660-    printf("#error\t--> term.h and comp_captab.c disagree about the <--\n");
     36661-    printf("#error\t--> numbers of booleans, numbers and/or strings <--\n");
     36662-    printf("#endif\n\n");
     36663 
     36664-    free(hash_table);
     36665-    return EXIT_SUCCESS;
    3528236666+    return ptr;
    3528336667 }
    35284  #endif
    35285  
     36668-#endif
    3528636669diff -Naur ncurses-5.7.orig/ncurses/tinfo/comp_parse.c ncurses-5.7/ncurses/tinfo/comp_parse.c
    3528736670--- ncurses-5.7.orig/ncurses/tinfo/comp_parse.c 2008-08-16 14:58:16.000000000 -0700
    35288 +++ ncurses-5.7/ncurses/tinfo/comp_parse.c      2009-07-19 15:04:17.000000000 -0700
     36671+++ ncurses-5.7/ncurses/tinfo/comp_parse.c      2009-09-12 08:51:54.000000000 -0700
    3528936672@@ -1,5 +1,5 @@
    3529036673 /****************************************************************************
     
    3532736710diff -Naur ncurses-5.7.orig/ncurses/tinfo/comp_scan.c ncurses-5.7/ncurses/tinfo/comp_scan.c
    3532836711--- ncurses-5.7.orig/ncurses/tinfo/comp_scan.c  2008-08-16 12:22:55.000000000 -0700
    35329 +++ ncurses-5.7/ncurses/tinfo/comp_scan.c       2009-07-19 15:03:59.000000000 -0700
     36712+++ ncurses-5.7/ncurses/tinfo/comp_scan.c       2009-09-12 08:51:37.000000000 -0700
    3533036713@@ -51,7 +51,7 @@
    3533136714 #include <term_entry.h>
     
    3538536768diff -Naur ncurses-5.7.orig/ncurses/tinfo/entries.c ncurses-5.7/ncurses/tinfo/entries.c
    3538636769--- ncurses-5.7.orig/ncurses/tinfo/entries.c    2008-09-27 06:11:10.000000000 -0700
    35387 +++ ncurses-5.7/ncurses/tinfo/entries.c 2009-07-19 15:04:15.000000000 -0700
     36770+++ ncurses-5.7/ncurses/tinfo/entries.c 2009-09-12 08:51:52.000000000 -0700
    3538836771@@ -1,5 +1,5 @@
    3538936772 /****************************************************************************
     
    3543736820diff -Naur ncurses-5.7.orig/ncurses/tinfo/hashed_db.c ncurses-5.7/ncurses/tinfo/hashed_db.c
    3543836821--- ncurses-5.7.orig/ncurses/tinfo/hashed_db.c  2006-08-19 12:48:38.000000000 -0700
    35439 +++ ncurses-5.7/ncurses/tinfo/hashed_db.c       2009-07-19 15:02:02.000000000 -0700
     36822+++ ncurses-5.7/ncurses/tinfo/hashed_db.c       2009-09-12 08:50:57.000000000 -0700
    3544036823@@ -1,5 +1,5 @@
    3544136824 /****************************************************************************
     
    3554336926diff -Naur ncurses-5.7.orig/ncurses/tinfo/init_keytry.c ncurses-5.7/ncurses/tinfo/init_keytry.c
    3554436927--- ncurses-5.7.orig/ncurses/tinfo/init_keytry.c        2008-05-24 14:44:51.000000000 -0700
    35545 +++ ncurses-5.7/ncurses/tinfo/init_keytry.c     2009-07-19 15:03:59.000000000 -0700
     36928+++ ncurses-5.7/ncurses/tinfo/init_keytry.c     2009-09-12 08:51:37.000000000 -0700
    3554636929@@ -1,5 +1,5 @@
    3554736930 /****************************************************************************
     
    3559036973diff -Naur ncurses-5.7.orig/ncurses/tinfo/lib_acs.c ncurses-5.7/ncurses/tinfo/lib_acs.c
    3559136974--- ncurses-5.7.orig/ncurses/tinfo/lib_acs.c    2008-08-16 12:22:55.000000000 -0700
    35592 +++ ncurses-5.7/ncurses/tinfo/lib_acs.c 2009-07-19 15:04:06.000000000 -0700
     36975+++ ncurses-5.7/ncurses/tinfo/lib_acs.c 2009-09-12 08:51:43.000000000 -0700
    3559336976@@ -1,5 +1,5 @@
    3559436977 /****************************************************************************
     
    3570037083diff -Naur ncurses-5.7.orig/ncurses/tinfo/lib_baudrate.c ncurses-5.7/ncurses/tinfo/lib_baudrate.c
    3570137084--- ncurses-5.7.orig/ncurses/tinfo/lib_baudrate.c       2008-06-28 08:19:24.000000000 -0700
    35702 +++ ncurses-5.7/ncurses/tinfo/lib_baudrate.c    2009-07-19 15:03:59.000000000 -0700
     37085+++ ncurses-5.7/ncurses/tinfo/lib_baudrate.c    2009-09-12 08:51:37.000000000 -0700
    3570337086@@ -1,5 +1,5 @@
    3570437087 /****************************************************************************
     
    3578737170diff -Naur ncurses-5.7.orig/ncurses/tinfo/lib_cur_term.c ncurses-5.7/ncurses/tinfo/lib_cur_term.c
    3578837171--- ncurses-5.7.orig/ncurses/tinfo/lib_cur_term.c       2008-08-16 12:22:55.000000000 -0700
    35789 +++ ncurses-5.7/ncurses/tinfo/lib_cur_term.c    2009-07-19 15:04:04.000000000 -0700
     37172+++ ncurses-5.7/ncurses/tinfo/lib_cur_term.c    2009-09-12 08:52:09.000000000 -0700
    3579037173@@ -1,5 +1,5 @@
    3579137174 /****************************************************************************
     
    3579537178  * Permission is hereby granted, free of charge, to any person obtaining a  *
    3579637179  * copy of this software and associated documentation files (the            *
    35797 @@ -40,12 +40,14 @@
     37180@@ -40,23 +40,41 @@
    3579837181 #include <term_entry.h>                /* TTY, cur_term */
    3579937182 #include <termcap.h>           /* ospeed */
    3580037183 
    3580137184-MODULE_ID("$Id: lib_cur_term.c,v 1.18 2008/08/16 19:22:55 tom Exp $")
    35802 +MODULE_ID("$Id: lib_cur_term.c,v 1.22 2009/05/30 13:55:19 tom Exp $")
     37185+MODULE_ID("$Id: lib_cur_term.c,v 1.26 2009/09/05 18:05:27 tom Exp $")
    3580337186 
    3580437187 #undef CUR
     
    3580937192+NCURSES_EXPORT_VAR(TERMINAL *) cur_term = 0;
    3581037193+#elif BROKEN_LINKER || USE_REENTRANT
     37194+
     37195+NCURSES_EXPORT(TERMINAL *)
     37196+NCURSES_SP_NAME(_nc_get_cur_term) (NCURSES_SP_DCL0)
     37197+{
     37198+    return ((0 != TerminalOf(SP_PARM)) ? TerminalOf(SP_PARM) : CurTerm);
     37199+}
     37200+
     37201+#if NCURSES_SP_FUNCS
     37202+NCURSES_EXPORT(TERMINAL *)
     37203+_nc_get_cur_term(void)
     37204+{
     37205+    return NCURSES_SP_NAME(_nc_get_cur_term) (CURRENT_SCREEN);
     37206+}
     37207+#endif
     37208+
    3581137209 NCURSES_EXPORT(TERMINAL *)
    3581237210 NCURSES_PUBLIC_VAR(cur_term) (void)
    3581337211 {
    35814 @@ -66,7 +68,9 @@
     37212-    return (SP != 0 && SP->_term != 0) ? SP->_term : _nc_prescreen._cur_term;
     37213+    return NCURSES_SP_NAME(_nc_get_cur_term) (NCURSES_SP_ARG);
     37214 }
     37215+
     37216 #else
     37217 NCURSES_EXPORT_VAR(TERMINAL *) cur_term = 0;
     37218 #endif
     37219 
     37220 NCURSES_EXPORT(TERMINAL *)
     37221-set_curterm(TERMINAL * termp)
     37222+NCURSES_SP_NAME(set_curterm) (NCURSES_SP_DCLx TERMINAL * termp)
     37223 {
     37224     TERMINAL *oldterm;
     37225 
     37226@@ -64,18 +82,27 @@
     37227 
     37228     _nc_lock_global(curses);
    3581537229     oldterm = cur_term;
    35816      if (SP)
    35817         SP->_term = termp;
     37230-    if (SP)
     37231-       SP->_term = termp;
    3581837232-#if BROKEN_LINKER || USE_REENTRANT
     37233-    _nc_prescreen._cur_term = termp;
     37234-#else
     37235+    if (SP_PARM)
     37236+       SP_PARM->_term = termp;
    3581937237+#if BROKEN_LINKER && !USE_REENTRANT
    35820 +    cur_term = termp;
    35821 +#elif BROKEN_LINKER || USE_REENTRANT
    35822      _nc_prescreen._cur_term = termp;
    35823  #else
    3582437238     cur_term = termp;
    35825 @@ -84,7 +88,7 @@
     37239+#else
     37240+    CurTerm = termp;
     37241 #endif
     37242     if (termp != 0) {
     37243+#ifdef USE_TERM_DRIVER
     37244+       TERMINAL_CONTROL_BLOCK *TCB = (TERMINAL_CONTROL_BLOCK *) termp;
     37245+       ospeed = _nc_ospeed(termp->_baudrate);
     37246+       if (TCB->drv->isTerminfo && termp->type.Strings) {
     37247+           PC = (char) ((pad_char != NULL) ? pad_char[0] : 0);
     37248+       }
     37249+       TCB->csp = SP_PARM;
     37250+#else
     37251        ospeed = _nc_ospeed(termp->_baudrate);
     37252        if (termp->type.Strings) {
     37253            PC = (char) ((pad_char != NULL) ? pad_char[0] : 0);
     37254        }
     37255+#endif
     37256     }
     37257     _nc_unlock_global(curses);
     37258 
     37259@@ -83,23 +110,65 @@
     37260     return (oldterm);
    3582637261 }
    3582737262 
     37263+#if NCURSES_SP_FUNCS
     37264+NCURSES_EXPORT(TERMINAL *)
     37265+set_curterm(TERMINAL * termp)
     37266+{
     37267+    return NCURSES_SP_NAME(set_curterm) (CURRENT_SCREEN, termp);
     37268+}
     37269+#endif
     37270+
    3582837271 NCURSES_EXPORT(int)
    3582937272-del_curterm(TERMINAL * termp)
     
    3583237275     int rc = ERR;
    3583337276 
    35834 @@ -94,6 +98,10 @@
     37277-    T((T_CALLED("del_curterm(%p)"), termp));
     37278+    T((T_CALLED("del_curterm(%p, %p)"), SP_PARM, termp));
     37279 
     37280-    _nc_lock_global(curses);
    3583537281     if (termp != 0) {
     37282+#ifdef USE_TERM_DRIVER
     37283+       TERMINAL_CONTROL_BLOCK *TCB = (TERMINAL_CONTROL_BLOCK *) termp;
     37284+#endif
     37285+       TERMINAL *cur = (
     37286+#if BROKEN_LINKER && !USE_REENTRANT
     37287+                           cur_term
     37288+#elif BROKEN_LINKER || USE_REENTRANT
     37289+                           NCURSES_SP_NAME(_nc_get_cur_term) (NCURSES_SP_ARG)
     37290+#else
     37291+                           cur_term
     37292+#endif
     37293+       );
     37294+
    3583637295        _nc_free_termtype(&(termp->type));
     37296+       if (termp == cur)
     37297+           NCURSES_SP_NAME(set_curterm) (NCURSES_SP_ARGx 0);
     37298+
    3583737299        FreeIfNeeded(termp->_termname);
    3583837300+#if USE_HOME_TERMINFO
     
    3584037302+           FreeAndNull(_nc_globals.home_terminfo);
    3584137303+#endif
     37304+#ifdef USE_TERM_DRIVER
     37305+       if (TCB->drv)
     37306+           TCB->drv->release(TCB);
     37307+#endif
    3584237308        free(termp);
    35843         if (termp == cur_term)
    35844             set_curterm(0);
    35845 @@ -103,3 +111,13 @@
    35846  
    35847      returnCode(rc);
    35848  }
     37309-       if (termp == cur_term)
     37310-           set_curterm(0);
     37311+
     37312        rc = OK;
     37313     }
     37314+    returnCode(rc);
     37315+}
    3584937316+
    3585037317+#if NCURSES_SP_FUNCS
     
    3585337320+{
    3585437321+    int rc = ERR;
     37322+
     37323+    _nc_lock_global(curses);
    3585537324+    rc = NCURSES_SP_NAME(del_curterm) (CURRENT_SCREEN, termp);
     37325     _nc_unlock_global(curses);
     37326 
     37327-    returnCode(rc);
    3585637328+    return (rc);
    35857 +}
     37329 }
    3585837330+#endif
    3585937331diff -Naur ncurses-5.7.orig/ncurses/tinfo/lib_data.c ncurses-5.7/ncurses/tinfo/lib_data.c
    3586037332--- ncurses-5.7.orig/ncurses/tinfo/lib_data.c   2008-08-23 15:16:15.000000000 -0700
    35861 +++ ncurses-5.7/ncurses/tinfo/lib_data.c        2009-07-19 15:04:09.000000000 -0700
     37333+++ ncurses-5.7/ncurses/tinfo/lib_data.c        2009-09-12 08:51:47.000000000 -0700
    3586237334@@ -1,5 +1,5 @@
    3586337335 /****************************************************************************
     
    3598937461diff -Naur ncurses-5.7.orig/ncurses/tinfo/lib_has_cap.c ncurses-5.7/ncurses/tinfo/lib_has_cap.c
    3599037462--- ncurses-5.7.orig/ncurses/tinfo/lib_has_cap.c        2003-10-25 12:43:55.000000000 -0700
    35991 +++ ncurses-5.7/ncurses/tinfo/lib_has_cap.c     2009-07-19 15:03:59.000000000 -0700
     37463+++ ncurses-5.7/ncurses/tinfo/lib_has_cap.c     2009-09-12 08:51:37.000000000 -0700
    3599237464@@ -1,5 +1,5 @@
    3599337465 /****************************************************************************
     
    3607237544diff -Naur ncurses-5.7.orig/ncurses/tinfo/lib_kernel.c ncurses-5.7/ncurses/tinfo/lib_kernel.c
    3607337545--- ncurses-5.7.orig/ncurses/tinfo/lib_kernel.c 2004-05-08 10:11:21.000000000 -0700
    36074 +++ ncurses-5.7/ncurses/tinfo/lib_kernel.c      2009-07-19 15:04:06.000000000 -0700
     37546+++ ncurses-5.7/ncurses/tinfo/lib_kernel.c      2009-09-12 08:51:43.000000000 -0700
    3607537547@@ -1,5 +1,5 @@
    3607637548 /****************************************************************************
     
    3622737699diff -Naur ncurses-5.7.orig/ncurses/tinfo/lib_longname.c ncurses-5.7/ncurses/tinfo/lib_longname.c
    3622837700--- ncurses-5.7.orig/ncurses/tinfo/lib_longname.c       2000-12-09 18:55:07.000000000 -0800
    36229 +++ ncurses-5.7/ncurses/tinfo/lib_longname.c    2009-07-19 15:03:59.000000000 -0700
     37701+++ ncurses-5.7/ncurses/tinfo/lib_longname.c    2009-09-12 08:51:37.000000000 -0700
    3623037702@@ -1,5 +1,5 @@
    3623137703 /****************************************************************************
     
    3630037772diff -Naur ncurses-5.7.orig/ncurses/tinfo/lib_napms.c ncurses-5.7/ncurses/tinfo/lib_napms.c
    3630137773--- ncurses-5.7.orig/ncurses/tinfo/lib_napms.c  2008-05-03 14:34:13.000000000 -0700
    36302 +++ ncurses-5.7/ncurses/tinfo/lib_napms.c       2009-07-19 15:04:06.000000000 -0700
     37774+++ ncurses-5.7/ncurses/tinfo/lib_napms.c       2009-09-12 08:51:43.000000000 -0700
    3630337775@@ -1,5 +1,5 @@
    3630437776 /****************************************************************************
     
    3635437826diff -Naur ncurses-5.7.orig/ncurses/tinfo/lib_options.c ncurses-5.7/ncurses/tinfo/lib_options.c
    3635537827--- ncurses-5.7.orig/ncurses/tinfo/lib_options.c        2008-08-16 14:20:48.000000000 -0700
    36356 +++ ncurses-5.7/ncurses/tinfo/lib_options.c     2009-07-19 15:04:13.000000000 -0700
     37828+++ ncurses-5.7/ncurses/tinfo/lib_options.c     2009-09-12 08:52:05.000000000 -0700
    3635737829@@ -1,5 +1,5 @@
    3635837830 /****************************************************************************
     
    3637037842 
    3637137843 /*
    36372 @@ -43,14 +44,20 @@
    36373  
    36374  #include <term.h>
    36375  
     37844@@ -41,23 +42,28 @@
     37845 
     37846 #include <curses.priv.h>
     37847 
     37848-#include <term.h>
     37849-
    3637637850-MODULE_ID("$Id: lib_options.c,v 1.58 2008/08/16 21:20:48 Werner.Fink Exp $")
    3637737851+#ifndef CUR
    3637837852+#define CUR SP_TERMTYPE
    3637937853+#endif
    36380 +
    36381 +MODULE_ID("$Id: lib_options.c,v 1.65 2009/07/04 18:14:31 tom Exp $")
    3638237854 
    3638337855-static int _nc_curs_set(SCREEN *, int);
    36384  static int _nc_meta(SCREEN *, bool);
     37856-static int _nc_meta(SCREEN *, bool);
     37857+MODULE_ID("$Id: lib_options.c,v 1.70 2009/08/16 14:16:38 tom Exp $")
    3638537858 
    3638637859 NCURSES_EXPORT(int)
    3638737860 idlok(WINDOW *win, bool flag)
    3638837861 {
    36389 +#if NCURSES_SP_FUNCS
    36390 +    SCREEN *sp = CURRENT_SCREEN;
    36391 +#endif
     37862+    int res = ERR;
    3639237863     T((T_CALLED("idlok(%p,%d)"), win, flag));
    3639337864 
    3639437865     if (win) {
    36395 @@ -63,6 +70,9 @@
     37866-       _nc_idlok = win->_idlok = (flag && (has_il() || change_scroll_region));
     37867-       returnCode(OK);
     37868-    } else
     37869-       returnCode(ERR);
     37870+       SCREEN *sp = _nc_screen_of(win);
     37871+       if (sp && IsTermInfo(sp)) {
     37872+           sp->_nc_sp_idlok =
     37873+               win->_idlok = (flag && (NCURSES_SP_NAME(has_il) (NCURSES_SP_ARG)
     37874+                                       || change_scroll_region));
     37875+           res = OK;
     37876+       }
     37877+    }
     37878+    returnCode(res);
     37879 }
     37880 
    3639637881 NCURSES_EXPORT(void)
    36397  idcok(WINDOW *win, bool flag)
     37882@@ -65,25 +71,34 @@
    3639837883 {
    36399 +#if NCURSES_SP_FUNCS
    36400 +    SCREEN *sp = CURRENT_SCREEN;
    36401 +#endif
    3640237884     T((T_CALLED("idcok(%p,%d)"), win, flag));
    3640337885 
    36404      if (win)
    36405 @@ -72,18 +82,26 @@
     37886-    if (win)
     37887-       _nc_idcok = win->_idcok = (flag && has_ic());
     37888-
     37889+    if (win) {
     37890+       SCREEN *sp = _nc_screen_of(win);
     37891+       sp->_nc_sp_idcok = win->_idcok = (flag && NCURSES_SP_NAME(has_ic) (NCURSES_SP_ARG));
     37892+    }
     37893     returnVoid;
    3640637894 }
    3640737895 
     
    3641037898+NCURSES_SP_NAME(halfdelay) (NCURSES_SP_DCLx int t)
    3641137899 {
    36412      T((T_CALLED("halfdelay(%d)"), t));
     37900-    T((T_CALLED("halfdelay(%d)"), t));
     37901+    T((T_CALLED("halfdelay(%p,%d)"), SP_PARM, t));
    3641337902 
    3641437903-    if (t < 1 || t > 255 || SP == 0)
    36415 +    if (t < 1 || t > 255 || SP_PARM == 0)
     37904+    if (t < 1 || t > 255 || !IsValidTIScreen(SP_PARM))
    3641637905        returnCode(ERR);
    3641737906 
    36418      cbreak();
     37907-    cbreak();
    3641937908-    SP->_cbreak = t + 1;
     37909+    NCURSES_SP_NAME(cbreak) (NCURSES_SP_ARG);
    3642037910+    SP_PARM->_cbreak = t + 1;
    3642137911     returnCode(OK);
     
    3643337923 nodelay(WINDOW *win, bool flag)
    3643437924 {
    36435 @@ -148,27 +166,64 @@
     37925@@ -129,7 +144,7 @@
     37926 
     37927     if (win) {
     37928        win->_use_keypad = flag;
     37929-       returnCode(_nc_keypad(SP, flag));
     37930+       returnCode(_nc_keypad(_nc_screen_of(win), flag));
     37931     } else
     37932        returnCode(ERR);
     37933 }
     37934@@ -137,38 +152,106 @@
     37935 NCURSES_EXPORT(int)
     37936 meta(WINDOW *win GCC_UNUSED, bool flag)
     37937 {
     37938-    int result;
     37939+    int result = ERR;
     37940+    SCREEN *sp = (win == 0) ? CURRENT_SCREEN : _nc_screen_of(win);
     37941 
     37942     /* Ok, we stay relaxed and don't signal an error if win is NULL */
     37943     T((T_CALLED("meta(%p,%d)"), win, flag));
     37944-    result = _nc_meta(SP, flag);
     37945+
     37946+    /* Ok, we stay relaxed and don't signal an error if win is NULL */
     37947+
     37948+    if (sp != 0) {
     37949+       sp->_use_meta = flag;
     37950+#ifdef USE_TERM_DRIVER
     37951+       if (IsTermInfo(sp)) {
     37952+           if (flag) {
     37953+               NCURSES_SP_NAME(_nc_putp) (NCURSES_SP_ARGx "meta_on", meta_on);
     37954+           } else {
     37955+               NCURSES_SP_NAME(_nc_putp) (NCURSES_SP_ARGx "meta_off", meta_off);
     37956+           }
     37957+       }
     37958+#else
     37959+       if (flag) {
     37960+           NCURSES_SP_NAME(_nc_putp) (NCURSES_SP_ARGx "meta_on", meta_on);
     37961+       } else {
     37962+           NCURSES_SP_NAME(_nc_putp) (NCURSES_SP_ARGx "meta_off", meta_off);
     37963+       }
     37964+#endif
     37965+       result = OK;
     37966+    }
     37967     returnCode(result);
     37968 }
     37969 
    3643637970 /* curs_set() moved here to narrow the kernel interface */
    3643737971 
     
    3644137975 {
    3644237976-    int result;
    36443 +    int result = ERR;
    36444 +
     37977+    int code = ERR;
    3644537978+    T((T_CALLED("curs_set(%p,%d)"), SP_PARM, vis));
     37979 
     37980-    T((T_CALLED("curs_set(%d)"), vis));
     37981-    result = _nc_curs_set(SP, vis);
     37982-    returnCode(result);
    3644637983+    if (SP_PARM != 0 && vis >= 0 && vis <= 2) {
    3644737984+       int cursor = SP_PARM->_cursor;
    36448  
    36449 -    T((T_CALLED("curs_set(%d)"), vis));
    36450 -    result = _nc_curs_set(SP, vis);
     37985+       bool bBuiltIn = !IsTermInfo(SP_PARM);
    3645137986+       if (vis == cursor) {
    36452 +           result = cursor;
     37987+           code = cursor;
    3645337988+       } else {
    36454 +           switch (vis) {
    36455 +           case 2:
    36456 +               result = _nc_putp_flush("cursor_visible", cursor_visible);
    36457 +               break;
    36458 +           case 1:
    36459 +               result = _nc_putp_flush("cursor_normal", cursor_normal);
    36460 +               break;
    36461 +           case 0:
    36462 +               result = _nc_putp_flush("cursor_invisible", cursor_invisible);
    36463 +               break;
    36464 +           }
    36465 +           if (result != ERR)
    36466 +               result = (cursor == -1 ? 1 : cursor);
     37989+           if (!bBuiltIn) {
     37990+               switch (vis) {
     37991+               case 2:
     37992+                   code = NCURSES_SP_NAME(_nc_putp_flush) (NCURSES_SP_ARGx
     37993+                                                           "cursor_visible",
     37994+                                                           cursor_visible);
     37995+                   break;
     37996+               case 1:
     37997+                   code = NCURSES_SP_NAME(_nc_putp_flush) (NCURSES_SP_ARGx
     37998+                                                           "cursor_normal",
     37999+                                                           cursor_normal);
     38000+                   break;
     38001+               case 0:
     38002+                   code = NCURSES_SP_NAME(_nc_putp_flush) (NCURSES_SP_ARGx
     38003+                                                           "cursor_invisible",
     38004+                                                           cursor_invisible);
     38005+                   break;
     38006+               }
     38007+           } else
     38008+               code = ERR;
     38009+           if (code != ERR)
     38010+               code = (cursor == -1 ? 1 : cursor);
    3646738011+           SP_PARM->_cursor = vis;
    3646838012+       }
    3646938013+    }
    36470      returnCode(result);
     38014+    returnCode(code);
    3647138015 }
    3647238016 
     
    3647538019-typeahead(int fd)
    3647638020+curs_set(int vis)
    36477 +{
     38021 {
     38022-    T((T_CALLED("typeahead(%d)"), fd));
     38023-    if (SP != 0) {
     38024-       SP->_checkfd = fd;
    3647838025+    return (NCURSES_SP_NAME(curs_set) (CURRENT_SCREEN, vis));
    3647938026+}
     
    3648238029+NCURSES_EXPORT(int)
    3648338030+NCURSES_SP_NAME(typeahead) (NCURSES_SP_DCLx int fd)
    36484  {
    36485      T((T_CALLED("typeahead(%d)"), fd));
    36486 -    if (SP != 0) {
    36487 -       SP->_checkfd = fd;
    36488 +    if (SP_PARM != 0) {
     38031+{
     38032+    T((T_CALLED("typeahead(%p, %d)"), SP_PARM, fd));
     38033+    if (IsValidTIScreen(SP_PARM)) {
    3648938034+       SP_PARM->_checkfd = fd;
    3649038035        returnCode(OK);
     
    3650538050 **      has_key()
    3650638051 **
    36507 @@ -190,11 +245,19 @@
     38052@@ -189,42 +272,49 @@
     38053                || has_key_internal(keycode, tp->sibling));
    3650838054 }
    3650938055 
    36510  NCURSES_EXPORT(int)
     38056+#ifdef USE_TERM_DRIVER
     38057+NCURSES_EXPORT(int)
     38058+TINFO_HAS_KEY(SCREEN *sp, int keycode)
     38059+{
     38060+    return IsValidTIScreen(sp) ?
     38061+       has_key_internal(keycode, sp->_keytry) : 0;
     38062+}
     38063+#else
     38064+NCURSES_EXPORT(int)
    3651138065+NCURSES_SP_NAME(has_key) (NCURSES_SP_DCLx int keycode)
    3651238066+{
     
    3651638070+
    3651738071+#if NCURSES_SP_FUNCS
    36518 +NCURSES_EXPORT(int)
     38072 NCURSES_EXPORT(int)
    3651938073 has_key(int keycode)
    3652038074 {
     
    3652438078 }
    3652538079+#endif
     38080+#endif
    3652638081 #endif /* NCURSES_EXT_FUNCS */
    3652738082 
    36528  /*
    36529 @@ -202,29 +265,26 @@
    36530   * than cur_term.
    36531   */
    36532  #undef CUR
     38083-/*
     38084- * Internal entrypoints use SCREEN* parameter to obtain capabilities rather
     38085- * than cur_term.
     38086- */
     38087-#undef CUR
    3653338088-#define CUR (sp->_term)->type.
    36534 +#define CUR SP_TERMTYPE
    36535  
     38089-
    3653638090-static int
    3653738091-_nc_putp(const char *name GCC_UNUSED, const char *value)
     
    3654538099-       TPUTS_TRACE(name);
    3654638100-       rc = putp(value);
    36547 +    int rc = _nc_putp(name, value);
     38101+    int rc = NCURSES_SP_NAME(_nc_putp) (NCURSES_SP_ARGx name, value);
    3654838102+    if (rc != ERR) {
    3654938103+       _nc_flush();
     
    3655338107 
    3655438108-static int
    36555 +#if NCURSES_SP_FUNCS
     38109+#if 0 && NCURSES_SP_FUNCS
    3655638110+NCURSES_EXPORT(int)
    3655738111 _nc_putp_flush(const char *name, const char *value)
     
    3656838122 /* Turn the keypad on/off
    3656938123  *
    36570 @@ -245,12 +305,12 @@
     38124@@ -245,12 +335,12 @@
    3657138125         * has wgetch() reading in more than one thread.  putp() and below
    3657238126         * may use SP explicitly.
     
    3658338137            rc = _nc_keypad(sp, flag);
    3658438138            _nc_set_screen(save_sp);
    36585 @@ -276,45 +336,14 @@
     38139@@ -258,10 +348,19 @@
     38140        } else
     38141 #endif
     38142        {
     38143+#ifdef USE_TERM_DRIVER
     38144+           rc = CallDriver_1(sp, kpad, flag);
     38145+           if (rc == OK)
     38146+               sp->_keypad_on = flag;
     38147+#else
     38148            if (flag) {
     38149-               (void) _nc_putp_flush("keypad_xmit", keypad_xmit);
     38150+               (void) NCURSES_SP_NAME(_nc_putp_flush) (NCURSES_SP_ARGx
     38151+                                                       "keypad_xmit",
     38152+                                                       keypad_xmit);
     38153            } else if (!flag && keypad_local) {
     38154-               (void) _nc_putp_flush("keypad_local", keypad_local);
     38155+               (void) NCURSES_SP_NAME(_nc_putp_flush) (NCURSES_SP_ARGx
     38156+                                                       "keypad_local",
     38157+                                                       keypad_local);
     38158            }
     38159 
     38160            if (flag && !sp->_tried) {
     38161@@ -270,58 +369,8 @@
     38162            }
     38163            sp->_keypad_on = flag;
     38164            rc = OK;
     38165+#endif
     38166        }
     38167     }
     38168     return (rc);
    3658638169 }
    36587  
    36588  static int
     38170-
     38171-static int
    3658938172-_nc_curs_set(SCREEN *sp, int vis)
    3659038173-{
     
    3661838201-
    3661938202-static int
    36620  _nc_meta(SCREEN *sp, bool flag)
    36621  {
    36622      int result = ERR;
    36623  
    36624      /* Ok, we stay relaxed and don't signal an error if win is NULL */
    36625  
     38203-_nc_meta(SCREEN *sp, bool flag)
     38204-{
     38205-    int result = ERR;
     38206-
     38207-    /* Ok, we stay relaxed and don't signal an error if win is NULL */
     38208-
    3662638209-    if (SP != 0) {
    3662738210-       SP->_use_meta = flag;
    36628 +    if (sp != 0) {
    36629 +       sp->_use_meta = flag;
    36630  
    36631         if (flag) {
    36632             _nc_putp("meta_on", meta_on);
     38211-
     38212-       if (flag) {
     38213-           _nc_putp("meta_on", meta_on);
     38214-       } else {
     38215-           _nc_putp("meta_off", meta_off);
     38216-       }
     38217-       result = OK;
     38218-    }
     38219-    return result;
     38220-}
    3663338221diff -Naur ncurses-5.7.orig/ncurses/tinfo/lib_print.c ncurses-5.7/ncurses/tinfo/lib_print.c
    3663438222--- ncurses-5.7.orig/ncurses/tinfo/lib_print.c  2006-11-25 16:26:34.000000000 -0800
    36635 +++ ncurses-5.7/ncurses/tinfo/lib_print.c       2009-07-19 15:04:06.000000000 -0700
     38223+++ ncurses-5.7/ncurses/tinfo/lib_print.c       2009-09-12 08:51:43.000000000 -0700
    3663638224@@ -1,5 +1,5 @@
    3663738225 /****************************************************************************
     
    3670238290diff -Naur ncurses-5.7.orig/ncurses/tinfo/lib_raw.c ncurses-5.7/ncurses/tinfo/lib_raw.c
    3670338291--- ncurses-5.7.orig/ncurses/tinfo/lib_raw.c    2007-09-29 14:50:22.000000000 -0700
    36704 +++ ncurses-5.7/ncurses/tinfo/lib_raw.c 2009-07-19 15:02:20.000000000 -0700
     38292+++ ncurses-5.7/ncurses/tinfo/lib_raw.c 2009-09-12 08:51:59.000000000 -0700
    3670538293@@ -1,5 +1,5 @@
    3670638294 /****************************************************************************
    3670738295- * Copyright (c) 1998-2002,2007 Free Software Foundation, Inc.              *
    36708 + * Copyright (c) 1998-2007,2009 Free Software Foundation, Inc.              *
     38296+ * Copyright (c) 1998-2008,2009 Free Software Foundation, Inc.              *
    3670938297  *                                                                          *
    3671038298  * Permission is hereby granted, free of charge, to any person obtaining a  *
     
    3672038308 
    3672138309 /*
    36722 @@ -49,7 +50,7 @@
     38310@@ -47,9 +48,8 @@
     38311  */
     38312 
    3672338313 #include <curses.priv.h>
    36724  #include <term.h>              /* cur_term */
     38314-#include <term.h>              /* cur_term */
    3672538315 
    3672638316-MODULE_ID("$Id: lib_raw.c,v 1.14 2007/09/29 21:50:22 tom Exp $")
    36727 +MODULE_ID("$Id: lib_raw.c,v 1.15 2009/02/15 00:49:02 tom Exp $")
     38317+MODULE_ID("$Id: lib_raw.c,v 1.17 2009/08/01 23:11:02 tom Exp $")
    3672838318 
    3672938319 #if SVR4_TERMIO && !defined(_POSIX_SOURCE)
    3673038320 #define _POSIX_SOURCE
    36731 @@ -61,7 +62,7 @@
     38321@@ -61,7 +61,7 @@
    3673238322 
    3673338323 #ifdef __EMX__
     
    3673838328 #define _nc_setmode(mode)      /* nothing */
    3673938329 #endif
    36740 @@ -77,13 +78,13 @@
     38330@@ -77,19 +77,19 @@
    3674138331 #endif /* TRACE */
    3674238332 
     
    3674638336 {
    3674738337     int result = ERR;
    36748  
    36749      T((T_CALLED("raw()")));
    36750  
     38338+    TERMINAL *termp;
     38339 
     38340-    T((T_CALLED("raw()")));
     38341-
    3675138342-    if (SP != 0 && cur_term != 0) {
    36752 +    if (SP_PARM != 0 && cur_term != 0) {
     38343+    T((T_CALLED("raw(%p)"), SP_PARM));
     38344+    if ((termp = TerminalOf(SP_PARM)) != 0) {
    3675338345        TTY buf;
    3675438346 
    3675538347        BEFORE("raw");
    36756 @@ -99,8 +100,8 @@
     38348        _nc_setmode(O_BINARY);
     38349 
     38350-       buf = cur_term->Nttyb;
     38351+       buf = termp->Nttyb;
     38352 #ifdef TERMIOS
     38353        buf.c_lflag &= ~(ICANON | ISIG | IEXTEN);
     38354        buf.c_iflag &= ~(COOKED_INPUT);
     38355@@ -98,30 +98,39 @@
     38356 #else
    3675738357        buf.sg_flags |= RAW;
    3675838358 #endif
    36759         if ((result = _nc_set_tty_mode(&buf)) == OK) {
     38359-       if ((result = _nc_set_tty_mode(&buf)) == OK) {
    3676038360-           SP->_raw = TRUE;
    3676138361-           SP->_cbreak = 1;
     38362-           cur_term->Nttyb = buf;
     38363+       result = NCURSES_SP_NAME(_nc_set_tty_mode) (NCURSES_SP_ARGx &buf);
     38364+       if (result == OK) {
    3676238365+           SP_PARM->_raw = TRUE;
    3676338366+           SP_PARM->_cbreak = 1;
    36764             cur_term->Nttyb = buf;
     38367+           termp->Nttyb = buf;
    3676538368        }
    3676638369        AFTER("raw");
    36767 @@ -108,14 +109,22 @@
     38370     }
    3676838371     returnCode(result);
    3676938372 }
     
    3677338376-cbreak(void)
    3677438377+raw(void)
    36775 +{
     38378 {
     38379-    int result = ERR;
    3677638380+    return NCURSES_SP_NAME(raw) (CURRENT_SCREEN);
    3677738381+}
    3677838382+#endif
    36779 +
     38383 
     38384-    T((T_CALLED("cbreak()")));
    3678038385+NCURSES_EXPORT(int)
    3678138386+NCURSES_SP_NAME(cbreak) (NCURSES_SP_DCL0)
    36782  {
    36783      int result = ERR;
    36784  
    36785      T((T_CALLED("cbreak()")));
     38387+{
     38388+    int result = ERR;
     38389+    TERMINAL *termp;
    3678638390 
    3678738391-    if (SP != 0 && cur_term != 0) {
    36788 +    if (SP_PARM != 0 && cur_term != 0) {
     38392+    T((T_CALLED("cbreak(%p)"), SP_PARM));
     38393+    if ((termp = TerminalOf(SP_PARM)) != 0) {
    3678938394        TTY buf;
    3679038395 
    3679138396        BEFORE("cbreak");
    36792 @@ -132,7 +141,7 @@
     38397        _nc_setmode(O_BINARY);
     38398 
     38399-       buf = cur_term->Nttyb;
     38400+       buf = termp->Nttyb;
     38401 #ifdef TERMIOS
     38402        buf.c_lflag &= ~ICANON;
     38403        buf.c_iflag &= ~ICRNL;
     38404@@ -131,134 +140,172 @@
     38405 #else
    3679338406        buf.sg_flags |= CBREAK;
    3679438407 #endif
    36795         if ((result = _nc_set_tty_mode(&buf)) == OK) {
     38408-       if ((result = _nc_set_tty_mode(&buf)) == OK) {
    3679638409-           SP->_cbreak = 1;
     38410-           cur_term->Nttyb = buf;
     38411+       result = NCURSES_SP_NAME(_nc_set_tty_mode) (NCURSES_SP_ARGx &buf);
     38412+       if (result == OK) {
    3679738413+           SP_PARM->_cbreak = 1;
    36798             cur_term->Nttyb = buf;
     38414+           termp->Nttyb = buf;
    3679938415        }
    3680038416        AFTER("cbreak");
    36801 @@ -140,12 +149,20 @@
     38417     }
    3680238418     returnCode(result);
    3680338419 }
     
    3682038436 {
    3682138437     int result = ERR;
    36822  
    36823 @@ -169,14 +186,22 @@
     38438+    TERMINAL *termp;
     38439 
     38440-    T((T_CALLED("qiflush()")));
     38441-
     38442-    if (cur_term != 0) {
     38443+    T((T_CALLED("qiflush(%p)"), SP_PARM));
     38444+    if ((termp = TerminalOf(SP_PARM)) != 0) {
     38445        TTY buf;
     38446 
     38447        BEFORE("qiflush");
     38448-       buf = cur_term->Nttyb;
     38449+       buf = termp->Nttyb;
     38450 #ifdef TERMIOS
     38451        buf.c_lflag &= ~(NOFLSH);
     38452-       result = _nc_set_tty_mode(&buf);
     38453+       result = NCURSES_SP_NAME(_nc_set_tty_mode) (NCURSES_SP_ARGx &buf);
     38454 #else
     38455        /* FIXME */
     38456 #endif
     38457        if (result == OK)
     38458-           cur_term->Nttyb = buf;
     38459+           termp->Nttyb = buf;
     38460        AFTER("qiflush");
     38461     }
    3682438462     returnVoid;
    3682538463 }
     
    3683838476 {
    3683938477     int result = ERR;
    36840  
    36841      T((T_CALLED("noraw()")));
    36842  
     38478+    TERMINAL *termp;
     38479 
     38480-    T((T_CALLED("noraw()")));
     38481-
    3684338482-    if (SP != 0 && cur_term != 0) {
    36844 +    if (SP_PARM != 0 && cur_term != 0) {
     38483+    T((T_CALLED("noraw(%p)"), SP_PARM));
     38484+    if ((termp = TerminalOf(SP_PARM)) != 0) {
    3684538485        TTY buf;
    3684638486 
    3684738487        BEFORE("noraw");
    36848 @@ -191,8 +216,8 @@
     38488        _nc_setmode(O_TEXT);
     38489 
     38490-       buf = cur_term->Nttyb;
     38491+       buf = termp->Nttyb;
     38492 #ifdef TERMIOS
     38493        buf.c_lflag |= ISIG | ICANON |
     38494-           (cur_term->Ottyb.c_lflag & IEXTEN);
     38495+           (termp->Ottyb.c_lflag & IEXTEN);
     38496        buf.c_iflag |= COOKED_INPUT;
     38497 #else
    3684938498        buf.sg_flags &= ~(RAW | CBREAK);
    3685038499 #endif
    36851         if ((result = _nc_set_tty_mode(&buf)) == OK) {
     38500-       if ((result = _nc_set_tty_mode(&buf)) == OK) {
    3685238501-           SP->_raw = FALSE;
    3685338502-           SP->_cbreak = 0;
     38503-           cur_term->Nttyb = buf;
     38504+       result = NCURSES_SP_NAME(_nc_set_tty_mode) (NCURSES_SP_ARGx &buf);
     38505+       if (result == OK) {
    3685438506+           SP_PARM->_raw = FALSE;
    3685538507+           SP_PARM->_cbreak = 0;
    36856             cur_term->Nttyb = buf;
     38508+           termp->Nttyb = buf;
    3685738509        }
    3685838510        AFTER("noraw");
    36859 @@ -200,14 +225,22 @@
     38511     }
    3686038512     returnCode(result);
    3686138513 }
     
    3686538517-nocbreak(void)
    3686638518+noraw(void)
    36867 +{
     38519 {
     38520-    int result = ERR;
    3686838521+    return NCURSES_SP_NAME(noraw) (CURRENT_SCREEN);
    3686938522+}
    3687038523+#endif
    36871 +
     38524 
     38525-    T((T_CALLED("nocbreak()")));
    3687238526+NCURSES_EXPORT(int)
    3687338527+NCURSES_SP_NAME(nocbreak) (NCURSES_SP_DCL0)
    36874  {
    36875      int result = ERR;
    36876  
    36877      T((T_CALLED("nocbreak()")));
     38528+{
     38529+    int result = ERR;
     38530+    TERMINAL *termp;
    3687838531 
    3687938532-    if (SP != 0 && cur_term != 0) {
    36880 +    if (SP_PARM != 0 && cur_term != 0) {
     38533+    T((T_CALLED("nocbreak(%p)"), SP_PARM));
     38534+    if ((termp = TerminalOf(SP_PARM)) != 0) {
    3688138535        TTY buf;
    3688238536 
    3688338537        BEFORE("nocbreak");
    36884 @@ -221,7 +254,7 @@
     38538        _nc_setmode(O_TEXT);
     38539 
     38540-       buf = cur_term->Nttyb;
     38541+       buf = termp->Nttyb;
     38542 #ifdef TERMIOS
     38543        buf.c_lflag |= ICANON;
     38544        buf.c_iflag |= ICRNL;
     38545 #else
    3688538546        buf.sg_flags &= ~CBREAK;
    3688638547 #endif
    36887         if ((result = _nc_set_tty_mode(&buf)) == OK) {
     38548-       if ((result = _nc_set_tty_mode(&buf)) == OK) {
    3688838549-           SP->_cbreak = 0;
     38550-           cur_term->Nttyb = buf;
     38551+       result = NCURSES_SP_NAME(_nc_set_tty_mode) (NCURSES_SP_ARGx &buf);
     38552+       if (result == OK) {
    3688938553+           SP_PARM->_cbreak = 0;
    36890             cur_term->Nttyb = buf;
     38554+           termp->Nttyb = buf;
    3689138555        }
    3689238556        AFTER("nocbreak");
    36893 @@ -229,12 +262,20 @@
     38557     }
    3689438558     returnCode(result);
    3689538559 }
    3689638560 
     38561-/*
     38562- * Note:
     38563- * this implementation may be wrong.  See the comment under intrflush().
     38564- */
    3689738565+#if NCURSES_SP_FUNCS
    3689838566+NCURSES_EXPORT(int)
     
    3690338571+#endif
    3690438572+
    36905  /*
    36906   * Note:
    36907   * this implementation may be wrong.  See the comment under intrflush().
    36908   */
    3690938573 NCURSES_EXPORT(void)
    3691038574-noqiflush(void)
     
    3691238576 {
    3691338577     int result = ERR;
    36914  
    36915 @@ -259,6 +300,14 @@
     38578+    TERMINAL *termp;
     38579 
     38580-    T((T_CALLED("noqiflush()")));
     38581-
     38582-    if (cur_term != 0) {
     38583+    T((T_CALLED("noqiflush(%p)"), SP_PARM));
     38584+    if ((termp = TerminalOf(SP_PARM)) != 0) {
     38585        TTY buf;
     38586 
     38587        BEFORE("noqiflush");
     38588-       buf = cur_term->Nttyb;
     38589+       buf = termp->Nttyb;
     38590 #ifdef TERMIOS
     38591        buf.c_lflag |= NOFLSH;
     38592-       result = _nc_set_tty_mode(&buf);
     38593+       result = NCURSES_SP_NAME(_nc_set_tty_mode) (NCURSES_SP_ARGx &buf);
     38594 #else
     38595        /* FIXME */
     38596 #endif
     38597-       if (result == OK) {
     38598-           cur_term->Nttyb = buf;
     38599-       }
     38600+       if (result == OK)
     38601+           termp->Nttyb = buf;
     38602        AFTER("noqiflush");
     38603     }
    3691638604     returnVoid;
    3691738605 }
     
    3692838616  * This call does the same thing as the qiflush()/noqiflush() pair.  We know
    3692938617  * for certain that SVr3 intrflush() tweaks the NOFLSH bit; on the other hand,
    36930 @@ -267,7 +316,7 @@
     38618@@ -267,30 +314,41 @@
    3693138619  * curs_inopts(3x) is too exact to be coincidence.
    3693238620  */
     
    3693638624 {
    3693738625     int result = ERR;
    36938  
    36939 @@ -294,3 +343,11 @@
     38626+    TERMINAL *termp;
     38627 
     38628-    T((T_CALLED("intrflush(%d)"), flag));
     38629+    T((T_CALLED("intrflush(%p,%d)"), SP_PARM, flag));
     38630+    if (SP_PARM == 0)
     38631+       returnCode(ERR);
     38632 
     38633-    if (cur_term != 0) {
     38634+    if ((termp = TerminalOf(SP_PARM)) != 0) {
     38635        TTY buf;
     38636 
     38637        BEFORE("intrflush");
     38638-       buf = cur_term->Nttyb;
     38639+       buf = termp->Nttyb;
     38640 #ifdef TERMIOS
     38641        if (flag)
     38642            buf.c_lflag &= ~(NOFLSH);
     38643        else
     38644            buf.c_lflag |= (NOFLSH);
     38645-       result = _nc_set_tty_mode(&buf);
     38646+       result = NCURSES_SP_NAME(_nc_set_tty_mode) (NCURSES_SP_ARGx &buf);
     38647 #else
     38648        /* FIXME */
     38649 #endif
     38650        if (result == OK) {
     38651-           cur_term->Nttyb = buf;
     38652+           termp->Nttyb = buf;
     38653        }
     38654        AFTER("intrflush");
    3694038655     }
    3694138656     returnCode(result);
     
    3695138666diff -Naur ncurses-5.7.orig/ncurses/tinfo/lib_setup.c ncurses-5.7/ncurses/tinfo/lib_setup.c
    3695238667--- ncurses-5.7.orig/ncurses/tinfo/lib_setup.c  2008-08-03 15:42:33.000000000 -0700
    36953 +++ ncurses-5.7/ncurses/tinfo/lib_setup.c       2009-07-19 15:04:06.000000000 -0700
     38668+++ ncurses-5.7/ncurses/tinfo/lib_setup.c       2009-09-12 08:52:09.000000000 -0700
    3695438669@@ -1,5 +1,5 @@
    3695538670 /****************************************************************************
     
    3696738682 
    3696838683 /*
    36969 @@ -53,7 +54,7 @@
    36970  
    36971  #include <term.h>              /* lines, columns, cur_term */
    36972  
     38684@@ -51,9 +52,7 @@
     38685 #include <locale.h>
     38686 #endif
     38687 
     38688-#include <term.h>              /* lines, columns, cur_term */
     38689-
    3697338690-MODULE_ID("$Id: lib_setup.c,v 1.111 2008/08/03 22:42:33 tom Exp $")
    36974 +MODULE_ID("$Id: lib_setup.c,v 1.117 2009/06/06 17:56:31 tom Exp $")
     38691+MODULE_ID("$Id: lib_setup.c,v 1.119 2009/09/05 20:10:02 tom Exp $")
    3697538692 
    3697638693 /****************************************************************************
    3697738694  *
    36978 @@ -116,54 +117,68 @@
    36979      return cur_term ? cur_term->type.term_names : empty;
     38695@@ -109,61 +108,96 @@
     38696  * Wrap global variables in this module.
     38697  */
     38698 #if USE_REENTRANT
     38699+
     38700 NCURSES_EXPORT(char *)
     38701 NCURSES_PUBLIC_VAR(ttytype) (void)
     38702 {
     38703     static char empty[] = "";
     38704-    return cur_term ? cur_term->type.term_names : empty;
     38705+    char *result = empty;
     38706+
     38707+#if NCURSES_SP_FUNCS
     38708+    if (CURRENT_SCREEN) {
     38709+       TERMINAL *termp = TerminalOf(CURRENT_SCREEN);
     38710+       if (termp != 0) {
     38711+           result = termp->type.term_names;
     38712+       }
     38713+    }
     38714+#else
     38715+    if (cur_term != 0) {
     38716+       result = cur_term->type.term_names;
     38717+    }
     38718+#endif
     38719+    return result;
    3698038720 }
     38721+
    3698138722 NCURSES_EXPORT(int *)
    3698238723-_nc_ptr_Lines(void)
     
    3698638727+    return ptrLines(sp);
    3698738728 }
     38729+
    3698838730 NCURSES_EXPORT(int)
    3698938731 NCURSES_PUBLIC_VAR(LINES) (void)
     
    3699238734+    return *_nc_ptr_Lines(CURRENT_SCREEN);
    3699338735 }
     38736+
    3699438737 NCURSES_EXPORT(int *)
    3699538738-_nc_ptr_Cols(void)
     
    3699938742+    return ptrCols(sp);
    3700038743 }
     38744+
    3700138745 NCURSES_EXPORT(int)
    3700238746 NCURSES_PUBLIC_VAR(COLS) (void)
     
    3700538749+    return *_nc_ptr_Cols(CURRENT_SCREEN);
    3700638750+}
     38751+
    3700738752+NCURSES_EXPORT(int *)
    3700838753+_nc_ptr_Tabsize(SCREEN *sp)
     
    3701038755+    return ptrTabsize(sp);
    3701138756 }
     38757+
    3701238758 NCURSES_EXPORT(int)
    3701338759 NCURSES_PUBLIC_VAR(TABSIZE) (void)
     
    3705638802 #if USE_SIGWINCH
    3705738803 /*
    37058 @@ -188,13 +203,25 @@
     38804@@ -188,17 +222,56 @@
    3705938805 #endif
    3706038806 
    3706138807 NCURSES_EXPORT(void)
    37062 -use_env(bool f)
    3706338808+NCURSES_SP_NAME(use_env) (NCURSES_SP_DCLx bool f)
    37064  {
    37065      T((T_CALLED("use_env()")));
    37066 -    _nc_prescreen.use_env = f;
     38809+{
     38810+    T((T_CALLED("use_env(%p,%d)"), SP_PARM, (int) f));
     38811+#if NCURSES_SP_FUNCS
    3706738812+    if (IsPreScreen(SP_PARM)) {
    3706838813+       SP_PARM->_use_env = f;
    37069 +    } else {
    37070 +       _nc_prescreen.use_env = f;
    3707138814+    }
     38815+#else
     38816+    _nc_prescreen.use_env = f;
     38817+#endif
     38818+    returnVoid;
     38819+}
     38820+
     38821+#if NCURSES_SP_FUNCS
     38822+NCURSES_EXPORT(void)
     38823 use_env(bool f)
     38824 {
     38825-    T((T_CALLED("use_env()")));
     38826+    T((T_CALLED("use_env(%d)"), (int) f));
     38827     _nc_prescreen.use_env = f;
    3707238828     returnVoid;
    3707338829 }
    37074  
    37075 +#if NCURSES_SP_FUNCS
    37076 +NCURSES_EXPORT(void)
    37077 +use_env(bool f)
    37078 +{
    37079 +    NCURSES_SP_NAME(use_env) (CURRENT_SCREEN, f);
    37080 +}
    3708138830+#endif
    37082 +
     38831 
    3708338832 NCURSES_EXPORT(void)
    37084  _nc_get_screensize(SCREEN *sp, int *linep, int *colp)
     38833-_nc_get_screensize(SCREEN *sp, int *linep, int *colp)
     38834+_nc_get_screensize(SCREEN *sp,
     38835+#ifdef USE_TERM_DRIVER
     38836+                  TERMINAL * termp,
     38837+#endif
     38838+                  int *linep, int *colp)
    3708538839 /* Obtain lines/columns values from the environment and/or terminfo entry */
    37086 @@ -320,7 +347,7 @@
     38840 {
     38841+#ifdef USE_TERM_DRIVER
     38842+    TERMINAL_CONTROL_BLOCK *TCB;
     38843+    int my_tabsize;
     38844+
     38845+    assert(termp != 0 && linep != 0 && colp != 0);
     38846+    TCB = (TERMINAL_CONTROL_BLOCK *) termp;
     38847+
     38848+    my_tabsize = TCB->info.tabsize;
     38849+    TCB->drv->size(TCB, linep, colp);
     38850+
     38851+#if USE_REENTRANT
     38852+    if (sp != 0) {
     38853+       sp->_TABSIZE = my_tabsize;
     38854+    }
     38855+#else
     38856+    TABSIZE = my_tabsize;
     38857+#endif
     38858+    T(("TABSIZE = %d", my_tabsize));
     38859+#else /* !USE_TERM_DRIVER */
     38860     TERMINAL *termp = cur_term;
     38861     int my_tabsize;
     38862 
     38863@@ -298,19 +371,31 @@
     38864     TABSIZE = my_tabsize;
     38865 #endif
     38866     T(("TABSIZE = %d", TABSIZE));
     38867+#endif /* USE_TERM_DRIVER */
     38868 }
     38869 
     38870 #if USE_SIZECHANGE
     38871 NCURSES_EXPORT(void)
     38872 _nc_update_screensize(SCREEN *sp)
     38873 {
     38874+    int new_lines;
     38875+    int new_cols;
     38876+
     38877+#ifdef USE_TERM_DRIVER
     38878+    int old_lines;
     38879+    int old_cols;
     38880+
     38881+    assert(sp != 0);
     38882+
     38883+    CallDriver_2(sp, getsize, &old_lines, &old_cols);
     38884+
     38885+#else
     38886     TERMINAL *termp = cur_term;
     38887     int old_lines = lines;
     38888-    int new_lines;
     38889     int old_cols = columns;
     38890-    int new_cols;
     38891+#endif
     38892 
     38893-    _nc_get_screensize(sp, &new_lines, &new_cols);
     38894+    TINFO_GET_SIZE(sp, sp->_term, &new_lines, &new_cols);
     38895 
     38896     /*
     38897      * See is_term_resized() and resizeterm().
     38898@@ -320,7 +405,7 @@
    3708738899     if (sp != 0
    3708838900        && sp->_resize != 0) {
     
    3709338905     }
    3709438906 }
    37095 @@ -604,7 +631,7 @@
     38907@@ -348,6 +433,7 @@
     38908                                            exit(EXIT_FAILURE);\
     38909                                        }
     38910 
     38911+#ifndef USE_TERM_DRIVER
     38912 #if USE_DATABASE || USE_TERMCAP
     38913 /*
     38914  * Return 1 if entry found, 0 if not found, -1 if database not accessible,
     38915@@ -407,6 +493,7 @@
     38916        }
     38917     }
     38918 }
     38919+#endif /* !USE_TERM_DRIVER */
     38920 
     38921 /*
     38922  * Find the locale which is in effect.
     38923@@ -486,18 +573,37 @@
     38924     return 0;
     38925 }
     38926 
     38927-/*
     38928- * This entrypoint is called from tgetent() to allow a special case of reusing
     38929- * the same TERMINAL data (see comment).
     38930- */
     38931 NCURSES_EXPORT(int)
     38932-_nc_setupterm(NCURSES_CONST char *tname, int Filedes, int *errret, bool reuse)
     38933+TINFO_SETUP_TERM(TERMINAL ** tp,
     38934+                NCURSES_CONST char *tname,
     38935+                int Filedes,
     38936+                int *errret,
     38937+                bool reuse)
     38938 {
     38939-    TERMINAL *termp;
     38940+#ifdef USE_TERM_DRIVER
     38941+    TERMINAL_CONTROL_BLOCK *TCB = 0;
     38942+#else
     38943     int status;
     38944+#endif
     38945+    TERMINAL *termp;
     38946+    SCREEN *sp = 0;
     38947+    int code = ERR;
     38948 
     38949     START_TRACE();
     38950+
     38951+#ifdef USE_TERM_DRIVER
     38952+    T((T_CALLED("_nc_setupterm_ex(%p,%s,%d,%p)"),
     38953+       tp, _nc_visbuf(tname), Filedes, errret));
     38954+
     38955+    if (tp == 0) {
     38956+       ret_error0(TGETENT_ERR,
     38957+                  "Invalid parameter, internal error.\n");
     38958+    } else
     38959+       termp = *tp;
     38960+#else
     38961+    termp = cur_term;
     38962     T((T_CALLED("setupterm(%s,%d,%p)"), _nc_visbuf(tname), Filedes, errret));
     38963+#endif
     38964 
     38965     if (tname == 0) {
     38966        tname = getenv("TERM");
     38967@@ -538,20 +644,34 @@
     38968      * properly with this feature).
     38969      */
     38970     if (reuse
     38971-       && (termp = cur_term) != 0
     38972+       && (termp != 0)
     38973        && termp->Filedes == Filedes
     38974        && termp->_termname != 0
     38975        && !strcmp(termp->_termname, tname)
     38976        && _nc_name_match(termp->type.term_names, tname, "|")) {
     38977        T(("reusing existing terminal information and mode-settings"));
     38978+       code = OK;
     38979     } else {
     38980-
     38981+#ifdef USE_TERM_DRIVER
     38982+       termp = (TERMINAL *) typeCalloc(TERMINAL_CONTROL_BLOCK, 1);
     38983+#else
     38984        termp = typeCalloc(TERMINAL, 1);
     38985-
     38986+#endif
     38987        if (termp == 0) {
     38988            ret_error0(TGETENT_ERR,
     38989                       "Not enough memory to create terminal structure.\n");
     38990        }
     38991+#ifdef USE_TERM_DRIVER
     38992+       TCB = (TERMINAL_CONTROL_BLOCK *) termp;
     38993+       code = _nc_get_driver(TCB, tname, errret);
     38994+       if (code == OK) {
     38995+           termp->Filedes = Filedes;
     38996+           termp->_termname = strdup(tname);
     38997+       } else {
     38998+           ret_error0(TGETENT_ERR,
     38999+                      "Could not find any driver to handle this terminal.\n");
     39000+       }
     39001+#else
     39002 #if USE_DATABASE || USE_TERMCAP
     39003        status = grab_entry(tname, &termp->type);
     39004 #else
     39005@@ -599,25 +719,57 @@
     39006            def_prog_mode();
     39007            baudrate();
     39008        }
     39009+       code = OK;
     39010+#endif
     39011     }
     39012 
     39013+#ifdef USE_TERM_DRIVER
     39014+    *tp = termp;
     39015+    NCURSES_SP_NAME(set_curterm) (sp, termp);
     39016+    TCB->drv->init(TCB);
     39017+#else
     39018+    sp = SP;
     39019+#endif
     39020+
    3709639021     /*
    3709739022      * We should always check the screensize, just in case.
    3709839023      */
    3709939024-    _nc_get_screensize(SP, ptrLines(), ptrCols());
    37100 +    _nc_get_screensize(SP, ptrLines(SP), ptrCols(SP));
     39025+    TINFO_GET_SIZE(sp, termp, ptrLines(sp), ptrCols(sp));
    3710139026 
    3710239027     if (errret)
    3710339028        *errret = TGETENT_YES;
     39029 
     39030+#ifndef USE_TERM_DRIVER
     39031     if (generic_type) {
     39032        ret_error(TGETENT_NO, "'%s': I need something more specific.\n", tname);
     39033     }
     39034     if (hard_copy) {
     39035        ret_error(TGETENT_YES, "'%s': I can't handle hardcopy terminals.\n", tname);
     39036     }
     39037-    returnCode(OK);
     39038+#endif
     39039+    returnCode(code);
     39040 }
     39041 
     39042+#ifdef USE_TERM_DRIVER
     39043+/*
     39044+ * This entrypoint is called from tgetent() to allow a special case of reusing
     39045+ * the same TERMINAL data (see comment).
     39046+ */
     39047+NCURSES_EXPORT(int)
     39048+_nc_setupterm(NCURSES_CONST char *tname,
     39049+             int Filedes,
     39050+             int *errret,
     39051+             bool reuse)
     39052+{
     39053+    int res;
     39054+    TERMINAL *termp;
     39055+    res = TINFO_SETUP_TERM(&termp, tname, Filedes, errret, reuse);
     39056+    if (ERR != res)
     39057+       NCURSES_SP_NAME(set_curterm) (CURRENT_SCREEN_PRE, termp);
     39058+    return res;
     39059+}
     39060+#endif
     39061+
     39062 /*
     39063  *     setupterm(termname, Filedes, errret)
     39064  *
    3710439065diff -Naur ncurses-5.7.orig/ncurses/tinfo/lib_termcap.c ncurses-5.7/ncurses/tinfo/lib_termcap.c
    3710539066--- ncurses-5.7.orig/ncurses/tinfo/lib_termcap.c        2008-08-16 12:22:55.000000000 -0700
    37106 +++ ncurses-5.7/ncurses/tinfo/lib_termcap.c     2009-07-19 15:04:15.000000000 -0700
     39067+++ ncurses-5.7/ncurses/tinfo/lib_termcap.c     2009-09-12 08:52:09.000000000 -0700
    3710739068@@ -1,5 +1,5 @@
    3710839069 /****************************************************************************
     
    3712939090+#endif
    3713039091+
    37131 +MODULE_ID("$Id: lib_termcap.c,v 1.69 2009/07/11 18:14:21 tom Exp $")
     39092+MODULE_ID("$Id: lib_termcap.c,v 1.70 2009/08/30 17:16:00 tom Exp $")
    3713239093 
    3713339094 NCURSES_EXPORT_VAR(char *) UP = 0;
    3713439095 NCURSES_EXPORT_VAR(char *) BC = 0;
    37135 @@ -76,16 +81,28 @@
     39096@@ -76,16 +81,26 @@
    3713639097  ***************************************************************************/
    3713739098 
     
    3715139112     T((T_CALLED("tgetent()")));
    3715239113 
     39114-    _nc_setupterm((NCURSES_CONST char *) name, STDOUT_FILENO, &errcode, TRUE);
     39115+    TINFO_SETUP_TERM(&termp, (NCURSES_CONST char *) name,
     39116+                    STDOUT_FILENO, &errcode, TRUE);
     39117+
    3715339118+#ifdef USE_TERM_DRIVER
    37154 +    _nc_setupterm_ex(&termp, (NCURSES_CONST char *) name,
    37155 +                    STDOUT_FILENO, &errcode, TRUE);
    37156 +
    3715739119+    if (termp == 0 ||
    3715839120+       !((TERMINAL_CONTROL_BLOCK *) termp)->drv->isTerminfo)
    3715939121+       return (errcode);
    37160 +#else
    37161      _nc_setupterm((NCURSES_CONST char *) name, STDOUT_FILENO, &errcode, TRUE);
    3716239122+#endif
    3716339123 
    3716439124     /*
    3716539125      * In general we cannot tell if the fixed sgr0 is still used by the
    37166 @@ -109,9 +126,9 @@
     39126@@ -109,9 +124,9 @@
    3716739127            /*
    3716839128             * Also free the terminfo data that we loaded (much bigger leak).
     
    3717639136                    if (LAST_TRM == trm)
    3717739137                        LAST_TRM = 0;
    37178 @@ -131,7 +148,7 @@
     39138@@ -131,7 +146,7 @@
    3717939139        }
    3718039140        CacheInx = best;
     
    3718539145 
    3718639146     PC = 0;
    37187 @@ -153,7 +170,7 @@
     39147@@ -153,7 +168,7 @@
    3718839148        if (backspace_if_not_bs != NULL)
    3718939149            BC = backspace_if_not_bs;
     
    3719439154                if (FIX_SGR0 != exit_attribute_mode) {
    3719539155                    free(FIX_SGR0);
    37196 @@ -164,8 +181,8 @@
     39156@@ -164,8 +179,8 @@
    3719739157        LAST_BUF = bufp;
    3719839158        LAST_USE = TRUE;
     
    3720539165 /* LINT_PREPRO
    3720639166 #if 0*/
    37207 @@ -177,6 +194,25 @@
     39167@@ -177,6 +192,25 @@
    3720839168     returnCode(errcode);
    3720939169 }
     
    3723139191  *
    3723239192  * tgetflag(str)
    37233 @@ -187,23 +223,47 @@
     39193@@ -187,24 +221,48 @@
    3723439194  ***************************************************************************/
    3723539195 
     
    3727839238-    returnCode(0);             /* Solaris does this */
    3727939239+    returnCode(result);
    37280 +}
    37281 +
     39240 }
     39241 
    3728239242+#if NCURSES_SP_FUNCS
    3728339243+NCURSES_EXPORT(int)
     
    3728539245+{
    3728639246+    return NCURSES_SP_NAME(tgetflag) (CURRENT_SCREEN, id);
    37287  }
     39247+}
    3728839248+#endif
    37289  
     39249+
    3729039250 /***************************************************************************
    3729139251  *
    37292 @@ -215,25 +275,48 @@
     39252  * tgetnum(str)
     39253@@ -215,25 +273,48 @@
    3729339254  ***************************************************************************/
    3729439255 
     
    3735139312  *
    3735239313  * tgetstr(str, area)
    37353 @@ -244,40 +327,62 @@
     39314@@ -244,40 +325,62 @@
    3735439315  ***************************************************************************/
    3735539316 
     
    3743939400diff -Naur ncurses-5.7.orig/ncurses/tinfo/lib_termname.c ncurses-5.7/ncurses/tinfo/lib_termname.c
    3744039401--- ncurses-5.7.orig/ncurses/tinfo/lib_termname.c       2003-12-27 10:23:01.000000000 -0800
    37441 +++ ncurses-5.7/ncurses/tinfo/lib_termname.c    2009-07-19 15:02:22.000000000 -0700
     39402+++ ncurses-5.7/ncurses/tinfo/lib_termname.c    2009-09-12 08:51:17.000000000 -0700
    3744239403@@ -1,5 +1,5 @@
    3744339404 /****************************************************************************
     
    3748439445diff -Naur ncurses-5.7.orig/ncurses/tinfo/lib_ti.c ncurses-5.7/ncurses/tinfo/lib_ti.c
    3748539446--- ncurses-5.7.orig/ncurses/tinfo/lib_ti.c     2003-05-24 14:10:28.000000000 -0700
    37486 +++ ncurses-5.7/ncurses/tinfo/lib_ti.c  2009-07-19 15:04:15.000000000 -0700
     39447+++ ncurses-5.7/ncurses/tinfo/lib_ti.c  2009-09-12 08:51:57.000000000 -0700
    3748739448@@ -1,5 +1,5 @@
    3748839449 /****************************************************************************
     
    3750039461 
    3750139462 #include <curses.priv.h>
    37502 @@ -36,68 +37,150 @@
     39463@@ -36,68 +37,152 @@
    3750339464 #include <term_entry.h>
    3750439465 #include <tic.h>
    3750539466 
    3750639467-MODULE_ID("$Id: lib_ti.c,v 1.23 2003/05/24 21:10:28 tom Exp $")
    37507 +MODULE_ID("$Id: lib_ti.c,v 1.26 2009/07/11 18:14:21 tom Exp $")
     39468+MODULE_ID("$Id: lib_ti.c,v 1.27 2009/07/28 22:03:36 tom Exp $")
    3750839469+
    3750939470+#if 0
     
    3757039531-tigetnum(NCURSES_CONST char *str)
    3757139532+tigetflag(NCURSES_CONST char *str)
    37572 +{
     39533 {
     39534-    unsigned i;
    3757339535+    return NCURSES_SP_NAME(tigetflag) (CURRENT_SCREEN, str);
    3757439536+}
    3757539537+#endif
    37576 +
     39538 
     39539-    T((T_CALLED("tigetnum(%s)"), str));
    3757739540+NCURSES_EXPORT(int)
    3757839541+NCURSES_SP_NAME(tigetnum) (NCURSES_SP_DCLx NCURSES_CONST char *str)
    37579  {
    37580 -    unsigned i;
     39542+{
    3758139543+    int i, j;
    3758239544+    int result = CANCELLED_NUMERIC;    /* Solaris returns a -1 on error */
    37583  
    37584 -    T((T_CALLED("tigetnum(%s)"), str));
    37585 +    T((T_CALLED("tigetnum(%p, %s)"), SP_PARM, str));
    3758639545 
    3758739546-    if (cur_term != 0) {
     
    3759339552-                   returnCode(ABSENT_NUMERIC);
    3759439553-               returnCode(tp->Numbers[i]);
     39554+    T((T_CALLED("tigetnum(%p, %s)"), SP_PARM, str));
     39555+
    3759539556+    if (HasTInfoTerminal(SP_PARM)) {
    3759639557+       TERMTYPE *tp = &(TerminalOf(SP_PARM)->type);
     
    3761339574        }
    3761439575+#endif
    37615 +       if (j >= 0 && VALID_NUMERIC(tp->Numbers[j]))
    37616 +           result = tp->Numbers[j];
    37617 +       else
    37618 +           result = ABSENT_NUMERIC;
     39576+       if (j >= 0) {
     39577+           if (VALID_NUMERIC(tp->Numbers[j]))
     39578+               result = tp->Numbers[j];
     39579+           else
     39580+               result = ABSENT_NUMERIC;
     39581+       }
    3761939582     }
    3762039583 
     
    3768839651diff -Naur ncurses-5.7.orig/ncurses/tinfo/lib_tparm.c ncurses-5.7/ncurses/tinfo/lib_tparm.c
    3768939652--- ncurses-5.7.orig/ncurses/tinfo/lib_tparm.c  2008-08-16 12:22:55.000000000 -0700
    37690 +++ ncurses-5.7/ncurses/tinfo/lib_tparm.c       2009-07-19 15:02:22.000000000 -0700
     39653+++ ncurses-5.7/ncurses/tinfo/lib_tparm.c       2009-09-12 08:51:17.000000000 -0700
    3769139654@@ -40,10 +40,9 @@
    3769239655 #include <curses.priv.h>
     
    3770339666diff -Naur ncurses-5.7.orig/ncurses/tinfo/lib_tputs.c ncurses-5.7/ncurses/tinfo/lib_tputs.c
    3770439667--- ncurses-5.7.orig/ncurses/tinfo/lib_tputs.c  2008-06-28 06:12:15.000000000 -0700
    37705 +++ ncurses-5.7/ncurses/tinfo/lib_tputs.c       2009-07-19 15:04:07.000000000 -0700
     39668+++ ncurses-5.7/ncurses/tinfo/lib_tputs.c       2009-09-12 08:51:45.000000000 -0700
    3770639669@@ -1,5 +1,5 @@
    3770739670 /****************************************************************************
     
    3798439947diff -Naur ncurses-5.7.orig/ncurses/tinfo/lib_ttyflags.c ncurses-5.7/ncurses/tinfo/lib_ttyflags.c
    3798539948--- ncurses-5.7.orig/ncurses/tinfo/lib_ttyflags.c       2008-08-03 15:10:44.000000000 -0700
    37986 +++ ncurses-5.7/ncurses/tinfo/lib_ttyflags.c    2009-07-19 15:04:06.000000000 -0700
     39949+++ ncurses-5.7/ncurses/tinfo/lib_ttyflags.c    2009-09-12 08:51:43.000000000 -0700
    3798739950@@ -1,5 +1,5 @@
    3798839951 /****************************************************************************
     
    3832340286 }
    3832440287+#endif
     40288diff -Naur ncurses-5.7.orig/ncurses/tinfo/make_hash.c ncurses-5.7/ncurses/tinfo/make_hash.c
     40289--- ncurses-5.7.orig/ncurses/tinfo/make_hash.c  1969-12-31 16:00:00.000000000 -0800
     40290+++ ncurses-5.7/ncurses/tinfo/make_hash.c       2009-09-12 08:52:02.000000000 -0700
     40291@@ -0,0 +1,294 @@
     40292+/****************************************************************************
     40293+ * Copyright (c) 1998-2008,2009 Free Software Foundation, Inc.              *
     40294+ *                                                                          *
     40295+ * Permission is hereby granted, free of charge, to any person obtaining a  *
     40296+ * copy of this software and associated documentation files (the            *
     40297+ * "Software"), to deal in the Software without restriction, including      *
     40298+ * without limitation the rights to use, copy, modify, merge, publish,      *
     40299+ * distribute, distribute with modifications, sublicense, and/or sell       *
     40300+ * copies of the Software, and to permit persons to whom the Software is    *
     40301+ * furnished to do so, subject to the following conditions:                 *
     40302+ *                                                                          *
     40303+ * The above copyright notice and this permission notice shall be included  *
     40304+ * in all copies or substantial portions of the Software.                   *
     40305+ *                                                                          *
     40306+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS  *
     40307+ * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF               *
     40308+ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.   *
     40309+ * IN NO EVENT SHALL THE ABOVE COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM,   *
     40310+ * DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR    *
     40311+ * OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR    *
     40312+ * THE USE OR OTHER DEALINGS IN THE SOFTWARE.                               *
     40313+ *                                                                          *
     40314+ * Except as contained in this notice, the name(s) of the above copyright   *
     40315+ * holders shall not be used in advertising or otherwise to promote the     *
     40316+ * sale, use or other dealings in this Software without prior written       *
     40317+ * authorization.                                                           *
     40318+ ****************************************************************************/
     40319+
     40320+/****************************************************************************
     40321+ *  Author: Zeyd M. Ben-Halim <zmbenhal@netcom.com> 1992,1995               *
     40322+ *     and: Eric S. Raymond <esr@snark.thyrsus.com>                         *
     40323+ *     and: Thomas E. Dickey                        1996-on                 *
     40324+ ****************************************************************************/
     40325+
     40326+/*
     40327+ *     make_hash.c --- build-time program for constructing comp_captab.c
     40328+ *
     40329+ */
     40330+
     40331+#include <curses.priv.h>
     40332+
     40333+#include <tic.h>
     40334+#include <hashsize.h>
     40335+
     40336+#include <ctype.h>
     40337+
     40338+MODULE_ID("$Id: make_hash.c,v 1.2 2009/08/08 17:42:41 tom Exp $")
     40339+
     40340+/*
     40341+ *     _nc_make_hash_table()
     40342+ *
     40343+ *     Takes the entries in table[] and hashes them into hash_table[]
     40344+ *     by name.  There are CAPTABSIZE entries in table[] and HASHTABSIZE
     40345+ *     slots in hash_table[].
     40346+ *
     40347+ */
     40348+
     40349+#undef MODULE_ID
     40350+#define MODULE_ID(id)          /*nothing */
     40351+#include <tinfo/doalloc.c>
     40352+
     40353+/*
     40354+ *     int hash_function(string)
     40355+ *
     40356+ *     Computes the hashing function on the given string.
     40357+ *
     40358+ *     The current hash function is the sum of each consectutive pair
     40359+ *     of characters, taken as two-byte integers, mod HASHTABSIZE.
     40360+ *
     40361+ */
     40362+
     40363+static int
     40364+hash_function(const char *string)
     40365+{
     40366+    long sum = 0;
     40367+
     40368+    while (*string) {
     40369+       sum += (long) (*string + (*(string + 1) << 8));
     40370+       string++;
     40371+    }
     40372+
     40373+    return (int) (sum % HASHTABSIZE);
     40374+}
     40375+
     40376+static void
     40377+_nc_make_hash_table(struct name_table_entry *table,
     40378+                   HashValue * hash_table)
     40379+{
     40380+    short i;
     40381+    int hashvalue;
     40382+    int collisions = 0;
     40383+
     40384+    for (i = 0; i < HASHTABSIZE; i++) {
     40385+       hash_table[i] = -1;
     40386+    }
     40387+    for (i = 0; i < CAPTABSIZE; i++) {
     40388+       hashvalue = hash_function(table[i].nte_name);
     40389+
     40390+       if (hash_table[hashvalue] >= 0)
     40391+           collisions++;
     40392+
     40393+       if (hash_table[hashvalue] != 0)
     40394+           table[i].nte_link = hash_table[hashvalue];
     40395+       hash_table[hashvalue] = i;
     40396+    }
     40397+
     40398+    printf("/* %d collisions out of %d entries */\n", collisions, CAPTABSIZE);
     40399+}
     40400+
     40401+/*
     40402+ * This filter reads from standard input a list of tab-delimited columns,
     40403+ * (e.g., from Caps.filtered) computes the hash-value of a specified column and
     40404+ * writes the hashed tables to standard output.
     40405+ *
     40406+ * By compiling the hash table at build time, we're able to make the entire
     40407+ * set of terminfo and termcap tables readonly (and also provide some runtime
     40408+ * performance enhancement).
     40409+ */
     40410+
     40411+#define MAX_COLUMNS BUFSIZ     /* this _has_ to be worst-case */
     40412+
     40413+static char **
     40414+parse_columns(char *buffer)
     40415+{
     40416+    static char **list;
     40417+
     40418+    int col = 0;
     40419+
     40420+    if (list == 0 && (list = typeCalloc(char *, MAX_COLUMNS)) == 0)
     40421+         return (0);
     40422+
     40423+    if (*buffer != '#') {
     40424+       while (*buffer != '\0') {
     40425+           char *s;
     40426+           for (s = buffer; (*s != '\0') && !isspace(UChar(*s)); s++)
     40427+               /*EMPTY */ ;
     40428+           if (s != buffer) {
     40429+               char mark = *s;
     40430+               *s = '\0';
     40431+               if ((s - buffer) > 1
     40432+                   && (*buffer == '"')
     40433+                   && (s[-1] == '"')) {        /* strip the quotes */
     40434+                   assert(s > buffer + 1);
     40435+                   s[-1] = '\0';
     40436+                   buffer++;
     40437+               }
     40438+               list[col] = buffer;
     40439+               col++;
     40440+               if (mark == '\0')
     40441+                   break;
     40442+               while (*++s && isspace(UChar(*s)))
     40443+                   /*EMPTY */ ;
     40444+               buffer = s;
     40445+           } else
     40446+               break;
     40447+       }
     40448+    }
     40449+    return col ? list : 0;
     40450+}
     40451+
     40452+int
     40453+main(int argc, char **argv)
     40454+{
     40455+    struct name_table_entry *name_table = typeCalloc(struct
     40456+                                                    name_table_entry, CAPTABSIZE);
     40457+    HashValue *hash_table = typeCalloc(HashValue, HASHTABSIZE);
     40458+    const char *root_name = "";
     40459+    int column = 0;
     40460+    int bigstring = 0;
     40461+    int n;
     40462+    char buffer[BUFSIZ];
     40463+
     40464+    static const char *typenames[] =
     40465+    {"BOOLEAN", "NUMBER", "STRING"};
     40466+
     40467+    short BoolCount = 0;
     40468+    short NumCount = 0;
     40469+    short StrCount = 0;
     40470+
     40471+    /* The first argument is the column-number (starting with 0).
     40472+     * The second is the root name of the tables to generate.
     40473+     */
     40474+    if (argc <= 3
     40475+       || (column = atoi(argv[1])) <= 0
     40476+       || (column >= MAX_COLUMNS)
     40477+       || *(root_name = argv[2]) == 0
     40478+       || (bigstring = atoi(argv[3])) < 0
     40479+       || name_table == 0
     40480+       || hash_table == 0) {
     40481+       fprintf(stderr, "usage: make_hash column root_name bigstring\n");
     40482+       exit(EXIT_FAILURE);
     40483+    }
     40484+
     40485+    /*
     40486+     * Read the table into our arrays.
     40487+     */
     40488+    for (n = 0; (n < CAPTABSIZE) && fgets(buffer, BUFSIZ, stdin);) {
     40489+       char **list, *nlp = strchr(buffer, '\n');
     40490+       if (nlp)
     40491+           *nlp = '\0';
     40492+       list = parse_columns(buffer);
     40493+       if (list == 0)          /* blank or comment */
     40494+           continue;
     40495+       name_table[n].nte_link = -1;    /* end-of-hash */
     40496+       name_table[n].nte_name = strdup(list[column]);
     40497+       if (!strcmp(list[2], "bool")) {
     40498+           name_table[n].nte_type = BOOLEAN;
     40499+           name_table[n].nte_index = BoolCount++;
     40500+       } else if (!strcmp(list[2], "num")) {
     40501+           name_table[n].nte_type = NUMBER;
     40502+           name_table[n].nte_index = NumCount++;
     40503+       } else if (!strcmp(list[2], "str")) {
     40504+           name_table[n].nte_type = STRING;
     40505+           name_table[n].nte_index = StrCount++;
     40506+       } else {
     40507+           fprintf(stderr, "Unknown type: %s\n", list[2]);
     40508+           exit(EXIT_FAILURE);
     40509+       }
     40510+       n++;
     40511+    }
     40512+    _nc_make_hash_table(name_table, hash_table);
     40513+
     40514+    /*
     40515+     * Write the compiled tables to standard output
     40516+     */
     40517+    if (bigstring) {
     40518+       int len = 0;
     40519+       int nxt;
     40520+
     40521+       printf("static const char %s_names_text[] = \\\n", root_name);
     40522+       for (n = 0; n < CAPTABSIZE; n++) {
     40523+           nxt = (int) strlen(name_table[n].nte_name) + 5;
     40524+           if (nxt + len > 72) {
     40525+               printf("\\\n");
     40526+               len = 0;
     40527+           }
     40528+           printf("\"%s\\0\" ", name_table[n].nte_name);
     40529+           len += nxt;
     40530+       }
     40531+       printf(";\n\n");
     40532+
     40533+       len = 0;
     40534+       printf("static name_table_data const %s_names_data[] =\n",
     40535+              root_name);
     40536+       printf("{\n");
     40537+       for (n = 0; n < CAPTABSIZE; n++) {
     40538+           printf("\t{ %15d,\t%10s,\t%3d, %3d }%c\n",
     40539+                  len,
     40540+                  typenames[name_table[n].nte_type],
     40541+                  name_table[n].nte_index,
     40542+                  name_table[n].nte_link,
     40543+                  n < CAPTABSIZE - 1 ? ',' : ' ');
     40544+           len += (int) strlen(name_table[n].nte_name) + 1;
     40545+       }
     40546+       printf("};\n\n");
     40547+       printf("static struct name_table_entry *_nc_%s_table = 0;\n\n", root_name);
     40548+    } else {
     40549+
     40550+       printf("static struct name_table_entry %s _nc_%s_table[] =\n",
     40551+              bigstring ? "" : "const",
     40552+              root_name);
     40553+       printf("{\n");
     40554+       for (n = 0; n < CAPTABSIZE; n++) {
     40555+           sprintf(buffer, "\"%s\"",
     40556+                   name_table[n].nte_name);
     40557+           printf("\t{ %15s,\t%10s,\t%3d, %3d }%c\n",
     40558+                  buffer,
     40559+                  typenames[name_table[n].nte_type],
     40560+                  name_table[n].nte_index,
     40561+                  name_table[n].nte_link,
     40562+                  n < CAPTABSIZE - 1 ? ',' : ' ');
     40563+       }
     40564+       printf("};\n\n");
     40565+    }
     40566+
     40567+    printf("static const HashValue _nc_%s_hash_table[%d] =\n",
     40568+          root_name,
     40569+          HASHTABSIZE + 1);
     40570+    printf("{\n");
     40571+    for (n = 0; n < HASHTABSIZE; n++) {
     40572+       printf("\t%3d,\n", hash_table[n]);
     40573+    }
     40574+    printf("\t0\t/* base-of-table */\n");
     40575+    printf("};\n\n");
     40576+
     40577+    printf("#if (BOOLCOUNT!=%d)||(NUMCOUNT!=%d)||(STRCOUNT!=%d)\n",
     40578+          BoolCount, NumCount, StrCount);
     40579+    printf("#error\t--> term.h and comp_captab.c disagree about the <--\n");
     40580+    printf("#error\t--> numbers of booleans, numbers and/or strings <--\n");
     40581+    printf("#endif\n\n");
     40582+
     40583+    free(hash_table);
     40584+    return EXIT_SUCCESS;
     40585+}
    3832540586diff -Naur ncurses-5.7.orig/ncurses/tinfo/make_keys.c ncurses-5.7/ncurses/tinfo/make_keys.c
    3832640587--- ncurses-5.7.orig/ncurses/tinfo/make_keys.c  2008-08-03 14:57:22.000000000 -0700
    38327 +++ ncurses-5.7/ncurses/tinfo/make_keys.c       2009-07-19 15:02:22.000000000 -0700
     40588+++ ncurses-5.7/ncurses/tinfo/make_keys.c       2009-09-12 08:51:17.000000000 -0700
    3832840589@@ -39,16 +39,16 @@
    3832940590 #define USE_TERMLIB 1
     
    3836840629            fprintf(ofp, "\t{ %4d, %-*.*s },\t/* %s */\n",
    3836940630                    code,
     40631diff -Naur ncurses-5.7.orig/ncurses/tinfo/MKcaptab.sh ncurses-5.7/ncurses/tinfo/MKcaptab.sh
     40632--- ncurses-5.7.orig/ncurses/tinfo/MKcaptab.sh  2007-08-12 06:13:51.000000000 -0700
     40633+++ ncurses-5.7/ncurses/tinfo/MKcaptab.sh       2009-09-12 08:52:02.000000000 -0700
     40634@@ -1,6 +1,6 @@
     40635 #!/bin/sh
     40636 ##############################################################################
     40637-# Copyright (c) 2007 Free Software Foundation, Inc.                          #
     40638+# Copyright (c) 2007,2009 Free Software Foundation, Inc.                     #
     40639 #                                                                            #
     40640 # Permission is hereby granted, free of charge, to any person obtaining a    #
     40641 # copy of this software and associated documentation files (the "Software"), #
     40642@@ -26,12 +26,19 @@
     40643 # use or other dealings in this Software without prior written               #
     40644 # authorization.                                                             #
     40645 ##############################################################################
     40646-# $Id: MKcaptab.sh,v 1.8 2007/08/12 13:13:51 tom Exp $
     40647+# $Id: MKcaptab.sh,v 1.10 2009/08/08 17:19:25 tom Exp $
     40648 AWK=${1-awk}
     40649 OPT1=${2-0}
     40650 OPT2=${3-tinfo/MKcaptab.awk}
     40651 DATA=${4-../include/Caps}
     40652 
     40653+cat <<EOF
     40654+/*
     40655+ * generated by $0
     40656+ */
     40657+
     40658+EOF
     40659+
     40660 cat <<'EOF'
     40661 /*
     40662  *     comp_captab.c -- The names of the capabilities indexed via a hash
     40663@@ -58,7 +65,7 @@
     40664 static void
     40665 next_string(const char *strings, unsigned *offset)
     40666 {
     40667-       *offset += strlen(strings + *offset) + 1;
     40668+    *offset += strlen(strings + *offset) + 1;
     40669 }
     40670 
     40671 static const struct name_table_entry *
     40672@@ -66,21 +73,21 @@
     40673                const name_table_data *source,
     40674                const char *strings)
     40675 {
     40676-       if (*actual == 0) {
     40677-               *actual = typeCalloc(struct name_table_entry, CAPTABSIZE);
     40678-               if (*actual != 0) {
     40679-                       unsigned n;
     40680-                       unsigned len = 0;
     40681-                       for (n = 0; n < CAPTABSIZE; ++n) {
     40682-                               (*actual)[n].nte_name = strings + len;
     40683-                               (*actual)[n].nte_type = source[n].nte_type;
     40684-                               (*actual)[n].nte_index = source[n].nte_index;
     40685-                               (*actual)[n].nte_link = source[n].nte_link;
     40686-                               next_string(strings, &len);
     40687-                       }
     40688-               }
     40689+    if (*actual == 0) {
     40690+       *actual = typeCalloc(struct name_table_entry, CAPTABSIZE);
     40691+       if (*actual != 0) {
     40692+           unsigned n;
     40693+           unsigned len = 0;
     40694+           for (n = 0; n < CAPTABSIZE; ++n) {
     40695+               (*actual)[n].nte_name = strings + len;
     40696+               (*actual)[n].nte_type = source[n].nte_type;
     40697+               (*actual)[n].nte_index = source[n].nte_index;
     40698+               (*actual)[n].nte_link = source[n].nte_link;
     40699+               next_string(strings, &len);
     40700+           }
     40701        }
     40702-       return *actual;
     40703+    }
     40704+    return *actual;
     40705 }
     40706 
     40707 #define add_alias(field) \\
     40708@@ -94,18 +101,18 @@
     40709                const char *strings,
     40710                unsigned tablesize)
     40711 {
     40712-       if (*actual == 0) {
     40713-               *actual = typeCalloc(struct alias, tablesize + 1);
     40714-               if (*actual != 0) {
     40715-                       unsigned n;
     40716-                       for (n = 0; n < tablesize; ++n) {
     40717-                               add_alias(from);
     40718-                               add_alias(to);
     40719-                               add_alias(source);
     40720-                       }
     40721-               }
     40722+    if (*actual == 0) {
     40723+       *actual = typeCalloc(struct alias, tablesize + 1);
     40724+       if (*actual != 0) {
     40725+           unsigned n;
     40726+           for (n = 0; n < tablesize; ++n) {
     40727+               add_alias(from);
     40728+               add_alias(to);
     40729+               add_alias(source);
     40730+           }
     40731        }
     40732-       return *actual;
     40733+    }
     40734+    return *actual;
     40735 }
     40736 
     40737 #define build_names(root) _nc_build_names(&_nc_##root##_table, \\
     40738@@ -122,27 +129,65 @@
     40739 
     40740 NCURSES_EXPORT(const struct name_table_entry *) _nc_get_table (bool termcap)
     40741 {
     40742-       return termcap ? build_names(cap) : build_names(info) ;
     40743+    return termcap ? build_names(cap) : build_names(info) ;
     40744 }
     40745 
     40746-NCURSES_EXPORT(const short *) _nc_get_hash_table (bool termcap)
     40747+/* entrypoint used by tack (do not alter) */
     40748+NCURSES_EXPORT(const HashValue *) _nc_get_hash_table (bool termcap)
     40749 {
     40750-       return termcap ? _nc_cap_hash_table: _nc_info_hash_table ;
     40751+    return termcap ? _nc_cap_hash_table: _nc_info_hash_table ;
     40752 }
     40753 
     40754 NCURSES_EXPORT(const struct alias *) _nc_get_alias_table (bool termcap)
     40755 {
     40756-       return termcap ? build_alias(cap) : build_alias(info) ;
     40757+    return termcap ? build_alias(cap) : build_alias(info) ;
     40758+}
     40759+
     40760+static HashValue
     40761+hash_function(const char *string)
     40762+{
     40763+    long sum = 0;
     40764+
     40765+    DEBUG(9, ("hashing %s", string));
     40766+    while (*string) {
     40767+       sum += (long) (*string + (*(string + 1) << 8));
     40768+       string++;
     40769+    }
     40770+
     40771+    DEBUG(9, ("sum is %ld", sum));
     40772+    return (HashValue) (sum % HASHTABSIZE);
     40773+}
     40774+
     40775+static int
     40776+compare_cap_names(const char *a, const char *b)
     40777+{
     40778+    return !strncmp(a, b, 2);
     40779+}
     40780+
     40781+static int
     40782+compare_info_names(const char *a, const char *b)
     40783+{
     40784+    return !strcmp(a, b);
     40785+}
     40786+
     40787+static const HashData hash_data[2] = {
     40788+    { HASHTABSIZE, _nc_info_hash_table, hash_function, compare_info_names },
     40789+    { HASHTABSIZE, _nc_cap_hash_table, hash_function, compare_cap_names }
     40790+};
     40791+
     40792+NCURSES_EXPORT(const HashData *) _nc_get_hash_info (bool termcap)
     40793+{
     40794+    return &hash_data[(termcap != FALSE)];
     40795 }
     40796 
     40797 #if NO_LEAKS
     40798 NCURSES_EXPORT(void) _nc_comp_captab_leaks(void)
     40799 {
     40800 #if $OPT1
     40801-       FreeIfNeeded(_nc_cap_table);
     40802-       FreeIfNeeded(_nc_info_table);
     40803-       FreeIfNeeded(_nc_capalias_table);
     40804-       FreeIfNeeded(_nc_infoalias_table);
     40805+    FreeIfNeeded(_nc_cap_table);
     40806+    FreeIfNeeded(_nc_info_table);
     40807+    FreeIfNeeded(_nc_capalias_table);
     40808+    FreeIfNeeded(_nc_infoalias_table);
     40809 #endif
     40810 }
     40811 #endif /* NO_LEAKS */
    3837040812diff -Naur ncurses-5.7.orig/ncurses/tinfo/MKcodes.awk ncurses-5.7/ncurses/tinfo/MKcodes.awk
    3837140813--- ncurses-5.7.orig/ncurses/tinfo/MKcodes.awk  2008-06-28 16:13:25.000000000 -0700
    38372 +++ ncurses-5.7/ncurses/tinfo/MKcodes.awk       2009-07-19 15:04:03.000000000 -0700
     40814+++ ncurses-5.7/ncurses/tinfo/MKcodes.awk       2009-09-12 08:51:40.000000000 -0700
    3837340815@@ -1,5 +1,5 @@
    3837440816 ##############################################################################
     
    3843240874diff -Naur ncurses-5.7.orig/ncurses/tinfo/MKfallback.sh ncurses-5.7/ncurses/tinfo/MKfallback.sh
    3843340875--- ncurses-5.7.orig/ncurses/tinfo/MKfallback.sh        2006-07-15 09:54:20.000000000 -0700
    38434 +++ ncurses-5.7/ncurses/tinfo/MKfallback.sh     2009-07-19 15:03:53.000000000 -0700
     40876+++ ncurses-5.7/ncurses/tinfo/MKfallback.sh     2009-09-12 08:51:30.000000000 -0700
    3843540877@@ -1,6 +1,6 @@
    3843640878 #!/bin/sh
     
    3846040902diff -Naur ncurses-5.7.orig/ncurses/tinfo/MKnames.awk ncurses-5.7/ncurses/tinfo/MKnames.awk
    3846140903--- ncurses-5.7.orig/ncurses/tinfo/MKnames.awk  2008-10-11 14:07:56.000000000 -0700
    38462 +++ ncurses-5.7/ncurses/tinfo/MKnames.awk       2009-07-19 15:03:45.000000000 -0700
     40904+++ ncurses-5.7/ncurses/tinfo/MKnames.awk       2009-09-12 08:51:23.000000000 -0700
    3846340905@@ -1,5 +1,5 @@
    3846440906 ##############################################################################
     
    3853140973diff -Naur ncurses-5.7.orig/ncurses/tinfo/name_match.c ncurses-5.7/ncurses/tinfo/name_match.c
    3853240974--- ncurses-5.7.orig/ncurses/tinfo/name_match.c 2008-08-03 12:49:33.000000000 -0700
    38533 +++ ncurses-5.7/ncurses/tinfo/name_match.c      2009-07-19 15:02:22.000000000 -0700
     40975+++ ncurses-5.7/ncurses/tinfo/name_match.c      2009-09-12 08:51:17.000000000 -0700
    3853440976@@ -31,10 +31,9 @@
    3853540977  ****************************************************************************/
     
    3854640988diff -Naur ncurses-5.7.orig/ncurses/tinfo/parse_entry.c ncurses-5.7/ncurses/tinfo/parse_entry.c
    3854740989--- ncurses-5.7.orig/ncurses/tinfo/parse_entry.c        2008-08-16 14:52:03.000000000 -0700
    38548 +++ ncurses-5.7/ncurses/tinfo/parse_entry.c     2009-07-19 15:04:15.000000000 -0700
     40990+++ ncurses-5.7/ncurses/tinfo/parse_entry.c     2009-09-12 08:51:52.000000000 -0700
    3854940991@@ -1,5 +1,5 @@
    3855040992 /****************************************************************************
     
    3866941111diff -Naur ncurses-5.7.orig/ncurses/tinfo/setbuf.c ncurses-5.7/ncurses/tinfo/setbuf.c
    3867041112--- ncurses-5.7.orig/ncurses/tinfo/setbuf.c     2007-05-12 12:04:02.000000000 -0700
    38671 +++ ncurses-5.7/ncurses/tinfo/setbuf.c  2009-07-19 15:03:59.000000000 -0700
     41113+++ ncurses-5.7/ncurses/tinfo/setbuf.c  2009-09-12 08:51:56.000000000 -0700
    3867241114@@ -1,5 +1,5 @@
    3867341115 /****************************************************************************
     
    3869141133 
    3869241134-MODULE_ID("$Id: setbuf.c,v 1.13 2007/05/12 19:04:02 tom Exp $")
    38693 +MODULE_ID("$Id: setbuf.c,v 1.14 2009/05/09 23:09:00 tom Exp $")
     41135+MODULE_ID("$Id: setbuf.c,v 1.15 2009/05/23 22:13:44 tom Exp $")
    3869441136 
    3869541137 /*
    3869641138  * If the output file descriptor is connected to a tty (the typical case) it
    38697 @@ -98,11 +100,11 @@
     41139@@ -98,11 +100,20 @@
    3869841140  * buffer.  So we disable this by default (there may yet be a workaround).
    3869941141  */
     
    3870241144+NCURSES_SP_NAME(_nc_set_buffer) (NCURSES_SP_DCLx FILE *ofp, bool buffered)
    3870341145 {
     41146+    int Cols;
     41147+    int Lines;
     41148+
     41149+    if (0 == SP_PARM)
     41150+       return;
     41151+
     41152+    Cols = *(ptrCols(SP_PARM));
     41153+    Lines = *(ptrLines(SP_PARM));
     41154+
    3870441155     /* optional optimization hack -- do before any output to ofp */
    3870541156 #if HAVE_SETVBUF || HAVE_SETBUFFER
     
    3870941160        char *buf_ptr;
    3871041161 
    38711 @@ -115,10 +117,10 @@
     41162@@ -114,11 +125,11 @@
     41163        setmode(ofp, O_BINARY);
    3871241164 #endif
    3871341165        if (buffered != 0) {
    38714             buf_len = min(LINES * (COLS + 6), 2800);
     41166-           buf_len = min(LINES * (COLS + 6), 2800);
    3871541167-           if ((buf_ptr = SP->_setbuf) == 0) {
     41168+           buf_len = min(Lines * (Cols + 6), 2800);
    3871641169+           if ((buf_ptr = SP_PARM->_setbuf) == 0) {
    3871741170                if ((buf_ptr = typeMalloc(char, buf_len)) == NULL)
     
    3872241175            }
    3872341176 #if !USE_SETBUF_0
    38724 @@ -144,7 +146,15 @@
     41177@@ -144,7 +155,15 @@
    3872541178        (void) setbuffer(ofp, buf_ptr, (int) buf_len);
    3872641179 #endif
     
    3873641189+_nc_set_buffer(FILE *ofp, bool buffered)
    3873741190+{
    38738 +    return NCURSES_SP_NAME(_nc_set_buffer) (CURRENT_SCREEN, ofp, buffered);
     41191+    NCURSES_SP_NAME(_nc_set_buffer) (CURRENT_SCREEN, ofp, buffered);
    3873941192+}
    3874041193+#endif
    3874141194diff -Naur ncurses-5.7.orig/ncurses/tinfo/tinfo_driver.c ncurses-5.7/ncurses/tinfo/tinfo_driver.c
    3874241195--- ncurses-5.7.orig/ncurses/tinfo/tinfo_driver.c       1969-12-31 16:00:00.000000000 -0800
    38743 +++ ncurses-5.7/ncurses/tinfo/tinfo_driver.c    2009-07-19 15:04:11.000000000 -0700
     41196+++ ncurses-5.7/ncurses/tinfo/tinfo_driver.c    2009-09-12 08:52:05.000000000 -0700
    3874441197@@ -0,0 +1,1389 @@
    3874541198+/****************************************************************************
     
    3878741240+#endif
    3878841241+
    38789 +MODULE_ID("$Id: tinfo_driver.c,v 1.1 2009/05/23 22:40:30 juergen Exp $")
     41242+MODULE_ID("$Id: tinfo_driver.c,v 1.2 2009/08/16 14:17:08 tom Exp $")
    3879041243+
    3879141244+/*
     
    3891841371+{
    3891941372+    AssertTCB();
    38920 +    return _nc_tinfo_doupdate(TCB->csp);
     41373+    return TINFO_DOUPDATE(TCB->csp);
    3892141374+}
    3892241375+
     
    3969042143+    SCREEN *sp = TCB->csp;
    3969142144+    AssertTCB();
    39692 +    return _nc_tinfo_mvcur(sp, yold, xold, ynew, xnew);
     42145+    return TINFO_MVCUR(sp, yold, xold, ynew, xnew);
    3969342146+}
    3969442147+
     
    4012842581+    AssertTCB();
    4012942582+    if (TCB->csp)
    40130 +       res = _nc_tinfo_has_key(TCB->csp, key) == 0 ? FALSE : TRUE;
     42583+       res = TINFO_HAS_KEY(TCB->csp, key) == 0 ? FALSE : TRUE;
    4013142584+
    4013242585+    return res;
     
    4013442587diff -Naur ncurses-5.7.orig/ncurses/tinfo/use_screen.c ncurses-5.7/ncurses/tinfo/use_screen.c
    4013542588--- ncurses-5.7.orig/ncurses/tinfo/use_screen.c 2008-06-07 12:16:56.000000000 -0700
    40136 +++ ncurses-5.7/ncurses/tinfo/use_screen.c      2009-07-19 15:02:22.000000000 -0700
     42589+++ ncurses-5.7/ncurses/tinfo/use_screen.c      2009-09-12 08:51:17.000000000 -0700
    4013742590@@ -32,7 +32,7 @@
    4013842591 
     
    4015542608diff -Naur ncurses-5.7.orig/ncurses/tinfo/write_entry.c ncurses-5.7/ncurses/tinfo/write_entry.c
    4015642609--- ncurses-5.7.orig/ncurses/tinfo/write_entry.c        2008-08-03 12:24:00.000000000 -0700
    40157 +++ ncurses-5.7/ncurses/tinfo/write_entry.c     2009-07-19 15:03:53.000000000 -0700
     42610+++ ncurses-5.7/ncurses/tinfo/write_entry.c     2009-09-12 08:51:30.000000000 -0700
    4015842611@@ -1,5 +1,5 @@
    4015942612 /****************************************************************************
     
    4029442747diff -Naur ncurses-5.7.orig/ncurses/trace/lib_traceatr.c ncurses-5.7/ncurses/trace/lib_traceatr.c
    4029542748--- ncurses-5.7.orig/ncurses/trace/lib_traceatr.c       2008-08-03 09:24:53.000000000 -0700
    40296 +++ ncurses-5.7/ncurses/trace/lib_traceatr.c    2009-07-19 15:03:59.000000000 -0700
     42749+++ ncurses-5.7/ncurses/trace/lib_traceatr.c    2009-09-12 08:51:37.000000000 -0700
    4029742750@@ -1,5 +1,5 @@
    4029842751 /****************************************************************************
     
    4038842841diff -Naur ncurses-5.7.orig/ncurses/trace/lib_tracebits.c ncurses-5.7/ncurses/trace/lib_tracebits.c
    4038942842--- ncurses-5.7.orig/ncurses/trace/lib_tracebits.c      2008-08-03 09:09:26.000000000 -0700
    40390 +++ ncurses-5.7/ncurses/trace/lib_tracebits.c   2009-07-19 15:02:22.000000000 -0700
     42843+++ ncurses-5.7/ncurses/trace/lib_tracebits.c   2009-09-12 08:51:17.000000000 -0700
    4039142844@@ -33,9 +33,8 @@
    4039242845  ****************************************************************************/
     
    4040242855diff -Naur ncurses-5.7.orig/ncurses/trace/lib_trace.c ncurses-5.7/ncurses/trace/lib_trace.c
    4040342856--- ncurses-5.7.orig/ncurses/trace/lib_trace.c  2008-08-23 11:04:29.000000000 -0700
    40404 +++ ncurses-5.7/ncurses/trace/lib_trace.c       2009-07-19 15:02:23.000000000 -0700
     42857+++ ncurses-5.7/ncurses/trace/lib_trace.c       2009-09-12 08:51:19.000000000 -0700
    4040542858@@ -1,5 +1,5 @@
    4040642859 /****************************************************************************
     
    4046242915diff -Naur ncurses-5.7.orig/ncurses/trace/lib_tracechr.c ncurses-5.7/ncurses/trace/lib_tracechr.c
    4046342916--- ncurses-5.7.orig/ncurses/trace/lib_tracechr.c       2008-08-03 08:39:29.000000000 -0700
    40464 +++ ncurses-5.7/ncurses/trace/lib_tracechr.c    2009-07-19 15:03:53.000000000 -0700
     42917+++ ncurses-5.7/ncurses/trace/lib_tracechr.c    2009-09-12 08:51:30.000000000 -0700
    4046542918@@ -1,5 +1,5 @@
    4046642919 /****************************************************************************
     
    4050842961diff -Naur ncurses-5.7.orig/ncurses/trace/lib_tracedmp.c ncurses-5.7/ncurses/trace/lib_tracedmp.c
    4050942962--- ncurses-5.7.orig/ncurses/trace/lib_tracedmp.c       2008-08-16 12:30:56.000000000 -0700
    40510 +++ ncurses-5.7/ncurses/trace/lib_tracedmp.c    2009-07-19 15:03:53.000000000 -0700
     42963+++ ncurses-5.7/ncurses/trace/lib_tracedmp.c    2009-09-12 08:51:30.000000000 -0700
    4051142964@@ -1,5 +1,5 @@
    4051242965 /****************************************************************************
     
    4056343016diff -Naur ncurses-5.7.orig/ncurses/trace/lib_tracemse.c ncurses-5.7/ncurses/trace/lib_tracemse.c
    4056443017--- ncurses-5.7.orig/ncurses/trace/lib_tracemse.c       2008-08-03 08:39:29.000000000 -0700
    40565 +++ ncurses-5.7/ncurses/trace/lib_tracemse.c    2009-07-19 15:02:22.000000000 -0700
     43018+++ ncurses-5.7/ncurses/trace/lib_tracemse.c    2009-09-12 08:51:17.000000000 -0700
    4056643019@@ -38,7 +38,7 @@
    4056743020 
     
    4058443037diff -Naur ncurses-5.7.orig/ncurses/trace/trace_tries.c ncurses-5.7/ncurses/trace/trace_tries.c
    4058543038--- ncurses-5.7.orig/ncurses/trace/trace_tries.c        2008-08-03 08:43:30.000000000 -0700
    40586 +++ ncurses-5.7/ncurses/trace/trace_tries.c     2009-07-19 15:03:48.000000000 -0700
     43039+++ ncurses-5.7/ncurses/trace/trace_tries.c     2009-09-12 08:51:25.000000000 -0700
    4058743040@@ -1,5 +1,5 @@
    4058843041 /****************************************************************************
     
    4061243065diff -Naur ncurses-5.7.orig/ncurses/trace/varargs.c ncurses-5.7/ncurses/trace/varargs.c
    4061343066--- ncurses-5.7.orig/ncurses/trace/varargs.c    2008-08-03 08:42:49.000000000 -0700
    40614 +++ ncurses-5.7/ncurses/trace/varargs.c 2009-07-19 15:02:22.000000000 -0700
     43067+++ ncurses-5.7/ncurses/trace/varargs.c 2009-09-12 08:51:17.000000000 -0700
    4061543068@@ -34,7 +34,7 @@
    4061643069 
     
    4063343086diff -Naur ncurses-5.7.orig/ncurses/trace/visbuf.c ncurses-5.7/ncurses/trace/visbuf.c
    4063443087--- ncurses-5.7.orig/ncurses/trace/visbuf.c     2008-08-04 16:07:39.000000000 -0700
    40635 +++ ncurses-5.7/ncurses/trace/visbuf.c  2009-07-19 15:04:15.000000000 -0700
     43088+++ ncurses-5.7/ncurses/trace/visbuf.c  2009-09-12 08:51:52.000000000 -0700
    4063643089@@ -1,5 +1,5 @@
    4063743090 /****************************************************************************
     
    4069343146diff -Naur ncurses-5.7.orig/ncurses/tty/hardscroll.c ncurses-5.7/ncurses/tty/hardscroll.c
    4069443147--- ncurses-5.7.orig/ncurses/tty/hardscroll.c   2008-08-03 16:49:30.000000000 -0700
    40695 +++ ncurses-5.7/ncurses/tty/hardscroll.c        2009-07-19 15:03:53.000000000 -0700
     43148+++ ncurses-5.7/ncurses/tty/hardscroll.c        2009-09-12 08:51:30.000000000 -0700
    4069643149@@ -1,5 +1,5 @@
    4069743150 /****************************************************************************
     
    4091243365diff -Naur ncurses-5.7.orig/ncurses/tty/hashmap.c ncurses-5.7/ncurses/tty/hashmap.c
    4091343366--- ncurses-5.7.orig/ncurses/tty/hashmap.c      2007-10-13 11:47:25.000000000 -0700
    40914 +++ ncurses-5.7/ncurses/tty/hashmap.c   2009-07-19 15:03:59.000000000 -0700
     43367+++ ncurses-5.7/ncurses/tty/hashmap.c   2009-09-12 08:51:37.000000000 -0700
    4091543368@@ -1,5 +1,5 @@
    4091643369 /****************************************************************************
     
    4137743830diff -Naur ncurses-5.7.orig/ncurses/tty/lib_mvcur.c ncurses-5.7/ncurses/tty/lib_mvcur.c
    4137843831--- ncurses-5.7.orig/ncurses/tty/lib_mvcur.c    2008-08-16 12:30:58.000000000 -0700
    41379 +++ ncurses-5.7/ncurses/tty/lib_mvcur.c 2009-07-19 15:03:59.000000000 -0700
     43832+++ ncurses-5.7/ncurses/tty/lib_mvcur.c 2009-09-12 08:52:09.000000000 -0700
    4138043833@@ -1,5 +1,5 @@
    4138143834 /****************************************************************************
     
    4140443857 
    4140543858 /****************************************************************************
    41406 @@ -152,13 +153,16 @@
     43859@@ -152,13 +153,21 @@
    4140743860  */
    4140843861 
     
    4141643869+#endif
    4141743870+
    41418 +MODULE_ID("$Id: lib_mvcur.c,v 1.120 2009/05/10 00:52:29 tom Exp $")
     43871+MODULE_ID("$Id: lib_mvcur.c,v 1.121 2009/08/30 16:52:00 tom Exp $")
     43872+
     43873+#define WANT_CHAR(sp, y, x) (sp)->_newscr->_line[y].text[x]    /* desired state */
    4141943874 
    4142043875-#define WANT_CHAR(y, x)        SP->_newscr->_line[y].text[x]   /* desired state */
    4142143876-#define BAUDRATE       cur_term->_baudrate     /* bits per second */
    41422 +#define WANT_CHAR(sp, y, x) (sp)->_newscr->_line[y].text[x]    /* desired state */
     43877+#if NCURSES_SP_FUNCS
     43878+#define BAUDRATE(sp)   sp->_term->_baudrate    /* bits per second */
     43879+#else
    4142343880+#define BAUDRATE(sp)   cur_term->_baudrate     /* bits per second */
     43881+#endif
    4142443882 
    4142543883 #if defined(MAIN) || defined(NCURSES_TEST)
    4142643884 #include <sys/time.h>
    41427 @@ -169,7 +173,7 @@
     43885@@ -169,7 +178,7 @@
    4142843886 
    4142943887 #define OPT_SIZE 512
     
    4143443892 /****************************************************************************
    4143543893  *
    41436 @@ -179,34 +183,34 @@
     43894@@ -179,34 +188,34 @@
    4143743895 
    4143843896 #ifdef TRACE
     
    4147843936 {
    4147943937     if (cap == 0)
    41480 @@ -230,45 +234,56 @@
     43938@@ -230,45 +239,59 @@
    4148143939                }
    4148243940 
     
    4153643994 /* what to do at initialization time and after each shellout */
    4153743995 {
     43996+    if (SP_PARM && !IsTermInfo(SP_PARM))
     43997+       return;
     43998+
    4153843999     /* initialize screen for cursor access */
    4153944000     if (enter_ca_mode) {
     
    4154644007 
    4154744008     /*
    41548 @@ -280,53 +295,63 @@
     44009@@ -280,53 +303,63 @@
    4154944010      * they know the screen size.  This is useful when you're running
    4155044011      * a vt100 emulation through xterm.
     
    4164044101 
    4164144102     /*
    41642 @@ -335,7 +360,7 @@
     44103@@ -335,7 +368,7 @@
    4164344104      * can treat it like absolute screen addressing.  This seems to be true
    4164444105      * for all cursor_mem_address terminal types in the terminfo database.
     
    4164944110     /*
    4165044111      * Parametrized local-motion strings.  This static cost computation
    41651 @@ -361,40 +386,43 @@
     44112@@ -361,40 +394,43 @@
    4165244113      * All these averages depend on the assumption that all parameter values
    4165344114      * are equally probable.
     
    4171744178     /*
    4171844179      * If save_cursor is used within enter_ca_mode, we should not use it for
    41719 @@ -411,30 +439,40 @@
     44180@@ -411,30 +447,42 @@
    4172044181     }
    4172144182 
     
    4172744188      * called by doupdate's return-from-shellout code.
    4172844189      */
     44190-    _nc_mvcur_resume();
    4172944191+    NCURSES_SP_NAME(_nc_mvcur_resume) (NCURSES_SP_ARG);
    41730 +}
    41731 +
     44192 }
     44193 
    4173244194+#if NCURSES_SP_FUNCS
    41733 +NCURSES_EXPORT(void)
     44195 NCURSES_EXPORT(void)
     44196-_nc_mvcur_wrap(void)
    4173444197+_nc_mvcur_init(void)
    4173544198+{
    4173644199+    NCURSES_SP_NAME(_nc_mvcur_init) (CURRENT_SCREEN);
    41737      _nc_mvcur_resume();
    41738  }
     44200+}
    4173944201+#endif
    41740  
    41741  NCURSES_EXPORT(void)
    41742 -_nc_mvcur_wrap(void)
     44202+
     44203+NCURSES_EXPORT(void)
    4174344204+NCURSES_SP_NAME(_nc_mvcur_wrap) (NCURSES_SP_DCL0)
    4174444205 /* wrap up cursor-addressing mode */
     
    4174644207     /* leave cursor at screen bottom */
    4174744208-    mvcur(-1, -1, screen_lines - 1, 0);
    41748 +    mvcur(-1, -1, screen_lines(CURRENT_SCREEN) - 1, 0);
     44209+    TINFO_MVCUR(NCURSES_SP_ARGx -1, -1, screen_lines(SP_PARM) - 1, 0);
     44210+
     44211+    if (SP_PARM && !IsTermInfo(SP_PARM))
     44212+       return;
    4174944213 
    4175044214     /* set cursor to normal mode */
     
    4176844232     /*
    4176944233      * Reset terminal's tab counter.  There's a long-time bug that
    41770 @@ -444,8 +482,16 @@
     44234@@ -444,9 +492,17 @@
    4177144235      * escape sequences that reset things as column positions.
    4177244236      * Utter a \r to reset this invisibly.
     
    4177444238-    _nc_outch('\r');
    4177544239+    NCURSES_SP_NAME(_nc_outch) (NCURSES_SP_ARGx '\r');
    41776 +}
    41777 +
     44240 }
     44241 
    4177844242+#if NCURSES_SP_FUNCS
    4177944243+NCURSES_EXPORT(void)
     
    4178144245+{
    4178244246+    NCURSES_SP_NAME(_nc_mvcur_wrap) (CURRENT_SCREEN);
    41783  }
     44247+}
    4178444248+#endif
    41785  
     44249+
    4178644250 /****************************************************************************
    4178744251  *
    41788 @@ -486,8 +532,13 @@
     44252  * Optimized cursor movement
     44253@@ -486,8 +542,13 @@
    4178944254 #define LASTTAB(fr)    ((fr > 0) ? ((fr - 1) / init_tabs) * init_tabs : -1)
    4179044255 
     
    4180244267 {
    4180344268     string_desc save;
    41804 @@ -500,38 +551,38 @@
     44269@@ -500,38 +561,38 @@
    4180544270 
    4180644271        if (row_address != 0
     
    4185144316        }
    4185244317 
    41853 @@ -550,17 +601,17 @@
     44318@@ -550,17 +611,17 @@
    4185444319        if (column_address
    4185544320            && _nc_safe_strcat(_nc_str_copy(target, &save),
     
    4187244337 
    4187344338            if (cursor_right) {
    41874 @@ -575,7 +626,7 @@
     44339@@ -575,7 +636,7 @@
    4187544340 
    4187644341                    for (fr = from_x; (nxt = NEXTTAB(fr)) <= to_x; fr = nxt) {
     
    4188144346                            break;
    4188244347                    }
    41883 @@ -599,7 +650,7 @@
     44348@@ -599,7 +660,7 @@
    4188444349                    && n < (int) check.s_size
    4188544350                    && vcost == 0
     
    4189044355                        ovw = FALSE;
    4189144356                }
    41892 @@ -616,8 +667,8 @@
     44357@@ -616,8 +677,8 @@
    4189344358                    int i;
    4189444359 
     
    4190144366                            || !Charable(ch)
    4190244367 #endif
    41903 @@ -631,13 +682,13 @@
     44368@@ -631,13 +692,13 @@
    4190444369                    int i;
    4190544370 
     
    4191844383                }
    4191944384 
    41920 @@ -650,10 +701,10 @@
     44385@@ -650,10 +711,10 @@
    4192144386            n = from_x - to_x;
    4192244387 
     
    4193144396 
    4193244397            if (cursor_left) {
    41933 @@ -667,7 +718,8 @@
     44398@@ -667,7 +728,8 @@
    4193444399 
    4193544400                    for (fr = from_x; (nxt = LASTTAB(fr)) >= to_x; fr = nxt) {
     
    4194144406                            break;
    4194244407                    }
    41943 @@ -676,7 +728,9 @@
     44408@@ -676,7 +738,9 @@
    4194444409                }
    4194544410 #endif /* USE_HARD_TABS */
     
    4195244417                if (lhcost < hcost
    4195344418                    && _nc_safe_strcat(_nc_str_copy(target, &save), str)) {
    41954 @@ -705,7 +759,7 @@
     44419@@ -705,7 +769,7 @@
    4195544420  */
    4195644421 
     
    4196144426 {
    4196244427     string_desc result;
    41963 @@ -723,9 +777,9 @@
     44428@@ -723,9 +787,9 @@
    4196444429 #define InitResult _nc_str_init(&result, buffer, sizeof(buffer))
    4196544430 
     
    4197344438 #if defined(TRACE) || defined(NCURSES_TEST)
    4197444439        if (!(_nc_optimize_enable & OPTIMIZE_MVCUR))
    41975 @@ -740,7 +794,7 @@
     44440@@ -740,7 +804,7 @@
    4197644441         * (like, say, local-movement \n getting mapped to some obscure
    4197744442         * character because A_ALTCHARSET is on).
     
    4198244447            if (!profiling) {
    4198344448                (void) fputs("nonlocal\n", stderr);
    41984 @@ -754,8 +808,10 @@
     44449@@ -754,8 +818,10 @@
    4198544450 #ifndef NO_OPTIMIZE
    4198644451     /* tactic #1: use local movement */
     
    4199544460        tactic = 1;
    4199644461        usecost = newcost;
    41997 @@ -763,42 +819,51 @@
     44462@@ -763,42 +829,51 @@
    4199844463 
    4199944464     /* tactic #2: use carriage-return + local movement */
     
    4206344528 
    4206444529     /*
    42065 @@ -808,26 +873,39 @@
     44530@@ -808,26 +883,39 @@
    4206644531        InitResult;
    4206744532     switch (tactic) {
     
    4210944574     }
    4211044575 #endif /* !NO_OPTIMIZE */
    42111 @@ -845,17 +923,19 @@
     44576@@ -845,25 +933,26 @@
    4211244577 
    4211344578     if (usecost != INFINITY) {
     
    4212544590 }
    4212644591 
    42127 -NCURSES_EXPORT(int)
     44592 NCURSES_EXPORT(int)
    4212844593-mvcur(int yold, int xold, int ynew, int xnew)
     44594+TINFO_MVCUR(NCURSES_SP_DCLx int yold, int xold, int ynew, int xnew)
    4212944595 /* optimized cursor move from (yold, xold) to (ynew, xnew) */
    42130 +NCURSES_EXPORT(int)
    42131 +NCURSES_SP_NAME(mvcur) (NCURSES_SP_DCLx
    42132 +                       int yold, int xold, int ynew, int xnew)
    4213344596 {
    4213444597     NCURSES_CH_T oldattr;
    4213544598     int code;
    42136 @@ -863,7 +943,7 @@
    42137      TR(TRACE_CALLS | TRACE_MOVE, (T_CALLED("mvcur(%d,%d,%d,%d)"),
    42138                                   yold, xold, ynew, xnew));
     44599 
     44600-    TR(TRACE_CALLS | TRACE_MOVE, (T_CALLED("mvcur(%d,%d,%d,%d)"),
     44601-                                 yold, xold, ynew, xnew));
     44602+    TR(TRACE_CALLS | TRACE_MOVE, (T_CALLED("_nc_tinfo_mvcur(%p,%d,%d,%d,%d)"),
     44603+                                 SP_PARM, yold, xold, ynew, xnew));
    4213944604 
    4214044605-    if (SP == 0) {
     
    4214344608     } else if (yold == ynew && xold == xnew) {
    4214444609        code = OK;
    42145 @@ -874,9 +954,9 @@
     44610@@ -874,9 +963,9 @@
    4214644611         * column position implied by wraparound or the lack thereof and
    4214744612         * rolling up the screen to get ynew on the screen.
     
    4215644621 
    4215744622        /*
    42158 @@ -884,38 +964,40 @@
     44623@@ -884,38 +973,40 @@
    4215944624         * character set -- these have a strong tendency to screw up the CR &
    4216044625         * LF used for local character motions!
     
    4221044675                    }
    4221144676                }
    42212 @@ -929,27 +1011,35 @@
     44677@@ -929,27 +1020,35 @@
    4221344678            }
    4221444679        }
     
    4224244707 }
    4224344708 
    42244 +#if NCURSES_SP_FUNCS
     44709+#if NCURSES_SP_FUNCS && !defined(USE_TERM_DRIVER)
    4224544710+NCURSES_EXPORT(int)
    4224644711+mvcur(int yold, int xold, int ynew, int xnew)
     
    4225344718 NCURSES_EXPORT_VAR(int) _nc_optimize_enable = OPTIMIZE_ALL;
    4225444719 #endif
    42255 @@ -1212,25 +1302,25 @@
     44720@@ -1212,25 +1311,25 @@
    4225644721                           speeds[i], overhead, totalest);
    4225744722            }
     
    4229844763diff -Naur ncurses-5.7.orig/ncurses/tty/lib_tstp.c ncurses-5.7/ncurses/tty/lib_tstp.c
    4229944764--- ncurses-5.7.orig/ncurses/tty/lib_tstp.c     2008-05-03 09:24:56.000000000 -0700
    42300 +++ ncurses-5.7/ncurses/tty/lib_tstp.c  2009-07-19 15:03:59.000000000 -0700
     44765+++ ncurses-5.7/ncurses/tty/lib_tstp.c  2009-09-12 08:51:37.000000000 -0700
    4230144766@@ -1,5 +1,5 @@
    4230244767 /****************************************************************************
     
    4244044905diff -Naur ncurses-5.7.orig/ncurses/tty/lib_twait.c ncurses-5.7/ncurses/tty/lib_twait.c
    4244144906--- ncurses-5.7.orig/ncurses/tty/lib_twait.c    2008-08-30 13:08:19.000000000 -0700
    42442 +++ ncurses-5.7/ncurses/tty/lib_twait.c 2009-07-19 15:03:53.000000000 -0700
     44907+++ ncurses-5.7/ncurses/tty/lib_twait.c 2009-09-12 08:51:30.000000000 -0700
    4244344908@@ -1,5 +1,5 @@
    4244444909 /****************************************************************************
     
    4264745112diff -Naur ncurses-5.7.orig/ncurses/tty/lib_vidattr.c ncurses-5.7/ncurses/tty/lib_vidattr.c
    4264845113--- ncurses-5.7.orig/ncurses/tty/lib_vidattr.c  2007-06-30 14:58:04.000000000 -0700
    42649 +++ ncurses-5.7/ncurses/tty/lib_vidattr.c       2009-07-19 15:04:09.000000000 -0700
     45114+++ ncurses-5.7/ncurses/tty/lib_vidattr.c       2009-09-12 08:52:04.000000000 -0700
    4265045115@@ -1,5 +1,5 @@
    4265145116 /****************************************************************************
     
    4267645141+#endif
    4267745142+
    42678 +MODULE_ID("$Id: lib_vidattr.c,v 1.57 2009/05/23 20:46:28 tom Exp $")
     45143+MODULE_ID("$Id: lib_vidattr.c,v 1.58 2009/08/15 22:12:01 tom Exp $")
    4267945144 
    4268045145-#define doPut(mode) TPUTS_TRACE(#mode); tputs(mode, 1, outc)
     
    4281045275        }
    4281145276 
    42812 @@ -282,27 +297,53 @@
     45277@@ -282,28 +297,53 @@
    4281345278     if (reverse)
    4281445279        newmode |= A_REVERSE;
     
    4286145326     chtype attrs = A_NORMAL;
    4286245327 
     45328-    T((T_CALLED("termattrs()")));
    4286345329+    T((T_CALLED("termattrs(%p)"), SP_PARM));
    4286445330+#ifdef USE_TERM_DRIVER
     
    4286745333+#else
    4286845334+
    42869      T((T_CALLED("termattrs()")));
    4287045335     if (enter_alt_charset_mode)
    4287145336        attrs |= A_ALTCHARSET;
    42872 @@ -331,8 +372,17 @@
     45337 
     45338@@ -331,8 +371,17 @@
    4287345339     if (enter_underline_mode)
    4287445340        attrs |= A_UNDERLINE;
     
    4289245358diff -Naur ncurses-5.7.orig/ncurses/tty/MKexpanded.sh ncurses-5.7/ncurses/tty/MKexpanded.sh
    4289345359--- ncurses-5.7.orig/ncurses/tty/MKexpanded.sh  2005-01-01 17:06:40.000000000 -0800
    42894 +++ ncurses-5.7/ncurses/tty/MKexpanded.sh       2009-07-19 15:04:13.000000000 -0700
     45360+++ ncurses-5.7/ncurses/tty/MKexpanded.sh       2009-09-12 08:51:50.000000000 -0700
    4289545361@@ -1,6 +1,6 @@
    4289645362 #! /bin/sh
     
    4299945465diff -Naur ncurses-5.7.orig/ncurses/tty/tty_update.c ncurses-5.7/ncurses/tty/tty_update.c
    4300045466--- ncurses-5.7.orig/ncurses/tty/tty_update.c   2008-08-30 13:08:19.000000000 -0700
    43001 +++ ncurses-5.7/ncurses/tty/tty_update.c        2009-07-19 15:04:11.000000000 -0700
     45467+++ ncurses-5.7/ncurses/tty/tty_update.c        2009-09-12 08:52:05.000000000 -0700
    4300245468@@ -1,5 +1,5 @@
    4300345469 /****************************************************************************
     
    4301545481 
    4301645482 /*-----------------------------------------------------------------
    43017 @@ -38,12 +39,17 @@
     45483@@ -38,12 +39,16 @@
    4301845484  *
    4301945485  *     The routine doupdate() and its dependents.
     
    4302445490  *-----------------------------------------------------------------*/
    4302545491 
    43026 +#define NEED_NCURSES_CH_T 1
    4302745492 #include <curses.priv.h>
    4302845493 
     
    4303445499 #undef __BEOS__
    4303545500 #endif
    43036 @@ -76,9 +82,8 @@
     45501@@ -76,9 +81,8 @@
    4303745502 #endif
    4303845503 
     
    4304145506 
    4304245507-MODULE_ID("$Id: tty_update.c,v 1.246 2008/08/30 20:08:19 tom Exp $")
    43043 +MODULE_ID("$Id: tty_update.c,v 1.258 2009/06/27 19:16:17 tom Exp $")
     45508+MODULE_ID("$Id: tty_update.c,v 1.258.1.2 2009/08/16 14:20:30 tom Exp tom $")
    4304445509 
    4304545510 /*
    4304645511  * This define controls the line-breakout optimization.  Every once in a
    43047 @@ -91,7 +96,7 @@
     45512@@ -91,7 +95,7 @@
    4304845513  */
    4304945514 #define CHECK_INTERVAL 5
     
    4305445519 static const NCURSES_CH_T blankchar = NewChar(BLANK_TEXT);
    4305545520 static NCURSES_CH_T normal = NewChar(BLANK_TEXT);
    43056 @@ -103,13 +108,23 @@
     45521@@ -103,13 +107,23 @@
    4305745522  */
    4305845523 /* #define POSITION_DEBUG */
     
    4307945544 #ifdef POSITION_DEBUG
    4308045545 /****************************************************************************
    43081 @@ -119,7 +134,7 @@
     45546@@ -119,7 +133,7 @@
    4308245547  ****************************************************************************/
    4308345548 
     
    4308845553 {
    4308945554     char buf[20];
    43090 @@ -129,10 +144,10 @@
     45555@@ -129,10 +143,10 @@
    4309145556     if (!_nc_tracing || (expected_y < 0 && expected_x < 0))
    4309245557        return;
     
    4310245567     do {
    4310345568        int ask = sizeof(buf) - 1 - (s - buf);
    43104 @@ -152,8 +167,12 @@
     45569@@ -152,8 +166,12 @@
    4310545570        if (expected_y < 0)
    4310645571            expected_y = y - 1;
     
    4311745582                    y - 1, x - 1, expected_y, expected_x, legend);
    4311845583        } else {
    43119 @@ -162,7 +181,7 @@
     45584@@ -162,7 +180,7 @@
    4312045585     }
    4312145586 }
     
    4312645591 
    4312745592 /****************************************************************************
    43128 @@ -172,19 +191,20 @@
     45593@@ -172,19 +190,22 @@
    4312945594  ****************************************************************************/
    4313045595 
     
    4314345608-    mvcur(SP->_cursrow, SP->_curscol, row, col);
    4314445609-    position_check(SP->_cursrow, SP->_curscol, "GoTo2");
    43145 +    NCURSES_SP_NAME(mvcur) (NCURSES_SP_ARGx SP_PARM->_cursrow,
    43146 +                           SP_PARM->_curscol, row, col);
     45610+    TINFO_MVCUR(NCURSES_SP_ARGx
     45611+               SP_PARM->_cursrow,
     45612+               SP_PARM->_curscol,
     45613+               row, col);
    4314745614+    position_check(SP_PARM, SP_PARM->_cursrow, SP_PARM->_curscol, "GoTo2");
    4314845615 }
     
    4315445621     int chlen = 1;
    4315545622     NCURSES_CH_T my_ch;
    43156 @@ -194,7 +214,7 @@
     45623@@ -194,7 +215,7 @@
    4315745624 
    4315845625     TR(TRACE_CHARPUT, ("PutAttrChar(%s) at (%d, %d)",
     
    4316345630     /*
    4316445631      * If this is not a valid character, there is nothing more to do.
    43165 @@ -224,12 +244,12 @@
     45632@@ -224,12 +245,12 @@
    4316645633         */
    4316745634        if (is8bits(CharOf(CHDEREF(ch)))
     
    4318045647            ;
    4318145648        } else {
    43182 @@ -241,7 +261,7 @@
     45649@@ -241,7 +262,7 @@
    4318345650 #endif
    4318445651 
     
    4318945656        my_ch = CHDEREF(ch);    /* work around const param */
    4319045657 #if USE_WIDEC_SUPPORT
    43191 @@ -251,8 +271,8 @@
     45658@@ -251,8 +272,8 @@
    4319245659         * character, and uses the wide-character mapping when we expect the
    4319345660         * normal one to be broken (by mis-design ;-).
     
    4320045667            my_ch = _nc_wacs[CharOf(my_ch)];
    4320145668        }
    43202 @@ -265,9 +285,9 @@
     45669@@ -265,9 +286,9 @@
    4320345670         */
    4320445671        if (AttrOf(attr) & A_ALTCHARSET) {
     
    4321245679                if (temp == 0)
    4321345680                    temp = ' ';
    43214 @@ -282,28 +302,28 @@
     45681@@ -282,28 +303,28 @@
    4321545682        ch = CHREF(tilde);
    4321645683     }
     
    4324845715 {
    4324945716     bool have_pending = FALSE;
    43250 @@ -313,13 +333,13 @@
     45717@@ -313,13 +334,13 @@
    4325145718      * have the refreshing slow down drastically (or stop) if there's an
    4325245719      * unread character available.
     
    4326545732        if (poll(fds, 1, 0) > 0) {
    4326645733            have_pending = TRUE;
    43267 @@ -347,43 +367,52 @@
     45734@@ -347,43 +368,52 @@
    4326845735            ktimeout.tv_usec = 0;
    4326945736 
     
    4333345800 }
    4333445801 
    43335 @@ -391,7 +420,7 @@
     45802@@ -391,7 +421,7 @@
    4333645803  * Wrap the cursor position, i.e., advance to the beginning of the next line.
    4333745804  */
     
    4334245809     if (eat_newline_glitch) {
    4334345810        /*
    43344 @@ -407,40 +436,45 @@
     45811@@ -407,40 +437,45 @@
    4334545812         * it's safe to just tell the code that the cursor is in hyperspace and
    4334645813         * let the next mvcur() call straighten things out.
     
    4340645873 
    4340745874 /*
    43408 @@ -450,19 +484,19 @@
     45875@@ -450,19 +485,19 @@
    4340945876  * or can be output by clearing (A_COLOR in case of bce-terminal) are excluded.
    4341045877  */
     
    4343145898                return FALSE;
    4343245899        }
    43433 @@ -488,7 +522,7 @@
     45900@@ -488,7 +523,7 @@
    4343445901  * This code is optimized using ech and rep.
    4343545902  */
     
    4344045907     int i;
    4344145908 
    43442 @@ -500,13 +534,13 @@
     45909@@ -500,13 +535,13 @@
    4344345910            NCURSES_CH_T ntext0;
    4344445911 
     
    4345645923            }
    4345745924            runcount = 2;
    43458 @@ -523,10 +557,11 @@
     45925@@ -523,10 +558,11 @@
    4345945926             * which it would be marginally advantageous.
    4346045927             */
     
    4347245939                /*
    4347345940                 * If this is the last part of the given interval,
    43474 @@ -534,27 +569,34 @@
     45941@@ -534,27 +570,34 @@
    4347545942                 * last update on the line.
    4347645943                 */
     
    4351645983            ntext += runcount;
    4351745984            num -= runcount;
    43518 @@ -563,7 +605,7 @@
     45985@@ -563,7 +606,7 @@
    4351945986     }
    4352045987 
     
    4352545992 }
    4352645993 
    43527 @@ -576,39 +618,40 @@
     45994@@ -576,39 +619,40 @@
    4352845995  * Returns: same as EmitRange
    4352945996  */
     
    4357546042 
    4357646043 /* leave unbracketed here so 'indent' works */
    43577 @@ -618,7 +661,7 @@
     46044@@ -618,7 +662,7 @@
    4357846045                if_USE_SCROLL_HINTS(win->_line[row].oldindex = row)
    4357946046 
    4358046047 NCURSES_EXPORT(int)
    4358146048-doupdate(void)
    43582 +NCURSES_SP_NAME(doupdate) (NCURSES_SP_DCL0)
     46049+TINFO_DOUPDATE(NCURSES_SP_DCL0)
    4358346050 {
    4358446051     int i;
    4358546052     int nonempty;
    43586 @@ -626,30 +669,49 @@
     46053@@ -626,30 +670,49 @@
    4358746054     struct tms before, after;
    4358846055 #endif /* USE_TRACE_TIMES */
     
    4364346110         * This is a transparent extension:  XSI does not address it,
    4364446111         * and applications need not know that ncurses can do it.
    43645 @@ -658,20 +720,20 @@
     46112@@ -658,20 +721,20 @@
    4364646113         * (this can happen in an xterm, for example), and resize the
    4364746114         * ncurses data structures accordingly.
     
    4367146138 #if USE_TRACE_TIMES
    4367246139     /* zero the metering machinery */
    43673 @@ -695,11 +757,11 @@
     46140@@ -695,11 +758,11 @@
    4367446141        int j, k;
    4367546142        attr_t rattr = A_NORMAL;
     
    4368746154 
    4368846155                /* is an attribute turned on here? */
    43689 @@ -717,8 +779,8 @@
     46156@@ -717,8 +780,8 @@
    4369046157                 * there's enough room to set the attribute before the first
    4369146158                 * non-blank in the run.
     
    4369846165                    continue;
    4369946166                }
    43700 @@ -727,14 +789,14 @@
     46167@@ -727,14 +790,14 @@
    4370146168                for (k = 1; k <= magic_cookie_glitch; k++) {
    4370246169                    if (j - k < 0
     
    4371546182                                          : ":unsafe")));
    4371646183                        break;
    43717 @@ -745,10 +807,11 @@
     46184@@ -745,10 +808,11 @@
    4371846185                    int m, n = j;
    4371946186 
     
    4373146198                                TR(TRACE_ATTRS,
    4373246199                                   ("Range attributed with %s ends at (%d, %d)",
    43733 @@ -764,7 +827,8 @@
     46200@@ -764,7 +828,8 @@
    4373446201                  foundit:;
    4373546202 
     
    4374146208                        /*
    4374246209                         * If there are safely-attributed blanks at the end of
    43743 @@ -773,15 +837,15 @@
     46210@@ -773,15 +838,15 @@
    4374446211                         */
    4374546212                        while (n >= 0
     
    4376046227                                TR(TRACE_ATTRS,
    4376146228                                   ("No room at end in %d,%d%s%s",
    43762 @@ -789,7 +853,7 @@
     46229@@ -789,7 +854,7 @@
    4376346230                                    (ISBLANK(lastline[n + k])
    4376446231                                     ? ""
     
    4376946236                                     : ":unsafe")));
    4377046237                                break;
    43771 @@ -806,12 +870,12 @@
     46238@@ -806,12 +871,12 @@
    4377246239                        _traceattr(turnon), i, j));
    4377346240 
     
    4378646253                        q = 0;
    4378746254                    }
    43788 @@ -837,7 +901,7 @@
     46255@@ -837,7 +902,7 @@
    4378946256        /* show altered highlights after magic-cookie check */
    4379046257        if (USE_TRACEF(TRACE_UPDATE)) {
     
    4379546262        }
    4379646263 #endif /* TRACE */
    43797 @@ -845,23 +909,23 @@
     46264@@ -845,23 +910,23 @@
    4379846265 #endif /* USE_XMC_SUPPORT */
    4379946266 
     
    4382846295        TR(TRACE_UPDATE, ("Transforming lines, nonempty %d", nonempty));
    4382946296        for (i = 0; i < nonempty; i++) {
    43830 @@ -869,7 +933,7 @@
     46297@@ -869,7 +934,7 @@
    4383146298             * Here is our line-breakout optimization.
    4383246299             */
     
    4383746304                changedlines = 0;
    4383846305            }
    43839 @@ -880,35 +944,35 @@
     46306@@ -880,35 +945,35 @@
    4384046307             * is normally set by _nc_scroll_window in the
    4384146308             * vertical-movement optimization code,
     
    4388846355 
    4388946356   cleanup:
    43890 @@ -921,10 +985,10 @@
     46357@@ -921,10 +986,10 @@
    4389146358 #if USE_XMC_SUPPORT
    4389246359     if (magic_cookie_glitch != 0)
     
    4390246369 #if USE_TRACE_TIMES
    4390346370     (void) times(&after);
    43904 @@ -940,6 +1004,14 @@
     46371@@ -940,6 +1005,14 @@
    4390546372     returnCode(OK);
    4390646373 }
    4390746374 
    43908 +#if NCURSES_SP_FUNCS
     46375+#if NCURSES_SP_FUNCS && !defined(USE_TERM_DRIVER)
    4390946376+NCURSES_EXPORT(int)
    4391046377+doupdate(void)
    4391146378+{
    43912 +    return NCURSES_SP_NAME(doupdate) (CURRENT_SCREEN);
     46379+    return TINFO_DOUPDATE(CURRENT_SCREEN);
    4391346380+}
    4391446381+#endif
     
    4391746384  *     ClrBlank(win)
    4391846385  *
    43919 @@ -951,14 +1023,14 @@
     46386@@ -951,14 +1024,14 @@
    4392046387  *     in the wbkgd() call.  Assume 'stdscr' for this case.
    4392146388  */
     
    4393546402 }
    4393646403 
    43937 @@ -970,23 +1042,24 @@
     46404@@ -970,23 +1043,24 @@
    4393846405 */
    4393946406 
     
    4397146438 }
    4397246439 
    43973 @@ -997,15 +1070,16 @@
     46440@@ -997,15 +1071,16 @@
    4397446441 */
    4397546442 
     
    4399346460                if (!CharEq(*cp, blank)) {
    4399446461                    *cp = blank;
    43995 @@ -1018,14 +1092,14 @@
     46462@@ -1018,14 +1093,14 @@
    4399646463     }
    4399746464 
     
    4401346480     }
    4401446481 }
    44015 @@ -1037,23 +1111,29 @@
     46482@@ -1037,23 +1112,29 @@
    4401646483 */
    4401746484 
     
    4405546522 }
    4405646523 
    44057 @@ -1065,26 +1145,26 @@
     46524@@ -1065,26 +1146,26 @@
    4405846525  *     screen, checking if each is blank, and one or more are changed.
    4405946526  */
     
    4408846555            if (!ok)
    4408946556                top = row;
    44090 @@ -1092,11 +1172,11 @@
     46557@@ -1092,11 +1173,11 @@
    4409146558 
    4409246559        /* don't use clr_eos for just one line if clr_eol available */
     
    4410546572        }
    4410646573     }
    44107 @@ -1105,15 +1185,15 @@
     46574@@ -1105,15 +1186,15 @@
    4410846575 
    4410946576 #if USE_XMC_SUPPORT
     
    4412746594 
    4412846595 /*
    44129 @@ -1135,19 +1215,19 @@
     46596@@ -1135,19 +1216,19 @@
    4413046597 */
    4413146598 
     
    4415346620     /*
    4415446621      * If we have colors, there is the possibility of having two color pairs
    44155 @@ -1155,19 +1235,20 @@
     46622@@ -1155,19 +1236,20 @@
    4415646623      * for this case, and update the old line with the new line's colors when
    4415746624      * they are equivalent.
     
    4417946646                    }
    4418046647                }
    44181 @@ -1177,7 +1258,7 @@
     46648@@ -1177,7 +1259,7 @@
    4418246649 
    4418346650     if (ceol_standout_glitch && clr_eol) {
     
    4418846655                attrchanged = TRUE;
    4418946656                break;
    44190 @@ -1189,9 +1270,13 @@
     46657@@ -1189,9 +1271,13 @@
    4419146658     firstChar = 0;
    4419246659 
     
    4420546672 
    4420646673        /*
    44207 @@ -1206,8 +1291,8 @@
     46674@@ -1206,8 +1292,8 @@
    4420846675         * following operation.
    4420946676         */
     
    4421646683 
    4421746684            /* check for turn-on:
    44218 @@ -1216,26 +1301,30 @@
     46685@@ -1216,26 +1302,30 @@
    4421946686             */
    4422046687            if (ISBLANK(newLine[n])
     
    4425546722            }
    4425646723 
    44257 @@ -1246,38 +1335,42 @@
     46724@@ -1246,38 +1336,42 @@
    4425846725 
    4425946726        /* it may be cheap to clear leading whitespace with clr_bol */
     
    4431146778 
    4431246779                    while (firstChar < nFirstChar)
    44313 @@ -1286,29 +1379,34 @@
     46780@@ -1286,29 +1380,34 @@
    4431446781            }
    4431546782        } else {
     
    4435346820                       newLine + firstChar,
    4435446821                       (nLastChar - firstChar + 1) * sizeof(NCURSES_CH_T));
    44355 @@ -1318,32 +1416,44 @@
     46822@@ -1318,32 +1417,44 @@
    4435646823        }
    4435746824 
     
    4441146878        } else {
    4441246879            int nLastNonblank = nLastChar;
    44413 @@ -1364,8 +1474,13 @@
     46880@@ -1364,8 +1475,13 @@
    4441446881 
    4441546882            n = min(oLastChar, nLastChar);
     
    4442746894 
    4442846895            if (oLastChar < nLastChar) {
    44429 @@ -1376,21 +1491,26 @@
     46896@@ -1376,21 +1492,26 @@
    4443046897                    --oLastChar;
    4443146898                }
     
    4446446931                    /*
    4446546932                     * The delete-char sequence will
    44466 @@ -1400,18 +1520,18 @@
     46933@@ -1400,18 +1521,18 @@
    4446746934                     * setting the video attributes from
    4446846935                     * the last character on the row.
     
    4448746954     return;
    4448846955 }
    44489 @@ -1424,7 +1544,7 @@
     46956@@ -1424,7 +1545,7 @@
    4449046957 */
    4449146958 
     
    4449646963     int i, j;
    4449746964     bool fast_clear = (clear_screen || clr_eos || clr_eol);
    44498 @@ -1432,9 +1552,13 @@
     46965@@ -1432,9 +1553,13 @@
    4449946966     TR(TRACE_UPDATE, ("ClearScreen() called"));
    4450046967 
     
    4451346980            fast_clear = FALSE;
    4451446981        }
    44515 @@ -1443,42 +1567,46 @@
     46982@@ -1443,42 +1568,46 @@
    4451646983 
    4451746984     if (fast_clear) {
     
    4458647053 
    4458747054     TR(TRACE_UPDATE, ("screen cleared"));
    44588 @@ -1492,49 +1620,52 @@
     47055@@ -1492,49 +1621,52 @@
    4458947056 */
    4459047057 
     
    4465147118 
    4465247119 /*
    44653 @@ -1545,22 +1676,25 @@
     47120@@ -1545,22 +1677,25 @@
    4465447121 */
    4465547122 
     
    4468447151     }
    4468547152 }
    44686 @@ -1599,54 +1733,66 @@
     47153@@ -1599,54 +1734,66 @@
    4468747154 
    4468847155 /* Try to scroll up assuming given csr (miny, maxy). Returns ERR on failure */
     
    4477447241     }
    4477547242 #endif
    44776 @@ -1656,55 +1802,66 @@
     47243@@ -1656,55 +1803,66 @@
    4477747244 /* Try to scroll down assuming given csr (miny, maxy). Returns ERR on failure */
    4477847245 /* n > 0 */
     
    4486447331     }
    4486547332 #endif
    44866 @@ -1714,40 +1871,46 @@
     47333@@ -1714,40 +1872,46 @@
    4486747334 /* scroll by using delete_line at del and insert_line at ins */
    4486847335 /* n > 0 */
     
    4492247389     }
    4492347390 
    44924 @@ -1763,15 +1926,24 @@
     47391@@ -1763,15 +1927,24 @@
    4492547392  * save/restore cursor capabilities if the terminal has them.
    4492647393  */
     
    4495047417 #if USE_XMC_SUPPORT
    4495147418     /*
    44952 @@ -1787,34 +1959,36 @@
     47419@@ -1787,34 +1960,36 @@
    4495347420         * Explicitly clear if stuff pushed off top of region might
    4495447421         * be saved by the terminal.
     
    4499847465        /*
    4499947466         * Clear the newly shifted-in text.
    45000 @@ -1823,44 +1997,49 @@
     47467@@ -1823,44 +1998,49 @@
    4500147468            && (non_dest_scroll_region || (memory_below && bot == maxy))) {
    4500247469            static const NCURSES_CH_T blank2 = NewChar(BLANK_TEXT);
     
    4506347530        /*
    4506447531         * Clear the newly shifted-in text.
    45065 @@ -1869,8 +2048,8 @@
     47532@@ -1869,8 +2049,8 @@
    4506647533            && (non_dest_scroll_region || (memory_above && top == 0))) {
    4506747534            static const NCURSES_CH_T blank2 = NewChar(BLANK_TEXT);
     
    4507447541        }
    4507547542     }
    45076 @@ -1878,99 +2057,159 @@
     47543@@ -1878,99 +2058,159 @@
    4507747544     if (res == ERR)
    4507847545        return (ERR);
     
    4521347680 
    4521447681-       mvcur(SP->_cursrow, SP->_curscol, screen_lines - 1, 0);
    45215 +       NCURSES_SP_NAME(mvcur) (NCURSES_SP_ARGx
    45216 +                               SP_PARM->_cursrow,
    45217 +                               SP_PARM->_curscol,
    45218 +                               screen_lines(SP_PARM) - 1,
    45219 +                               0);
     47682+       TINFO_MVCUR(NCURSES_SP_ARGx
     47683+                   SP_PARM->_cursrow,
     47684+                   SP_PARM->_curscol,
     47685+                   screen_lines(SP_PARM) - 1,
     47686+                   0);
    4522047687 
    4522147688-       ClrToEOL(blank, TRUE);
     
    4527847745diff -Naur ncurses-5.7.orig/ncurses/widechar/lib_add_wch.c ncurses-5.7/ncurses/widechar/lib_add_wch.c
    4527947746--- ncurses-5.7.orig/ncurses/widechar/lib_add_wch.c     2006-12-02 13:19:17.000000000 -0800
    45280 +++ ncurses-5.7/ncurses/widechar/lib_add_wch.c  2009-07-19 15:04:13.000000000 -0700
     47747+++ ncurses-5.7/ncurses/widechar/lib_add_wch.c  2009-09-12 08:51:56.000000000 -0700
    4528147748@@ -1,5 +1,5 @@
    4528247749 /****************************************************************************
     
    4528647753  * Permission is hereby granted, free of charge, to any person obtaining a  *
    4528747754  * copy of this software and associated documentation files (the            *
    45288 @@ -35,39 +35,389 @@
     47755@@ -35,39 +35,392 @@
    4528947756 
    4529047757 #include <curses.priv.h>
     
    4529747764-NCURSES_EXPORT(int)
    4529847765-wadd_wch(WINDOW *win, const cchar_t *wch)
    45299 +MODULE_ID("$Id: lib_add_wch.c,v 1.7 2009/07/04 21:59:25 tom Exp $")
     47766+MODULE_ID("$Id: lib_add_wch.c,v 1.8 2009/07/25 14:38:01 tom Exp $")
    4530047767+
    4530147768+/* clone/adapt lib_addch.c */
     
    4558548052+    wchar_t *s;
    4558648053+    int tabsize = 8;
     48054+#if USE_REENTRANT
     48055+    SCREEN *sp = _nc_screen_of(win);
     48056+#endif
    4558748057+
    4558848058+    /*
     
    4560548075+    case '\t':
    4560648076+#if USE_REENTRANT
    45607 +       tabsize = sp->_TABSIZE;
     48077+       tabsize = *ptrTabsize(sp);
    4560848078+#else
    4560948079+       tabsize = TABSIZE;
     
    4570048170 
    4570148171     TR(TRACE_VIRTPUT | TRACE_CCALLS, (T_RETURN("%d"), code));
    45702 @@ -77,37 +427,18 @@
     48172@@ -77,37 +430,18 @@
    4570348173 NCURSES_EXPORT(int)
    4570448174 wecho_wchar(WINDOW *win, const cchar_t *wch)
     
    4574848218diff -Naur ncurses-5.7.orig/ncurses/widechar/lib_cchar.c ncurses-5.7/ncurses/widechar/lib_cchar.c
    4574948219--- ncurses-5.7.orig/ncurses/widechar/lib_cchar.c       2007-05-12 12:03:06.000000000 -0700
    45750 +++ ncurses-5.7/ncurses/widechar/lib_cchar.c    2009-07-19 15:04:17.000000000 -0700
     48220+++ ncurses-5.7/ncurses/widechar/lib_cchar.c    2009-09-12 08:51:54.000000000 -0700
    4575148221@@ -1,5 +1,5 @@
    4575248222 /****************************************************************************
     
    4579148261diff -Naur ncurses-5.7.orig/ncurses/widechar/lib_get_wch.c ncurses-5.7/ncurses/widechar/lib_get_wch.c
    4579248262--- ncurses-5.7.orig/ncurses/widechar/lib_get_wch.c     2008-08-16 12:22:55.000000000 -0700
    45793 +++ ncurses-5.7/ncurses/widechar/lib_get_wch.c  2009-07-19 15:03:53.000000000 -0700
     48263+++ ncurses-5.7/ncurses/widechar/lib_get_wch.c  2009-09-12 08:51:30.000000000 -0700
    4579448264@@ -1,5 +1,5 @@
    4579548265 /****************************************************************************
     
    4583448304diff -Naur ncurses-5.7.orig/ncurses/widechar/lib_get_wstr.c ncurses-5.7/ncurses/widechar/lib_get_wstr.c
    4583548305--- ncurses-5.7.orig/ncurses/widechar/lib_get_wstr.c    2008-08-16 12:25:33.000000000 -0700
    45836 +++ ncurses-5.7/ncurses/widechar/lib_get_wstr.c 2009-07-19 15:02:22.000000000 -0700
     48306+++ ncurses-5.7/ncurses/widechar/lib_get_wstr.c 2009-09-12 08:51:17.000000000 -0700
    4583748307@@ -38,9 +38,8 @@
    4583848308 */
     
    4584848318diff -Naur ncurses-5.7.orig/ncurses/widechar/lib_ins_wch.c ncurses-5.7/ncurses/widechar/lib_ins_wch.c
    4584948319--- ncurses-5.7.orig/ncurses/widechar/lib_ins_wch.c     2005-12-03 12:24:19.000000000 -0800
    45850 +++ ncurses-5.7/ncurses/widechar/lib_ins_wch.c  2009-07-19 15:04:04.000000000 -0700
     48320+++ ncurses-5.7/ncurses/widechar/lib_ins_wch.c  2009-09-12 08:51:42.000000000 -0700
    4585148321@@ -1,5 +1,5 @@
    4585248322 /****************************************************************************
     
    4588548355diff -Naur ncurses-5.7.orig/ncurses/widechar/lib_unget_wch.c ncurses-5.7/ncurses/widechar/lib_unget_wch.c
    4588648356--- ncurses-5.7.orig/ncurses/widechar/lib_unget_wch.c   2008-06-07 07:50:37.000000000 -0700
    45887 +++ ncurses-5.7/ncurses/widechar/lib_unget_wch.c        2009-07-19 15:03:53.000000000 -0700
     48357+++ ncurses-5.7/ncurses/widechar/lib_unget_wch.c        2009-09-12 08:51:30.000000000 -0700
    4588848358@@ -1,5 +1,5 @@
    4588948359 /****************************************************************************
     
    4594248412diff -Naur ncurses-5.7.orig/ncurses/widechar/lib_vid_attr.c ncurses-5.7/ncurses/widechar/lib_vid_attr.c
    4594348413--- ncurses-5.7.orig/ncurses/widechar/lib_vid_attr.c    2007-06-30 15:03:02.000000000 -0700
    45944 +++ ncurses-5.7/ncurses/widechar/lib_vid_attr.c 2009-07-19 15:04:00.000000000 -0700
     48414+++ ncurses-5.7/ncurses/widechar/lib_vid_attr.c 2009-09-12 08:51:37.000000000 -0700
    4594548415@@ -1,5 +1,5 @@
    4594648416 /****************************************************************************
     
    4617448644diff -Naur ncurses-5.7.orig/ncurses/widechar/lib_wacs.c ncurses-5.7/ncurses/widechar/lib_wacs.c
    4617548645--- ncurses-5.7.orig/ncurses/widechar/lib_wacs.c        2006-12-17 07:16:17.000000000 -0800
    46176 +++ ncurses-5.7/ncurses/widechar/lib_wacs.c     2009-07-19 15:02:22.000000000 -0700
     48646+++ ncurses-5.7/ncurses/widechar/lib_wacs.c     2009-09-12 08:51:17.000000000 -0700
    4617748647@@ -31,9 +31,8 @@
    4617848648  ****************************************************************************/
     
    4618848658diff -Naur ncurses-5.7.orig/ncurses/widechar/lib_wunctrl.c ncurses-5.7/ncurses/widechar/lib_wunctrl.c
    4618948659--- ncurses-5.7.orig/ncurses/widechar/lib_wunctrl.c     2007-06-12 13:22:32.000000000 -0700
    46190 +++ ncurses-5.7/ncurses/widechar/lib_wunctrl.c  2009-07-19 15:03:53.000000000 -0700
     48660+++ ncurses-5.7/ncurses/widechar/lib_wunctrl.c  2009-09-12 08:51:30.000000000 -0700
    4619148661@@ -1,5 +1,5 @@
    4619248662 /****************************************************************************
     
    4623748707diff -Naur ncurses-5.7.orig/ncurses/win32con/gettimeofday.c ncurses-5.7/ncurses/win32con/gettimeofday.c
    4623848708--- ncurses-5.7.orig/ncurses/win32con/gettimeofday.c    1969-12-31 16:00:00.000000000 -0800
    46239 +++ ncurses-5.7/ncurses/win32con/gettimeofday.c 2009-07-19 15:04:11.000000000 -0700
     48709+++ ncurses-5.7/ncurses/win32con/gettimeofday.c 2009-09-12 08:51:49.000000000 -0700
    4624048710@@ -0,0 +1,51 @@
    4624148711+/****************************************************************************
     
    4629248762diff -Naur ncurses-5.7.orig/ncurses/win32con/win_driver.c ncurses-5.7/ncurses/win32con/win_driver.c
    4629348763--- ncurses-5.7.orig/ncurses/win32con/win_driver.c      1969-12-31 16:00:00.000000000 -0800
    46294 +++ ncurses-5.7/ncurses/win32con/win_driver.c   2009-07-19 15:04:11.000000000 -0700
     48764+++ ncurses-5.7/ncurses/win32con/win_driver.c   2009-09-12 08:51:49.000000000 -0700
    4629548765@@ -0,0 +1,1085 @@
    4629648766+/****************************************************************************
     
    4738149851diff -Naur ncurses-5.7.orig/NEWS ncurses-5.7/NEWS
    4738249852--- ncurses-5.7.orig/NEWS       2008-11-01 17:56:22.000000000 -0700
    47383 +++ ncurses-5.7/NEWS    2009-07-19 15:04:17.000000000 -0700
     49853+++ ncurses-5.7/NEWS    2009-09-12 08:52:10.000000000 -0700
    4738449854@@ -1,5 +1,5 @@
    4738549855 -------------------------------------------------------------------------------
     
    4739449864 -------------------------------------------------------------------------------
    4739549865--- $Id: NEWS,v 1.1320 2008/11/02 00:56:22 tom Exp $
    47396 +-- $Id: NEWS,v 1.1409 2009/07/19 00:09:05 tom Exp $
     49866+-- $Id: NEWS,v 1.1430 2009/09/06 16:03:13 tom Exp $
    4739749867 -------------------------------------------------------------------------------
    4739849868 
    4739949869 This is a log of changes that ncurses has gone through since Zeyd started
    47400 @@ -45,6 +45,300 @@
     49870@@ -45,6 +45,362 @@
    4740149871 Changes through 1.9.9e did not credit all contributions;
    4740249872 it is not possible to add this information.
    4740349873 
     49874+20090906
     49875+       + fix typo s/is_timeout/is_notimeout/ which made "man is_notimeout" not
     49876+         work.
     49877+       + add null-pointer checks to other opaque-functions.
     49878+       + add is_pad() and is_subwin() functions for opaque access to WINDOW
     49879+         (discussion with Mark Dickinson).
     49880+       + correct merge to lib_newterm.c, which broke when sp-funcs was
     49881+         enabled.
     49882+
     49883+20090905
     49884+       + build-fix for building outside source-tree (report by Sven Joachim).
     49885+       + fix Debian lintian warning for man/tabs.1 by making section number
     49886+         agree with file-suffix (report by Sven Joachim).
     49887+       + continue integrating "sp-funcs" by Juergen Pfeifer (incomplete).
     49888+
     49889+20090829
     49890+       + workaround for bug in g++ 4.1-4.4 warnings for wattrset() macro on
     49891+         amd64 (Debian #542031).
     49892+       + fix typo in curs_mouse.3x (Debian #429198).
     49893+
     49894+20090822
     49895+       + continue integrating "sp-funcs" by Juergen Pfeifer (incomplete).
     49896+
     49897+20090815
     49898+       + correct use of terminfo capabilities for initializing soft-keys,
     49899+         broken in 20090509 merging.
     49900+       + modify wgetch() to ensure it checks SIGWINCH when it gets an error
     49901+         in non-blocking mode (patch by Clemens Ladisch).
     49902+       + use PATH_SEPARATOR symbol when substituting into run_tic.sh, to
     49903+         help with builds on non-Unix platforms such as OS/2 EMX.
     49904+       + modify scripting for misc/run_tic.sh to test configure script's
     49905+         $cross_compiling variable directly rather than comparing host/build
     49906+         compiler names (prompted by comment in GenToo #249363).
     49907+       + fix configure script option --with-database, which was coded as an
     49908+         enable-type switch.
     49909+       + build-fixes for --srcdir (report by Frederic L W Meunier).
     49910+
     49911+20090808
     49912+       + separate _nc_find_entry() and _nc_find_type_entry() from
     49913+         implementation details of hash function.
     49914+
     49915+20090803
     49916+       + add tabs.1 to man/man_db.renames
     49917+       + modify lib_addch.c to compensate for removal of wide-character test
     49918+         from unctrl() in 20090704 (Debian #539735).
     49919+
     49920+20090801
     49921+       + improve discussion in INSTALL for use of system's tic/infocmp for
     49922+         cross-compiling and building fallbacks.
     49923+       + modify test/demo_termcap.c to correspond better to options in
     49924+         test/demo_terminfo.c
     49925+       + continue integrating "sp-funcs" by Juergen Pfeifer (incomplete).
     49926+       + fix logic for 'V' in test/ncurses.c tests f/F.
     49927+
     49928+20090728
     49929+       + correct logic in tigetnum(), which caused tput program to treat all
     49930+         string capabilities as numeric (report by Rajeev V Pillai,
     49931+         cf: 20090711).
     49932+
     49933+20090725
     49934+       + continue integrating "sp-funcs" by Juergen Pfeifer (incomplete).
     49935+
    4740449936+20090718
    4740549937+       + fix a null-pointer check in _nc_format_slks() in lib_slk.c, from
     
    4770150233diff -Naur ncurses-5.7.orig/panel/Makefile.in ncurses-5.7/panel/Makefile.in
    4770250234--- ncurses-5.7.orig/panel/Makefile.in  2007-04-28 07:56:11.000000000 -0700
    47703 +++ ncurses-5.7/panel/Makefile.in       2009-07-19 15:03:48.000000000 -0700
     50235+++ ncurses-5.7/panel/Makefile.in       2009-09-12 08:51:25.000000000 -0700
    4770450236@@ -1,6 +1,6 @@
    4770550237-# $Id: Makefile.in,v 1.52 2007/04/28 14:56:11 tom Exp $
     
    4773050262diff -Naur ncurses-5.7.orig/panel/p_above.c ncurses-5.7/panel/p_above.c
    4773150263--- ncurses-5.7.orig/panel/p_above.c    2005-02-19 08:44:57.000000000 -0800
    47732 +++ ncurses-5.7/panel/p_above.c 2009-07-19 15:03:51.000000000 -0700
     50264+++ ncurses-5.7/panel/p_above.c 2009-09-12 08:51:28.000000000 -0700
    4773350265@@ -1,5 +1,5 @@
    4773450266 /****************************************************************************
     
    4780250334diff -Naur ncurses-5.7.orig/panel/panel.c ncurses-5.7/panel/panel.c
    4780350335--- ncurses-5.7.orig/panel/panel.c      2005-02-19 10:04:31.000000000 -0800
    47804 +++ ncurses-5.7/panel/panel.c   2009-07-19 15:03:51.000000000 -0700
     50336+++ ncurses-5.7/panel/panel.c   2009-09-12 08:51:28.000000000 -0700
    4780550337@@ -1,5 +1,5 @@
    4780650338 /****************************************************************************
     
    4783750369diff -Naur ncurses-5.7.orig/panel/panel.h ncurses-5.7/panel/panel.h
    4783850370--- ncurses-5.7.orig/panel/panel.h      2006-05-27 12:49:40.000000000 -0700
    47839 +++ ncurses-5.7/panel/panel.h   2009-07-19 15:03:51.000000000 -0700
     50371+++ ncurses-5.7/panel/panel.h   2009-09-12 08:51:28.000000000 -0700
    4784050372@@ -1,5 +1,5 @@
    4784150373 /****************************************************************************
     
    4787350405diff -Naur ncurses-5.7.orig/panel/panel.priv.h ncurses-5.7/panel/panel.priv.h
    4787450406--- ncurses-5.7.orig/panel/panel.priv.h 2008-09-27 15:36:11.000000000 -0700
    47875 +++ ncurses-5.7/panel/panel.priv.h      2009-07-19 15:03:51.000000000 -0700
     50407+++ ncurses-5.7/panel/panel.priv.h      2009-09-12 08:51:28.000000000 -0700
    4787650408@@ -1,5 +1,5 @@
    4787750409 /****************************************************************************
     
    4798650518diff -Naur ncurses-5.7.orig/panel/p_below.c ncurses-5.7/panel/p_below.c
    4798750519--- ncurses-5.7.orig/panel/p_below.c    2005-02-19 08:45:10.000000000 -0800
    47988 +++ ncurses-5.7/panel/p_below.c 2009-07-19 15:03:51.000000000 -0700
     50520+++ ncurses-5.7/panel/p_below.c 2009-09-12 08:51:28.000000000 -0700
    4798950521@@ -1,5 +1,5 @@
    4799050522 /****************************************************************************
     
    4805950591diff -Naur ncurses-5.7.orig/panel/p_bottom.c ncurses-5.7/panel/p_bottom.c
    4806050592--- ncurses-5.7.orig/panel/p_bottom.c   2005-02-19 08:38:16.000000000 -0800
    48061 +++ ncurses-5.7/panel/p_bottom.c        2009-07-19 15:03:51.000000000 -0700
     50593+++ ncurses-5.7/panel/p_bottom.c        2009-09-12 08:51:28.000000000 -0700
    4806250594@@ -1,5 +1,5 @@
    4806350595 /****************************************************************************
     
    4809450626diff -Naur ncurses-5.7.orig/panel/p_delete.c ncurses-5.7/panel/p_delete.c
    4809550627--- ncurses-5.7.orig/panel/p_delete.c   2005-02-19 08:38:45.000000000 -0800
    48096 +++ ncurses-5.7/panel/p_delete.c        2009-07-19 15:03:51.000000000 -0700
     50628+++ ncurses-5.7/panel/p_delete.c        2009-09-12 08:51:28.000000000 -0700
    4809750629@@ -1,5 +1,5 @@
    4809850630 /****************************************************************************
     
    4813550667diff -Naur ncurses-5.7.orig/panel/p_hidden.c ncurses-5.7/panel/p_hidden.c
    4813650668--- ncurses-5.7.orig/panel/p_hidden.c   2005-02-19 08:39:17.000000000 -0800
    48137 +++ ncurses-5.7/panel/p_hidden.c        2009-07-19 15:03:51.000000000 -0700
     50669+++ ncurses-5.7/panel/p_hidden.c        2009-09-12 08:51:28.000000000 -0700
    4813850670@@ -1,5 +1,5 @@
    4813950671 /****************************************************************************
     
    4817650708diff -Naur ncurses-5.7.orig/panel/p_hide.c ncurses-5.7/panel/p_hide.c
    4817750709--- ncurses-5.7.orig/panel/p_hide.c     2005-02-19 08:39:41.000000000 -0800
    48178 +++ ncurses-5.7/panel/p_hide.c  2009-07-19 15:03:51.000000000 -0700
     50710+++ ncurses-5.7/panel/p_hide.c  2009-09-12 08:51:28.000000000 -0700
    4817950711@@ -36,23 +36,27 @@
    4818050712  */
     
    4821550747diff -Naur ncurses-5.7.orig/panel/p_move.c ncurses-5.7/panel/p_move.c
    4821650748--- ncurses-5.7.orig/panel/p_move.c     2005-02-19 08:46:49.000000000 -0800
    48217 +++ ncurses-5.7/panel/p_move.c  2009-07-19 15:03:51.000000000 -0700
     50749+++ ncurses-5.7/panel/p_move.c  2009-09-12 08:51:28.000000000 -0700
    4821850750@@ -1,5 +1,5 @@
    4821950751 /****************************************************************************
     
    4826750799diff -Naur ncurses-5.7.orig/panel/p_new.c ncurses-5.7/panel/p_new.c
    4826850800--- ncurses-5.7.orig/panel/p_new.c      2008-08-04 11:25:48.000000000 -0700
    48269 +++ ncurses-5.7/panel/p_new.c   2009-07-19 15:03:51.000000000 -0700
     50801+++ ncurses-5.7/panel/p_new.c   2009-09-12 08:51:28.000000000 -0700
    4827050802@@ -1,5 +1,5 @@
    4827150803 /****************************************************************************
     
    4833550867diff -Naur ncurses-5.7.orig/panel/p_replace.c ncurses-5.7/panel/p_replace.c
    4833650868--- ncurses-5.7.orig/panel/p_replace.c  2005-02-19 08:41:31.000000000 -0800
    48337 +++ ncurses-5.7/panel/p_replace.c       2009-07-19 15:03:51.000000000 -0700
     50869+++ ncurses-5.7/panel/p_replace.c       2009-09-12 08:51:28.000000000 -0700
    4833850870@@ -36,23 +36,25 @@
    4833950871  */
     
    4837550907diff -Naur ncurses-5.7.orig/panel/p_show.c ncurses-5.7/panel/p_show.c
    4837650908--- ncurses-5.7.orig/panel/p_show.c     2005-02-19 08:42:02.000000000 -0800
    48377 +++ ncurses-5.7/panel/p_show.c  2009-07-19 15:03:51.000000000 -0700
     50909+++ ncurses-5.7/panel/p_show.c  2009-09-12 08:51:28.000000000 -0700
    4837850910@@ -36,34 +36,37 @@
    4837950911  */
     
    4843250964diff -Naur ncurses-5.7.orig/panel/p_update.c ncurses-5.7/panel/p_update.c
    4843350965--- ncurses-5.7.orig/panel/p_update.c   2005-02-19 08:49:47.000000000 -0800
    48434 +++ ncurses-5.7/panel/p_update.c        2009-07-19 15:03:51.000000000 -0700
     50966+++ ncurses-5.7/panel/p_update.c        2009-09-12 08:51:28.000000000 -0700
    4843550967@@ -1,5 +1,5 @@
    4843650968 /****************************************************************************
     
    4850651038diff -Naur ncurses-5.7.orig/progs/Makefile.in ncurses-5.7/progs/Makefile.in
    4850751039--- ncurses-5.7.orig/progs/Makefile.in  2008-09-07 06:58:55.000000000 -0700
    48508 +++ ncurses-5.7/progs/Makefile.in       2009-07-19 15:03:48.000000000 -0700
     51040+++ ncurses-5.7/progs/Makefile.in       2009-09-12 08:51:25.000000000 -0700
    4850951041@@ -1,6 +1,6 @@
    4851051042-# $Id: Makefile.in,v 1.79 2008/09/07 13:58:55 tom Exp $
     
    4861751149diff -Naur ncurses-5.7.orig/progs/modules ncurses-5.7/progs/modules
    4861851150--- ncurses-5.7.orig/progs/modules      2006-12-23 16:53:21.000000000 -0800
    48619 +++ ncurses-5.7/progs/modules   2009-07-19 15:03:43.000000000 -0700
     51151+++ ncurses-5.7/progs/modules   2009-09-12 08:51:21.000000000 -0700
    4862051152@@ -1,7 +1,7 @@
    4862151153-# $Id: modules,v 1.13 2006/12/24 00:53:21 tom Exp $
     
    4864051172diff -Naur ncurses-5.7.orig/progs/tabs.c ncurses-5.7/progs/tabs.c
    4864151173--- ncurses-5.7.orig/progs/tabs.c       1969-12-31 16:00:00.000000000 -0800
    48642 +++ ncurses-5.7/progs/tabs.c    2009-07-19 15:01:57.000000000 -0700
     51174+++ ncurses-5.7/progs/tabs.c    2009-09-12 08:50:52.000000000 -0700
    4864351175@@ -0,0 +1,506 @@
    4864451176+/****************************************************************************
     
    4915051682diff -Naur ncurses-5.7.orig/progs/tic.c ncurses-5.7/progs/tic.c
    4915151683--- ncurses-5.7.orig/progs/tic.c        2008-09-13 09:59:24.000000000 -0700
    49152 +++ ncurses-5.7/progs/tic.c     2009-07-19 15:03:43.000000000 -0700
     51684+++ ncurses-5.7/progs/tic.c     2009-09-12 08:51:21.000000000 -0700
    4915351685@@ -1,5 +1,5 @@
    4915451686 /****************************************************************************
     
    4918351715diff -Naur ncurses-5.7.orig/progs/tput.c ncurses-5.7/progs/tput.c
    4918451716--- ncurses-5.7.orig/progs/tput.c       2008-07-13 04:05:12.000000000 -0700
    49185 +++ ncurses-5.7/progs/tput.c    2009-07-19 15:03:43.000000000 -0700
     51717+++ ncurses-5.7/progs/tput.c    2009-09-12 08:51:21.000000000 -0700
    4918651718@@ -1,5 +1,5 @@
    4918751719 /****************************************************************************
     
    4921351745diff -Naur ncurses-5.7.orig/progs/transform.c ncurses-5.7/progs/transform.c
    4921451746--- ncurses-5.7.orig/progs/transform.c  1969-12-31 16:00:00.000000000 -0800
    49215 +++ ncurses-5.7/progs/transform.c       2009-07-19 15:03:43.000000000 -0700
     51747+++ ncurses-5.7/progs/transform.c       2009-09-12 08:51:21.000000000 -0700
    4921651748@@ -0,0 +1,79 @@
    4921751749+/****************************************************************************
     
    4929651828diff -Naur ncurses-5.7.orig/progs/tset.c ncurses-5.7/progs/tset.c
    4929751829--- ncurses-5.7.orig/progs/tset.c       2008-10-11 12:26:19.000000000 -0700
    49298 +++ ncurses-5.7/progs/tset.c    2009-07-19 15:03:43.000000000 -0700
     51830+++ ncurses-5.7/progs/tset.c    2009-09-12 08:51:21.000000000 -0700
    4929951831@@ -1,5 +1,5 @@
    4930051832 /****************************************************************************
     
    4932451856diff -Naur ncurses-5.7.orig/README.MinGW ncurses-5.7/README.MinGW
    4932551857--- ncurses-5.7.orig/README.MinGW       1969-12-31 16:00:00.000000000 -0800
    49326 +++ ncurses-5.7/README.MinGW    2009-07-19 15:04:11.000000000 -0700
     51858+++ ncurses-5.7/README.MinGW    2009-09-12 08:51:49.000000000 -0700
    4932751859@@ -0,0 +1,79 @@
    4932851860+-------------------------------------------------------------------------------
     
    4940751939diff -Naur ncurses-5.7.orig/test/aclocal.m4 ncurses-5.7/test/aclocal.m4
    4940851940--- ncurses-5.7.orig/test/aclocal.m4    2008-02-09 10:22:17.000000000 -0800
    49409 +++ ncurses-5.7/test/aclocal.m4 2009-07-19 15:04:17.000000000 -0700
     51941+++ ncurses-5.7/test/aclocal.m4 2009-09-12 08:51:54.000000000 -0700
    4941051942@@ -1,5 +1,5 @@
    4941151943 dnl***************************************************************************
     
    5031152843+#endif
    5031252844+])
     52845diff -Naur ncurses-5.7.orig/test/blue.c ncurses-5.7/test/blue.c
     52846--- ncurses-5.7.orig/test/blue.c        2008-08-03 11:20:27.000000000 -0700
     52847+++ ncurses-5.7/test/blue.c     2009-09-12 08:52:07.000000000 -0700
     52848@@ -1,5 +1,5 @@
     52849 /****************************************************************************
     52850- * Copyright (c) 1998-2006,2008 Free Software Foundation, Inc.              *
     52851+ * Copyright (c) 1998-2008,2009 Free Software Foundation, Inc.              *
     52852  *                                                                          *
     52853  * Permission is hereby granted, free of charge, to any person obtaining a  *
     52854  * copy of this software and associated documentation files (the            *
     52855@@ -40,7 +40,7 @@
     52856  * results, use the ncurses(3) library.  On non-Intel machines, SVr4 curses is
     52857  * just as good.
     52858  *
     52859- * $Id: blue.c,v 1.30 2008/08/03 18:20:27 tom Exp $
     52860+ * $Id: blue.c,v 1.31 2009/08/29 19:02:25 tom Exp $
     52861  */
     52862 
     52863 #include <test.priv.h>
     52864@@ -353,9 +353,9 @@
     52865     }
     52866 
     52867     move(PROMPTROW, 0);
     52868-    standout();
     52869+    (void) standout();
     52870     (void) printw("Finished deal %d - type any character to continue...", deal_number);
     52871-    standend();
     52872+    (void) standend();
     52873     (void) getch();
     52874 }
     52875 
     52876@@ -386,7 +386,7 @@
     52877 {
     52878     clear();
     52879     (void) printw("You finished the game in %d deals. This is ", deal);
     52880-    standout();
     52881+    (void) standout();
     52882     if (deal < 2)
     52883        (void) addstr("excellent");
     52884     else if (deal < 4)
     52885@@ -395,7 +395,7 @@
     52886        (void) addstr("average");
     52887     else
     52888        (void) addstr("poor");
     52889-    standend();
     52890+    (void) standend();
     52891     (void) addstr(".         ");
     52892     refresh();
     52893 }
     52894diff -Naur ncurses-5.7.orig/test/bs.c ncurses-5.7/test/bs.c
     52895--- ncurses-5.7.orig/test/bs.c  2008-08-03 11:30:28.000000000 -0700
     52896+++ ncurses-5.7/test/bs.c       2009-09-12 08:52:07.000000000 -0700
     52897@@ -1,5 +1,5 @@
     52898 /****************************************************************************
     52899- * Copyright (c) 1998-2007,2008 Free Software Foundation, Inc.              *
     52900+ * Copyright (c) 1998-2008,2009 Free Software Foundation, Inc.              *
     52901  *                                                                          *
     52902  * Permission is hereby granted, free of charge, to any person obtaining a  *
     52903  * copy of this software and associated documentation files (the            *
     52904@@ -34,7 +34,7 @@
     52905  * v2.0 featuring strict ANSI/POSIX conformance, November 1993.
     52906  * v2.1 with ncurses mouse support, September 1995
     52907  *
     52908- * $Id: bs.c,v 1.47 2008/08/03 18:30:28 tom Exp $
     52909+ * $Id: bs.c,v 1.48 2009/08/29 19:02:25 tom Exp $
     52910  */
     52911 
     52912 #include <test.priv.h>
     52913@@ -374,7 +374,7 @@
     52914        for (j = 0; j < BWIDTH; j++)
     52915            (void) addstr(" . ");
     52916 #ifdef A_COLOR
     52917-       attrset(0);
     52918+       (void) attrset(0);
     52919 #endif /* A_COLOR */
     52920        (void) addch(' ');
     52921        (void) addch((chtype) (i + 'A'));
     52922@@ -392,7 +392,7 @@
     52923        for (j = 0; j < BWIDTH; j++)
     52924            (void) addstr(" . ");
     52925 #ifdef A_COLOR
     52926-       attrset(0);
     52927+       (void) attrset(0);
     52928 #endif /* A_COLOR */
     52929        (void) addch(' ');
     52930        (void) addch((chtype) (i + 'A'));
     52931@@ -773,7 +773,7 @@
     52932 #endif /* A_COLOR */
     52933                                    (void) addch(MARK_MISS);
     52934 #ifdef A_COLOR
     52935-                                   attrset(0);
     52936+                                   (void) attrset(0);
     52937 #endif /* A_COLOR */
     52938                                } else {
     52939                                    pgoto(y1, x1);
     52940@@ -799,7 +799,7 @@
     52941 #endif /* A_COLOR */
     52942                        (void) addch(SHOWHIT);
     52943 #ifdef A_COLOR
     52944-                       attrset(0);
     52945+                       (void) attrset(0);
     52946 #endif /* A_COLOR */
     52947                    }
     52948                }
     52949@@ -841,7 +841,7 @@
     52950 #endif /* A_COLOR */
     52951     (void) addch((chtype) hits[PLAYER][curx][cury]);
     52952 #ifdef A_COLOR
     52953-    attrset(0);
     52954+    (void) attrset(0);
     52955 #endif /* A_COLOR */
     52956 
     52957     prompt(1, "You %s.", hit ? "scored a hit" : "missed");
     52958@@ -971,7 +971,7 @@
     52959 #endif /* A_COLOR */
     52960     (void) addch((chtype) (hit ? SHOWHIT : SHOWSPLASH));
     52961 #ifdef A_COLOR
     52962-    attrset(0);
     52963+    (void) attrset(0);
     52964 #endif /* A_COLOR */
     52965 
     52966     return hit ? (sunk ? S_SUNK : S_HIT) : S_MISS;
    5031352967diff -Naur ncurses-5.7.orig/test/chgat.c ncurses-5.7/test/chgat.c
    5031452968--- ncurses-5.7.orig/test/chgat.c       2008-02-09 15:19:13.000000000 -0800
    50315 +++ ncurses-5.7/test/chgat.c    2009-07-19 15:04:17.000000000 -0700
     52969+++ ncurses-5.7/test/chgat.c    2009-09-12 08:51:54.000000000 -0700
    5031652970@@ -1,5 +1,5 @@
    5031752971 /****************************************************************************
     
    5035053004diff -Naur ncurses-5.7.orig/test/clip_printw.c ncurses-5.7/test/clip_printw.c
    5035153005--- ncurses-5.7.orig/test/clip_printw.c 1969-12-31 16:00:00.000000000 -0800
    50352 +++ ncurses-5.7/test/clip_printw.c      2009-07-19 15:04:17.000000000 -0700
    50353 @@ -0,0 +1,377 @@
     53006+++ ncurses-5.7/test/clip_printw.c      2009-09-12 08:52:07.000000000 -0700
     53007@@ -0,0 +1,378 @@
    5035453008+/****************************************************************************
    5035553009+ * Copyright (c) 2008,2009 Free Software Foundation, Inc.                   *
     
    5038053034+ ****************************************************************************/
    5038153035+/*
    50382 + * $Id: clip_printw.c,v 1.3 2009/07/17 09:28:52 tom Exp $
     53036+ * $Id: clip_printw.c,v 1.4 2009/08/29 19:00:44 tom Exp $
    5038353037+ *
    5038453038+ * demonstrate how to use printw without wrapping.
     
    5068153335+       switch (st.ch) {
    5068253336+       case '.':               /* change from current position */
    50683 +           wattrset(win, st.attr | COLOR_PAIR(st.pair));
     53337+           (void) wattrset(win, st.attr | COLOR_PAIR(st.pair));
    5068453338+           if (st.count > 0) {
    5068553339+               need = st.count + 1;
     
    5072153375+    ExitProgram(EXIT_SUCCESS);
    5072253376+}
     53377+
    5072353378+#else
    5072453379+int
     
    5073153386diff -Naur ncurses-5.7.orig/test/configure ncurses-5.7/test/configure
    5073253387--- ncurses-5.7.orig/test/configure     2008-09-06 15:11:48.000000000 -0700
    50733 +++ ncurses-5.7/test/configure  2009-07-19 15:04:17.000000000 -0700
     53388+++ ncurses-5.7/test/configure  2009-09-12 08:51:54.000000000 -0700
    5073453389@@ -194,6 +194,7 @@
    5073553390   --with-Xaw3d            link with Xaw 3d library
     
    5924861903diff -Naur ncurses-5.7.orig/test/configure.in ncurses-5.7/test/configure.in
    5924961904--- ncurses-5.7.orig/test/configure.in  2008-09-06 15:10:23.000000000 -0700
    59250 +++ ncurses-5.7/test/configure.in       2009-07-19 15:04:17.000000000 -0700
     61905+++ ncurses-5.7/test/configure.in       2009-09-12 08:51:54.000000000 -0700
    5925161906@@ -1,5 +1,5 @@
    5925261907 dnl***************************************************************************
     
    5932761982diff -Naur ncurses-5.7.orig/test/demo_forms.c ncurses-5.7/test/demo_forms.c
    5932861983--- ncurses-5.7.orig/test/demo_forms.c  2008-10-18 13:38:20.000000000 -0700
    59329 +++ ncurses-5.7/test/demo_forms.c       2009-07-19 15:04:04.000000000 -0700
     61984+++ ncurses-5.7/test/demo_forms.c       2009-09-12 08:52:07.000000000 -0700
    5933061985@@ -1,5 +1,5 @@
    5933161986 /****************************************************************************
     
    5934061995 /*
    5934161996- * $Id: demo_forms.c,v 1.30 2008/10/18 20:38:20 tom Exp $
    59342 + * $Id: demo_forms.c,v 1.32 2009/05/30 16:52:42 tom Exp $
     61997+ * $Id: demo_forms.c,v 1.33 2009/08/29 18:47:26 tom Exp $
    5934361998  *
    5934461999  * Demonstrate a variety of functions from the form library.
     
    5936762022            set_field_buffer(f, 0, t_value);
    5936862023     }
     62024@@ -300,13 +307,13 @@
     62025        }
     62026 
     62027        waddch(win, ' ');
     62028-       wattrset(win, field_fore(field));
     62029+       (void) wattrset(win, field_fore(field));
     62030        waddstr(win, "fore");
     62031        wattroff(win, field_fore(field));
     62032 
     62033        waddch(win, '/');
     62034 
     62035-       wattrset(win, field_back(field));
     62036+       (void) wattrset(win, field_back(field));
     62037        waddstr(win, "back");
     62038        wattroff(win, field_back(field));
     62039 
     62040@@ -317,7 +324,7 @@
     62041        for (nbuf = 0; nbuf <= 2; ++nbuf) {
     62042            if ((buffer = field_buffer(field, nbuf)) != 0) {
     62043                wprintw(win, "buffer %d:", nbuf);
     62044-               wattrset(win, A_REVERSE);
     62045+               (void) wattrset(win, A_REVERSE);
     62046                waddstr(win, buffer);
     62047                wattroff(win, A_REVERSE);
     62048                waddstr(win, "\n");
    5936962049@@ -444,8 +451,11 @@
    5937062050 
     
    5938062060     nl();
    5938162061 
     62062diff -Naur ncurses-5.7.orig/test/demo_termcap.c ncurses-5.7/test/demo_termcap.c
     62063--- ncurses-5.7.orig/test/demo_termcap.c        2008-02-09 10:08:36.000000000 -0800
     62064+++ ncurses-5.7/test/demo_termcap.c     2009-09-12 08:51:59.000000000 -0700
     62065@@ -1,5 +1,5 @@
     62066 /****************************************************************************
     62067- * Copyright (c) 2005-2007,2008 Free Software Foundation, Inc.              *
     62068+ * Copyright (c) 2005-2008,2009 Free Software Foundation, Inc.              *
     62069  *                                                                          *
     62070  * Permission is hereby granted, free of charge, to any person obtaining a  *
     62071  * copy of this software and associated documentation files (the            *
     62072@@ -29,7 +29,7 @@
     62073 /*
     62074  * Author: Thomas E. Dickey
     62075  *
     62076- * $Id: demo_termcap.c,v 1.7 2008/02/09 18:08:36 tom Exp $
     62077+ * $Id: demo_termcap.c,v 1.11 2009/08/02 00:02:53 tom Exp $
     62078  *
     62079  * A simple demo of the termcap interface.
     62080  */
     62081@@ -38,10 +38,25 @@
     62082 
     62083 #if HAVE_TGETENT
     62084 
     62085+#if defined(HAVE_CURSES_DATA_BOOLNAMES) || defined(DECL_CURSES_DATA_BOOLNAMES)
     62086+#define USE_CODE_LISTS 1
     62087+#else
     62088+#define USE_CODE_LISTS 0
     62089+#endif
     62090+
     62091+#define FCOLS 8
     62092+#define FNAME(type) "%s %-*s = ", #type, FCOLS
     62093+
     62094+#if USE_CODE_LISTS
     62095+static bool b_opt = FALSE;
     62096+static bool n_opt = FALSE;
     62097+static bool s_opt = FALSE;
     62098+#endif
     62099+
     62100 #define isCapName(c) (isgraph(c) && strchr("^#=:\\", c) == 0)
     62101 
     62102 static void
     62103-dumpit(char *cap)
     62104+dumpit(NCURSES_CONST char *cap)
     62105 {
     62106     /*
     62107      * One of the limitations of the termcap interface is that the library
     62108@@ -59,7 +74,7 @@
     62109         * Note that the strings returned are mostly terminfo format, since
     62110         * ncurses does not convert except for a handful of special cases.
     62111         */
     62112-       printf("str %s = ", cap);
     62113+       printf(FNAME(str), cap);
     62114        while (*str != 0) {
     62115            int ch = UChar(*str++);
     62116            switch (ch) {
     62117@@ -108,15 +123,17 @@
     62118        }
     62119        printf("\n");
     62120     } else if ((num = tgetnum(cap)) >= 0) {
     62121-       printf("num %s = %d\n", cap, num);
     62122+       printf(FNAME(num), cap);
     62123+       printf(" %d\n", num);
     62124     } else if ((num = tgetflag(cap)) > 0) {
     62125-       printf("flg %s\n", cap);
     62126+       printf(FNAME(flg), cap);
     62127+       printf("%s\n", "true");
     62128     }
     62129     fflush(stdout);
     62130 }
     62131 
     62132 static void
     62133-demo_termcap(char *name)
     62134+brute_force(const char *name)
     62135 {
     62136     char buffer[1024];
     62137 
     62138@@ -140,23 +157,142 @@
     62139     }
     62140 }
     62141 
     62142+#if USE_CODE_LISTS
     62143+static void
     62144+demo_terminfo(NCURSES_CONST char *name)
     62145+{
     62146+    unsigned n;
     62147+    NCURSES_CONST char *cap;
     62148+
     62149+    printf("Terminal type \"%s\"\n", name);
     62150+    setupterm(name, 1, (int *) 0);
     62151+
     62152+    if (b_opt) {
     62153+       for (n = 0;; ++n) {
     62154+           cap = boolcodes[n];
     62155+           if (cap == 0)
     62156+               break;
     62157+           dumpit(cap);
     62158+       }
     62159+    }
     62160+
     62161+    if (n_opt) {
     62162+       for (n = 0;; ++n) {
     62163+           cap = numcodes[n];
     62164+           if (cap == 0)
     62165+               break;
     62166+           dumpit(cap);
     62167+       }
     62168+    }
     62169+
     62170+    if (s_opt) {
     62171+       for (n = 0;; ++n) {
     62172+           cap = strcodes[n];
     62173+           if (cap == 0)
     62174+               break;
     62175+           dumpit(cap);
     62176+       }
     62177+    }
     62178+}
     62179+
     62180+static void
     62181+usage(void)
     62182+{
     62183+    static const char *msg[] =
     62184+    {
     62185+       "Usage: demo_terminfo [options] [terminal]",
     62186+       "",
     62187+       "If no options are given, print all (boolean, numeric, string)",
     62188+       "capabilities for the given terminal, using short names.",
     62189+       "",
     62190+       "Options:",
     62191+       " -a       try all names, print capabilities found",
     62192+       " -b       print boolean-capabilities",
     62193+       " -n       print numeric-capabilities",
     62194+       " -r COUNT repeat for given count",
     62195+       " -s       print string-capabilities",
     62196+    };
     62197+    unsigned n;
     62198+    for (n = 0; n < SIZEOF(msg); ++n) {
     62199+       fprintf(stderr, "%s\n", msg[n]);
     62200+    }
     62201+    ExitProgram(EXIT_FAILURE);
     62202+}
     62203+#endif
     62204+
     62205 int
     62206 main(int argc, char *argv[])
     62207 {
     62208     int n;
     62209     char *name;
     62210+    bool a_opt = FALSE;
     62211 
     62212-    if (argc > 1) {
     62213-       for (n = 1; n < argc; ++n) {
     62214-           demo_termcap(argv[n]);
     62215-       }
     62216-    } else if ((name = getenv("TERM")) != 0) {
     62217-       demo_termcap(name);
     62218-    } else {
     62219-       static char dumb[] = "dumb";
     62220-       demo_termcap(dumb);
     62221+#if USE_CODE_LISTS
     62222+    int repeat;
     62223+    int r_opt = 1;
     62224+
     62225+    while ((n = getopt(argc, argv, "abnr:s")) != -1) {
     62226+       switch (n) {
     62227+       case 'a':
     62228+           a_opt = TRUE;
     62229+           break;
     62230+       case 'b':
     62231+           b_opt = TRUE;
     62232+           break;
     62233+       case 'n':
     62234+           n_opt = TRUE;
     62235+           break;
     62236+       case 'r':
     62237+           if ((r_opt = atoi(optarg)) <= 0)
     62238+               usage();
     62239+           break;
     62240+       case 's':
     62241+           s_opt = TRUE;
     62242+           break;
     62243+       default:
     62244+           usage();
     62245+           break;
     62246+       }
     62247     }
     62248 
     62249+    if (!(b_opt || n_opt || s_opt)) {
     62250+       b_opt = TRUE;
     62251+       n_opt = TRUE;
     62252+       s_opt = TRUE;
     62253+    }
     62254+#else
     62255+    a_opt = TRUE;
     62256+#endif
     62257+
     62258+    if (a_opt) {
     62259+       if (optind < argc) {
     62260+           for (n = optind; n < argc; ++n) {
     62261+               brute_force(argv[n]);
     62262+           }
     62263+       } else if ((name = getenv("TERM")) != 0) {
     62264+           brute_force(name);
     62265+       } else {
     62266+           static char dumb[] = "dumb";
     62267+           brute_force(dumb);
     62268+       }
     62269+    }
     62270+#if USE_CODE_LISTS
     62271+    else {
     62272+       for (repeat = 0; repeat < r_opt; ++repeat) {
     62273+           if (optind < argc) {
     62274+               for (n = optind; n < argc; ++n) {
     62275+                   demo_terminfo(argv[n]);
     62276+               }
     62277+           } else if ((name = getenv("TERM")) != 0) {
     62278+               demo_terminfo(name);
     62279+           } else {
     62280+               static char dumb[] = "dumb";
     62281+               demo_terminfo(dumb);
     62282+           }
     62283+       }
     62284+    }
     62285+#endif
     62286+
     62287     ExitProgram(EXIT_SUCCESS);
     62288 }
     62289 
    5938262290diff -Naur ncurses-5.7.orig/test/demo_terminfo.c ncurses-5.7/test/demo_terminfo.c
    5938362291--- ncurses-5.7.orig/test/demo_terminfo.c       1969-12-31 16:00:00.000000000 -0800
    59384 +++ ncurses-5.7/test/demo_terminfo.c    2009-07-19 15:04:17.000000000 -0700
     62292+++ ncurses-5.7/test/demo_terminfo.c    2009-09-12 08:51:54.000000000 -0700
    5938562293@@ -0,0 +1,304 @@
    5938662294+/****************************************************************************
     
    5969062598diff -Naur ncurses-5.7.orig/test/ditto.c ncurses-5.7/test/ditto.c
    5969162599--- ncurses-5.7.orig/test/ditto.c       2008-08-04 06:21:41.000000000 -0700
    59692 +++ ncurses-5.7/test/ditto.c    2009-07-19 15:04:17.000000000 -0700
     62600+++ ncurses-5.7/test/ditto.c    2009-09-12 08:51:54.000000000 -0700
    5969362601@@ -29,7 +29,7 @@
    5969462602 /*
     
    5978562693diff -Naur ncurses-5.7.orig/test/edit_field.c ncurses-5.7/test/edit_field.c
    5978662694--- ncurses-5.7.orig/test/edit_field.c  2008-10-18 13:40:20.000000000 -0700
    59787 +++ ncurses-5.7/test/edit_field.c       2009-07-19 15:02:04.000000000 -0700
     62695+++ ncurses-5.7/test/edit_field.c       2009-09-12 08:50:59.000000000 -0700
    5978862696@@ -26,7 +26,7 @@
    5978962697  * authorization.                                                           *
     
    5980862716diff -Naur ncurses-5.7.orig/test/edit_field.h ncurses-5.7/test/edit_field.h
    5980962717--- ncurses-5.7.orig/test/edit_field.h  2006-06-03 09:38:57.000000000 -0700
    59810 +++ ncurses-5.7/test/edit_field.h       2009-07-19 15:02:04.000000000 -0700
     62718+++ ncurses-5.7/test/edit_field.h       2009-09-12 08:50:59.000000000 -0700
    5981162719@@ -1,5 +1,5 @@
    5981262720 /****************************************************************************
     
    5983862746diff -Naur ncurses-5.7.orig/test/filter.c ncurses-5.7/test/filter.c
    5983962747--- ncurses-5.7.orig/test/filter.c      2006-12-09 08:53:47.000000000 -0800
    59840 +++ ncurses-5.7/test/filter.c   2009-07-19 15:02:00.000000000 -0700
     62748+++ ncurses-5.7/test/filter.c   2009-09-12 08:50:55.000000000 -0700
    5984162749@@ -1,5 +1,5 @@
    5984262750 /****************************************************************************
     
    5990862816     keypad(stdscr, TRUE);
    5990962817 
     62818diff -Naur ncurses-5.7.orig/test/firework.c ncurses-5.7/test/firework.c
     62819--- ncurses-5.7.orig/test/firework.c    2006-05-20 08:36:08.000000000 -0700
     62820+++ ncurses-5.7/test/firework.c 2009-09-12 08:52:07.000000000 -0700
     62821@@ -1,5 +1,5 @@
     62822 /****************************************************************************
     62823- * Copyright (c) 1998-2005,2006 Free Software Foundation, Inc.              *
     62824+ * Copyright (c) 1998-2006,2009 Free Software Foundation, Inc.              *
     62825  *                                                                          *
     62826  * Permission is hereby granted, free of charge, to any person obtaining a  *
     62827  * copy of this software and associated documentation files (the            *
     62828@@ -26,7 +26,7 @@
     62829  * authorization.                                                           *
     62830  ****************************************************************************/
     62831 /*
     62832- * $Id: firework.c,v 1.24 2006/05/20 15:36:08 tom Exp $
     62833+ * $Id: firework.c,v 1.25 2009/08/29 19:02:25 tom Exp $
     62834  */
     62835 #include <test.priv.h>
     62836 
     62837@@ -94,14 +94,14 @@
     62838     showit();
     62839 
     62840     init_pair(1, get_colour(&bold), my_bg);
     62841-    attrset(COLOR_PAIR(1) | bold);
     62842+    (void) attrset(COLOR_PAIR(1) | bold);
     62843     mvprintw(row - 1, col - 1, " - ");
     62844     mvprintw(row + 0, col - 1, "-+-");
     62845     mvprintw(row + 1, col - 1, " - ");
     62846     showit();
     62847 
     62848     init_pair(1, get_colour(&bold), my_bg);
     62849-    attrset(COLOR_PAIR(1) | bold);
     62850+    (void) attrset(COLOR_PAIR(1) | bold);
     62851     mvprintw(row - 2, col - 2, " --- ");
     62852     mvprintw(row - 1, col - 2, "-+++-");
     62853     mvprintw(row + 0, col - 2, "-+#+-");
     62854@@ -110,7 +110,7 @@
     62855     showit();
     62856 
     62857     init_pair(1, get_colour(&bold), my_bg);
     62858-    attrset(COLOR_PAIR(1) | bold);
     62859+    (void) attrset(COLOR_PAIR(1) | bold);
     62860     mvprintw(row - 2, col - 2, " +++ ");
     62861     mvprintw(row - 1, col - 2, "++#++");
     62862     mvprintw(row + 0, col - 2, "+# #+");
     62863@@ -119,7 +119,7 @@
     62864     showit();
     62865 
     62866     init_pair(1, get_colour(&bold), my_bg);
     62867-    attrset(COLOR_PAIR(1) | bold);
     62868+    (void) attrset(COLOR_PAIR(1) | bold);
     62869     mvprintw(row - 2, col - 2, "  #  ");
     62870     mvprintw(row - 1, col - 2, "## ##");
     62871     mvprintw(row + 0, col - 2, "#   #");
     62872@@ -128,7 +128,7 @@
     62873     showit();
     62874 
     62875     init_pair(1, get_colour(&bold), my_bg);
     62876-    attrset(COLOR_PAIR(1) | bold);
     62877+    (void) attrset(COLOR_PAIR(1) | bold);
     62878     mvprintw(row - 2, col - 2, " # # ");
     62879     mvprintw(row - 1, col - 2, "#   #");
     62880     mvprintw(row + 0, col - 2, "     ");
     62881@@ -173,7 +173,7 @@
     62882            direction = (start > end) ? -1 : 1;
     62883            diff = abs(start - end);
     62884        } while (diff < 2 || diff >= LINES - 2);
     62885-       attrset(A_NORMAL);
     62886+       (void) attrset(A_NORMAL);
     62887        for (row = 0; row < diff; row++) {
     62888            mvprintw(LINES - row, start + (row * direction),
     62889                     (direction < 0) ? "\\" : "/");
    5991062890diff -Naur ncurses-5.7.orig/test/firstlast.c ncurses-5.7/test/firstlast.c
    5991162891--- ncurses-5.7.orig/test/firstlast.c   2006-04-01 11:03:18.000000000 -0800
    59912 +++ ncurses-5.7/test/firstlast.c        2009-07-19 15:04:17.000000000 -0700
     62892+++ ncurses-5.7/test/firstlast.c        2009-09-12 08:51:54.000000000 -0700
    5991362893@@ -1,5 +1,5 @@
    5991462894 /****************************************************************************
     
    5994862928     }
    5994962929 }
     62930diff -Naur ncurses-5.7.orig/test/gdc.c ncurses-5.7/test/gdc.c
     62931--- ncurses-5.7.orig/test/gdc.c 2008-08-03 16:58:42.000000000 -0700
     62932+++ ncurses-5.7/test/gdc.c      2009-09-12 08:52:07.000000000 -0700
     62933@@ -1,5 +1,5 @@
     62934 /****************************************************************************
     62935- * Copyright (c) 1998-2007,2008 Free Software Foundation, Inc.              *
     62936+ * Copyright (c) 1998-2008,2009 Free Software Foundation, Inc.              *
     62937  *                                                                          *
     62938  * Permission is hereby granted, free of charge, to any person obtaining a  *
     62939  * copy of this software and associated documentation files (the            *
     62940@@ -33,7 +33,7 @@
     62941  * modified 10-18-89 for curses (jrl)
     62942  * 10-18-89 added signal handling
     62943  *
     62944- * $Id: gdc.c,v 1.31 2008/08/03 23:58:42 tom Exp $
     62945+ * $Id: gdc.c,v 1.32 2009/08/29 19:02:25 tom Exp $
     62946  */
     62947 
     62948 #include <test.priv.h>
     62949@@ -78,7 +78,7 @@
     62950     int n;
     62951 
     62952     if (hascolor)
     62953-       attrset(COLOR_PAIR(PAIR_FRAMES));
     62954+       (void) attrset(COLOR_PAIR(PAIR_FRAMES));
     62955 
     62956     mvaddch(YBASE - 1, XBASE - 1, ACS_ULCORNER);
     62957     hline(ACS_HLINE, XLENGTH);
     62958@@ -102,7 +102,7 @@
     62959     vline(ACS_VLINE, YDEPTH);
     62960 
     62961     if (hascolor)
     62962-       attrset(COLOR_PAIR(PAIR_OTHERS));
     62963+       (void) attrset(COLOR_PAIR(PAIR_OTHERS));
     62964 }
     62965 
     62966 static void
     62967@@ -220,7 +220,7 @@
     62968        init_pair(PAIR_DIGITS, COLOR_BLACK, COLOR_RED);
     62969        init_pair(PAIR_OTHERS, COLOR_RED, bg);
     62970        init_pair(PAIR_FRAMES, COLOR_WHITE, bg);
     62971-       attrset(COLOR_PAIR(PAIR_OTHERS));
     62972+       (void) attrset(COLOR_PAIR(PAIR_OTHERS));
     62973     }
     62974 
     62975   restart:
     62976@@ -335,7 +335,7 @@
     62977            goto restart;
     62978        case ERR:
     62979            if (sigtermed) {
     62980-               standend();
     62981+               (void) standend();
     62982                endwin();
     62983                fprintf(stderr, "gdc terminated by signal %d\n", sigtermed);
     62984                ExitProgram(EXIT_FAILURE);
     62985@@ -345,7 +345,7 @@
     62986            continue;
     62987        }
     62988     } while (--count);
     62989-    standend();
     62990+    (void) standend();
     62991     endwin();
     62992     ExitProgram(EXIT_SUCCESS);
     62993 }
     62994diff -Naur ncurses-5.7.orig/test/hanoi.c ncurses-5.7/test/hanoi.c
     62995--- ncurses-5.7.orig/test/hanoi.c       2008-08-04 03:57:59.000000000 -0700
     62996+++ ncurses-5.7/test/hanoi.c    2009-09-12 08:52:07.000000000 -0700
     62997@@ -1,5 +1,5 @@
     62998 /****************************************************************************
     62999- * Copyright (c) 1998-2006,2008 Free Software Foundation, Inc.              *
     63000+ * Copyright (c) 1998-2008,2009 Free Software Foundation, Inc.              *
     63001  *                                                                          *
     63002  * Permission is hereby granted, free of charge, to any person obtaining a  *
     63003  * copy of this software and associated documentation files (the            *
     63004@@ -41,7 +41,7 @@
     63005  *
     63006  *     Date: 05.Nov.90
     63007  *
     63008- * $Id: hanoi.c,v 1.27 2008/08/04 10:57:59 tom Exp $
     63009+ * $Id: hanoi.c,v 1.28 2009/08/29 19:02:25 tom Exp $
     63010  */
     63011 
     63012 #include <test.priv.h>
     63013@@ -229,7 +229,7 @@
     63014     mvaddstr(1, 24, "T O W E R S   O F   H A N O I");
     63015     mvaddstr(3, 34, "SJR 1990");
     63016     mvprintw(19, 5, "Moves : %d", NMoves);
     63017-    attrset(A_REVERSE);
     63018+    (void) attrset(A_REVERSE);
     63019     mvaddstr(BASELINE, 8,
     63020             "                                                               ");
     63021 
     63022@@ -241,7 +241,7 @@
     63023     mvaddch(BASELINE, LEFTPEG, '1');
     63024     mvaddch(BASELINE, MIDPEG, '2');
     63025     mvaddch(BASELINE, RIGHTPEG, '3');
     63026-    attrset(A_NORMAL);
     63027+    (void) attrset(A_NORMAL);
     63028 
     63029     /* Draw tiles */
     63030     for (peg = 0; peg < NPEGS; peg++) {
     63031@@ -251,16 +251,16 @@
     63032                memset(TileBuf, ' ', len);
     63033                TileBuf[len] = '\0';
     63034                if (has_colors())
     63035-                   attrset(COLOR_PAIR(LENTOIND(len)));
     63036+                   (void) attrset(COLOR_PAIR(LENTOIND(len)));
     63037                else
     63038-                   attrset(A_REVERSE);
     63039+                   (void) attrset(A_REVERSE);
     63040                mvaddstr(BASELINE - (SlotNo + 1),
     63041                         (int) (PegPos[peg] - len / 2),
     63042                         TileBuf);
     63043            }
     63044        }
     63045     }
     63046-    attrset(A_NORMAL);
     63047+    (void) attrset(A_NORMAL);
     63048     refresh();
     63049 }
     63050 
    5995063051diff -Naur ncurses-5.7.orig/test/insdelln.c ncurses-5.7/test/insdelln.c
    5995163052--- ncurses-5.7.orig/test/insdelln.c    1969-12-31 16:00:00.000000000 -0800
    59952 +++ ncurses-5.7/test/insdelln.c 2009-07-19 15:04:17.000000000 -0700
     63053+++ ncurses-5.7/test/insdelln.c 2009-09-12 08:52:07.000000000 -0700
    5995363054@@ -0,0 +1,387 @@
    5995463055+/****************************************************************************
     
    5998063081+ ****************************************************************************/
    5998163082+/*
    59982 + * $Id: insdelln.c,v 1.2 2009/07/15 23:21:04 tom Exp $
     63083+ * $Id: insdelln.c,v 1.3 2009/08/29 18:47:26 tom Exp $
    5998363084+ *
    5998463085+ * test-driver for deleteln, wdeleteln, insdelln, winsdelln, insertln, winsertln
     
    6025463355+
    6025563356+    do {
    60256 +       wattrset(win, st.attr | COLOR_PAIR(st.pair));
     63357+       (void) wattrset(win, st.attr | COLOR_PAIR(st.pair));
    6025763358+       switch (st.ch) {
    6025863359+       case 'i':
     
    6029563396+
    6029663397+    do {
    60297 +       attrset(st.attr | COLOR_PAIR(st.pair));
     63398+       (void) attrset(st.attr | COLOR_PAIR(st.pair));
    6029863399+       switch (st.ch) {
    6029963400+       case 'i':
     
    6034163442diff -Naur ncurses-5.7.orig/test/modules ncurses-5.7/test/modules
    6034263443--- ncurses-5.7.orig/test/modules       2007-08-18 10:57:08.000000000 -0700
    60343 +++ ncurses-5.7/test/modules    2009-07-19 15:04:15.000000000 -0700
     63444+++ ncurses-5.7/test/modules    2009-09-12 08:51:52.000000000 -0700
    6034463445@@ -1,6 +1,6 @@
    6034563446-# $Id: modules,v 1.36 2007/08/18 17:57:08 tom Exp $
     
    6037763478diff -Naur ncurses-5.7.orig/test/ncurses.c ncurses-5.7/test/ncurses.c
    6037863479--- ncurses-5.7.orig/test/ncurses.c     2008-09-27 07:34:58.000000000 -0700
    60379 +++ ncurses-5.7/test/ncurses.c  2009-07-19 15:04:17.000000000 -0700
     63480+++ ncurses-5.7/test/ncurses.c  2009-09-12 08:52:07.000000000 -0700
    6038063481@@ -1,5 +1,5 @@
    6038163482 /****************************************************************************
     
    6039063491 
    6039163492-$Id: ncurses.c,v 1.329 2008/09/27 14:34:58 tom Exp $
    60392 +$Id: ncurses.c,v 1.342 2009/07/18 11:48:42 tom Exp $
     63493+$Id: ncurses.c,v 1.345 2009/08/29 20:24:57 tom Exp $
    6039363494 
    6039463495 ***************************************************************************/
    6039563496 
     63497@@ -232,7 +232,7 @@
     63498 
     63499     echo();
     63500     getyx(win, y0, x0);
     63501-    wattrset(win, A_REVERSE);
     63502+    (void) wattrset(win, A_REVERSE);
     63503 
     63504     x = (int) strlen(buffer);
     63505     while (!done) {
    6039663506@@ -318,6 +318,7 @@
    6039763507     *target = 0;
     
    6041063520 static int
    6041163521 wGet_wchar(WINDOW *win, wint_t *result)
     63522@@ -363,7 +365,7 @@
     63523 
     63524     echo();
     63525     getyx(win, y0, x0);
     63526-    wattrset(win, A_REVERSE);
     63527+    (void) wattrset(win, A_REVERSE);
     63528 
     63529     x = (int) wcslen(buffer);
     63530     while (!done) {
    6041263531@@ -483,7 +485,11 @@
    6041363532        addstr("Shelling out...");
     
    6045463573     static const char *help[] =
    6045563574     {
     63575@@ -610,12 +629,12 @@
     63576        int flg = ((strstr(help[n], "toggle") != 0)
     63577                   && (flags[UChar(*help[n])] != FALSE));
     63578        if (flg)
     63579-           standout();
     63580+           (void) standout();
     63581        mvprintw(row, col, "%s", help[n]);
     63582        if (col == 0)
     63583            clrtoeol();
     63584        if (flg)
     63585-           standend();
     63586+           (void) standend();
     63587     }
     63588     wrefresh(stdscr);
     63589     wmove(win, y, x);
    6045663590@@ -657,7 +676,7 @@
    6045763591 {
     
    6057763711 #endif
    6057863712 
     63713@@ -1331,7 +1358,7 @@
     63714            addch(ch | attr);
     63715        }
     63716     } else {
     63717-       attrset(attr);
     63718+       (void) attrset(attr);
     63719        addstr(attr_test_string);
     63720        attroff(attr);
     63721     }
    6057963722@@ -1840,6 +1867,8 @@
    6058063723            width = 4;
     
    6065863801                init_pair(pair, fg, bg);
    6065963802                attron((attr_t) COLOR_PAIR(pair));
    60660 @@ -1960,6 +2002,8 @@
     63803@@ -1960,16 +2002,18 @@
    6066163804                    attron((attr_t) A_ALTCHARSET);
    6066263805                if (opt_bold)
     
    6066763810                if (opt_nums) {
    6066863811                    sprintf(numbered, "{%02X}", i);
    60669 @@ -1968,8 +2012,8 @@
     63812                    hello = numbered;
     63813                }
    6067063814                printw("%-*.*s", width, width, hello);
    60671                 attrset(A_NORMAL);
     63815-               attrset(A_NORMAL);
     63816+               (void) attrset(A_NORMAL);
    6067263817 
    6067363818-               if ((i % per_row) == 0 && (i % COLORS) == 0) {
     
    6079363938            done = TRUE;
    6079463939            continue;
     63940@@ -2324,9 +2395,9 @@
     63941                     (i == current ? '>' : ' '),
     63942                     (i < (int) SIZEOF(the_color_names)
     63943                      ? the_color_names[i] : numeric));
     63944-           attrset(COLOR_PAIR(i));
     63945+           (void) attrset(COLOR_PAIR(i));
     63946            addstr("        ");
     63947-           attrset(A_NORMAL);
     63948+           (void) attrset(A_NORMAL);
     63949 
     63950            color_content((short) i, &red, &green, &blue);
     63951            addstr("   R = ");
     63952@@ -2334,20 +2405,20 @@
     63953                attron(A_STANDOUT);
     63954            printw("%04d", red);
     63955            if (current == i && field == 0)
     63956-               attrset(A_NORMAL);
     63957+               (void) attrset(A_NORMAL);
     63958            addstr(", G = ");
     63959            if (current == i && field == 1)
     63960                attron(A_STANDOUT);
     63961            printw("%04d", green);
     63962            if (current == i && field == 1)
     63963-               attrset(A_NORMAL);
     63964+               (void) attrset(A_NORMAL);
     63965            addstr(", B = ");
     63966            if (current == i && field == 2)
     63967                attron(A_STANDOUT);
     63968            printw("%04d", blue);
     63969            if (current == i && field == 2)
     63970-               attrset(A_NORMAL);
     63971-           attrset(A_NORMAL);
     63972+               (void) attrset(A_NORMAL);
     63973+           (void) attrset(A_NORMAL);
     63974            printw(" ( %3d %3d %3d )",
     63975                   scaled_rgb(red),
     63976                   scaled_rgb(green),
    6079563977@@ -2802,6 +2873,7 @@
    6079663978 } attrs_to_cycle[] = {
     
    6080163983     { A_UNDERLINE,     "underline" },
    6080263984 };
     63985@@ -2818,7 +2890,7 @@
     63986            *at_code = 0;
     63987        break;
     63988     case 'V':
     63989-       if (*at_code == 1)
     63990+       if (*at_code == 0)
     63991            *at_code = SIZEOF(attrs_to_cycle) - 1;
     63992        else
     63993            *at_code -= 1;
    6080363994@@ -2902,7 +2974,7 @@
    6080463995        do {
     
    6095964150 
    6096064151 }
     64152@@ -4954,7 +5037,7 @@
     64153        wbkgd(subWin, COLOR_PAIR(2) | ' ');
     64154     }
     64155 #endif
     64156-    wattrset(subWin, A_BOLD);
     64157+    (void) wattrset(subWin, A_BOLD);
     64158     box(subWin, ACS_VLINE, ACS_HLINE);
     64159     mvwaddstr(subWin, 2, 1, "This is a subwindow");
     64160     wrefresh(win);
     64161@@ -5774,18 +5857,18 @@
     64162 
     64163     switch (flavor) {
     64164     case 0:
     64165-       wattrset(win, A_NORMAL);
     64166+       (void) wattrset(win, A_NORMAL);
     64167        break;
     64168     case 1:
     64169-       wattrset(win, A_BOLD);
     64170+       (void) wattrset(win, A_BOLD);
     64171        break;
     64172     case 2:
     64173        init_pair(cpair, COLOR_BLUE, COLOR_WHITE);
     64174-       wattrset(win, COLOR_PAIR(cpair) | A_NORMAL);
     64175+       (void) wattrset(win, COLOR_PAIR(cpair) | A_NORMAL);
     64176        break;
     64177     case 3:
     64178        init_pair(cpair, COLOR_WHITE, COLOR_BLUE);
     64179-       wattrset(win, COLOR_PAIR(cpair) | A_BOLD);
     64180+       (void) wattrset(win, COLOR_PAIR(cpair) | A_BOLD);
     64181        break;
     64182     }
     64183 }
    6096164184@@ -5804,7 +5887,7 @@
    6096264185        break;
     
    6096864191     case 3:
    6096964192        wbkgdset(win, ' ' | A_NORMAL);
     64193@@ -5890,7 +5973,7 @@
     64194            break;
     64195        }
     64196        overlap_helpitem(state, item, msg);
     64197-       wattrset(stdscr, A_NORMAL);
     64198+       (void) wattrset(stdscr, A_NORMAL);
     64199        wbkgdset(stdscr, ' ' | A_NORMAL);
     64200     }
     64201     move(LINES - 1, 0);
     64202@@ -5915,7 +5998,7 @@
     64203 {
     64204     overlap_test_1_attr(a, flavor, col);
     64205     fillwin(a, fill);
     64206-    wattrset(a, A_NORMAL);
     64207+    (void) wattrset(a, A_NORMAL);
     64208 }
     64209 
     64210 static void
     64211@@ -6497,7 +6580,7 @@
     64212            min_colors = -1;
     64213        }
     64214 #if NCURSES_VERSION_PATCH >= 20000708
     64215-       else if (assumed_colors)
     64216+       if (assumed_colors)
     64217            assume_default_colors(default_fg, default_bg);
     64218 #endif
     64219 #endif
     64220diff -Naur ncurses-5.7.orig/test/newdemo.c ncurses-5.7/test/newdemo.c
     64221--- ncurses-5.7.orig/test/newdemo.c     2008-08-03 13:19:38.000000000 -0700
     64222+++ ncurses-5.7/test/newdemo.c  2009-09-12 08:52:07.000000000 -0700
     64223@@ -2,7 +2,7 @@
     64224  *  newdemo.c  -       A demo program using PDCurses. The program illustrate
     64225  *                     the use of colours for text output.
     64226  *
     64227- * $Id: newdemo.c,v 1.31 2008/08/03 20:19:38 tom Exp $
     64228+ * $Id: newdemo.c,v 1.32 2009/08/29 18:47:26 tom Exp $
     64229  */
     64230 
     64231 #include <test.priv.h>
     64232@@ -84,7 +84,7 @@
     64233        if (pair > COLOR_PAIRS)
     64234            pair = COLOR_PAIRS;
     64235        init_pair(pair, foreground, background);
     64236-       wattrset(win, COLOR_PAIR(pair));
     64237+       (void) wattrset(win, COLOR_PAIR(pair));
     64238     }
     64239 }
     64240 
     64241@@ -96,7 +96,7 @@
     64242            pair = COLOR_PAIRS;
     64243        attrs |= COLOR_PAIR(pair);
     64244     }
     64245-    wattrset(win, attrs);
     64246+    (void) wattrset(win, attrs);
     64247     return attrs;
     64248 }
     64249 
    6097064250diff -Naur ncurses-5.7.orig/test/programs ncurses-5.7/test/programs
    6097164251--- ncurses-5.7.orig/test/programs      2008-08-16 14:47:39.000000000 -0700
    60972 +++ ncurses-5.7/test/programs   2009-07-19 15:04:15.000000000 -0700
     64252+++ ncurses-5.7/test/programs   2009-09-12 08:51:52.000000000 -0700
    6097364253@@ -1,6 +1,6 @@
    6097464254-# $Id: programs,v 1.14 2008/08/16 21:47:39 tom Exp $
     
    6100664286diff -Naur ncurses-5.7.orig/test/railroad.c ncurses-5.7/test/railroad.c
    6100764287--- ncurses-5.7.orig/test/railroad.c    2008-02-09 10:08:43.000000000 -0800
    61008 +++ ncurses-5.7/test/railroad.c 2009-07-19 15:02:23.000000000 -0700
     64288+++ ncurses-5.7/test/railroad.c 2009-09-12 08:51:19.000000000 -0700
    6100964289@@ -29,7 +29,7 @@
    6101064290 /*
     
    6105164331 }
    6105264332 
     64333diff -Naur ncurses-5.7.orig/test/rain.c ncurses-5.7/test/rain.c
     64334--- ncurses-5.7.orig/test/rain.c        2008-05-24 16:34:34.000000000 -0700
     64335+++ ncurses-5.7/test/rain.c     2009-09-12 08:52:07.000000000 -0700
     64336@@ -1,5 +1,5 @@
     64337 /****************************************************************************
     64338- * Copyright (c) 1998-2006,2008 Free Software Foundation, Inc.              *
     64339+ * Copyright (c) 1998-2008,2009 Free Software Foundation, Inc.              *
     64340  *                                                                          *
     64341  * Permission is hereby granted, free of charge, to any person obtaining a  *
     64342  * copy of this software and associated documentation files (the            *
     64343@@ -26,7 +26,7 @@
     64344  * authorization.                                                           *
     64345  ****************************************************************************/
     64346 /*
     64347- * $Id: rain.c,v 1.34 2008/05/24 23:34:34 tom Exp $
     64348+ * $Id: rain.c,v 1.35 2009/08/29 19:02:25 tom Exp $
     64349  */
     64350 #include <test.priv.h>
     64351 
     64352@@ -105,7 +105,7 @@
     64353        chtype color = COLOR_PAIR(z);
     64354        if (z)
     64355            color |= A_BOLD;
     64356-       attrset(color);
     64357+       (void) attrset(color);
     64358     }
     64359     return j;
     64360 }
    6105364361diff -Naur ncurses-5.7.orig/test/README ncurses-5.7/test/README
    6105464362--- ncurses-5.7.orig/test/README        2008-10-18 14:02:45.000000000 -0700
    61055 +++ ncurses-5.7/test/README     2009-07-19 15:04:15.000000000 -0700
     64363+++ ncurses-5.7/test/README     2009-09-12 08:51:52.000000000 -0700
    6105664364@@ -25,7 +25,7 @@
    6105764365 -- sale, use or other dealings in this Software without prior written        --
     
    6139364701 wscanw                         test: testcurs
    6139464702 wscrl                          test: ncurses testcurs
     64703diff -Naur ncurses-5.7.orig/test/tclock.c ncurses-5.7/test/tclock.c
     64704--- ncurses-5.7.orig/test/tclock.c      2005-04-16 09:39:27.000000000 -0700
     64705+++ ncurses-5.7/test/tclock.c   2009-09-12 08:52:07.000000000 -0700
     64706@@ -1,4 +1,4 @@
     64707-/* $Id: tclock.c,v 1.25 2005/04/16 16:39:27 tom Exp $ */
     64708+/* $Id: tclock.c,v 1.26 2009/08/29 18:47:26 tom Exp $ */
     64709 
     64710 #include <test.priv.h>
     64711 
     64712@@ -67,7 +67,7 @@
     64713     int d;
     64714 
     64715     if (has_colors())
     64716-       attrset(COLOR_PAIR(pair));
     64717+       (void) attrset(COLOR_PAIR(pair));
     64718 
     64719     dx = x2 - from_x;
     64720     dy = y2 - from_y;
     64721@@ -209,17 +209,17 @@
     64722 
     64723        dline(3, cx, cy, cx + mdx, cy - mdy, '#');
     64724 
     64725-       attrset(A_REVERSE);
     64726+       (void) attrset(A_REVERSE);
     64727        dline(2, cx, cy, cx + hdx, cy - hdy, '.');
     64728        attroff(A_REVERSE);
     64729 
     64730        if (has_colors())
     64731-           attrset(COLOR_PAIR(1));
     64732+           (void) attrset(COLOR_PAIR(1));
     64733 
     64734        dline(1, cx, cy, cx + sdx, cy - sdy, 'O');
     64735 
     64736        if (has_colors())
     64737-           attrset(COLOR_PAIR(0));
     64738+           (void) attrset(COLOR_PAIR(0));
     64739 
     64740        text = ctime(&tim);
     64741        mvprintw(2, 0, "%.*s", (int) (strlen(text) - 1), text);
     64742diff -Naur ncurses-5.7.orig/test/testaddch.c ncurses-5.7/test/testaddch.c
     64743--- ncurses-5.7.orig/test/testaddch.c   2006-04-01 11:08:03.000000000 -0800
     64744+++ ncurses-5.7/test/testaddch.c        2009-09-12 08:52:07.000000000 -0700
     64745@@ -1,5 +1,5 @@
     64746 /****************************************************************************
     64747- * Copyright (c) 1998-2002,2006 Free Software Foundation, Inc.              *
     64748+ * Copyright (c) 1998-2006,2009 Free Software Foundation, Inc.              *
     64749  *                                                                          *
     64750  * Permission is hereby granted, free of charge, to any person obtaining a  *
     64751  * copy of this software and associated documentation files (the            *
     64752@@ -29,7 +29,7 @@
     64753  * This is an example written by Alexander V. Lukyanov <lav@yars.free.net>,
     64754  * to demonstrate an inconsistency between ncurses and SVr4 curses.
     64755  *
     64756- * $Id: testaddch.c,v 1.6 2006/04/01 19:08:03 tom Exp $
     64757+ * $Id: testaddch.c,v 1.7 2009/08/29 19:02:25 tom Exp $
     64758  */
     64759 #include <test.priv.h>
     64760 
     64761@@ -66,7 +66,7 @@
     64762        attr = (i & 4) ? COLOR_PAIR(4) : 0;
     64763 
     64764        bkgdset(back);
     64765-       attrset(set);
     64766+       (void) attrset(set);
     64767 
     64768        attr_addstr("Test string with spaces ->   <-\n", attr);
     64769     }
     64770@@ -77,7 +77,7 @@
     64771        attr = (i & 4) ? COLOR_PAIR(4) : 0;
     64772 
     64773        bkgdset(back);
     64774-       attrset(set);
     64775+       (void) attrset(set);
     64776 
     64777        attr_addstr("Test string with spaces ->   <-\n", attr);
     64778     }
    6139564779diff -Naur ncurses-5.7.orig/test/test_arrays.c ncurses-5.7/test/test_arrays.c
    6139664780--- ncurses-5.7.orig/test/test_arrays.c 2008-02-09 10:09:43.000000000 -0800
    61397 +++ ncurses-5.7/test/test_arrays.c      2009-07-19 15:04:17.000000000 -0700
     64781+++ ncurses-5.7/test/test_arrays.c      2009-09-12 08:51:54.000000000 -0700
    6139864782@@ -26,7 +26,7 @@
    6139964783  * authorization.                                                           *
     
    6141464798 #define DUMP(name) dump_array(#name, name)
    6141564799 
     64800diff -Naur ncurses-5.7.orig/test/testcurs.c ncurses-5.7/test/testcurs.c
     64801--- ncurses-5.7.orig/test/testcurs.c    2008-08-03 10:58:09.000000000 -0700
     64802+++ ncurses-5.7/test/testcurs.c 2009-09-12 08:52:07.000000000 -0700
     64803@@ -7,7 +7,7 @@
     64804  *  wrs(5/28/93) -- modified to be consistent (perform identically) with either
     64805  *                  PDCurses or under Unix System V, R4
     64806  *
     64807- * $Id: testcurs.c,v 1.39 2008/08/03 17:58:09 tom Exp $
     64808+ * $Id: testcurs.c,v 1.40 2009/08/29 18:47:26 tom Exp $
     64809  */
     64810 
     64811 #include <test.priv.h>
     64812@@ -682,7 +682,7 @@
     64813     if ((pad = newpad(50, 100)) != 0) {
     64814        wattron(pad, A_REVERSE);
     64815        mvwaddstr(pad, 5, 2, "This is a new pad");
     64816-       wattrset(pad, A_NORMAL);
     64817+       (void) wattrset(pad, A_NORMAL);
     64818        mvwaddstr(pad, 8, 0,
     64819                  "The end of this line should be truncated here:except  now");
     64820        mvwaddstr(pad, 11, 1, "This line should not appear.It will now");
     64821@@ -720,7 +720,7 @@
     64822 
     64823     assert((new_option >= 0) && (new_option < MAX_OPTIONS));
     64824 
     64825-    attrset(A_NORMAL);
     64826+    (void) attrset(A_NORMAL);
     64827     mvaddstr(3, 20, "PDCurses Test Program");
     64828 
     64829     for (i = 0; i < (int) MAX_OPTIONS; i++)
     64830@@ -729,9 +729,9 @@
     64831     if ((old_option >= 0) && (old_option < MAX_OPTIONS))
     64832        mvaddstr(5 + old_option, 25, command[old_option].text);
     64833 
     64834-    attrset(A_REVERSE);
     64835+    (void) attrset(A_REVERSE);
     64836     mvaddstr(5 + new_option, 25, command[new_option].text);
     64837-    attrset(A_NORMAL);
     64838+    (void) attrset(A_NORMAL);
     64839     mvaddstr(13, 3,
     64840             "Use Up and Down Arrows to select - Enter to run - Q to quit");
     64841     refresh();
     64842diff -Naur ncurses-5.7.orig/test/test_getstr.c ncurses-5.7/test/test_getstr.c
     64843--- ncurses-5.7.orig/test/test_getstr.c 2008-02-09 10:09:35.000000000 -0800
     64844+++ ncurses-5.7/test/test_getstr.c      2009-09-12 08:52:07.000000000 -0700
     64845@@ -1,5 +1,5 @@
     64846 /****************************************************************************
     64847- * Copyright (c) 2007,2008 Free Software Foundation, Inc.                   *
     64848+ * Copyright (c) 2007-2008,2009 Free Software Foundation, Inc.              *
     64849  *                                                                          *
     64850  * Permission is hereby granted, free of charge, to any person obtaining a  *
     64851  * copy of this software and associated documentation files (the            *
     64852@@ -26,7 +26,7 @@
     64853  * authorization.                                                           *
     64854  ****************************************************************************/
     64855 /*
     64856- * $Id: test_getstr.c,v 1.8 2008/02/09 18:09:35 tom Exp $
     64857+ * $Id: test_getstr.c,v 1.9 2009/08/29 19:02:25 tom Exp $
     64858  *
     64859  * Author: Thomas E Dickey
     64860  *
     64861@@ -271,7 +271,7 @@
     64862            *buffer = '\0';
     64863            rc = ERR;
     64864            echo();
     64865-           wattrset(txtwin, A_REVERSE);
     64866+           (void) wattrset(txtwin, A_REVERSE);
     64867            switch (flavor) {
     64868            case eGetStr:
     64869                if (txtwin != stdscr) {
     64870@@ -309,7 +309,7 @@
     64871                break;
     64872            }
     64873            noecho();
     64874-           wattrset(txtwin, A_NORMAL);
     64875+           (void) wattrset(txtwin, A_NORMAL);
     64876            wprintw(strwin, "%d:%s", rc, buffer);
     64877            wnoutrefresh(strwin);
     64878            break;
     64879diff -Naur ncurses-5.7.orig/test/test_get_wstr.c ncurses-5.7/test/test_get_wstr.c
     64880--- ncurses-5.7.orig/test/test_get_wstr.c       2007-08-11 10:01:43.000000000 -0700
     64881+++ ncurses-5.7/test/test_get_wstr.c    2009-09-12 08:52:07.000000000 -0700
     64882@@ -1,5 +1,5 @@
     64883 /****************************************************************************
     64884- * Copyright (c) 2007 Free Software Foundation, Inc.                        *
     64885+ * Copyright (c) 2007,2009 Free Software Foundation, Inc.                   *
     64886  *                                                                          *
     64887  * Permission is hereby granted, free of charge, to any person obtaining a  *
     64888  * copy of this software and associated documentation files (the            *
     64889@@ -26,7 +26,7 @@
     64890  * authorization.                                                           *
     64891  ****************************************************************************/
     64892 /*
     64893- * $Id: test_get_wstr.c,v 1.5 2007/08/11 17:01:43 tom Exp $
     64894+ * $Id: test_get_wstr.c,v 1.6 2009/08/29 19:02:25 tom Exp $
     64895  *
     64896  * Author: Thomas E Dickey
     64897  *
     64898@@ -269,7 +269,7 @@
     64899            *buffer = '\0';
     64900            rc = ERR;
     64901            echo();
     64902-           wattrset(txtwin, A_REVERSE);
     64903+           (void) wattrset(txtwin, A_REVERSE);
     64904            switch (flavor) {
     64905            case eGetStr:
     64906                if (txtwin != stdscr) {
     64907@@ -307,9 +307,9 @@
     64908                break;
     64909            }
     64910            noecho();
     64911-           wattrset(txtwin, A_NORMAL);
     64912+           (void) wattrset(txtwin, A_NORMAL);
     64913            wprintw(strwin, "%d", rc);
     64914-           waddwstr(strwin, (wchar_t *) buffer);
     64915+           (void) waddwstr(strwin, (wchar_t *) buffer);
     64916            wnoutrefresh(strwin);
     64917            break;
     64918        default:
     64919diff -Naur ncurses-5.7.orig/test/test_opaque.c ncurses-5.7/test/test_opaque.c
     64920--- ncurses-5.7.orig/test/test_opaque.c 2008-07-05 16:18:40.000000000 -0700
     64921+++ ncurses-5.7/test/test_opaque.c      2009-09-12 08:52:07.000000000 -0700
     64922@@ -1,5 +1,5 @@
     64923 /****************************************************************************
     64924- * Copyright (c) 2007,2008 Free Software Foundation, Inc.                   *
     64925+ * Copyright (c) 2007-2008,2009 Free Software Foundation, Inc.              *
     64926  *                                                                          *
     64927  * Permission is hereby granted, free of charge, to any person obtaining a  *
     64928  * copy of this software and associated documentation files (the            *
     64929@@ -26,7 +26,7 @@
     64930  * authorization.                                                           *
     64931  ****************************************************************************/
     64932 /*
     64933- * $Id: test_opaque.c,v 1.7 2008/07/05 23:18:40 tom Exp $
     64934+ * $Id: test_opaque.c,v 1.8 2009/08/29 19:02:25 tom Exp $
     64935  *
     64936  * Author: Thomas E Dickey
     64937  *
     64938@@ -185,10 +185,10 @@
     64939 {
     64940     to_keyword(stswin, cell);
     64941     if (active == cell)
     64942-       wstandout(stswin);
     64943+       (void) wstandout(stswin);
     64944     wprintw(stswin, "%s:", name);
     64945     if (active == cell)
     64946-       wstandend(stswin);
     64947+       (void) wstandend(stswin);
     64948 }
     64949 /* *INDENT-OFF* */
     64950 static struct {
    6141664951diff -Naur ncurses-5.7.orig/test/test.priv.h ncurses-5.7/test/test.priv.h
    6141764952--- ncurses-5.7.orig/test/test.priv.h   2008-10-04 14:53:41.000000000 -0700
    61418 +++ ncurses-5.7/test/test.priv.h        2009-07-19 15:04:17.000000000 -0700
     64953+++ ncurses-5.7/test/test.priv.h        2009-09-12 08:51:54.000000000 -0700
    6141964954@@ -1,5 +1,5 @@
    6142064955 /****************************************************************************
     
    6157765112diff -Naur ncurses-5.7.orig/test/view.c ncurses-5.7/test/view.c
    6157865113--- ncurses-5.7.orig/test/view.c        2008-09-06 15:10:50.000000000 -0700
    61579 +++ ncurses-5.7/test/view.c     2009-07-19 15:04:17.000000000 -0700
     65114+++ ncurses-5.7/test/view.c     2009-09-12 08:51:54.000000000 -0700
    6158065115@@ -1,5 +1,5 @@
    6158165116 /****************************************************************************
     
    6163865173diff -Naur ncurses-5.7.orig/test/worm.c ncurses-5.7/test/worm.c
    6163965174--- ncurses-5.7.orig/test/worm.c        2008-10-04 14:54:09.000000000 -0700
    61640 +++ ncurses-5.7/test/worm.c     2009-07-19 15:03:58.000000000 -0700
     65175+++ ncurses-5.7/test/worm.c     2009-09-12 08:51:35.000000000 -0700
    6164165176@@ -61,7 +61,7 @@
    6164265177   traces will be dumped.  The program stops and waits for one character of
     
    6167565210     }
    6167665211 #endif
     65212diff -Naur ncurses-5.7.orig/test/xmas.c ncurses-5.7/test/xmas.c
     65213--- ncurses-5.7.orig/test/xmas.c        2008-08-03 04:08:59.000000000 -0700
     65214+++ ncurses-5.7/test/xmas.c     2009-09-12 08:52:07.000000000 -0700
     65215@@ -92,7 +92,7 @@
     65216 /******************************************************************************/
     65217 
     65218 /*
     65219- * $Id: xmas.c,v 1.24 2008/08/03 11:08:59 tom Exp $
     65220+ * $Id: xmas.c,v 1.25 2009/08/29 18:47:26 tom Exp $
     65221  */
     65222 #include <test.priv.h>
     65223 
     65224@@ -170,7 +170,7 @@
     65225 unset_color(WINDOW *win)
     65226 {
     65227     if (has_colors())
     65228-       wattrset(win, COLOR_PAIR(0));
     65229+       (void) wattrset(win, COLOR_PAIR(0));
     65230 }
     65231 
     65232 static void
     65233@@ -533,9 +533,9 @@
     65234        mvwaddch(treescrn4, 12, 23, ' ');
     65235 
     65236        /*star */
     65237-       wstandout(treescrn4);
     65238+       (void) wstandout(treescrn4);
     65239        mvwaddch(treescrn4, 0, 12, '*');
     65240-       wstandend(treescrn4);
     65241+       (void) wstandend(treescrn4);
     65242 
     65243        /*strng1 */
     65244        mvwaddch(treescrn4, 3, 13, ' ');
     65245@@ -597,9 +597,9 @@
     65246        mvwaddch(treescrn6, 11, 23, ' ');
     65247 
     65248        /*star */
     65249-       wstandout(treescrn6);
     65250+       (void) wstandout(treescrn6);
     65251        mvwaddch(treescrn6, 0, 12, '*');
     65252-       wstandend(treescrn6);
     65253+       (void) wstandend(treescrn6);
     65254 
     65255        /*strng1 */
     65256 
     65257@@ -816,11 +816,11 @@
     65258 static int
     65259 star(void)
     65260 {
     65261-    wattrset(treescrn2, A_BOLD | A_BLINK);
     65262+    (void) wattrset(treescrn2, A_BOLD | A_BLINK);
     65263     set_color(treescrn2, COLOR_YELLOW);
     65264 
     65265     mvwaddch(treescrn2, 0, 12, (chtype) '*');
     65266-    wstandend(treescrn2);
     65267+    (void) wstandend(treescrn2);
     65268 
     65269     unset_color(treescrn2);
     65270     wrefresh(treescrn2);
     65271@@ -831,7 +831,7 @@
     65272 static int
     65273 strng1(void)
     65274 {
     65275-    wattrset(treescrn2, A_BOLD | A_BLINK);
     65276+    (void) wattrset(treescrn2, A_BOLD | A_BLINK);
     65277     set_color(treescrn2, COLOR_WHITE);
     65278 
     65279     mvwaddch(treescrn2, 3, 13, (chtype) '\'');
     65280@@ -849,7 +849,7 @@
     65281 static int
     65282 strng2(void)
     65283 {
     65284-    wattrset(treescrn2, A_BOLD | A_BLINK);
     65285+    (void) wattrset(treescrn2, A_BOLD | A_BLINK);
     65286     set_color(treescrn2, COLOR_WHITE);
     65287 
     65288     mvwaddch(treescrn2, 5, 14, (chtype) '\'');
     65289@@ -870,7 +870,7 @@
     65290 static int
     65291 strng3(void)
     65292 {
     65293-    wattrset(treescrn2, A_BOLD | A_BLINK);
     65294+    (void) wattrset(treescrn2, A_BOLD | A_BLINK);
     65295     set_color(treescrn2, COLOR_WHITE);
     65296 
     65297     mvwaddch(treescrn2, 7, 16, (chtype) '\'');
     65298@@ -893,7 +893,7 @@
     65299 static int
     65300 strng4(void)
     65301 {
     65302-    wattrset(treescrn2, A_BOLD | A_BLINK);
     65303+    (void) wattrset(treescrn2, A_BOLD | A_BLINK);
     65304     set_color(treescrn2, COLOR_WHITE);
     65305 
     65306     mvwaddch(treescrn2, 9, 17, (chtype) '\'');
     65307@@ -921,7 +921,7 @@
     65308 static int
     65309 strng5(void)
     65310 {
     65311-    wattrset(treescrn2, A_BOLD | A_BLINK);
     65312+    (void) wattrset(treescrn2, A_BOLD | A_BLINK);
     65313     set_color(treescrn2, COLOR_WHITE);
     65314 
     65315     mvwaddch(treescrn2, 11, 19, (chtype) '\'');
    6167765316diff -Naur ncurses-5.7.orig/TO-DO ncurses-5.7/TO-DO
    6167865317--- ncurses-5.7.orig/TO-DO      2008-10-11 12:22:27.000000000 -0700
    61679 +++ ncurses-5.7/TO-DO   2009-07-19 15:01:59.000000000 -0700
     65318+++ ncurses-5.7/TO-DO   2009-09-12 08:50:54.000000000 -0700
    6168065319@@ -25,7 +25,7 @@
    6168165320 -- sale, use or other dealings in this Software without prior written        --
  • patches/vim-7.2-branch_update-21.patch

    rdca5b7b re92465d  
    11Submitted By: Jim Gifford (jim at cross-lfs dot org)
    2 Date: 07-19-2009
     2Date: 09-12-2009
    33Initial Package Version: 7.2
    44Origin: Upstream
    55Upstream Status: Applied
    6 Description: Contains all upstream patches up to 7.2.234
     6Description: Contains all upstream patches up to 7.2.259
    77             The following patches were skipped
    8              007 036 041 049 071 072 074 088 089 093 101 138 150 172 173 191 194 204 205 212 216 219 233
     8             007 036 041 049 071 072 074 088 089 093 101 138 150 172 173 191 194 204 205 212 216 219 233 247 248 249 250
    99
    1010diff -Naur vim72.orig/Filelist vim72/Filelist
    1111--- vim72.orig/Filelist 2008-07-06 11:02:23.000000000 -0700
    12 +++ vim72/Filelist      2009-07-19 15:17:20.000000000 -0700
     12+++ vim72/Filelist      2009-09-12 08:39:38.000000000 -0700
    1313@@ -285,6 +285,7 @@
    1414                src/proto/os_win32.pro \
     
    3131diff -Naur vim72.orig/runtime/doc/cmdline.txt vim72/runtime/doc/cmdline.txt
    3232--- vim72.orig/runtime/doc/cmdline.txt  2008-08-09 07:22:59.000000000 -0700
    33 +++ vim72/runtime/doc/cmdline.txt       2009-07-19 15:19:00.000000000 -0700
     33+++ vim72/runtime/doc/cmdline.txt       2009-09-12 08:41:24.000000000 -0700
    3434@@ -1,4 +1,4 @@
    3535-*cmdline.txt*   For Vim version 7.2.  Last change: 2008 Jul 29
     
    112112diff -Naur vim72.orig/runtime/doc/eval.txt vim72/runtime/doc/eval.txt
    113113--- vim72.orig/runtime/doc/eval.txt     2008-08-09 07:22:59.000000000 -0700
    114 +++ vim72/runtime/doc/eval.txt  2009-07-19 15:15:05.000000000 -0700
     114+++ vim72/runtime/doc/eval.txt  2009-09-12 08:37:22.000000000 -0700
    115115@@ -1,4 +1,4 @@
    116116-*eval.txt*     For Vim version 7.2.  Last change: 2008 Aug 09
     
    248248diff -Naur vim72.orig/runtime/doc/if_cscop.txt vim72/runtime/doc/if_cscop.txt
    249249--- vim72.orig/runtime/doc/if_cscop.txt 2008-08-09 07:22:59.000000000 -0700
    250 +++ vim72/runtime/doc/if_cscop.txt      2009-07-19 15:18:44.000000000 -0700
     250+++ vim72/runtime/doc/if_cscop.txt      2009-09-12 08:41:56.000000000 -0700
    251251@@ -1,4 +1,4 @@
    252252-*if_cscop.txt*  For Vim version 7.2.  Last change: 2005 Mar 29
     
    296296 ==============================================================================
    297297 6. Suggested usage                                     *cscope-suggestions*
     298@@ -475,7 +481,8 @@
     299 any problems, suggestions, patches, et al., you have for the usage of
     300 cscope within Vim to him.
     301                                                        *cscope-win32*
     302-For a cscope version for Win32 see: http://iamphet.nm.ru/cscope/index.html
     303+For a cscope version for Win32 see:
     304+       http://code.google.com/p/cscope-win32/
     305 
     306 Win32 support was added by Sergey Khorev <sergey.khorev@gmail.com>.  Contact
     307 him if you have Win32-specific issues.
    298308diff -Naur vim72.orig/runtime/doc/netbeans.txt vim72/runtime/doc/netbeans.txt
    299309--- vim72.orig/runtime/doc/netbeans.txt 2008-08-09 07:22:59.000000000 -0700
    300 +++ vim72/runtime/doc/netbeans.txt      2009-07-19 15:12:02.000000000 -0700
     310+++ vim72/runtime/doc/netbeans.txt      2009-09-12 08:34:15.000000000 -0700
    301311@@ -1,4 +1,4 @@
    302312-*netbeans.txt*  For Vim version 7.2.  Last change: 2008 Jun 28
     
    320330diff -Naur vim72.orig/runtime/doc/options.txt vim72/runtime/doc/options.txt
    321331--- vim72.orig/runtime/doc/options.txt  2008-08-09 07:22:59.000000000 -0700
    322 +++ vim72/runtime/doc/options.txt       2009-07-19 15:17:33.000000000 -0700
     332+++ vim72/runtime/doc/options.txt       2009-09-12 08:39:52.000000000 -0700
    323333@@ -1,4 +1,4 @@
    324334-*options.txt*  For Vim version 7.2.  Last change: 2008 Aug 06
     
    366376diff -Naur vim72.orig/runtime/doc/spell.txt vim72/runtime/doc/spell.txt
    367377--- vim72.orig/runtime/doc/spell.txt    2008-08-09 07:23:00.000000000 -0700
    368 +++ vim72/runtime/doc/spell.txt 2009-07-19 15:11:11.000000000 -0700
     378+++ vim72/runtime/doc/spell.txt 2009-09-12 08:33:24.000000000 -0700
    369379@@ -1,4 +1,4 @@
    370380-*spell.txt*    For Vim version 7.2.  Last change: 2008 Jun 21
     
    496506diff -Naur vim72.orig/runtime/doc/starting.txt vim72/runtime/doc/starting.txt
    497507--- vim72.orig/runtime/doc/starting.txt 2008-08-09 07:23:00.000000000 -0700
    498 +++ vim72/runtime/doc/starting.txt      2009-07-19 15:09:53.000000000 -0700
     508+++ vim72/runtime/doc/starting.txt      2009-09-12 08:32:04.000000000 -0700
    499509@@ -1,4 +1,4 @@
    500510-*starting.txt*  For Vim version 7.2.  Last change: 2008 Jun 21
     
    558568diff -Naur vim72.orig/runtime/doc/usr_21.txt vim72/runtime/doc/usr_21.txt
    559569--- vim72.orig/runtime/doc/usr_21.txt   2008-08-09 07:23:01.000000000 -0700
    560 +++ vim72/runtime/doc/usr_21.txt        2009-07-19 15:09:53.000000000 -0700
     570+++ vim72/runtime/doc/usr_21.txt        2009-09-12 08:32:04.000000000 -0700
    561571@@ -1,4 +1,4 @@
    562572-*usr_21.txt*   For Vim version 7.2.  Last change: 2007 May 01
     
    625635diff -Naur vim72.orig/runtime/doc/various.txt vim72/runtime/doc/various.txt
    626636--- vim72.orig/runtime/doc/various.txt  2008-08-09 07:23:01.000000000 -0700
    627 +++ vim72/runtime/doc/various.txt       2009-07-19 15:18:31.000000000 -0700
     637+++ vim72/runtime/doc/various.txt       2009-09-12 08:40:55.000000000 -0700
    628638@@ -508,6 +508,17 @@
    629639                        messages though.  Use ":silent" in the command itself
     
    646656diff -Naur vim72.orig/runtime/scripts.vim vim72/runtime/scripts.vim
    647657--- vim72.orig/runtime/scripts.vim      2008-08-08 15:27:21.000000000 -0700
    648 +++ vim72/runtime/scripts.vim   2009-07-19 15:08:47.000000000 -0700
     658+++ vim72/runtime/scripts.vim   2009-09-12 08:30:57.000000000 -0700
    649659@@ -234,6 +234,10 @@
    650660   elseif s:line1 =~ '\<DTD\s\+XHTML\s'
     
    660670diff -Naur vim72.orig/src/auto/configure vim72/src/auto/configure
    661671--- vim72.orig/src/auto/configure       2008-07-24 05:40:36.000000000 -0700
    662 +++ vim72/src/auto/configure    2009-07-19 15:16:46.000000000 -0700
     672+++ vim72/src/auto/configure    2009-09-12 08:42:09.000000000 -0700
    663673@@ -1,6 +1,6 @@
    664674 #! /bin/sh
     
    11541164           cat >>confdefs.h <<\_ACEOF
    11551165 #define HAVE_SELINUX 1
    1156 @@ -5891,7 +5898,7 @@
     1166@@ -5745,7 +5752,10 @@
     1167        fi
     1168        rubyldflags=`$vi_cv_path_ruby -r rbconfig -e 'print Config::CONFIG["LDFLAGS"]'`
     1169        if test "X$rubyldflags" != "X"; then
     1170-         LDFLAGS="$rubyldflags $LDFLAGS"
     1171+                                 rubyldflags=`echo "$rubyldflags" | sed -e 's/-arch\ ppc//' -e 's/-arch\ i386//'`
     1172+         if test "X$rubyldflags" != "X"; then
     1173+           LDFLAGS="$rubyldflags $LDFLAGS"
     1174+         fi
     1175        fi
     1176        RUBY_SRC="if_ruby.c"
     1177        RUBY_OBJ="objects/if_ruby.o"
     1178@@ -5891,7 +5901,7 @@
    11571179 fi
    11581180 { $as_echo "$as_me:$LINENO: result: $ac_cv_lib_socket_socket" >&5
     
    11631185 #define HAVE_LIBSOCKET 1
    11641186 _ACEOF
    1165 @@ -5966,7 +5973,7 @@
     1187@@ -5966,7 +5976,7 @@
    11661188 fi
    11671189 { $as_echo "$as_me:$LINENO: result: $ac_cv_lib_nsl_gethostbyname" >&5
     
    11721194 #define HAVE_LIBNSL 1
    11731195 _ACEOF
    1174 @@ -6203,8 +6210,8 @@
     1196@@ -6203,8 +6213,8 @@
    11751197   have_x=disabled
    11761198 else
     
    11831205     *,NONE | NONE,*) if test "${ac_cv_have_x+set}" = set; then
    11841206   $as_echo_n "(cached) " >&6
    1185 @@ -6242,7 +6249,7 @@
     1207@@ -6242,7 +6252,7 @@
    11861208        *) test -f "$ac_im_incroot/X11/Xos.h" && ac_x_includes=$ac_im_incroot;;
    11871209     esac
     
    11921214     esac
    11931215   fi
    1194 @@ -6682,7 +6689,7 @@
     1216@@ -6682,7 +6692,7 @@
    11951217 fi
    11961218 { $as_echo "$as_me:$LINENO: result: $ac_cv_lib_dnet_dnet_ntoa" >&5
     
    12011223 fi
    12021224 
    1203 @@ -6752,7 +6759,7 @@
     1225@@ -6752,7 +6762,7 @@
    12041226 fi
    12051227 { $as_echo "$as_me:$LINENO: result: $ac_cv_lib_dnet_stub_dnet_ntoa" >&5
     
    12101232 fi
    12111233 
    1212 @@ -6924,7 +6931,7 @@
     1234@@ -6924,7 +6934,7 @@
    12131235 fi
    12141236 { $as_echo "$as_me:$LINENO: result: $ac_cv_lib_nsl_gethostbyname" >&5
     
    12191241 fi
    12201242 
    1221 @@ -6994,7 +7001,7 @@
     1243@@ -6994,7 +7004,7 @@
    12221244 fi
    12231245 { $as_echo "$as_me:$LINENO: result: $ac_cv_lib_bsd_gethostbyname" >&5
     
    12281250 fi
    12291251 
    1230 @@ -7160,7 +7167,7 @@
     1252@@ -7160,7 +7170,7 @@
    12311253 fi
    12321254 { $as_echo "$as_me:$LINENO: result: $ac_cv_lib_socket_connect" >&5
     
    12371259 fi
    12381260 
    1239 @@ -7319,7 +7326,7 @@
     1261@@ -7319,7 +7329,7 @@
    12401262 fi
    12411263 { $as_echo "$as_me:$LINENO: result: $ac_cv_lib_posix_remove" >&5
     
    12461268 fi
    12471269 
    1248 @@ -7478,7 +7485,7 @@
     1270@@ -7478,7 +7488,7 @@
    12491271 fi
    12501272 { $as_echo "$as_me:$LINENO: result: $ac_cv_lib_ipc_shmat" >&5
     
    12551277 fi
    12561278 
    1257 @@ -7559,7 +7566,7 @@
     1279@@ -7559,7 +7569,7 @@
    12581280 fi
    12591281 { $as_echo "$as_me:$LINENO: result: $ac_cv_lib_ICE_IceConnectionNumber" >&5
     
    12641286 fi
    12651287 
    1266 @@ -7727,7 +7734,7 @@
     1288@@ -7727,7 +7737,7 @@
    12671289 fi
    12681290 { $as_echo "$as_me:$LINENO: result: $ac_cv_lib_Xdmcp__XdmcpAuthDoIt" >&5
     
    12731295 fi
    12741296 
    1275 @@ -7797,7 +7804,7 @@
     1297@@ -7797,7 +7807,7 @@
    12761298 fi
    12771299 { $as_echo "$as_me:$LINENO: result: $ac_cv_lib_ICE_IceOpenConnection" >&5
     
    12821304 fi
    12831305 
    1284 @@ -7868,7 +7875,7 @@
     1306@@ -7868,7 +7878,7 @@
    12851307 fi
    12861308 { $as_echo "$as_me:$LINENO: result: $ac_cv_lib_Xpm_XpmCreatePixmapFromData" >&5
     
    12911313 fi
    12921314 
    1293 @@ -7970,6 +7977,82 @@
     1315@@ -7970,6 +7980,82 @@
    12941316 
    12951317     LDFLAGS="$ac_save_LDFLAGS"
     
    13741396 fi
    13751397 
    1376 @@ -9251,7 +9334,7 @@
     1398@@ -9251,7 +9337,7 @@
    13771399 fi
    13781400 { $as_echo "$as_me:$LINENO: result: $ac_cv_lib_Xext_XShapeQueryExtension" >&5
     
    13831405 fi
    13841406 
    1385 @@ -9320,7 +9403,7 @@
     1407@@ -9320,7 +9406,7 @@
    13861408 fi
    13871409 { $as_echo "$as_me:$LINENO: result: $ac_cv_lib_w_wslen" >&5
     
    13921414 fi
    13931415 
    1394 @@ -9389,7 +9472,7 @@
     1416@@ -9389,7 +9475,7 @@
    13951417 fi
    13961418 { $as_echo "$as_me:$LINENO: result: $ac_cv_lib_dl_dlsym" >&5
     
    14011423 fi
    14021424 
    1403 @@ -9458,7 +9541,7 @@
     1425@@ -9458,7 +9544,7 @@
    14041426 fi
    14051427 { $as_echo "$as_me:$LINENO: result: $ac_cv_lib_Xmu_XmuCreateStippledPixmap" >&5
     
    14101432 fi
    14111433 
    1412 @@ -9528,7 +9611,7 @@
     1434@@ -9528,7 +9614,7 @@
    14131435 fi
    14141436 { $as_echo "$as_me:$LINENO: result: $ac_cv_lib_Xp_XpEndJob" >&5
     
    14191441 fi
    14201442 
    1421 @@ -9699,8 +9782,9 @@
     1443@@ -9699,8 +9785,9 @@
    14221444 $as_echo "$ac_res" >&6; }
    14231445 
     
    14311453 #define `$as_echo "HAVE_$ac_header" | $as_tr_cpp` 1
    14321454 _ACEOF
    1433 @@ -9852,8 +9936,9 @@
     1455@@ -9852,8 +9939,9 @@
    14341456 $as_echo "$ac_res" >&6; }
    14351457 
     
    14431465 #define `$as_echo "HAVE_$ac_header" | $as_tr_cpp` 1
    14441466 _ACEOF
    1445 @@ -10098,8 +10183,9 @@
     1467@@ -10098,8 +10186,9 @@
    14461468 $as_echo "$ac_res" >&6; }
    14471469 
     
    14551477 #define `$as_echo "HAVE_$ac_header" | $as_tr_cpp` 1
    14561478 _ACEOF
    1457 @@ -10489,7 +10575,7 @@
     1479@@ -10489,7 +10578,7 @@
    14581480 $as_echo "$ac_cv_header_elf_h" >&6; }
    14591481 
     
    14641486 fi
    14651487 
    1466 @@ -10555,7 +10641,7 @@
     1488@@ -10555,7 +10644,7 @@
    14671489 fi
    14681490 { $as_echo "$as_me:$LINENO: result: $ac_cv_lib_elf_main" >&5
     
    14731495 #define HAVE_LIBELF 1
    14741496 _ACEOF
    1475 @@ -10629,8 +10715,9 @@
     1497@@ -10629,8 +10718,9 @@
    14761498                 $as_echo "$as_val"'`
    14771499               { $as_echo "$as_me:$LINENO: result: $ac_res" >&5
     
    14851507 #define `$as_echo "HAVE_$ac_hdr" | $as_tr_cpp` 1
    14861508 _ACEOF
    1487 @@ -10916,7 +11003,6 @@
     1509@@ -10916,7 +11006,6 @@
    14881510 
    14891511 
     
    14931515        termcap.h fcntl.h sgtty.h sys/ioctl.h sys/time.h sys/types.h termio.h \
    14941516        iconv.h langinfo.h math.h unistd.h stropts.h errno.h \
    1495 @@ -10924,7 +11010,7 @@
     1517@@ -10924,7 +11013,7 @@
    14961518        sys/stream.h termios.h libc.h sys/statfs.h \
    14971519        poll.h sys/poll.h pwd.h utime.h sys/param.h libintl.h \
     
    15021524 as_ac_Header=`$as_echo "ac_cv_header_$ac_header" | $as_tr_sh`
    15031525 if { as_var=$as_ac_Header; eval "test \"\${$as_var+set}\" = set"; }; then
    1504 @@ -11058,8 +11144,9 @@
     1526@@ -11058,8 +11147,9 @@
    15051527 $as_echo "$ac_res" >&6; }
    15061528 
     
    15141536 #define `$as_echo "HAVE_$ac_header" | $as_tr_cpp` 1
    15151537 _ACEOF
    1516 @@ -11122,8 +11209,74 @@
     1538@@ -11122,8 +11212,74 @@
    15171539                 $as_echo "$as_val"'`
    15181540               { $as_echo "$as_me:$LINENO: result: $ac_res" >&5
     
    15911613 #define `$as_echo "HAVE_$ac_header" | $as_tr_cpp` 1
    15921614 _ACEOF
    1593 @@ -11322,8 +11475,9 @@
     1615@@ -11322,8 +11478,9 @@
    15941616 $as_echo "$ac_res" >&6; }
    15951617 
     
    16031625 #define `$as_echo "HAVE_$ac_header" | $as_tr_cpp` 1
    16041626 _ACEOF
    1605 @@ -11565,6 +11719,67 @@
     1627@@ -11565,6 +11722,67 @@
    16061628 
    16071629 fi
     
    16711693 $as_echo_n "checking for mode_t... " >&6; }
    16721694 if test "${ac_cv_type_mode_t+set}" = set; then
    1673 @@ -11659,7 +11874,7 @@
     1695@@ -11659,7 +11877,7 @@
    16741696 fi
    16751697 { $as_echo "$as_me:$LINENO: result: $ac_cv_type_mode_t" >&5
     
    16801702 else
    16811703 
    1682 @@ -11763,7 +11978,7 @@
     1704@@ -11763,7 +11981,7 @@
    16831705 fi
    16841706 { $as_echo "$as_me:$LINENO: result: $ac_cv_type_off_t" >&5
     
    16891711 else
    16901712 
    1691 @@ -11867,7 +12082,7 @@
     1713@@ -11867,7 +12085,7 @@
    16921714 fi
    16931715 { $as_echo "$as_me:$LINENO: result: $ac_cv_type_pid_t" >&5
     
    16981720 else
    16991721 
    1700 @@ -11971,7 +12186,7 @@
     1722@@ -11971,7 +12189,7 @@
    17011723 fi
    17021724 { $as_echo "$as_me:$LINENO: result: $ac_cv_type_size_t" >&5
     
    17071729 else
    17081730 
    1709 @@ -12175,7 +12390,7 @@
     1731@@ -12175,7 +12393,7 @@
    17101732 fi
    17111733 { $as_echo "$as_me:$LINENO: result: $ac_cv_type_ino_t" >&5
     
    17161738 else
    17171739 
    1718 @@ -12279,7 +12494,7 @@
     1740@@ -12279,7 +12497,7 @@
    17191741 fi
    17201742 { $as_echo "$as_me:$LINENO: result: $ac_cv_type_dev_t" >&5
     
    17251747 else
    17261748 
    1727 @@ -12569,8 +12784,9 @@
     1749@@ -12569,8 +12787,9 @@
    17281750                 $as_echo "$as_val"'`
    17291751               { $as_echo "$as_me:$LINENO: result: $ac_res" >&5
     
    17371759 #define `$as_echo "HAVE_LIB${libname}" | $as_tr_cpp` 1
    17381760 _ACEOF
    1739 @@ -13818,8 +14034,9 @@
     1761@@ -13818,8 +14037,9 @@
    17401762                 $as_echo "$as_val"'`
    17411763               { $as_echo "$as_me:$LINENO: result: $ac_res" >&5
     
    17491771 #define `$as_echo "HAVE_$ac_func" | $as_tr_cpp` 1
    17501772 _ACEOF
    1751 @@ -14202,7 +14419,7 @@
     1773@@ -14202,7 +14422,7 @@
    17521774 fi
    17531775 { $as_echo "$as_me:$LINENO: result: $ac_cv_lib_m_strtod" >&5
     
    17581780 #define HAVE_LIBM 1
    17591781 _ACEOF
    1760 @@ -14362,7 +14579,7 @@
     1782@@ -14362,7 +14582,7 @@
    17611783 fi
    17621784 { $as_echo "$as_me:$LINENO: result: $ac_cv_lib_posix1e_acl_get_file" >&5
     
    17671789 else
    17681790   { $as_echo "$as_me:$LINENO: checking for acl_get_file in -lacl" >&5
    1769 @@ -14430,7 +14647,7 @@
     1791@@ -14430,7 +14650,7 @@
    17701792 fi
    17711793 { $as_echo "$as_me:$LINENO: result: $ac_cv_lib_acl_acl_get_file" >&5
     
    17761798                  { $as_echo "$as_me:$LINENO: checking for fgetxattr in -lattr" >&5
    17771799 $as_echo_n "checking for fgetxattr in -lattr... " >&6; }
    1778 @@ -14497,7 +14714,7 @@
     1800@@ -14497,7 +14717,7 @@
    17791801 fi
    17801802 { $as_echo "$as_me:$LINENO: result: $ac_cv_lib_attr_fgetxattr" >&5
     
    17851807 fi
    17861808 
    1787 @@ -15226,7 +15443,6 @@
     1809@@ -15226,7 +15446,6 @@
    17881810 
    17891811 
     
    17931815 #include "confdefs.h"
    17941816 #ifdef HAVE_STRING_H
    1795 @@ -15458,7 +15674,7 @@
     1817@@ -15458,7 +15677,7 @@
    17961818 if test "$enable_multibyte" = "yes"; then
    17971819   cflags_save=$CFLAGS
     
    18021824     LDFLAGS="$X_LIBS $LDFLAGS -lX11"
    18031825     { $as_echo "$as_me:$LINENO: checking whether X_LOCALE needed" >&5
    1804 @@ -15635,7 +15851,7 @@
     1826@@ -15635,7 +15854,7 @@
    18051827 fi
    18061828 { $as_echo "$as_me:$LINENO: result: $ac_cv_lib_xpg4__xpg4_setrunelocale" >&5
     
    18111833 fi
    18121834 
    1813 @@ -15646,6 +15862,7 @@
     1835@@ -15646,6 +15865,7 @@
    18141836 if (eval ctags --version /dev/null | grep Exuberant) < /dev/null 1>&5 2>&1; then
    18151837   TAGPRG="ctags -I INIT+ --fields=+S"
     
    18191841   (eval etags -c   /dev/null) < /dev/null 1>&5 2>&1 && TAGPRG="etags -c"
    18201842   (eval ctags     /dev/null) < /dev/null 1>&5 2>&1 && TAGPRG="ctags"
    1821 @@ -15933,8 +16150,9 @@
     1843@@ -15933,8 +16153,9 @@
    18221844                 $as_echo "$as_val"'`
    18231845               { $as_echo "$as_me:$LINENO: result: $ac_res" >&5
     
    18311853 #define `$as_echo "HAVE_$ac_func" | $as_tr_cpp` 1
    18321854 _ACEOF
    1833 @@ -16134,7 +16352,7 @@
     1855@@ -16134,7 +16355,7 @@
    18341856 $as_echo "$ac_cv_header_dlfcn_h" >&6; }
    18351857 
     
    18401862 else
    18411863   if test "${ac_cv_header_dl_h+set}" = set; then
    1842 @@ -16264,7 +16482,7 @@
     1864@@ -16264,7 +16485,7 @@
    18431865 $as_echo "$ac_cv_header_dl_h" >&6; }
    18441866 
     
    18491871 fi
    18501872 
    1851 @@ -16783,8 +17001,9 @@
     1873@@ -16783,8 +17004,9 @@
    18521874 $as_echo "$ac_res" >&6; }
    18531875 
     
    18611883 #define `$as_echo "HAVE_$ac_header" | $as_tr_cpp` 1
    18621884 _ACEOF
    1863 @@ -16819,21 +17038,29 @@
     1885@@ -16819,21 +17041,29 @@
    18641886   LDFLAGS="$LDFLAGS -isysroot /Developer/SDKs/MacOSX10.4u.sdk -arch i386 -arch ppc"
    18651887 fi
     
    18891911+$as_echo_n "checking whether we need -D_FORTIFY_SOURCE=1... " >&6; }
    18901912+  if test "$gccmajor" -gt "3"; then
    1891 +    CFLAGS="$CFLAGS -D_FORTIFY_SOURCE=1"
     1913+    CFLAGS=`echo "$CFLAGS -D_FORTIFY_SOURCE=1" | sed -e 's/-Wp,-D_FORTIFY_SOURCE=2//g' -e 's/-D_FORTIFY_SOURCE=2//g'`
    18921914+    { $as_echo "$as_me:$LINENO: result: yes" >&5
    18931915 $as_echo "yes" >&6; }
     
    18991921 
    19001922 
    1901 @@ -16866,8 +17093,8 @@
     1923@@ -16866,8 +17096,8 @@
    19021924     case $ac_val in #(
    19031925     *${as_nl}*)
     
    19101932       case $ac_var in #(
    19111933       _ | IFS | as_nl) ;; #(
    1912 @@ -17259,7 +17486,7 @@
     1934@@ -17259,7 +17489,7 @@
    19131935 # values after options handling.
    19141936 ac_log="
     
    19191941   CONFIG_FILES    = $CONFIG_FILES
    19201942   CONFIG_HEADERS  = $CONFIG_HEADERS
    1921 @@ -17272,6 +17499,15 @@
     1943@@ -17272,6 +17502,15 @@
    19221944 
    19231945 _ACEOF
     
    19351957 # Files that config.status was made for.
    19361958 config_files="$ac_config_files"
    1937 @@ -17284,16 +17520,17 @@
     1959@@ -17284,16 +17523,17 @@
    19381960 \`$as_me' instantiates files from templates according to the
    19391961 current configuration.
     
    19571979 
    19581980 Configuration files:
    1959 @@ -17308,7 +17545,7 @@
     1981@@ -17308,7 +17548,7 @@
    19601982 cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1
    19611983 ac_cs_version="\\
     
    19661988 
    19671989 Copyright (C) 2008 Free Software Foundation, Inc.
    1968 @@ -17505,7 +17742,8 @@
     1990@@ -17505,7 +17745,8 @@
    19691991 $as_echo "$as_me: error: could not make $CONFIG_STATUS" >&2;}
    19701992    { (exit 1); exit 1; }; }
     
    19761998   elif $ac_last_try; then
    19771999     { { $as_echo "$as_me:$LINENO: error: could not make $CONFIG_STATUS" >&5
    1978 @@ -17710,9 +17948,9 @@
     2000@@ -17710,9 +17951,9 @@
    19792001   }
    19802002   split(mac1, mac2, "(") #)
     
    19872009     next
    19882010   } else {
    1989 @@ -17720,7 +17958,7 @@
     2011@@ -17720,7 +17961,7 @@
    19902012     # in the case of _POSIX_SOURCE, which is predefined and required
    19912013     # on some systems where configure will not decide to define it.
     
    19962018     }
    19972019   }
    1998 @@ -17744,8 +17982,8 @@
     2020@@ -17744,8 +17985,8 @@
    19992021   esac
    20002022   case $ac_mode$ac_tag in
     
    20072029   :[FH]-) ac_tag=-:-;;
    20082030   :[FH]*) ac_tag=$ac_tag:$ac_tag.in;;
    2009 @@ -18063,8 +18301,8 @@
     2031@@ -18063,8 +18304,8 @@
    20102032   $ac_cs_success || { (exit 1); exit 1; }
    20112033 fi
     
    20202042diff -Naur vim72.orig/src/buffer.c vim72/src/buffer.c
    20212043--- vim72.orig/src/buffer.c     2008-08-06 04:00:48.000000000 -0700
    2022 +++ vim72/src/buffer.c  2009-07-19 15:16:33.000000000 -0700
     2044+++ vim72/src/buffer.c  2009-09-12 08:38:51.000000000 -0700
    20232045@@ -44,6 +44,7 @@
    20242046 #ifdef FEAT_TITLE
     
    25472569diff -Naur vim72.orig/src/charset.c vim72/src/charset.c
    25482570--- vim72.orig/src/charset.c    2008-07-24 07:59:44.000000000 -0700
    2549 +++ vim72/src/charset.c 2009-07-19 15:15:54.000000000 -0700
     2571+++ vim72/src/charset.c 2009-09-12 08:42:12.000000000 -0700
    25502572@@ -17,7 +17,7 @@
    25512573 static int win_nolbr_chartabsize __ARGS((win_T *wp, char_u *s, colnr_T col, int *headp));
     
    25572579 static int    chartab_initialized = FALSE;
    25582580 
    2559 @@ -664,7 +664,7 @@
     2581@@ -174,6 +174,11 @@
     2582            if (VIM_ISDIGIT(*p))
     2583                c = getdigits(&p);
     2584            else
     2585+#ifdef FEAT_MBYTE
     2586+                if (has_mbyte)
     2587+               c = mb_ptr2char_adv(&p);
     2588+           else
     2589+#endif
     2590                c = *p++;
     2591            c2 = -1;
     2592            if (*p == '-' && p[1] != NUL)
     2593@@ -664,7 +669,7 @@
    25602594     }
    25612595 #endif
     
    25662600     buf[++i] = NUL;
    25672601 }
    2568 @@ -674,9 +674,9 @@
     2602@@ -674,9 +679,9 @@
    25692603  * Lower case letters are used to avoid the confusion of <F1> being 0xf1 or
    25702604  * function key 1.
     
    25782612     if ((c & 0xf) <= 9)
    25792613        return (c & 0xf) + '0';
    2580 @@ -884,7 +884,7 @@
     2614@@ -884,7 +889,7 @@
    25812615     if (c >= 0x100)
    25822616     {
     
    25872621            return utf_class(c) >= 2;
    25882622     }
    2589 @@ -1090,7 +1090,7 @@
     2623@@ -1090,7 +1095,7 @@
    25902624         */
    25912625        numberextra = win_col_off(wp);
     
    25962630        {
    25972631            n = colmax + win_col_off2(wp);
    2598 @@ -1201,17 +1201,17 @@
     2632@@ -1201,17 +1206,17 @@
    25992633     win_T      *wp;
    26002634     colnr_T    vcol;
     
    26182652     width2 = width1 + win_col_off2(wp);
    26192653     return ((vcol - width1) % width2 == width2 - 1);
    2620 @@ -1396,13 +1396,13 @@
     2654@@ -1396,13 +1401,13 @@
    26212655 # ifdef FEAT_MBYTE
    26222656        /* Cannot put the cursor on part of a wide character. */
     
    26362670diff -Naur vim72.orig/src/config.h.in vim72/src/config.h.in
    26372671--- vim72.orig/src/config.h.in  2008-06-21 08:01:41.000000000 -0700
    2638 +++ vim72/src/config.h.in       2009-07-19 15:16:46.000000000 -0700
     2672+++ vim72/src/config.h.in       2009-09-12 08:39:05.000000000 -0700
    26392673@@ -36,6 +36,9 @@
    26402674 /* Defined to the size of an int */
     
    26592693diff -Naur vim72.orig/src/configure.in vim72/src/configure.in
    26602694--- vim72.orig/src/configure.in 2008-07-24 05:40:26.000000000 -0700
    2661 +++ vim72/src/configure.in      2009-07-19 15:16:46.000000000 -0700
    2662 @@ -1193,6 +1193,28 @@
     2695+++ vim72/src/configure.in      2009-09-12 08:42:09.000000000 -0700
     2696@@ -957,7 +957,13 @@
     2697        fi
     2698        rubyldflags=`$vi_cv_path_ruby -r rbconfig -e 'print Config::CONFIG[["LDFLAGS"]]'`
     2699        if test "X$rubyldflags" != "X"; then
     2700-         LDFLAGS="$rubyldflags $LDFLAGS"
     2701+         dnl Ruby on Mac OS X 10.5 adds "-arch" flags but these should only
     2702+         dnl be included if requested by passing --with-mac-arch to
     2703+         dnl configure, so strip these flags first (if present)
     2704+         rubyldflags=`echo "$rubyldflags" | sed -e 's/-arch\ ppc//' -e 's/-arch\ i386//'`
     2705+         if test "X$rubyldflags" != "X"; then
     2706+           LDFLAGS="$rubyldflags $LDFLAGS"
     2707+         fi
     2708        fi
     2709        RUBY_SRC="if_ruby.c"
     2710        RUBY_OBJ="objects/if_ruby.o"
     2711@@ -1193,6 +1199,28 @@
    26632712 
    26642713     LDFLAGS="$ac_save_LDFLAGS"
     
    26892738 fi
    26902739 
    2691 @@ -2095,7 +2117,7 @@
     2740@@ -2095,7 +2123,7 @@
    26922741        sys/stream.h termios.h libc.h sys/statfs.h \
    26932742        poll.h sys/poll.h pwd.h utime.h sys/param.h libintl.h \
     
    26982747 dnl sys/ptem.h depends on sys/stream.h on Solaris
    26992748 AC_CHECK_HEADERS(sys/ptem.h, [], [],
    2700 @@ -2103,6 +2125,12 @@
     2749@@ -2103,6 +2131,12 @@
    27012750 #  include <sys/stream.h>
    27022751 #endif])
     
    27112760 dnl pthread_np.h may exist but can only be used after including pthread.h
    27122761 AC_MSG_CHECKING([for pthread_np.h])
    2713 @@ -2148,6 +2176,7 @@
     2762@@ -2148,6 +2182,7 @@
    27142763 dnl Checks for typedefs, structures, and compiler characteristics.
    27152764 AC_PROG_GCC_TRADITIONAL
     
    27192768 AC_TYPE_OFF_T
    27202769 AC_TYPE_PID_T
    2721 @@ -2869,7 +2898,6 @@
     2770@@ -2869,7 +2904,6 @@
    27222771 AC_MSG_RESULT($ac_cv_sizeof_int)
    27232772 AC_DEFINE_UNQUOTED(SIZEOF_INT, $ac_cv_sizeof_int)
     
    27272776 dnl present, fixes problem with incompatibility between Solaris 2.4 and 2.5.
    27282777 
    2729 @@ -2951,7 +2979,7 @@
     2778@@ -2951,7 +2985,7 @@
    27302779 if test "$enable_multibyte" = "yes"; then
    27312780   cflags_save=$CFLAGS
     
    27362785     LDFLAGS="$X_LIBS $LDFLAGS -lX11"
    27372786     AC_MSG_CHECKING(whether X_LOCALE needed)
    2738 @@ -2967,7 +2995,7 @@
     2787@@ -2967,7 +3001,7 @@
    27392788 dnl Link with xpg4, it is said to make Korean locale working
    27402789 AC_CHECK_LIB(xpg4, _xpg4_setrunelocale, [LIBS="$LIBS -lxpg4"],,)
     
    27452794 dnl       Add --fields=+S to get function signatures for omni completion.
    27462795 dnl -t for typedefs (many ctags have this)
    2747 @@ -2979,6 +3007,7 @@
     2796@@ -2979,6 +3013,7 @@
    27482797 if (eval ctags --version /dev/null | grep Exuberant) < /dev/null 1>&AC_FD_CC 2>&1; then
    27492798   TAGPRG="ctags -I INIT+ --fields=+S"
     
    27532802   (eval etags -c   /dev/null) < /dev/null 1>&AC_FD_CC 2>&1 && TAGPRG="etags -c"
    27542803   (eval ctags     /dev/null) < /dev/null 1>&AC_FD_CC 2>&1 && TAGPRG="ctags"
    2755 @@ -3152,18 +3181,25 @@
     2804@@ -3152,18 +3187,25 @@
    27562805 dnl But only when making dependencies, cproto and lint don't take "-isystem".
    27572806 dnl Mac gcc returns "powerpc-apple-darwin8-gcc-4.0.1 (GCC)...", need to allow
     
    27722821+  AC_MSG_CHECKING(whether we need -D_FORTIFY_SOURCE=1)
    27732822+  if test "$gccmajor" -gt "3"; then
    2774 +    CFLAGS="$CFLAGS -D_FORTIFY_SOURCE=1"
     2823+    CFLAGS=`echo "$CFLAGS -D_FORTIFY_SOURCE=1" | sed -e 's/-Wp,-D_FORTIFY_SOURCE=2//g' -e 's/-D_FORTIFY_SOURCE=2//g'`
    27752824+    AC_MSG_RESULT(yes)
    27762825+  else
     
    27872836diff -Naur vim72.orig/src/diff.c vim72/src/diff.c
    27882837--- vim72.orig/src/diff.c       2008-03-05 03:16:56.000000000 -0800
    2789 +++ vim72/src/diff.c    2009-07-19 15:16:00.000000000 -0700
     2838+++ vim72/src/diff.c    2009-09-12 08:41:38.000000000 -0700
    27902839@@ -8,7 +8,7 @@
    27912840  */
     
    29262975     char_u     *newname = NULL;        /* name of patched file buffer */
    29272976 #ifdef UNIX
    2928 @@ -905,16 +923,17 @@
     2977@@ -876,6 +894,7 @@
     2978     char_u     *browseFile = NULL;
     2979     int                browse_flag = cmdmod.browse;
     2980 #endif
     2981+    struct stat st;
     2982 
     2983 #ifdef FEAT_BROWSE
     2984     if (cmdmod.browse)
     2985@@ -905,16 +924,17 @@
    29292986     /* Get the absolute path of the patchfile, changing directory below. */
    29302987     fullname = FullName_save(eap->arg, FALSE);
     
    29473004      * have our own temp dir use that instead, it will be cleaned up when we
    29483005      * exit (any .rej files created).  Don't change directory if we can't
    2949 @@ -925,10 +944,10 @@
     3006@@ -925,10 +945,10 @@
    29503007     {
    29513008 # ifdef TEMPDIRNAMES
     
    29603017     }
    29613018 #endif
    2962 @@ -946,7 +965,8 @@
     3019@@ -946,7 +966,8 @@
    29633020     {
    29643021        /* Build the patch command and execute it.  Ignore errors.  Switch to
     
    29703027                fullname != NULL ? fullname :
    29713028 # endif
    2972 @@ -1138,7 +1158,7 @@
     3029@@ -980,44 +1001,51 @@
     3030     STRCAT(buf, ".rej");
     3031     mch_remove(buf);
     3032 
     3033-    if (curbuf->b_fname != NULL)
     3034+    /* Only continue if the output file was created. */
     3035+    if (mch_stat((char *)tmp_new, &st) < 0 || st.st_size == 0)
     3036+       EMSG(_("E816: Cannot read patch output"));
     3037+    else
     3038     {
     3039-       newname = vim_strnsave(curbuf->b_fname,
     3040+       if (curbuf->b_fname != NULL)
     3041+       {
     3042+           newname = vim_strnsave(curbuf->b_fname,
     3043                                          (int)(STRLEN(curbuf->b_fname) + 4));
     3044-       if (newname != NULL)
     3045-           STRCAT(newname, ".new");
     3046-    }
     3047+           if (newname != NULL)
     3048+               STRCAT(newname, ".new");
     3049+       }
     3050 
     3051 #ifdef FEAT_GUI
     3052-    need_mouse_correct = TRUE;
     3053+       need_mouse_correct = TRUE;
     3054 #endif
     3055-    /* don't use a new tab page, each tab page has its own diffs */
     3056-    cmdmod.tab = 0;
     3057+       /* don't use a new tab page, each tab page has its own diffs */
     3058+       cmdmod.tab = 0;
     3059 
     3060-    if (win_split(0, (diff_flags & DIFF_VERTICAL) ? WSP_VERT : 0) != FAIL)
     3061-    {
     3062-       /* Pretend it was a ":split fname" command */
     3063-       eap->cmdidx = CMD_split;
     3064-       eap->arg = tmp_new;
     3065-       do_exedit(eap, old_curwin);
     3066-
     3067-       if (curwin != old_curwin)               /* split must have worked */
     3068+       if (win_split(0, (diff_flags & DIFF_VERTICAL) ? WSP_VERT : 0) != FAIL)
     3069        {
     3070-           /* Set 'diff', 'scrollbind' on and 'wrap' off. */
     3071-           diff_win_options(curwin, TRUE);
     3072-           diff_win_options(old_curwin, TRUE);
     3073+           /* Pretend it was a ":split fname" command */
     3074+           eap->cmdidx = CMD_split;
     3075+           eap->arg = tmp_new;
     3076+           do_exedit(eap, old_curwin);
     3077 
     3078-           if (newname != NULL)
     3079+           /* check that split worked and editing tmp_new */
     3080+           if (curwin != old_curwin && win_valid(old_curwin))
     3081            {
     3082-               /* do a ":file filename.new" on the patched buffer */
     3083-               eap->arg = newname;
     3084-               ex_file(eap);
     3085+               /* Set 'diff', 'scrollbind' on and 'wrap' off. */
     3086+               diff_win_options(curwin, TRUE);
     3087+               diff_win_options(old_curwin, TRUE);
     3088+
     3089+               if (newname != NULL)
     3090+               {
     3091+                   /* do a ":file filename.new" on the patched buffer */
     3092+                   eap->arg = newname;
     3093+                   ex_file(eap);
     3094 
     3095 #ifdef FEAT_AUTOCMD
     3096-               /* Do filetype detection with the new name. */
     3097-               if (au_has_group((char_u *)"filetypedetect"))
     3098-                   do_cmdline_cmd((char_u *)":doau filetypedetect BufRead");
     3099+                   /* Do filetype detection with the new name. */
     3100+                   if (au_has_group((char_u *)"filetypedetect"))
     3101+                       do_cmdline_cmd((char_u *)":doau filetypedetect BufRead");
     3102 #endif
     3103+               }
     3104            }
     3105        }
     3106     }
     3107@@ -1138,7 +1166,7 @@
    29733108 
    29743109     for (wp = firstwin; wp != NULL; wp = wp->w_next)
     
    29793114            /* Set 'diff', 'scrollbind' off and 'wrap' on. */
    29803115            wp->w_p_diff = FALSE;
    2981 @@ -2114,6 +2134,8 @@
     3116@@ -2114,6 +2142,8 @@
    29823117            EMSG2(_("E102: Can't find buffer \"%s\""), eap->arg);
    29833118            return;
     
    29903125diff -Naur vim72.orig/src/digraph.c vim72/src/digraph.c
    29913126--- vim72.orig/src/digraph.c    2008-06-23 14:12:51.000000000 -0700
    2992 +++ vim72/src/digraph.c 2009-07-19 15:15:54.000000000 -0700
     3127+++ vim72/src/digraph.c 2009-09-12 08:38:11.000000000 -0700
    29933128@@ -32,7 +32,7 @@
    29943129 static void printdigraph __ARGS((digr_T *));
     
    30623197diff -Naur vim72.orig/src/edit.c vim72/src/edit.c
    30633198--- vim72.orig/src/edit.c       2008-08-06 05:51:17.000000000 -0700
    3064 +++ vim72/src/edit.c    2009-07-19 15:18:33.000000000 -0700
     3199+++ vim72/src/edit.c    2009-09-12 08:40:57.000000000 -0700
    30653200@@ -57,7 +57,7 @@
    30663201     N_(" Keyword Local completion (^N^P)"),
     
    37343869diff -Naur vim72.orig/src/eval.c vim72/src/eval.c
    37353870--- vim72.orig/src/eval.c       2008-08-07 12:37:22.000000000 -0700
    3736 +++ vim72/src/eval.c    2009-07-19 15:17:12.000000000 -0700
     3871+++ vim72/src/eval.c    2009-09-12 08:39:30.000000000 -0700
    37373872@@ -32,6 +32,9 @@
    37383873 
     
    61716306diff -Naur vim72.orig/src/ex_cmds2.c vim72/src/ex_cmds2.c
    61726307--- vim72.orig/src/ex_cmds2.c   2008-07-13 09:18:22.000000000 -0700
    6173 +++ vim72/src/ex_cmds2.c        2009-07-19 15:16:28.000000000 -0700
     6308+++ vim72/src/ex_cmds2.c        2009-09-12 08:38:46.000000000 -0700
    61746309@@ -28,7 +28,8 @@
    61756310 {
     
    63066441diff -Naur vim72.orig/src/ex_cmds.c vim72/src/ex_cmds.c
    63076442--- vim72.orig/src/ex_cmds.c    2008-08-04 12:15:00.000000000 -0700
    6308 +++ vim72/src/ex_cmds.c 2009-07-19 15:18:39.000000000 -0700
     6443+++ vim72/src/ex_cmds.c 2009-09-12 08:41:03.000000000 -0700
    63096444@@ -24,7 +24,7 @@
    63106445 static void do_filter __ARGS((linenr_T line1, linenr_T line2, exarg_T *eap, char_u *cmd, int do_in, int do_out));
     
    71347269diff -Naur vim72.orig/src/ex_cmds.h vim72/src/ex_cmds.h
    71357270--- vim72.orig/src/ex_cmds.h    2008-06-21 11:47:57.000000000 -0700
    7136 +++ vim72/src/ex_cmds.h 2009-07-19 15:18:31.000000000 -0700
     7271+++ vim72/src/ex_cmds.h 2009-09-12 08:40:55.000000000 -0700
    71377272@@ -278,7 +278,7 @@
    71387273 EX(CMD_crewind,                "crewind",      ex_cc,
     
    71917326diff -Naur vim72.orig/src/ex_docmd.c vim72/src/ex_docmd.c
    71927327--- vim72.orig/src/ex_docmd.c   2008-07-26 04:51:05.000000000 -0700
    7193 +++ vim72/src/ex_docmd.c        2009-07-19 15:18:41.000000000 -0700
     7328+++ vim72/src/ex_docmd.c        2009-09-12 08:41:05.000000000 -0700
    71947329@@ -364,6 +364,7 @@
    71957330 # define ex_function           ex_ni
     
    79808115diff -Naur vim72.orig/src/ex_eval.c vim72/src/ex_eval.c
    79818116--- vim72.orig/src/ex_eval.c    2007-11-24 07:34:09.000000000 -0800
    7982 +++ vim72/src/ex_eval.c 2009-07-19 15:16:23.000000000 -0700
     8117+++ vim72/src/ex_eval.c 2009-09-12 08:38:41.000000000 -0700
    79838118@@ -60,7 +60,9 @@
    79848119 #else
     
    80268161diff -Naur vim72.orig/src/ex_getln.c vim72/src/ex_getln.c
    80278162--- vim72.orig/src/ex_getln.c   2008-08-08 02:31:33.000000000 -0700
    8028 +++ vim72/src/ex_getln.c        2009-07-19 15:18:07.000000000 -0700
     8163+++ vim72/src/ex_getln.c        2009-09-12 08:40:31.000000000 -0700
    80298164@@ -31,6 +31,8 @@
    80308165     int                cmdattr;        /* attributes for prompt */
     
    83368471diff -Naur vim72.orig/src/farsi.c vim72/src/farsi.c
    83378472--- vim72.orig/src/farsi.c      2007-12-31 08:28:10.000000000 -0800
    8338 +++ vim72/src/farsi.c   2009-07-19 15:16:23.000000000 -0700
     8473+++ vim72/src/farsi.c   2009-09-12 08:38:41.000000000 -0700
    83398474@@ -103,7 +103,8 @@
    83408475        case F_HE:
     
    83898524diff -Naur vim72.orig/src/feature.h vim72/src/feature.h
    83908525--- vim72.orig/src/feature.h    2008-08-06 04:00:39.000000000 -0700
    8391 +++ vim72/src/feature.h 2009-07-19 15:09:53.000000000 -0700
     8526+++ vim72/src/feature.h 2009-09-12 08:32:04.000000000 -0700
    83928527@@ -767,9 +767,13 @@
    83938528 
     
    84088543diff -Naur vim72.orig/src/fileio.c vim72/src/fileio.c
    84098544--- vim72.orig/src/fileio.c     2008-08-06 04:01:03.000000000 -0700
    8410 +++ vim72/src/fileio.c  2009-07-19 15:18:23.000000000 -0700
     8545+++ vim72/src/fileio.c  2009-09-12 08:42:30.000000000 -0700
    84118546@@ -69,7 +69,7 @@
    84128547 static int au_find_group __ARGS((char_u *name));
     
    84188553 #endif
    84198554 
    8420 @@ -144,7 +144,9 @@
     8555@@ -121,6 +121,8 @@
     8556     char_u     *bw_conv_buf;   /* buffer for writing converted chars */
     8557     int                bw_conv_buflen; /* size of bw_conv_buf */
     8558     int                bw_conv_error;  /* set for conversion error */
     8559+    linenr_T   bw_conv_error_lnum;  /* first line with error or zero */
     8560+    linenr_T   bw_start_lnum;  /* line number at start of buffer */
     8561 # ifdef USE_ICONV
     8562     iconv_t    bw_iconv_fd;    /* descriptor for iconv() or -1 */
     8563 # endif
     8564@@ -132,7 +134,7 @@
     8565 #ifdef FEAT_MBYTE
     8566 static linenr_T readfile_linenr __ARGS((linenr_T linecnt, char_u *p, char_u *endp));
     8567 static int ucs2bytes __ARGS((unsigned c, char_u **pp, int flags));
     8568-static int same_encoding __ARGS((char_u *a, char_u *b));
     8569+static int need_conversion __ARGS((char_u *fenc));
     8570 static int get_fio_flags __ARGS((char_u *ptr));
     8571 static char_u *check_for_bom __ARGS((char_u *p, long size, int *lenp, int flags));
     8572 static int make_bom __ARGS((char_u *buf, char_u *name));
     8573@@ -144,7 +146,9 @@
    84218574 # endif
    84228575 #endif
     
    84298582     void
    84308583 filemess(buf, name, s, attr)
    8431 @@ -295,6 +297,19 @@
     8584@@ -295,6 +299,19 @@
    84328585     int                conv_restlen = 0;       /* nr of bytes in conv_rest[] */
    84338586 #endif
     
    84498602 
    84508603     /*
    8451 @@ -589,7 +604,21 @@
     8604@@ -589,7 +606,21 @@
    84528605 #ifdef FEAT_QUICKFIX
    84538606                    if (!bt_dontwrite(curbuf))
     
    84718624                        filemess(curbuf, sfname, (char_u *)_("[New File]"), 0);
    84728625                    else
    8473 @@ -668,9 +697,21 @@
     8626@@ -668,9 +699,21 @@
    84748627 #endif
    84758628     {
     
    84948647 #endif
    84958648     }
    8496 @@ -698,7 +739,6 @@
     8649@@ -698,7 +741,6 @@
    84978650     {
    84988651        int     m = msg_scroll;
     
    85028655        /*
    85038656         * The file must be closed again, the autocommands may want to change
    8504 @@ -740,8 +780,13 @@
     8657@@ -740,8 +782,13 @@
    85058658        /*
    85068659         * Don't allow the autocommands to change the current buffer.
     
    85168669        {
    85178670            --no_wait_return;
    8518 @@ -932,7 +977,10 @@
     8671@@ -932,7 +979,10 @@
    85198672     else
    85208673     {
     
    85278680            fileformat = EOL_UNIX;              /* binary: use Unix format */
    85288681        else if (*p_ffs == NUL)
    8529 @@ -2211,7 +2259,7 @@
     8682@@ -993,13 +1043,12 @@
     8683     }
     8684 
     8685     /*
     8686-     * Conversion is required when the encoding of the file is different
     8687-     * from 'encoding' or 'encoding' is UTF-16, UCS-2 or UCS-4 (requires
     8688-     * conversion to UTF-8).
     8689+     * Conversion may be required when the encoding of the file is different
     8690+     * from 'encoding' or 'encoding' is UTF-16, UCS-2 or UCS-4.
     8691      */
     8692     fio_flags = 0;
     8693-    converted = (*fenc != NUL && !same_encoding(p_enc, fenc));
     8694-    if (converted || enc_unicode != 0)
     8695+    converted = need_conversion(fenc);
     8696+    if (converted)
     8697     {
     8698 
     8699        /* "ucs-bom" means we need to check the first bytes of the file
     8700@@ -2211,7 +2260,7 @@
    85308701     {
    85318702        /* Use stderr for stdin, makes shell commands work. */
     
    85368707 #endif
    85378708 
    8538 @@ -2341,11 +2389,6 @@
     8709@@ -2341,11 +2390,6 @@
    85398710                STRCAT(IObuff, _("[CR missing]"));
    85408711                c = TRUE;
     
    85488719            {
    85498720                STRCAT(IObuff, _("[long lines split]"));
    8550 @@ -2711,7 +2754,7 @@
     8721@@ -2711,7 +2755,7 @@
    85518722 {
    85528723     if (!curbuf->b_marks_read && get_viminfo_parameter('\'') > 0
     
    85578728     /* Always set b_marks_read; needed when 'viminfo' is changed to include
    85588729      * the ' parameter after opening a buffer. */
    8559 @@ -3451,12 +3494,12 @@
     8730@@ -2881,6 +2925,7 @@
     8731     linenr_T       lnum;
     8732     long           nchars;
     8733     char_u         *errmsg = NULL;
     8734+    int                    errmsg_allocated = FALSE;
     8735     char_u         *errnum = NULL;
     8736     char_u         *buffer;
     8737     char_u         smallbuf[SMBUFSIZE];
     8738@@ -2944,6 +2989,7 @@
     8739     /* must init bw_conv_buf and bw_iconv_fd before jumping to "fail" */
     8740     write_info.bw_conv_buf = NULL;
     8741     write_info.bw_conv_error = FALSE;
     8742+    write_info.bw_conv_error_lnum = 0;
     8743     write_info.bw_restlen = 0;
     8744 # ifdef USE_ICONV
     8745     write_info.bw_iconv_fd = (iconv_t)-1;
     8746@@ -3451,12 +3497,12 @@
    85608747                {
    85618748 # ifdef UNIX
     
    85728759 # endif
    85738760                    /* Close the file before removing it, on MS-Windows we
    8574 @@ -4367,14 +4410,14 @@
     8761@@ -3922,10 +3968,9 @@
     8762        fenc = buf->b_p_fenc;
     8763 
     8764     /*
     8765-     * The file needs to be converted when 'fileencoding' is set and
     8766-     * 'fileencoding' differs from 'encoding'.
     8767+     * Check if the file needs to be converted.
     8768      */
     8769-    converted = (*fenc != NUL && !same_encoding(p_enc, fenc));
     8770+    converted = need_conversion(fenc);
     8771 
     8772     /*
     8773      * Check if UTF-8 to UCS-2/4 or Latin1 conversion needs to be done.  Or
     8774@@ -4200,6 +4245,7 @@
     8775                nchars += write_info.bw_len;
     8776        }
     8777     }
     8778+    write_info.bw_start_lnum = start;
     8779 #endif
     8780 
     8781     write_info.bw_len = bufsize;
     8782@@ -4235,6 +4281,9 @@
     8783            nchars += bufsize;
     8784            s = buffer;
     8785            len = 0;
     8786+#ifdef FEAT_MBYTE
     8787+           write_info.bw_start_lnum = lnum;
     8788+#endif
     8789        }
     8790        /* write failed or last line has no EOL: stop here */
     8791        if (end == 0
     8792@@ -4367,14 +4416,14 @@
    85758793                || st.st_uid != st_old.st_uid
    85768794                || st.st_gid != st_old.st_gid)
     
    85898807        buf_setino(buf);
    85908808 #endif
    8591 @@ -4782,6 +4825,8 @@
     8809@@ -4431,7 +4480,17 @@
     8810        {
     8811 #ifdef FEAT_MBYTE
     8812            if (write_info.bw_conv_error)
     8813-               errmsg = (char_u *)_("E513: write error, conversion failed (make 'fenc' empty to override)");
     8814+           {
     8815+               if (write_info.bw_conv_error_lnum == 0)
     8816+                   errmsg = (char_u *)_("E513: write error, conversion failed (make 'fenc' empty to override)");
     8817+               else
     8818+               {
     8819+                   errmsg_allocated = TRUE;
     8820+                   errmsg = alloc(300);
     8821+                   vim_snprintf((char *)errmsg, 300, _("E513: write error, conversion failed in line %ld (make 'fenc' empty to override)"),
     8822+                                        (long)write_info.bw_conv_error_lnum);
     8823+               }
     8824+           }
     8825            else
     8826 #endif
     8827                if (got_int)
     8828@@ -4507,6 +4566,12 @@
     8829        {
     8830            STRCAT(IObuff, _(" CONVERSION ERROR"));
     8831            c = TRUE;
     8832+           if (write_info.bw_conv_error_lnum != 0)
     8833+           {
     8834+               size_t l = STRLEN(IObuff);
     8835+               vim_snprintf((char *)IObuff + l, IOSIZE - l, _(" in line %ld;"),
     8836+                       (long)write_info.bw_conv_error_lnum);
     8837+           }
     8838        }
     8839        else if (notconverted)
     8840        {
     8841@@ -4703,6 +4768,8 @@
     8842        }
     8843        STRCAT(IObuff, errmsg);
     8844        emsg(IObuff);
     8845+       if (errmsg_allocated)
     8846+           vim_free(errmsg);
     8847 
     8848        retval = FAIL;
     8849        if (end == 0)
     8850@@ -4782,6 +4849,8 @@
    85928851     char_u     *sfname;
    85938852 {
     
    85988857     if (curbuf->b_p_bl)
    85998858        apply_autocmds(EVENT_BUFDELETE, NULL, NULL, FALSE, curbuf);
    8600 @@ -4790,6 +4835,12 @@
     8859@@ -4790,6 +4859,12 @@
    86018860     if (aborting())        /* autocmds may abort script processing */
    86028861        return FAIL;
     
    86118870 
    86128871     if (setfname(curbuf, fname, sfname, FALSE) == OK)
    8613 @@ -5246,13 +5297,16 @@
     8872@@ -5054,7 +5129,13 @@
     8873                        c = buf[wlen];
     8874                }
     8875 
     8876-               ip->bw_conv_error |= ucs2bytes(c, &p, flags);
     8877+               if (ucs2bytes(c, &p, flags) && !ip->bw_conv_error)
     8878+               {
     8879+                   ip->bw_conv_error = TRUE;
     8880+                   ip->bw_conv_error_lnum = ip->bw_start_lnum;
     8881+               }
     8882+               if (c == NL)
     8883+                   ++ip->bw_start_lnum;
     8884            }
     8885            if (flags & FIO_LATIN1)
     8886                len = (int)(p - buf);
     8887@@ -5246,13 +5327,16 @@
    86148888            /* Convert with iconv(). */
    86158889            if (ip->bw_restlen > 0)
     
    86318905            }
    86328906            else
    8633 @@ -5550,9 +5604,10 @@
     8907@@ -5332,6 +5416,7 @@
     8908 #ifdef FEAT_MBYTE
     8909 /*
     8910  * Convert a Unicode character to bytes.
     8911+ * Return TRUE for an error, FALSE when it's OK.
     8912  */
     8913     static int
     8914 ucs2bytes(c, pp, flags)
     8915@@ -5415,20 +5500,37 @@
     8916 }
     8917 
     8918 /*
     8919- * Return TRUE if "a" and "b" are the same 'encoding'.
     8920- * Ignores difference between "ansi" and "latin1", "ucs-4" and "ucs-4be", etc.
     8921+ * Return TRUE if file encoding "fenc" requires conversion from or to
     8922+ * 'encoding'.
     8923  */
     8924     static int
     8925-same_encoding(a, b)
     8926-    char_u     *a;
     8927-    char_u     *b;
     8928+need_conversion(fenc)
     8929+    char_u     *fenc;
     8930 {
     8931-    int                f;
     8932+    int                same_encoding;
     8933+    int                enc_flags;
     8934+    int                fenc_flags;
     8935 
     8936-    if (STRCMP(a, b) == 0)
     8937-       return TRUE;
     8938-    f = get_fio_flags(a);
     8939-    return (f != 0 && get_fio_flags(b) == f);
     8940+    if (*fenc == NUL || STRCMP(p_enc, fenc) == 0)
     8941+       same_encoding = TRUE;
     8942+    else
     8943+    {
     8944+       /* Ignore difference between "ansi" and "latin1", "ucs-4" and
     8945+        * "ucs-4be", etc. */
     8946+       enc_flags = get_fio_flags(p_enc);
     8947+       fenc_flags = get_fio_flags(fenc);
     8948+       same_encoding = (enc_flags != 0 && fenc_flags == enc_flags);
     8949+    }
     8950+    if (same_encoding)
     8951+    {
     8952+       /* Specified encoding matches with 'encoding'.  This requires
     8953+        * conversion when 'encoding' is Unicode but not UTF-8. */
     8954+       return enc_unicode != 0;
     8955+    }
     8956+
     8957+    /* Encodings differ.  However, conversion is not needed when 'enc' is any
     8958+     * Unicode encoding and the file is UTF-8. */
     8959+    return !(enc_utf8 && fenc_flags == FIO_UTF8);
     8960 }
     8961 
     8962 /*
     8963@@ -5550,9 +5652,10 @@
    86348964            name = "ucs-4le";   /* FF FE 00 00 */
    86358965            len = 4;
     
    86448974     }
    86458975     else if (p[0] == 0xfe && p[1] == 0xff
    8646 @@ -5917,7 +5972,7 @@
     8976@@ -5917,7 +6020,7 @@
    86478977        else if (*ext == '.')
    86488978 #endif
     
    86538983                s = ptr + 8;
    86548984                *s = '\0';
    8655 @@ -6031,9 +6086,9 @@
     8985@@ -6031,9 +6134,9 @@
    86568986        {
    86578987            tbuf[FGETS_SIZE - 2] = NUL;
     
    86658995        } while (tbuf[FGETS_SIZE - 2] != NUL && tbuf[FGETS_SIZE - 2] != '\n');
    86668996     }
    8667 @@ -6107,12 +6162,24 @@
     8997@@ -6107,12 +6210,24 @@
    86688998 #ifdef HAVE_ACL
    86698999     vim_acl_T  acl;            /* ACL from original file */
     
    86929022     /*
    86939023      * Fail if the "from" file doesn't exist.  Avoids that "to" is deleted.
    8694 @@ -6120,6 +6187,55 @@
     9024@@ -6120,6 +6235,55 @@
    86959025     if (mch_stat((char *)from, &st) < 0)
    86969026        return -1;
     
    87489078      * Delete the "to" file, this is required on some systems to make the
    87499079      * mch_rename() work, on other systems it makes sure that we don't have
    8750 @@ -6260,7 +6376,7 @@
     9080@@ -6260,7 +6424,7 @@
    87519081 
    87529082     if (!stuff_empty() || global_busy || !typebuf_typed()
     
    87579087                                        )
    87589088        need_check_timestamps = TRUE;           /* check later */
    8759 @@ -6353,11 +6469,10 @@
     9089@@ -6353,11 +6517,10 @@
    87609090  * return 2 if a message has been displayed.
    87619091  * return 0 otherwise.
     
    87709100     struct stat        st;
    87719101     int                stat_res;
    8772 @@ -6462,8 +6577,10 @@
     9102@@ -6462,8 +6625,10 @@
    87739103            set_vim_var_string(VV_FCS_REASON, (char_u *)reason, -1);
    87749104            set_vim_var_string(VV_FCS_CHOICE, (char_u *)"", -1);
     
    87819111            if (n)
    87829112            {
    8783 @@ -6511,7 +6628,10 @@
     9113@@ -6511,7 +6676,10 @@
    87849114                        mesg = _("W16: Warning: Mode of file \"%s\" has changed since editing started");
    87859115                        mesg2 = _("See \":help W16\" for more info.");
     
    87939123            }
    87949124        }
    8795 @@ -6538,6 +6658,11 @@
     9125@@ -6538,6 +6706,11 @@
    87969126            tbuf = alloc((unsigned)(STRLEN(path) + STRLEN(mesg)
    87979127                                                        + STRLEN(mesg2) + 2));
     
    88059135            if (can_reload)
    88069136            {
    8807 @@ -6732,10 +6857,11 @@
     9137@@ -6732,10 +6905,11 @@
    88089138 #endif
    88099139 #ifdef FEAT_FOLDING
     
    88199149                        && !foldmethodIsManual(wp))
    88209150                    foldUpdateAll(wp);
    8821 @@ -6753,12 +6879,11 @@
     9151@@ -6753,12 +6927,11 @@
    88229152     /* Careful: autocommands may have made "buf" invalid! */
    88239153 }
     
    88339163     buf->b_mtime = (long)st->st_mtime;
    88349164     buf->b_orig_size = (size_t)st->st_size;
    8835 @@ -6821,10 +6946,9 @@
     9165@@ -6821,10 +6994,9 @@
    88369166  * The returned pointer is to allocated memory.
    88379167  * The returned pointer is NULL if no valid name was found.
     
    88459175 #ifdef USE_TMPNAM
    88469176     char_u     itmp[L_tmpnam]; /* use tmpnam() */
    8847 @@ -6853,7 +6977,7 @@
     9177@@ -6853,7 +7025,7 @@
    88489178        /*
    88499179         * Try the entries in TEMPDIRNAMES to create the temp directory.
     
    88549184            /* expand $TMP, leave room for "/v1100000/999999999" */
    88559185            expand_env((char_u *)tempdirs[i], itmp, TEMPNAMELEN - 20);
    8856 @@ -8245,7 +8369,7 @@
     9186@@ -8245,7 +8417,7 @@
    88579187 
    88589188            /* Execute the modeline settings, but don't set window-local
     
    88639193            /* restore the current window */
    88649194            aucmd_restbuf(&aco);
    8865 @@ -8261,8 +8385,8 @@
     9195@@ -8261,8 +8433,8 @@
    88669196 
    88679197 /*
     
    88749204  * When FEAT_AUTOCMD is not defined another version is used, see below.
    88759205  */
    8876 @@ -8272,8 +8396,9 @@
     9206@@ -8272,8 +8444,9 @@
    88779207     buf_T      *buf;           /* new curbuf */
    88789208 {
     
    88869216     /* Find a window that is for the new buffer */
    88879217     if (buf == curbuf)         /* be quick when buf is curbuf */
    8888 @@ -8287,42 +8412,51 @@
     9218@@ -8287,42 +8460,67 @@
    88899219        win = NULL;
    88909220 #endif
     
    89049234+           win = curwin;
    89059235+    }
     9236+    if (win == NULL && aucmd_win_used)
     9237+       /* Strange recursive autocommand, fall back to using the current
     9238+        * window.  Expect a few side effects... */
     9239+       win = curwin;
    89069240+
    89079241+    aco->save_curwin = curwin;
     
    89149248+        * curwin.  This is preferred, it has the least side effects (esp. if
    89159249+        * "buf" is curbuf). */
     9250+       aco->use_aucmd_win = FALSE;
    89169251        curwin = win;
    89179252-       aco->save_buf = win->w_buffer;
     
    89299264+        * Anything related to a window (e.g., setting folds) may have
    89309265+        * unexpected results. */
     9266+       aco->use_aucmd_win = TRUE;
     9267+       aucmd_win_used = TRUE;
    89319268+       aucmd_win->w_buffer = buf;
    89329269        ++buf->b_nwindows;
    89339270+       win_init_empty(aucmd_win); /* set cursor and topline to safe values */
     9271+       vim_free(aucmd_win->w_localdir);
     9272+       aucmd_win->w_localdir = NULL;
     9273+
     9274+       /* Make sure w_localdir and globaldir are NULL to avoid a chdir() in
     9275+        * win_enter_ext(). */
     9276+       aucmd_win->w_localdir = NULL;
     9277+       aco->globaldir = globaldir;
     9278+       globaldir = NULL;
    89349279 
    89359280-       /* save cursor and topline, set them to safe values */
     
    89429287-       aco->save_topfill = curwin->w_topfill;
    89439288-       curwin->w_topfill = 0;
     9289+
    89449290+#ifdef FEAT_WINDOWS
    89459291+       /* Split the current window, put the aucmd_win in the upper half.
     
    89639309 
    89649310 /*
    8965 @@ -8334,21 +8468,88 @@
     9311@@ -8334,21 +8532,92 @@
    89669312 aucmd_restbuf(aco)
    89679313     aco_save_T *aco;           /* structure holding saved values */
     
    89729318+#endif
    89739319+
    8974 +    if (aco->new_curwin == aucmd_win)
     9320+    if (aco->use_aucmd_win)
    89759321+    {
    89769322+       --curbuf->b_nwindows;
     
    89999345+       (void)winframe_remove(curwin, &dummy, NULL);
    90009346+       win_remove(curwin, NULL);
     9347+       aucmd_win_used = FALSE;
    90019348+       last_status(FALSE);         /* may need to remove last status line */
    90029349+       restore_snapshot(SNAP_AUCMD_IDX, FALSE);
     
    90169363+#endif
    90179364+       curbuf = curwin->w_buffer;
     9365+
     9366+       vim_free(globaldir);
     9367+       globaldir = aco->globaldir;
    90189368+
    90199369+       /* the buffer contents may have changed */
     
    90439393-            * it's still the same window and it's valid */
    90449394+           /* Restore the buffer which was previously edited by curwin, if
    9045 +            * it was chagned, we are still the same window and the buffer is
     9395+            * it was changed, we are still the same window and the buffer is
    90469396+            * valid. */
    90479397            if (curwin == aco->new_curwin
     
    90589408                ++curbuf->b_nwindows;
    90599409            }
    9060 @@ -8357,34 +8558,6 @@
     9410@@ -8357,34 +8626,6 @@
    90619411            curbuf = curwin->w_buffer;
    90629412        }
     
    90939443 
    90949444 static int     autocmd_nested = FALSE;
    9095 @@ -8523,6 +8696,7 @@
     9445@@ -8523,6 +8764,7 @@
    90969446     char_u     *save_sourcing_name;
    90979447     linenr_T   save_sourcing_lnum;
     
    91019451     char_u     *save_autocmd_match;
    91029452     int                save_autocmd_busy;
    9103 @@ -8601,6 +8775,7 @@
     9453@@ -8601,6 +8843,7 @@
    91049454      * Save the autocmd_* variables and info about the current buffer.
    91059455      */
     
    91099459     save_autocmd_match = autocmd_match;
    91109460     save_autocmd_busy = autocmd_busy;
    9111 @@ -8618,14 +8793,15 @@
     9461@@ -8618,14 +8861,15 @@
    91129462        if (fname != NULL && *fname != NUL)
    91139463            autocmd_fname = fname;
     
    91279477     /*
    91289478      * Set the buffer number to be used for <abuf>.
    9129 @@ -8667,9 +8843,11 @@
     9479@@ -8667,9 +8911,11 @@
    91309480     else
    91319481     {
     
    91409490                || event == EVENT_SPELLFILEMISSING
    91419491                || event == EVENT_QUICKFIXCMDPRE
    9142 @@ -8810,6 +8988,7 @@
     9492@@ -8810,6 +9056,7 @@
    91439493     sourcing_lnum = save_sourcing_lnum;
    91449494     vim_free(autocmd_fname);
     
    91489498     autocmd_match = save_autocmd_match;
    91499499 #ifdef FEAT_EVAL
    9150 @@ -8918,7 +9097,7 @@
     9500@@ -8918,7 +9165,7 @@
    91519501     {
    91529502        apc->curpat = NULL;
     
    91579507         * buffer number. */
    91589508        if (ap->pat != NULL && ap->cmds != NULL
    9159 @@ -8967,12 +9146,11 @@
     9509@@ -8967,12 +9214,11 @@
    91609510  * Called by do_cmdline() to get the next line for ":if".
    91619511  * Returns allocated string, or NULL for end of autocommands.
     
    91729522     AutoPatCmd     *acp = (AutoPatCmd *)cookie;
    91739523     char_u         *retval;
    9174 @@ -9083,10 +9261,9 @@
     9524@@ -9083,10 +9329,9 @@
    91759525  * Function given to ExpandGeneric() to obtain the list of autocommand group
    91769526  * names.
     
    91849534 {
    91859535     if (idx == augroups.ga_len)                /* add "END" add the end */
    9186 @@ -9104,7 +9281,7 @@
     9536@@ -9104,7 +9349,7 @@
    91879537 set_context_in_autocmd(xp, arg, doautocmd)
    91889538     expand_T   *xp;
     
    91939543     char_u     *p;
    91949544     int                group;
    9195 @@ -9152,10 +9329,9 @@
     9545@@ -9152,10 +9397,9 @@
    91969546 /*
    91979547  * Function given to ExpandGeneric() to obtain the list of event names.
     
    92059555 {
    92069556     if (idx < augroups.ga_len)         /* First list group names, if wanted */
    9207 @@ -9296,9 +9472,11 @@
     9557@@ -9254,15 +9498,10 @@
     9558     ap = first_autopat[(int)event];
     9559     if (ap == NULL)
     9560        goto theend;
     9561-    if (pattern == NULL)
     9562-    {
     9563-       retval = TRUE;
     9564-       goto theend;
     9565-    }
     9566 
     9567     /* if pattern is "<buffer>", special handling is needed which uses curbuf */
     9568     /* for pattern "<buffer=N>, fnamecmp() will work fine */
     9569-    if (STRICMP(pattern, "<buffer>") == 0)
     9570+    if (pattern != NULL && STRICMP(pattern, "<buffer>") == 0)
     9571        buflocal_buf = curbuf;
     9572 
     9573     /* Check if there is an autocommand with the given pattern. */
     9574@@ -9271,9 +9510,10 @@
     9575        /* For buffer-local autocommands, fnamecmp() works fine. */
     9576        if (ap->pat != NULL && ap->cmds != NULL
     9577            && (group == AUGROUP_ALL || ap->group == group)
     9578-           && (buflocal_buf == NULL
     9579-                ? fnamecmp(ap->pat, pattern) == 0
     9580-                : ap->buflocal_nr == buflocal_buf->b_fnum))
     9581+           && (pattern == NULL
     9582+               || (buflocal_buf == NULL
     9583+                   ? fnamecmp(ap->pat, pattern) == 0
     9584+                   : ap->buflocal_nr == buflocal_buf->b_fnum)))
     9585        {
     9586            retval = TRUE;
     9587            break;
     9588@@ -9296,9 +9536,11 @@
    92089589     aco_save_T *aco;           /* structure to save values in */
    92099590     buf_T      *buf;           /* new curbuf */
     
    92189599 
    92199600 /*
    9220 @@ -9309,8 +9487,10 @@
     9601@@ -9309,8 +9551,10 @@
    92219602 aucmd_restbuf(aco)
    92229603     aco_save_T *aco;           /* structure holding saved values */
     
    92309611 
    92319612 #endif /* FEAT_AUTOCMD */
    9232 @@ -9467,13 +9647,12 @@
     9613@@ -9467,13 +9711,12 @@
    92339614  *
    92349615  * Returns NULL when out of memory.
     
    92479628diff -Naur vim72.orig/src/fold.c vim72/src/fold.c
    92489629--- vim72.orig/src/fold.c       2008-08-06 04:01:12.000000000 -0700
    9249 +++ vim72/src/fold.c    2009-07-19 15:11:59.000000000 -0700
     9630+++ vim72/src/fold.c    2009-09-12 08:34:12.000000000 -0700
    92509631@@ -48,7 +48,7 @@
    92519632 static int foldFind __ARGS((garray_T *gap, linenr_T lnum, fold_T **fpp));
     
    93369717diff -Naur vim72.orig/src/getchar.c vim72/src/getchar.c
    93379718--- vim72.orig/src/getchar.c    2008-07-22 09:57:48.000000000 -0700
    9338 +++ vim72/src/getchar.c 2009-07-19 15:18:49.000000000 -0700
     9719+++ vim72/src/getchar.c 2009-09-12 08:41:14.000000000 -0700
    93399720@@ -1309,6 +1309,9 @@
    93409721     return OK;
     
    94419822diff -Naur vim72.orig/src/globals.h vim72/src/globals.h
    94429823--- vim72.orig/src/globals.h    2008-07-26 04:53:29.000000000 -0700
    9443 +++ vim72/src/globals.h 2009-07-19 15:17:39.000000000 -0700
     9824+++ vim72/src/globals.h 2009-09-12 08:41:43.000000000 -0700
    94449825@@ -482,8 +482,10 @@
    94459826 /*
     
    94719852        for ((wp) = ((tp) == curtab) \
    94729853                ? firstwin : (tp)->tp_firstwin; (wp); (wp) = (wp)->w_next)
    9473 @@ -536,6 +539,10 @@
     9854@@ -536,6 +539,11 @@
    94749855 
    94759856 EXTERN win_T   *curwin;        /* currently active window */
     
    94779858+#ifdef FEAT_AUTOCMD
    94789859+EXTERN win_T   *aucmd_win;     /* window used in aucmd_prepbuf() */
     9860+EXTERN int     aucmd_win_used INIT(= FALSE);   /* aucmd_win is being used */
    94799861+#endif
    94809862+
     
    94829864  * The window layout is kept in a tree of frames.  topframe points to the top
    94839865  * of the tree.
    9484 @@ -597,7 +604,8 @@
     9866@@ -597,7 +605,8 @@
    94859867 EXTERN int     really_exiting INIT(= FALSE);
    94869868                                /* TRUE when we are sure to exit, e.g., after
     
    94929874                                 * otherwise only writing some messages */
    94939875 
    9494 @@ -616,6 +624,11 @@
     9876@@ -616,6 +625,11 @@
    94959877 EXTERN int     curbuf_lock INIT(= 0);
    94969878                                /* non-zero when the current buffer can't be
     
    95049886 #ifdef FEAT_EVAL
    95059887 # define HAVE_SANDBOX
    9506 @@ -710,7 +723,7 @@
     9888@@ -710,7 +724,7 @@
    95079889 
    95089890 EXTERN pos_T   saved_cursor            /* w_cursor before formatting text. */
     
    95139895        ;
    95149896 
    9515 @@ -739,10 +752,12 @@
     9897@@ -739,10 +753,12 @@
    95169898  */
    95179899 EXTERN JMP_BUF lc_jump_env;    /* argument to SETJMP() */
     
    95299911 
    95309912 #if defined(FEAT_MBYTE) || defined(FEAT_POSTSCRIPT)
    9531 @@ -800,11 +815,14 @@
     9913@@ -800,11 +816,14 @@
    95329914  */
    95339915 /* length of char in bytes, including following composing chars */
     
    95449926 EXTERN int (*mb_off2cells) __ARGS((unsigned off, unsigned max_off)) INIT(= latin_off2cells);
    95459927 EXTERN int (*mb_ptr2char) __ARGS((char_u *p)) INIT(= latin_ptr2char);
    9546 @@ -950,7 +968,7 @@
     9928@@ -950,7 +969,7 @@
    95479929                    ;
    95489930 EXTERN typebuf_T typebuf               /* typeahead buffer */
     
    95539935                    ;
    95549936 #ifdef FEAT_EX_EXTRA
    9555 @@ -986,7 +1004,8 @@
     9937@@ -986,7 +1005,8 @@
    95569938 EXTERN FILE    *scriptout  INIT(= NULL);   /* stream to write script to */
    95579939 EXTERN int     read_cmd_fd INIT(= 0);      /* fd to read commands from */
     
    95639945 #ifdef USE_TERM_CONSOLE
    95649946 EXTERN int     term_console INIT(= FALSE); /* set to TRUE when console used */
    9565 @@ -1022,12 +1041,13 @@
     9947@@ -1022,12 +1042,13 @@
    95669948 #endif
    95679949 #ifdef FEAT_AUTOCMD
     
    95789960                        ;
    95799961 #endif
    9580 @@ -1339,7 +1359,6 @@
     9962@@ -1339,7 +1360,6 @@
    95819963 
    95829964 #ifdef FEAT_NETBEANS_INTG
     
    95869968 EXTERN int netbeansForcedQuit INIT(= 0);/* don't write modified files */
    95879969 EXTERN int netbeansReadFile INIT(= 1); /* OK to read from disk if != 0 */
    9588 @@ -1548,6 +1567,14 @@
     9970@@ -1548,6 +1568,14 @@
    95899971 EXTERN time_t starttime;
    95909972 
     
    96039985diff -Naur vim72.orig/src/gui_at_fs.c vim72/src/gui_at_fs.c
    96049986--- vim72.orig/src/gui_at_fs.c  2006-05-12 02:26:24.000000000 -0700
    9605 +++ vim72/src/gui_at_fs.c       2009-07-19 15:16:46.000000000 -0700
     9987+++ vim72/src/gui_at_fs.c       2009-09-12 08:39:05.000000000 -0700
    96069988@@ -829,7 +829,7 @@
    96079989     text.format = FMT8BIT;
     
    988910271diff -Naur vim72.orig/src/gui_athena.c vim72/src/gui_athena.c
    989010272--- vim72.orig/src/gui_athena.c 2008-06-21 12:38:58.000000000 -0700
    9891 +++ vim72/src/gui_athena.c      2009-07-19 15:16:46.000000000 -0700
     10273+++ vim72/src/gui_athena.c      2009-09-12 08:39:05.000000000 -0700
    989210274@@ -86,10 +86,9 @@
    989310275  * Scrollbar callback (XtNjumpProc) for when the scrollbar is dragged with the
     
    1014610528diff -Naur vim72.orig/src/gui_at_sb.c vim72/src/gui_at_sb.c
    1014710529--- vim72.orig/src/gui_at_sb.c  2004-06-07 07:32:25.000000000 -0700
    10148 +++ vim72/src/gui_at_sb.c       2009-07-19 15:16:46.000000000 -0700
     10530+++ vim72/src/gui_at_sb.c       2009-09-12 08:39:05.000000000 -0700
    1014910531@@ -198,10 +198,13 @@
    1015010532     /* extension       */  NULL
     
    1039610778diff -Naur vim72.orig/src/gui_beval.c vim72/src/gui_beval.c
    1039710779--- vim72.orig/src/gui_beval.c  2007-05-07 12:33:41.000000000 -0700
    10398 +++ vim72/src/gui_beval.c       2009-07-19 15:16:46.000000000 -0700
     10780+++ vim72/src/gui_beval.c       2009-09-12 08:39:05.000000000 -0700
    1039910781@@ -15,11 +15,10 @@
    1040010782 /*
     
    1049710879diff -Naur vim72.orig/src/gui.c vim72/src/gui.c
    1049810880--- vim72.orig/src/gui.c        2008-07-27 12:32:14.000000000 -0700
    10499 +++ vim72/src/gui.c     2009-07-19 15:18:18.000000000 -0700
     10881+++ vim72/src/gui.c     2009-09-12 08:41:40.000000000 -0700
    1050010882@@ -139,7 +139,7 @@
    1050110883                /* The read returns when the child closes the pipe (or when
     
    1070011082 #ifdef FEAT_WINDOWS
    1070111083     int                row;
    10702 @@ -5120,11 +5134,10 @@
     11084@@ -4990,6 +5004,19 @@
     11085     char_u     *p;
     11086     regmatch_T regmatch;
     11087     int                save_did_emsg = did_emsg;
     11088+    static int  busy = FALSE;
     11089+
     11090+    /* When the screen is being updated we should not change buffers and
     11091+     * windows structures, it may cause freed memory to be used.  Also don't
     11092+     * do this recursively (pressing "Find" quickly several times. */
     11093+    if (updating_screen || busy)
     11094+       return FALSE;
     11095+
     11096+    /* refuse replace when text cannot be changed */
     11097+    if ((type == FRD_REPLACE || type == FRD_REPLACEALL) && text_locked())
     11098+       return FALSE;
     11099+
     11100+    busy = TRUE;
     11101 
     11102     ga_init2(&ga, 1, 100);
     11103     if (type == FRD_REPLACEALL)
     11104@@ -5080,6 +5107,7 @@
     11105     }
     11106 
     11107     vim_free(ga.ga_data);
     11108+    busy = FALSE;
     11109     return (ga.ga_len > 0);
     11110 }
     11111 
     11112@@ -5120,11 +5148,10 @@
    1070311113  * of dropped files, they will be freed in this function, and caller can't use
    1070411114  * fnames after call this function.
     
    1071611126diff -Naur vim72.orig/src/gui_gtk.c vim72/src/gui_gtk.c
    1071711127--- vim72.orig/src/gui_gtk.c    2008-07-31 12:48:20.000000000 -0700
    10718 +++ vim72/src/gui_gtk.c 2009-07-19 15:16:36.000000000 -0700
     11128+++ vim72/src/gui_gtk.c 2009-09-12 08:38:54.000000000 -0700
    1071911129@@ -285,14 +285,14 @@
    1072011130     return image;
     
    1092011330diff -Naur vim72.orig/src/gui_gtk_f.c vim72/src/gui_gtk_f.c
    1092111331--- vim72.orig/src/gui_gtk_f.c  2007-05-07 12:38:02.000000000 -0700
    10922 +++ vim72/src/gui_gtk_f.c       2009-07-19 15:16:39.000000000 -0700
     11332+++ vim72/src/gui_gtk_f.c       2009-09-12 08:42:25.000000000 -0700
    1092311333@@ -227,14 +227,14 @@
    1092411334 
     
    1098011390     XEvent *xevent;
    1098111391     GtkForm *form;
    10982 @@ -911,9 +910,8 @@
     11392@@ -861,11 +860,9 @@
     11393 gtk_form_set_static_gravity(GdkWindow *window, gboolean use_static)
     11394 {
     11395 #ifdef HAVE_GTK2
     11396-    gboolean static_gravity_supported;
     11397-
     11398-    static_gravity_supported = gdk_window_set_static_gravities(window,
     11399-                                                              use_static);
     11400-    g_return_if_fail(static_gravity_supported);
     11401+    /* We don't check if static gravity is actually supported, because it
     11402+     * results in an annoying assertion error message. */
     11403+    gdk_window_set_static_gravities(window, use_static);
     11404 #else
     11405     XSetWindowAttributes xattributes;
     11406 
     11407@@ -911,9 +908,8 @@
    1098311408 #endif
    1098411409 }
     
    1099111416     GtkFormChild *child;
    1099211417 
    10993 @@ -923,9 +921,8 @@
     11418@@ -923,9 +919,8 @@
    1099411419     gdk_window_show(child->window);
    1099511420 }
     
    1100411429diff -Naur vim72.orig/src/gui_gtk_x11.c vim72/src/gui_gtk_x11.c
    1100511430--- vim72.orig/src/gui_gtk_x11.c        2008-07-04 03:46:24.000000000 -0700
    11006 +++ vim72/src/gui_gtk_x11.c     2009-07-19 15:18:26.000000000 -0700
     11431+++ vim72/src/gui_gtk_x11.c     2009-09-12 08:42:22.000000000 -0700
    1100711432@@ -107,6 +107,7 @@
    1100811433     TARGET_UTF8_STRING,
     
    1174512170 gui_mch_get_fontset(char_u *name, int report_error, int fixed_width)
    1174612171 {
    11747 @@ -4863,7 +4915,7 @@
     12172@@ -4677,6 +4729,9 @@
     12173     if (oldval != NULL && *oldval != NUL)
     12174        gtk_font_selection_dialog_set_font_name(
     12175                GTK_FONT_SELECTION_DIALOG(gui.fontdlg), (char *)oldval);
     12176+    else
     12177+       gtk_font_selection_dialog_set_font_name(
     12178+               GTK_FONT_SELECTION_DIALOG(gui.fontdlg), DEFAULT_FONT);
     12179 
     12180     if (gui.fontname)
     12181     {
     12182@@ -4764,6 +4819,9 @@
     12183        if (oldname != oldval)
     12184            vim_free(oldname);
     12185     }
     12186+    else
     12187+       gtk_font_selection_dialog_set_font_name(
     12188+               GTK_FONT_SELECTION_DIALOG(dialog), DEFAULT_FONT);
     12189 
     12190     response = gtk_dialog_run(GTK_DIALOG(dialog));
     12191 
     12192@@ -4863,7 +4921,7 @@
    1174812193     styled_font[1] = &gui.ital_font;
    1174912194     styled_font[2] = &gui.boldital_font;
     
    1175412199        if (*styled_font[i])
    1175512200        {
    11756 @@ -5012,9 +5064,8 @@
     12201@@ -5012,9 +5070,8 @@
    1175712202  * Initialize Vim to use the font or fontset with the given name.
    1175812203  * Return FAIL if the font could not be loaded, OK otherwise.
     
    1176512210 #ifdef HAVE_GTK2
    1176612211     PangoFontDescription    *font_desc;
    11767 @@ -5326,9 +5377,8 @@
     12212@@ -5326,9 +5383,8 @@
    1176812213 /*
    1176912214  * Return the name of font "font" in allocated memory.
     
    1177612221 # ifdef HAVE_GTK2
    1177712222     if (font != NOFONT)
    11778 @@ -5732,7 +5782,7 @@
     12223@@ -5732,7 +5788,7 @@
    1177912224 {
    1178012225     int                        i;
     
    1178512230 
    1178612231     /* Undercurl: draw curl at the bottom of the character cell. */
    11787 @@ -6085,12 +6135,15 @@
     12232@@ -6085,12 +6141,15 @@
    1178812233 # ifdef FEAT_MBYTE
    1178912234            if (enc_utf8)
     
    1180312248            }
    1180412249            else
    11805 @@ -6114,8 +6167,8 @@
     12250@@ -6114,8 +6173,8 @@
    1180612251        if (has_mbyte)
    1180712252        {
     
    1181412259        else
    1181512260 # endif
    11816 @@ -6402,7 +6455,6 @@
     12261@@ -6402,7 +6461,6 @@
    1181712262 /*
    1181812263  * Callback function, used when data is available on the SNiFF connection.
     
    1182212267 sniff_request_cb(
    1182312268     gpointer   data,
    11824 @@ -6665,12 +6717,14 @@
     12269@@ -6665,12 +6723,14 @@
    1182512270 {
    1182612271     GdkAtom    target;
     
    1183912284        target = gdk_atom_intern(selection_targets[i].target, FALSE);
    1184012285 
    11841 @@ -6690,30 +6744,14 @@
     12286@@ -6690,30 +6750,14 @@
    1184212287     }
    1184312288 
     
    1187212317     /* WEIRD: when using NULL to actually disown the selection, we lose the
    1187312318      * selection the first time we own it. */
    11874 @@ -6741,9 +6779,8 @@
     12319@@ -6741,9 +6785,8 @@
    1187512320  * Send the current selection to the clipboard.  Do nothing for X because we
    1187612321  * will fill in the selection only when requested by another app.
     
    1188312328 }
    1188412329 
    11885 @@ -6950,7 +6987,7 @@
     12330@@ -6950,7 +6993,7 @@
    1188612331            else
    1188712332                id &= ~1;       /* they are always even (why?) */
     
    1189412339diff -Naur vim72.orig/src/gui_motif.c vim72/src/gui_motif.c
    1189512340--- vim72.orig/src/gui_motif.c  2008-06-07 06:06:33.000000000 -0700
    11896 +++ vim72/src/gui_motif.c       2009-07-19 15:16:46.000000000 -0700
     12341+++ vim72/src/gui_motif.c       2009-09-12 08:39:05.000000000 -0700
    1189712342@@ -117,10 +117,9 @@
    1189812343  * Call-back routines.
     
    1225712702diff -Naur vim72.orig/src/gui_x11.c vim72/src/gui_x11.c
    1225812703--- vim72.orig/src/gui_x11.c    2008-06-08 08:13:45.000000000 -0700
    12259 +++ vim72/src/gui_x11.c 2009-07-19 15:16:46.000000000 -0700
     12704+++ vim72/src/gui_x11.c 2009-09-12 08:39:05.000000000 -0700
    1226012705@@ -570,22 +570,20 @@
    1226112706  * Call-back routines.
     
    1270213147diff -Naur vim72.orig/src/gui_xmdlg.c vim72/src/gui_xmdlg.c
    1270313148--- vim72.orig/src/gui_xmdlg.c  2008-06-21 09:05:32.000000000 -0700
    12704 +++ vim72/src/gui_xmdlg.c       2009-07-19 15:16:46.000000000 -0700
     13149+++ vim72/src/gui_xmdlg.c       2009-09-12 08:39:05.000000000 -0700
    1270513150@@ -369,10 +369,10 @@
    1270613151     char       buf[TEMP_BUF_SIZE];
     
    1292413369diff -Naur vim72.orig/src/gui_xmebw.c vim72/src/gui_xmebw.c
    1292513370--- vim72.orig/src/gui_xmebw.c  2007-09-06 03:57:51.000000000 -0700
    12926 +++ vim72/src/gui_xmebw.c       2009-07-19 15:16:46.000000000 -0700
     13371+++ vim72/src/gui_xmebw.c       2009-09-12 08:39:05.000000000 -0700
    1292713372@@ -235,13 +235,12 @@
    1292813373     return tmp;
     
    1305113496diff -Naur vim72.orig/src/hardcopy.c vim72/src/hardcopy.c
    1305213497--- vim72.orig/src/hardcopy.c   2008-01-11 12:46:20.000000000 -0800
    13053 +++ vim72/src/hardcopy.c        2009-07-19 15:16:23.000000000 -0700
     13498+++ vim72/src/hardcopy.c        2009-09-12 08:38:41.000000000 -0700
    1305413499@@ -442,12 +442,11 @@
    1305513500 /*
     
    1313413579diff -Naur vim72.orig/src/if_cscope.c vim72/src/if_cscope.c
    1313513580--- vim72.orig/src/if_cscope.c  2008-06-24 09:32:34.000000000 -0700
    13136 +++ vim72/src/if_cscope.c       2009-07-19 15:18:44.000000000 -0700
     13581+++ vim72/src/if_cscope.c       2009-09-12 08:41:09.000000000 -0700
    1313713582@@ -46,7 +46,6 @@
    1313813583 static int         cs_find __ARGS((exarg_T *eap));
     
    1372614171diff -Naur vim72.orig/src/if_cscope.h vim72/src/if_cscope.h
    1372714172--- vim72.orig/src/if_cscope.h  2007-09-02 07:51:08.000000000 -0700
    13728 +++ vim72/src/if_cscope.h       2009-07-19 15:18:44.000000000 -0700
     14173+++ vim72/src/if_cscope.h       2009-09-12 08:41:09.000000000 -0700
    1372914174@@ -25,7 +25,6 @@
    1373014175 
     
    1375514200diff -Naur vim72.orig/src/if_mzsch.c vim72/src/if_mzsch.c
    1375614201--- vim72.orig/src/if_mzsch.c   2007-07-01 09:44:49.000000000 -0700
    13757 +++ vim72/src/if_mzsch.c        2009-07-19 15:18:39.000000000 -0700
     14202+++ vim72/src/if_mzsch.c        2009-09-12 08:41:03.000000000 -0700
    1375814203@@ -667,13 +667,11 @@
    1375914204     static void CALLBACK
     
    1379614241diff -Naur vim72.orig/src/if_perl.xs vim72/src/if_perl.xs
    1379714242--- vim72.orig/src/if_perl.xs   2008-07-17 13:55:09.000000000 -0700
    13798 +++ vim72/src/if_perl.xs        2009-07-19 15:18:52.000000000 -0700
     14243+++ vim72/src/if_perl.xs        2009-09-12 08:41:16.000000000 -0700
    1379914244@@ -136,6 +136,9 @@
    1380014245 #  define Perl_newXS_flags dll_Perl_newXS_flags
     
    1387014315diff -Naur vim72.orig/src/if_python.c vim72/src/if_python.c
    1387114316--- vim72.orig/src/if_python.c  2008-07-17 14:09:32.000000000 -0700
    13872 +++ vim72/src/if_python.c       2009-07-19 15:18:39.000000000 -0700
     14317+++ vim72/src/if_python.c       2009-09-12 08:41:03.000000000 -0700
    1387314318@@ -531,6 +531,12 @@
    1387414319        if (PythonMod_Init())
     
    1408314528diff -Naur vim72.orig/src/if_ruby.c vim72/src/if_ruby.c
    1408414529--- vim72.orig/src/if_ruby.c    2007-09-10 01:40:38.000000000 -0700
    14085 +++ vim72/src/if_ruby.c 2009-07-19 15:16:49.000000000 -0700
     14530+++ vim72/src/if_ruby.c 2009-09-12 08:39:07.000000000 -0700
    1408614531@@ -492,7 +492,7 @@
    1408714532     }
     
    1417514620diff -Naur vim72.orig/src/if_tcl.c vim72/src/if_tcl.c
    1417614621--- vim72.orig/src/if_tcl.c     2007-05-07 12:50:14.000000000 -0700
    14177 +++ vim72/src/if_tcl.c  2009-07-19 15:16:54.000000000 -0700
     14622+++ vim72/src/if_tcl.c  2009-09-12 08:39:13.000000000 -0700
    1417814623@@ -161,7 +161,7 @@
    1417914624 # endif
     
    1439014835diff -Naur vim72.orig/src/if_xcmdsrv.c vim72/src/if_xcmdsrv.c
    1439114836--- vim72.orig/src/if_xcmdsrv.c 2008-07-18 06:05:03.000000000 -0700
    14392 +++ vim72/src/if_xcmdsrv.c      2009-07-19 15:16:23.000000000 -0700
     14837+++ vim72/src/if_xcmdsrv.c      2009-09-12 08:38:41.000000000 -0700
    1439314838@@ -682,7 +682,7 @@
    1439414839      * Scan all of the names out of the property.
     
    1450614951diff -Naur vim72.orig/src/macros.h vim72/src/macros.h
    1450714952--- vim72.orig/src/macros.h     2007-08-04 04:44:18.000000000 -0700
    14508 +++ vim72/src/macros.h  2009-07-19 15:16:33.000000000 -0700
     14953+++ vim72/src/macros.h  2009-09-12 08:38:51.000000000 -0700
    1450914954@@ -127,15 +127,31 @@
    1451014955 #ifdef FEAT_LANGMAP
     
    1455515000diff -Naur vim72.orig/src/main.c vim72/src/main.c
    1455615001--- vim72.orig/src/main.c       2008-07-24 01:40:56.000000000 -0700
    14557 +++ vim72/src/main.c    2009-07-19 15:16:33.000000000 -0700
     15002+++ vim72/src/main.c    2009-09-12 08:38:51.000000000 -0700
    1455815003@@ -645,11 +645,12 @@
    1455915004 
     
    1464715092diff -Naur vim72.orig/src/Makefile vim72/src/Makefile
    1464815093--- vim72.orig/src/Makefile     2008-08-09 07:50:04.000000000 -0700
    14649 +++ vim72/src/Makefile  2009-07-19 15:16:49.000000000 -0700
     15094+++ vim72/src/Makefile  2009-09-12 08:39:07.000000000 -0700
    1465015095@@ -105,8 +105,8 @@
    1465115096 # 4. "make test"  {{{1
     
    1476115206diff -Naur vim72.orig/src/mark.c vim72/src/mark.c
    1476215207--- vim72.orig/src/mark.c       2008-08-08 15:06:49.000000000 -0700
    14763 +++ vim72/src/mark.c    2009-07-19 15:16:23.000000000 -0700
     15208+++ vim72/src/mark.c    2009-09-12 08:38:41.000000000 -0700
    1476415209@@ -884,10 +884,9 @@
    1476515210 /*
     
    1488215327diff -Naur vim72.orig/src/mbyte.c vim72/src/mbyte.c
    1488315328--- vim72.orig/src/mbyte.c      2008-07-14 05:38:05.000000000 -0700
    14884 +++ vim72/src/mbyte.c   2009-07-19 15:17:33.000000000 -0700
     15329+++ vim72/src/mbyte.c   2009-09-12 08:39:52.000000000 -0700
    1488515330@@ -127,7 +127,10 @@
    1488615331 static int dbcs_char2len __ARGS((int c));
     
    1549015935diff -Naur vim72.orig/src/memline.c vim72/src/memline.c
    1549115936--- vim72.orig/src/memline.c    2008-07-13 09:19:22.000000000 -0700
    15492 +++ vim72/src/memline.c 2009-07-19 15:15:19.000000000 -0700
     15937+++ vim72/src/memline.c 2009-09-12 08:37:35.000000000 -0700
    1549315938@@ -1554,10 +1554,15 @@
    1549415939            for (i = 0; i < num_files; ++i)
     
    1555015995diff -Naur vim72.orig/src/menu.c vim72/src/menu.c
    1555115996--- vim72.orig/src/menu.c       2008-06-21 12:53:43.000000000 -0700
    15552 +++ vim72/src/menu.c    2009-07-19 15:16:33.000000000 -0700
     15997+++ vim72/src/menu.c    2009-09-12 08:38:51.000000000 -0700
    1555315998@@ -231,7 +231,7 @@
    1555415999                if (skipdigits(menu_path + 7) == p)
     
    1562716072diff -Naur vim72.orig/src/message.c vim72/src/message.c
    1562816073--- vim72.orig/src/message.c    2008-07-09 11:24:55.000000000 -0700
    15629 +++ vim72/src/message.c 2009-07-19 15:18:26.000000000 -0700
     16074+++ vim72/src/message.c 2009-09-12 08:40:50.000000000 -0700
    1563016075@@ -107,7 +107,7 @@
    1563116076 }
     
    1594816393diff -Naur vim72.orig/src/misc1.c vim72/src/misc1.c
    1594916394--- vim72.orig/src/misc1.c      2008-07-12 12:20:53.000000000 -0700
    15950 +++ vim72/src/misc1.c   2009-07-19 15:19:00.000000000 -0700
     16395+++ vim72/src/misc1.c   2009-09-12 08:41:27.000000000 -0700
    1595116396@@ -2188,12 +2188,11 @@
    1595216397  *
     
    1608416529     /* Set the state such that text can be selected/copied/pasted and we still
    1608516530      * get mouse events. */
    16086 @@ -4141,10 +4153,9 @@
     16531@@ -3264,6 +3276,7 @@
     16532        cmdline_row = msg_row - 1;
     16533        need_wait_return = FALSE;
     16534        msg_didany = FALSE;
     16535+       msg_didout = FALSE;
     16536     }
     16537     else
     16538        cmdline_row = save_cmdline_row;
     16539@@ -4141,10 +4154,9 @@
    1608716540 /*
    1608816541  * Function given to ExpandGeneric() to obtain an environment variable name.
     
    1609616549 {
    1609716550 # if defined(AMIGA) || defined(__MRC__) || defined(__SC__)
    16098 @@ -4736,9 +4747,9 @@
     16551@@ -4736,9 +4748,9 @@
    1609916552         * If it is then restrict the search to below this line and try again.
    1610016553         */
     
    1610816561        cur_maxcomment = curwin->w_cursor.lnum - pos->lnum - 1;
    1610916562        if (cur_maxcomment <= 0)
    16110 @@ -6269,7 +6280,7 @@
     16563@@ -6269,7 +6281,7 @@
    1611116564      * check for that.
    1611216565      */
     
    1611716570        linecopy[curwin->w_cursor.col] = NUL;
    1611816571 
    16119 @@ -8522,11 +8533,25 @@
     16572@@ -8522,11 +8534,25 @@
    1612016573     for (setsuf = p_su; *setsuf; )
    1612116574     {
     
    1614816601     return (setsuflen != 0);
    1614916602 }
    16150 @@ -9188,7 +9213,7 @@
     16603@@ -9188,7 +9214,7 @@
    1615116604                else if (vim_strpbrk(p, (char_u *)"$~") != NULL)
    1615216605                {
     
    1615916612diff -Naur vim72.orig/src/misc2.c vim72/src/misc2.c
    1616016613--- vim72.orig/src/misc2.c      2008-07-23 12:12:56.000000000 -0700
    16161 +++ vim72/src/misc2.c   2009-07-19 15:16:25.000000000 -0700
     16614+++ vim72/src/misc2.c   2009-09-12 08:38:43.000000000 -0700
    1616216615@@ -496,7 +496,8 @@
    1616316616 {
     
    1636516818diff -Naur vim72.orig/src/move.c vim72/src/move.c
    1636616819--- vim72.orig/src/move.c       2008-07-12 09:26:47.000000000 -0700
    16367 +++ vim72/src/move.c    2009-07-19 15:16:14.000000000 -0700
     16820+++ vim72/src/move.c    2009-09-12 08:38:31.000000000 -0700
    1636816821@@ -280,18 +280,20 @@
    1636916822 
     
    1644116894diff -Naur vim72.orig/src/nbdebug.c vim72/src/nbdebug.c
    1644216895--- vim72.orig/src/nbdebug.c    2008-06-22 08:38:58.000000000 -0700
    16443 +++ vim72/src/nbdebug.c 2009-07-19 15:13:36.000000000 -0700
     16896+++ vim72/src/nbdebug.c 2009-09-12 08:35:50.000000000 -0700
    1644416897@@ -33,7 +33,6 @@
    1644516898 u_int           nb_dlevel = 0;         /* nb_debug verbosity level */
     
    1650216955diff -Naur vim72.orig/src/nbdebug.h vim72/src/nbdebug.h
    1650316956--- vim72.orig/src/nbdebug.h    2008-06-22 07:31:50.000000000 -0700
    16504 +++ vim72/src/nbdebug.h 2009-07-19 15:13:36.000000000 -0700
     16957+++ vim72/src/nbdebug.h 2009-09-12 08:35:50.000000000 -0700
    1650516958@@ -43,8 +43,6 @@
    1650616959 
     
    1653416987diff -Naur vim72.orig/src/netbeans.c vim72/src/netbeans.c
    1653516988--- vim72.orig/src/netbeans.c   2008-07-13 09:19:54.000000000 -0700
    16536 +++ vim72/src/netbeans.c        2009-07-19 15:18:05.000000000 -0700
     16989+++ vim72/src/netbeans.c        2009-09-12 08:42:14.000000000 -0700
    1653716990@@ -32,6 +32,7 @@
    1653816991 /* WinSock API is separated from C API, thus we can't use read(), write(),
     
    1657917032 }
    1658017033 
    16581 @@ -1582,7 +1585,9 @@
     17034@@ -1493,7 +1496,8 @@
     17035                    return FAIL;
     17036                }
     17037                first = *pos;
     17038-               nbdebug(("    FIRST POS: line %d, col %d\n", first.lnum, first.col));
     17039+               nbdebug(("    FIRST POS: line %d, col %d\n",
     17040+                                                     first.lnum, first.col));
     17041                pos = off2pos(buf->bufp, off+count-1);
     17042                if (!pos)
     17043                {
     17044@@ -1504,7 +1508,8 @@
     17045                    return FAIL;
     17046                }
     17047                last = *pos;
     17048-               nbdebug(("    LAST POS: line %d, col %d\n", last.lnum, last.col));
     17049+               nbdebug(("    LAST POS: line %d, col %d\n",
     17050+                                                       last.lnum, last.col));
     17051                del_from_lnum = first.lnum;
     17052                del_to_lnum = last.lnum;
     17053                doupdate = 1;
     17054@@ -1515,7 +1520,8 @@
     17055                next = off2pos(buf->bufp, off + count);
     17056 
     17057                /* Remove part of the first line. */
     17058-               if (first.col != 0 || (next != NULL && first.lnum == next->lnum))
     17059+               if (first.col != 0
     17060+                               || (next != NULL && first.lnum == next->lnum))
     17061                {
     17062                    if (first.lnum != last.lnum
     17063                            || (next != NULL && first.lnum != next->lnum))
     17064@@ -1578,14 +1584,18 @@
     17065                        int id = buf_findsign_id(buf->bufp, (linenr_T)i);
     17066                        if (id > 0)
     17067                        {
     17068-                           nbdebug(("    Deleting sign %d on line %d\n", id, i));
     17069+                           nbdebug(("    Deleting sign %d on line %d\n",
     17070+                                                                     id, i));
    1658217071                            buf_delsign(buf->bufp, id);
    1658317072                        }
     
    1658817077                    }
    1658917078 
    16590                     nbdebug(("    Deleting lines %d through %d\n", del_from_lnum, del_to_lnum));
    16591 @@ -1921,7 +1926,7 @@
     17079-                   nbdebug(("    Deleting lines %d through %d\n", del_from_lnum, del_to_lnum));
     17080+                   nbdebug(("    Deleting lines %d through %d\n",
     17081+                                                del_from_lnum, del_to_lnum));
     17082                    curwin->w_cursor.lnum = del_from_lnum;
     17083                    curwin->w_cursor.col = 0;
     17084                    del_lines(del_to_lnum - del_from_lnum + 1, FALSE);
     17085@@ -1921,7 +1931,7 @@
    1659217086            vim_free(path);
    1659317087            if (bufp == NULL)
     
    1659817092                return FAIL;
    1659917093            }
    16600 @@ -2141,7 +2146,9 @@
     17094@@ -2141,7 +2151,9 @@
    1660117095 #endif
    1660217096            }
     
    1660817102            /* gui_update_cursor(TRUE, FALSE); */
    1660917103            /* update_curbuf(NOT_VALID); */
    16610 @@ -2277,9 +2284,6 @@
     17104@@ -2277,9 +2289,6 @@
    1661117105            int serNum;
    1661217106            int localTypeNum;
     
    1661817112 
    1661917113            if (buf == NULL || buf->bufp == NULL)
    16620 @@ -2303,13 +2307,10 @@
     17114@@ -2303,13 +2312,10 @@
    1662117115            pos = get_off_or_lnum(buf->bufp, &args);
    1662217116 
     
    1663417128                nbdebug(("    partial line annotation -- Not Yet Implemented!\n"));
    1663517129            }
    16636 @@ -2321,7 +2322,7 @@
     17130@@ -2321,7 +2327,7 @@
    1663717131            }
    1663817132            if (pos)
     
    1664317137                if (typeNum == curPCtype)
    1664417138                    coloncmd(":sign jump %d buffer=%d", serNum,
    16645 @@ -2425,7 +2426,7 @@
     17139@@ -2425,7 +2431,7 @@
    1664617140                                GUARDED) == 0)
    1664717141                            {
     
    1665217146                                     buf->bufp->b_fnum);
    1665317147                            }
    16654 @@ -2582,7 +2583,7 @@
     17148@@ -2582,7 +2588,7 @@
    1665517149     va_list ap;
    1665617150 
     
    1666117155 
    1666217156     nbdebug(("    COLONCMD %s\n", buf));
    16663 @@ -2747,11 +2748,10 @@
     17157@@ -2747,11 +2753,10 @@
    1666417158  * cursor and sends it to the debugger for evaluation.  The debugger should
    1666517159  * respond with a showBalloon command when there is a useful result.
     
    1667417168     win_T      *wp;
    1667517169     char_u     *text;
    16676 @@ -2924,44 +2924,26 @@
     17170@@ -2924,44 +2929,26 @@
    1667717171 }
    1667817172 
     
    1672517219     if (nbbuf != NULL)
    1672617220        nbbuf->bufp = NULL;
    16727 @@ -3082,9 +3064,8 @@
     17221@@ -3082,9 +3069,8 @@
    1672817222 /*
    1672917223  * Send netbeans an unmodufied command.
     
    1673617230 #if 0
    1673717231     char_u     buf[128];
    16738 @@ -3391,13 +3372,12 @@
     17232@@ -3391,13 +3377,12 @@
    1673917233  * buf->signmapused[]  maps buffer-local annotation IDs to an index in
    1674017234  *                     globalsignmap[].
     
    1675117245     int                use_fg,
    1675217246     int                fg,
     17247@@ -3531,7 +3516,8 @@
     17248            eol_size = 1;
     17249        for (lnum = 1; lnum <= bufp->b_ml.ml_line_count; ++lnum)
     17250        {
     17251-           char_count += (long)STRLEN(ml_get(lnum)) + eol_size;
     17252+           char_count += (long)STRLEN(ml_get_buf(bufp, lnum, FALSE))
     17253+                                                                  + eol_size;
     17254            /* Check for a CTRL-C every 100000 characters */
     17255            if (char_count > last_check)
     17256            {
    1675317257diff -Naur vim72.orig/src/normal.c vim72/src/normal.c
    1675417258--- vim72.orig/src/normal.c     2008-07-31 13:03:08.000000000 -0700
    16755 +++ vim72/src/normal.c  2009-07-19 15:16:33.000000000 -0700
     17259+++ vim72/src/normal.c  2009-09-12 08:38:51.000000000 -0700
    1675617260@@ -183,6 +183,8 @@
    1675717261 static void    nv_cursorhold __ARGS((cmdarg_T *cap));
     
    1717917683diff -Naur vim72.orig/src/ops.c vim72/src/ops.c
    1718017684--- vim72.orig/src/ops.c        2008-06-21 13:08:59.000000000 -0700
    17181 +++ vim72/src/ops.c     2009-07-19 15:18:26.000000000 -0700
     17685+++ vim72/src/ops.c     2009-09-12 08:40:50.000000000 -0700
    1718217686@@ -72,11 +72,11 @@
    1718317687  */
     
    1759618100diff -Naur vim72.orig/src/option.c vim72/src/option.c
    1759718101--- vim72.orig/src/option.c     2008-07-18 06:05:33.000000000 -0700
    17598 +++ vim72/src/option.c  2009-07-19 15:17:52.000000000 -0700
     18102+++ vim72/src/option.c  2009-09-12 08:42:20.000000000 -0700
    1759918103@@ -387,6 +387,9 @@
    1760018104     char_u     *def_val[2];    /* default values for variable (vi and vim) */
     
    1760718111 };
    1760818112 
    17609 @@ -477,7 +480,7 @@
     18113@@ -400,8 +403,9 @@
     18114 #define P_NUM          0x02    /* the option is numeric */
     18115 #define P_STRING       0x04    /* the option is a string */
     18116 #define P_ALLOCED      0x08    /* the string option is in allocated memory,
     18117-                                   must use vim_free() when assigning new
     18118-                                   value. Not set if default is the same. */
     18119+                                  must use free_string_option() when
     18120+                                  assigning new value. Not set if default is
     18121+                                  the same. */
     18122 #define P_EXPAND       0x10    /* environment expansion.  NOTE: P_EXPAND can
     18123                                   never be used for local or hidden options! */
     18124 #define P_NODEFAULT    0x40    /* don't set to default value */
     18125@@ -477,7 +481,7 @@
    1761018126 #else
    1761118127                            (char_u *)224L,
     
    1761618132 #if defined(FEAT_GUI) && defined(MACOS_X)
    1761718133                            (char_u *)&p_antialias, PV_NONE,
    17618 @@ -486,35 +489,35 @@
     18134@@ -486,35 +490,35 @@
    1761918135                            (char_u *)NULL, PV_NONE,
    1762018136                            {(char_u *)FALSE, (char_u *)FALSE}
     
    1765718173 #if defined(FEAT_MBYTE)
    1765818174                            (char_u *)&p_ambw, PV_NONE,
    17659 @@ -523,27 +526,27 @@
     18175@@ -523,27 +527,27 @@
    1766018176                            (char_u *)NULL, PV_NONE,
    1766118177                            {(char_u *)0L, (char_u *)0L}
     
    1769218208                            (char_u *)&p_bg, PV_NONE,
    1769318209                            {
    17694 @@ -552,13 +555,13 @@
     18210@@ -552,13 +556,13 @@
    1769518211 #else
    1769618212                            (char_u *)"light",
     
    1770918225                            (char_u *)&p_bkc, PV_NONE,
    1771018226 #ifdef UNIX
    17711 @@ -566,10 +569,10 @@
     18227@@ -566,10 +570,10 @@
    1771218228 #else
    1771318229                            {(char_u *)"auto", (char_u *)"auto"}
     
    1772218238                            (char_u *)&p_bex, PV_NONE,
    1772318239                            {
    17724 @@ -578,7 +581,7 @@
     18240@@ -578,7 +582,7 @@
    1772518241 #else
    1772618242                            (char_u *)"~",
     
    1773118247 #ifdef FEAT_WILDIGN
    1773218248                            (char_u *)&p_bsk, PV_NONE,
    17733 @@ -587,40 +590,40 @@
     18249@@ -587,40 +591,40 @@
    1773418250                            (char_u *)NULL, PV_NONE,
    1773518251                            {(char_u *)0L, (char_u *)0L}
     
    1778018296 #ifdef FEAT_LINEBREAK
    1778118297                            (char_u *)&p_breakat, PV_NONE,
    17782 @@ -629,7 +632,7 @@
     18298@@ -629,7 +633,7 @@
    1778318299                            (char_u *)NULL, PV_NONE,
    1778418300                            {(char_u *)0L, (char_u *)0L}
     
    1778918305 #ifdef FEAT_BROWSE
    1779018306                            (char_u *)&p_bsdir, PV_NONE,
    17791 @@ -638,7 +641,7 @@
     18307@@ -638,7 +642,7 @@
    1779218308                            (char_u *)NULL, PV_NONE,
    1779318309                            {(char_u *)0L, (char_u *)0L}
     
    1779818314 #if defined(FEAT_QUICKFIX)
    1779918315                            (char_u *)&p_bh, PV_BH,
    17800 @@ -647,11 +650,11 @@
     18316@@ -647,11 +651,11 @@
    1780118317                            (char_u *)NULL, PV_NONE,
    1780218318                            {(char_u *)0L, (char_u *)0L}
     
    1781218328 #if defined(FEAT_QUICKFIX)
    1781318329                            (char_u *)&p_bt, PV_BT,
    17814 @@ -660,7 +663,7 @@
     18330@@ -660,7 +664,7 @@
    1781518331                            (char_u *)NULL, PV_NONE,
    1781618332                            {(char_u *)0L, (char_u *)0L}
     
    1782118337 #ifdef FEAT_MBYTE
    1782218338                            (char_u *)&p_cmp, PV_NONE,
    17823 @@ -669,7 +672,7 @@
     18339@@ -669,7 +673,7 @@
    1782418340                            (char_u *)NULL, PV_NONE,
    1782518341                            {(char_u *)0L, (char_u *)0L}
     
    1783018346 #ifdef FEAT_SEARCHPATH
    1783118347                            (char_u *)&p_cdpath, PV_NONE,
    17832 @@ -678,7 +681,7 @@
     18348@@ -678,7 +682,7 @@
    1783318349                            (char_u *)NULL, PV_NONE,
    1783418350                            {(char_u *)0L, (char_u *)0L}
     
    1783918355 #ifdef FEAT_CMDWIN
    1784018356                            (char_u *)&p_cedit, PV_NONE,
    17841 @@ -687,7 +690,7 @@
     18357@@ -687,7 +691,7 @@
    1784218358                            (char_u *)NULL, PV_NONE,
    1784318359                            {(char_u *)0L, (char_u *)0L}
     
    1784818364 #if defined(FEAT_MBYTE) && defined(FEAT_EVAL)
    1784918365                            (char_u *)&p_ccv, PV_NONE,
    17850 @@ -696,14 +699,14 @@
     18366@@ -696,14 +700,14 @@
    1785118367                            (char_u *)NULL, PV_NONE,
    1785218368                            {(char_u *)0L, (char_u *)0L}
     
    1786518381 #ifdef FEAT_CINDENT
    1786618382                            (char_u *)&p_cink, PV_CINK,
    17867 @@ -712,14 +715,14 @@
     18383@@ -712,14 +716,14 @@
    1786818384                            (char_u *)NULL, PV_NONE,
    1786918385                            {(char_u *)0L, (char_u *)0L}
     
    1788218398 #if defined(FEAT_SMARTINDENT) || defined(FEAT_CINDENT)
    1788318399                            (char_u *)&p_cinw, PV_CINW,
    17884 @@ -729,7 +732,7 @@
     18400@@ -729,7 +733,7 @@
    1788518401                            (char_u *)NULL, PV_NONE,
    1788618402                            {(char_u *)0L, (char_u *)0L}
     
    1789118407 #ifdef FEAT_CLIPBOARD
    1789218408                            (char_u *)&p_cb, PV_NONE,
    17893 @@ -743,20 +746,20 @@
     18409@@ -743,20 +747,20 @@
    1789418410                            (char_u *)NULL, PV_NONE,
    1789518411                            {(char_u *)"", (char_u *)0L}
     
    1791618432 #ifdef FEAT_COMMENTS
    1791718433                            (char_u *)&p_com, PV_COM,
    17918 @@ -766,7 +769,7 @@
     18434@@ -766,7 +770,7 @@
    1791918435                            (char_u *)NULL, PV_NONE,
    1792018436                            {(char_u *)0L, (char_u *)0L}
     
    1792518441 #ifdef FEAT_FOLDING
    1792618442                            (char_u *)&p_cms, PV_CMS,
    17927 @@ -775,12 +778,12 @@
     18443@@ -775,12 +779,12 @@
    1792818444                            (char_u *)NULL, PV_NONE,
    1792918445                            {(char_u *)0L, (char_u *)0L}
     
    1794018456 #ifdef FEAT_INS_EXPAND
    1794118457                            (char_u *)&p_cpt, PV_CPT,
    17942 @@ -789,7 +792,7 @@
     18458@@ -789,7 +793,7 @@
    1794318459                            (char_u *)NULL, PV_NONE,
    1794418460                            {(char_u *)0L, (char_u *)0L}
     
    1794918465 #ifdef FEAT_COMPL_FUNC
    1795018466                            (char_u *)&p_cfu, PV_CFU,
    17951 @@ -798,7 +801,7 @@
     18467@@ -798,7 +802,7 @@
    1795218468                            (char_u *)NULL, PV_NONE,
    1795318469                            {(char_u *)0L, (char_u *)0L}
     
    1795818474 #ifdef FEAT_INS_EXPAND
    1795918475                            (char_u *)&p_cot, PV_NONE,
    17960 @@ -807,34 +810,35 @@
     18476@@ -807,34 +811,35 @@
    1796118477                            (char_u *)NULL, PV_NONE,
    1796218478                            {(char_u *)0L, (char_u *)0L}
     
    1800018516 #ifdef FEAT_CSCOPE
    1800118517                            (char_u *)&p_csprg, PV_NONE,
    18002 @@ -843,7 +847,7 @@
     18518@@ -843,7 +848,7 @@
    1800318519                            (char_u *)NULL, PV_NONE,
    1800418520                            {(char_u *)0L, (char_u *)0L}
     
    1800918525 #if defined(FEAT_CSCOPE) && defined(FEAT_QUICKFIX)
    1801018526                            (char_u *)&p_csqf, PV_NONE,
    18011 @@ -852,45 +856,45 @@
     18527@@ -852,45 +857,45 @@
    1801218528                            (char_u *)NULL, PV_NONE,
    1801318529                            {(char_u *)0L, (char_u *)0L}
     
    1806218578 #ifdef FEAT_FIND_ID
    1806318579                            (char_u *)&p_def, PV_DEF,
    18064 @@ -899,28 +903,28 @@
     18580@@ -899,28 +904,28 @@
    1806518581                            (char_u *)NULL, PV_NONE,
    1806618582                            {(char_u *)NULL, (char_u *)0L}
     
    1809518611 #if defined(FEAT_DIFF) && defined(FEAT_EVAL)
    1809618612                            (char_u *)&p_dex, PV_NONE,
    18097 @@ -929,7 +933,7 @@
     18613@@ -929,7 +934,7 @@
    1809818614                            (char_u *)NULL, PV_NONE,
    1809918615                            {(char_u *)0L, (char_u *)0L}
     
    1810418620 #ifdef FEAT_DIFF
    1810518621                            (char_u *)&p_dip, PV_NONE,
    18106 @@ -938,20 +942,20 @@
     18622@@ -938,20 +943,20 @@
    1810718623                            (char_u *)NULL, PV_NONE,
    1810818624                            {(char_u *)"", (char_u *)NULL}
     
    1812918645 #ifdef FEAT_VERTSPLIT
    1813018646                            (char_u *)&p_ead, PV_NONE,
    18131 @@ -960,10 +964,10 @@
     18647@@ -960,10 +965,10 @@
    1813218648                            (char_u *)NULL, PV_NONE,
    1813318649                            {(char_u *)NULL, (char_u *)0L}
     
    1814218658 #ifdef FEAT_MBYTE
    1814318659                            (char_u *)&p_enc, PV_NONE,
    18144 @@ -972,19 +976,19 @@
     18660@@ -972,19 +977,19 @@
    1814518661                            (char_u *)NULL, PV_NONE,
    1814618662                            {(char_u *)0L, (char_u *)0L}
     
    1816718683 #ifdef FEAT_QUICKFIX
    1816818684                            (char_u *)&p_ef, PV_NONE,
    18169 @@ -993,32 +997,32 @@
     18685@@ -993,32 +998,32 @@
    1817018686                            (char_u *)NULL, PV_NONE,
    1817118687                            {(char_u *)NULL, (char_u *)0L}
     
    1820718723 #ifdef FEAT_MBYTE
    1820818724                            (char_u *)&p_fenc, PV_FENC,
    18209 @@ -1027,7 +1031,7 @@
     18725@@ -1027,7 +1032,7 @@
    1821018726                            (char_u *)NULL, PV_NONE,
    1821118727                            {(char_u *)0L, (char_u *)0L}
     
    1821618732 #ifdef FEAT_MBYTE
    1821718733                            (char_u *)&p_fencs, PV_NONE,
    18218 @@ -1036,13 +1040,14 @@
     18734@@ -1036,13 +1041,14 @@
    1821918735                            (char_u *)NULL, PV_NONE,
    1822018736                            {(char_u *)0L, (char_u *)0L}
     
    1823418750 #ifdef FEAT_AUTOCMD
    1823518751                            (char_u *)&p_ft, PV_FT,
    18236 @@ -1051,7 +1056,7 @@
     18752@@ -1051,7 +1057,7 @@
    1823718753                            (char_u *)NULL, PV_NONE,
    1823818754                            {(char_u *)0L, (char_u *)0L}
     
    1824318759 #if defined(FEAT_WINDOWS) || defined(FEAT_FOLDING)
    1824418760                            (char_u *)&p_fcs, PV_NONE,
    18245 @@ -1060,27 +1065,27 @@
     18761@@ -1060,27 +1066,27 @@
    1824618762                            (char_u *)NULL, PV_NONE,
    1824718763                            {(char_u *)"", (char_u *)0L}
     
    1827718793 # ifdef FEAT_EVAL
    1827818794                            (char_u *)VAR_WIN, PV_FDE,
    18279 @@ -1089,33 +1094,34 @@
     18795@@ -1089,33 +1095,34 @@
    1828018796                            (char_u *)NULL, PV_NONE,
    1828118797                            {(char_u *)NULL, (char_u *)0L}
     
    1832118837 # ifdef FEAT_EVAL
    1832218838                            (char_u *)VAR_WIN, PV_FDT,
    18323 @@ -1124,7 +1130,7 @@
     18839@@ -1124,7 +1131,7 @@
    1832418840                            (char_u *)NULL, PV_NONE,
    1832518841                            {(char_u *)NULL, (char_u *)0L}
     
    1833018846     {"formatexpr", "fex",   P_STRING|P_ALLOCED|P_VI_DEF|P_VIM,
    1833118847 #ifdef FEAT_EVAL
    18332 @@ -1134,16 +1140,18 @@
     18848@@ -1134,16 +1141,18 @@
    1833318849                            (char_u *)NULL, PV_NONE,
    1833418850                            {(char_u *)0L, (char_u *)0L}
     
    1835318869 #ifdef HAVE_FSYNC
    1835418870                            (char_u *)&p_fs, PV_NONE,
    18355 @@ -1152,22 +1160,22 @@
     18871@@ -1152,22 +1161,22 @@
    1835618872                            (char_u *)NULL, PV_NONE,
    1835718873                            {(char_u *)FALSE, (char_u *)0L}
     
    1838118897 #ifdef FEAT_QUICKFIX
    1838218898                            (char_u *)&p_gp, PV_GP,
    18383 @@ -1185,15 +1193,15 @@
     18899@@ -1185,15 +1194,15 @@
    1838418900                            (char_u *)"SEARCH/NUMBERS ",
    1838518901 #   else
     
    1840118917 #ifdef CURSOR_SHAPE
    1840218918                            (char_u *)&p_guicursor, PV_NONE,
    18403 @@ -1208,7 +1216,7 @@
     18919@@ -1208,7 +1217,7 @@
    1840418920                            (char_u *)NULL, PV_NONE,
    1840518921                            {(char_u *)NULL, (char_u *)0L}
     
    1841018926 #ifdef FEAT_GUI
    1841118927                            (char_u *)&p_guifont, PV_NONE,
    18412 @@ -1217,7 +1225,7 @@
     18928@@ -1217,7 +1226,7 @@
    1841318929                            (char_u *)NULL, PV_NONE,
    1841418930                            {(char_u *)NULL, (char_u *)0L}
     
    1841918935 #if defined(FEAT_GUI) && defined(FEAT_XFONTSET)
    1842018936                            (char_u *)&p_guifontset, PV_NONE,
    18421 @@ -1226,7 +1234,7 @@
     18937@@ -1226,7 +1235,7 @@
    1842218938                            (char_u *)NULL, PV_NONE,
    1842318939                            {(char_u *)NULL, (char_u *)0L}
     
    1842818944 #if defined(FEAT_GUI) && defined(FEAT_MBYTE)
    1842918945                            (char_u *)&p_guifontwide, PV_NONE,
    18430 @@ -1235,14 +1243,14 @@
     18946@@ -1235,14 +1244,14 @@
    1843118947                            (char_u *)NULL, PV_NONE,
    1843218948                            {(char_u *)NULL, (char_u *)0L}
     
    1844518961 #if defined(FEAT_GUI)
    1844618962                            (char_u *)&p_go, PV_NONE,
    18447 @@ -1255,14 +1263,14 @@
     18963@@ -1255,14 +1264,14 @@
    1844818964                            (char_u *)NULL, PV_NONE,
    1844918965                            {(char_u *)NULL, (char_u *)0L}
     
    1846218978 #if defined(FEAT_GUI_TABLINE)
    1846318979                            (char_u *)&p_gtl, PV_NONE,
    18464 @@ -1271,7 +1279,7 @@
     18980@@ -1271,7 +1280,7 @@
    1846518981                            (char_u *)NULL, PV_NONE,
    1846618982                            {(char_u *)NULL, (char_u *)0L}
     
    1847118987 #if defined(FEAT_GUI_TABLINE)
    1847218988                            (char_u *)&p_gtt, PV_NONE,
    18473 @@ -1280,20 +1288,21 @@
     18989@@ -1280,20 +1289,21 @@
    1847418990                            (char_u *)NULL, PV_NONE,
    1847518991                            {(char_u *)NULL, (char_u *)0L}
     
    1849719013 #ifdef FEAT_MULTI_LANG
    1849819014                            (char_u *)&p_hlg, PV_NONE,
    18499 @@ -1302,64 +1311,65 @@
     19015@@ -1302,64 +1312,65 @@
    1850019016                            (char_u *)NULL, PV_NONE,
    1850119017                            {(char_u *)0L, (char_u *)0L}
     
    1857519091 #ifdef USE_IM_CONTROL
    1857619092                            (char_u *)&p_imdisable, PV_NONE,
    18577 @@ -1371,7 +1381,7 @@
     19093@@ -1371,7 +1382,7 @@
    1857819094 #else
    1857919095                            {(char_u *)FALSE, (char_u *)0L}
     
    1858419100                            (char_u *)&p_iminsert, PV_IMI,
    1858519101 #ifdef B_IMODE_IM
    18586 @@ -1379,7 +1389,7 @@
     19102@@ -1379,7 +1390,7 @@
    1858719103 #else
    1858819104                            {(char_u *)B_IMODE_NONE, (char_u *)0L}
     
    1859319109                            (char_u *)&p_imsearch, PV_IMS,
    1859419110 #ifdef B_IMODE_IM
    18595 @@ -1387,7 +1397,7 @@
     19111@@ -1387,7 +1398,7 @@
    1859619112 #else
    1859719113                            {(char_u *)B_IMODE_NONE, (char_u *)0L}
     
    1860219118 #ifdef FEAT_FIND_ID
    1860319119                            (char_u *)&p_inc, PV_INC,
    18604 @@ -1396,7 +1406,7 @@
     19120@@ -1396,7 +1407,7 @@
    1860519121                            (char_u *)NULL, PV_NONE,
    1860619122                            {(char_u *)0L, (char_u *)0L}
     
    1861119127 #if defined(FEAT_FIND_ID) && defined(FEAT_EVAL)
    1861219128                            (char_u *)&p_inex, PV_INEX,
    18613 @@ -1405,10 +1415,10 @@
     19129@@ -1405,10 +1416,10 @@
    1861419130                            (char_u *)NULL, PV_NONE,
    1861519131                            {(char_u *)0L, (char_u *)0L}
     
    1862419140 #if defined(FEAT_CINDENT) && defined(FEAT_EVAL)
    1862519141                            (char_u *)&p_inde, PV_INDE,
    18626 @@ -1417,7 +1427,7 @@
     19142@@ -1417,7 +1428,7 @@
    1862719143                            (char_u *)NULL, PV_NONE,
    1862819144                            {(char_u *)0L, (char_u *)0L}
     
    1863319149 #if defined(FEAT_CINDENT) && defined(FEAT_EVAL)
    1863419150                            (char_u *)&p_indk, PV_INDK,
    18635 @@ -1426,13 +1436,13 @@
     19151@@ -1426,13 +1437,13 @@
    1863619152                            (char_u *)NULL, PV_NONE,
    1863719153                            {(char_u *)0L, (char_u *)0L}
     
    1865019166                            (char_u *)&p_isf, PV_NONE,
    1865119167                            {
    18652 @@ -1455,7 +1465,7 @@
     19168@@ -1455,7 +1466,7 @@
    1865319169 #  endif
    1865419170 # endif
     
    1865919175                            (char_u *)&p_isi, PV_NONE,
    1866019176                            {
    18661 @@ -1472,7 +1482,7 @@
     19177@@ -1472,7 +1483,7 @@
    1866219178                            (char_u *)"@,48-57,_,192-255",
    1866319179 # endif
     
    1866819184                            (char_u *)&p_isk, PV_ISK,
    1866919185                            {
    18670 @@ -1491,7 +1501,7 @@
     19186@@ -1491,7 +1502,7 @@
    1867119187                                ISK_LATIN1
    1867219188 # endif
     
    1867719193                            (char_u *)&p_isp, PV_NONE,
    1867819194                            {
    18679 @@ -1507,10 +1517,10 @@
     19195@@ -1507,10 +1518,10 @@
    1868019196                            ISP_LATIN1,
    1868119197 # endif
     
    1869019206 #ifdef FEAT_CRYPT
    1869119207                            (char_u *)&p_key, PV_KEY,
    18692 @@ -1519,7 +1529,7 @@
     19208@@ -1519,7 +1530,7 @@
    1869319209                            (char_u *)NULL, PV_NONE,
    1869419210                            {(char_u *)0L, (char_u *)0L}
     
    1869919215 #ifdef FEAT_KEYMAP
    1870019216                            (char_u *)&p_keymap, PV_KMAP,
    18701 @@ -1528,14 +1538,14 @@
     19217@@ -1528,14 +1539,14 @@
    1870219218                            (char_u *)NULL, PV_NONE,
    1870319219                            {(char_u *)"", (char_u *)0L}
     
    1871619232                            (char_u *)&p_kp, PV_KP,
    1871719233                            {
    18718 @@ -1556,7 +1566,7 @@
     19234@@ -1556,7 +1567,7 @@
    1871919235 # endif
    1872019236 #endif
     
    1872519241 #ifdef FEAT_LANGMAP
    1872619242                            (char_u *)&p_langmap, PV_NONE,
    18727 @@ -1565,31 +1575,31 @@
     19243@@ -1565,31 +1576,31 @@
    1872819244                            (char_u *)NULL, PV_NONE,
    1872919245                            {(char_u *)NULL,
     
    1876219278                            (char_u *)&Rows, PV_NONE,
    1876319279                            {
    18764 @@ -1598,7 +1608,7 @@
     19280@@ -1598,7 +1609,7 @@
    1876519281 #else
    1876619282                            (char_u *)24L,
     
    1877119287 #ifdef FEAT_GUI
    1877219288                            (char_u *)&p_linespace, PV_NONE,
    18773 @@ -1610,14 +1620,14 @@
     19289@@ -1610,14 +1621,14 @@
    1877419290 #else
    1877519291                            {(char_u *)0L, (char_u *)0L}
     
    1878819304 #ifdef FEAT_LISP
    1878919305                            (char_u *)&p_lispwords, PV_NONE,
    18790 @@ -1626,24 +1636,24 @@
     19306@@ -1626,24 +1637,24 @@
    1879119307                            (char_u *)NULL, PV_NONE,
    1879219308                            {(char_u *)"", (char_u *)0L}
     
    1881919335 #ifdef FEAT_QUICKFIX
    1882019336                            (char_u *)&p_mef, PV_NONE,
    18821 @@ -1652,7 +1662,7 @@
     19337@@ -1652,7 +1663,7 @@
    1882219338                            (char_u *)NULL, PV_NONE,
    1882319339                            {(char_u *)NULL, (char_u *)0L}
     
    1882819344 #ifdef FEAT_QUICKFIX
    1882919345                            (char_u *)&p_mp, PV_MP,
    18830 @@ -1665,49 +1675,52 @@
     19346@@ -1665,49 +1676,52 @@
    1883119347                            (char_u *)NULL, PV_NONE,
    1883219348                            {(char_u *)NULL, (char_u *)0L}
     
    1889219408 #ifdef FEAT_SPELL
    1889319409                            (char_u *)&p_msm, PV_NONE,
    18894 @@ -1716,22 +1729,22 @@
     19410@@ -1716,22 +1730,22 @@
    1889519411                            (char_u *)NULL, PV_NONE,
    1889619412                            {(char_u *)0L, (char_u *)0L}
     
    1892119437                            (char_u *)&p_mouse, PV_NONE,
    1892219438                            {
    18923 @@ -1740,21 +1753,21 @@
     19439@@ -1740,21 +1754,21 @@
    1892419440 #else
    1892519441                                (char_u *)"",
     
    1894619462                            (char_u *)&p_mousem, PV_NONE,
    1894719463                            {
    18948 @@ -1767,7 +1780,7 @@
     19464@@ -1767,7 +1781,7 @@
    1894919465                                (char_u *)"extend",
    1895019466 # endif
     
    1895519471 #ifdef FEAT_MOUSESHAPE
    1895619472                            (char_u *)&p_mouseshape, PV_NONE,
    18957 @@ -1776,33 +1789,34 @@
     19473@@ -1776,33 +1790,34 @@
    1895819474                            (char_u *)NULL, PV_NONE,
    1895919475                            {(char_u *)NULL, (char_u *)0L}
     
    1899719513 #ifdef FEAT_COMPL_FUNC
    1899819514                            (char_u *)&p_ofu, PV_OFU,
    18999 @@ -1811,10 +1825,10 @@
     19515@@ -1811,10 +1826,10 @@
    1900019516                            (char_u *)NULL, PV_NONE,
    1900119517                            {(char_u *)0L, (char_u *)0L}
     
    1901019526 #if defined(MSDOS) || defined(MSWIN) || defined(OS2)
    1901119527                            (char_u *)&p_odev, PV_NONE,
    19012 @@ -1822,13 +1836,13 @@
     19528@@ -1822,13 +1837,13 @@
    1901319529                            (char_u *)NULL, PV_NONE,
    1901419530 #endif
     
    1902719543 #ifdef FEAT_OSFILETYPE
    1902819544                            (char_u *)&p_oft, PV_OFT,
    19029 @@ -1837,17 +1851,17 @@
     19545@@ -1837,17 +1852,17 @@
    1903019546                            (char_u *)NULL, PV_NONE,
    1903119547                            {(char_u *)0L, (char_u *)0L}
     
    1904919565 #if defined(FEAT_DIFF) && defined(FEAT_EVAL)
    1905019566                            (char_u *)&p_pex, PV_NONE,
    19051 @@ -1856,10 +1870,10 @@
     19567@@ -1856,10 +1871,10 @@
    1905219568                            (char_u *)NULL, PV_NONE,
    1905319569                            {(char_u *)0L, (char_u *)0L}
     
    1906219578                            (char_u *)&p_path, PV_PATH,
    1906319579                            {
    19064 @@ -1872,24 +1886,24 @@
     19580@@ -1872,24 +1887,24 @@
    1906519581                            (char_u *)".,/usr/include,,",
    1906619582 # endif
     
    1909119607 #ifdef FEAT_PRINTER
    1909219608                            (char_u *)&p_pdev, PV_NONE,
    19093 @@ -1898,7 +1912,7 @@
     19609@@ -1898,7 +1913,7 @@
    1909419610                            (char_u *)NULL, PV_NONE,
    1909519611                            {(char_u *)NULL, (char_u *)0L}
     
    1910019616 #ifdef FEAT_POSTSCRIPT
    1910119617                            (char_u *)&p_penc, PV_NONE,
    19102 @@ -1907,7 +1921,7 @@
     19618@@ -1907,7 +1922,7 @@
    1910319619                            (char_u *)NULL, PV_NONE,
    1910419620                            {(char_u *)NULL, (char_u *)0L}
     
    1910919625 #ifdef FEAT_POSTSCRIPT
    1911019626                            (char_u *)&p_pexpr, PV_NONE,
    19111 @@ -1916,7 +1930,7 @@
     19627@@ -1916,7 +1931,7 @@
    1911219628                            (char_u *)NULL, PV_NONE,
    1911319629                            {(char_u *)NULL, (char_u *)0L}
     
    1911819634 #ifdef FEAT_PRINTER
    1911919635                            (char_u *)&p_pfn, PV_NONE,
    19120 @@ -1931,7 +1945,7 @@
     19636@@ -1931,7 +1946,7 @@
    1912119637                            (char_u *)NULL, PV_NONE,
    1912219638                            {(char_u *)NULL, (char_u *)0L}
     
    1912719643 #ifdef FEAT_PRINTER
    1912819644                            (char_u *)&p_header, PV_NONE,
    19129 @@ -1940,7 +1954,7 @@
     19645@@ -1940,7 +1955,7 @@
    1913019646                            (char_u *)NULL, PV_NONE,
    1913119647                            {(char_u *)NULL, (char_u *)0L}
     
    1913619652 #if defined(FEAT_POSTSCRIPT) && defined(FEAT_MBYTE)
    1913719653                            (char_u *)&p_pmcs, PV_NONE,
    19138 @@ -1949,7 +1963,7 @@
     19654@@ -1949,7 +1964,7 @@
    1913919655                            (char_u *)NULL, PV_NONE,
    1914019656                            {(char_u *)NULL, (char_u *)0L}
     
    1914519661 #if defined(FEAT_POSTSCRIPT) && defined(FEAT_MBYTE)
    1914619662                            (char_u *)&p_pmfn, PV_NONE,
    19147 @@ -1958,7 +1972,7 @@
     19663@@ -1958,7 +1973,7 @@
    1914819664                            (char_u *)NULL, PV_NONE,
    1914919665                            {(char_u *)NULL, (char_u *)0L}
     
    1915419670 #ifdef FEAT_PRINTER
    1915519671                            (char_u *)&p_popt, PV_NONE,
    19156 @@ -1967,17 +1981,17 @@
     19672@@ -1967,17 +1982,17 @@
    1915719673                            (char_u *)NULL, PV_NONE,
    1915819674                            {(char_u *)NULL, (char_u *)0L}
     
    1917519691 #ifdef FEAT_TEXTOBJ
    1917619692                            (char_u *)&p_qe, PV_QE,
    19177 @@ -1986,47 +2000,47 @@
     19693@@ -1986,47 +2001,47 @@
    1917819694                            (char_u *)NULL, PV_NONE,
    1917919695                            {(char_u *)NULL, (char_u *)0L}
     
    1923219748 #ifdef FEAT_RIGHTLEFT
    1923319749                            (char_u *)VAR_WIN, PV_RLC,
    19234 @@ -2035,40 +2049,41 @@
     19750@@ -2035,40 +2050,41 @@
    1923519751                            (char_u *)NULL, PV_NONE,
    1923619752                            {(char_u *)NULL, (char_u *)0L}
     
    1928219798 #ifdef FEAT_SCROLLBIND
    1928319799                            (char_u *)&p_sbo, PV_NONE,
    19284 @@ -2077,27 +2092,29 @@
     19800@@ -2077,27 +2093,29 @@
    1928519801                            (char_u *)NULL, PV_NONE,
    1928619802                            {(char_u *)0L, (char_u *)0L}
     
    1931719833 #ifdef FEAT_SESSION
    1931819834                            (char_u *)&p_ssop, PV_NONE,
    19319 @@ -2107,7 +2124,7 @@
     19835@@ -2107,7 +2125,7 @@
    1932019836                            (char_u *)NULL, PV_NONE,
    1932119837                            {(char_u *)0L, (char_u *)0L}
     
    1932619842                            (char_u *)&p_sh, PV_NONE,
    1932719843                            {
    19328 @@ -2136,7 +2153,7 @@
     19844@@ -2136,7 +2154,7 @@
    1932919845 #  endif
    1933019846 # endif
     
    1933519851                            (char_u *)&p_shcf, PV_NONE,
    1933619852                            {
    19337 @@ -2149,7 +2166,7 @@
     19853@@ -2149,7 +2167,7 @@
    1933819854                            (char_u *)"-c",
    1933919855 # endif
     
    1934419860 #ifdef FEAT_QUICKFIX
    1934519861                            (char_u *)&p_sp, PV_NONE,
    19346 @@ -2168,30 +2185,30 @@
     19862@@ -2168,30 +2186,30 @@
    1934719863                            (char_u *)NULL, PV_NONE,
    1934819864                            {(char_u *)0L, (char_u *)0L}
     
    1938119897                            (char_u *)&p_sxq, PV_NONE,
    1938219898                            {
    19383 @@ -2200,30 +2217,31 @@
     19899@@ -2200,30 +2218,31 @@
    1938419900 #else
    1938519901                            (char_u *)"",
     
    1941919935 #ifdef FEAT_CMDL_INFO
    1942019936                            (char_u *)&p_sc, PV_NONE,
    19421 @@ -2236,58 +2254,58 @@
     19937@@ -2236,58 +2255,58 @@
    1942219938 #else
    1942319939                                (char_u *)TRUE
     
    1949220008 #ifdef FEAT_SPELL
    1949320009                            (char_u *)&p_spc, PV_SPC,
    19494 @@ -2296,7 +2314,7 @@
     20010@@ -2296,7 +2315,7 @@
    1949520011                            (char_u *)NULL, PV_NONE,
    1949620012                            {(char_u *)0L, (char_u *)0L}
     
    1950120017 #ifdef FEAT_SPELL
    1950220018                            (char_u *)&p_spf, PV_SPF,
    19503 @@ -2305,7 +2323,7 @@
     20019@@ -2305,7 +2324,7 @@
    1950420020                            (char_u *)NULL, PV_NONE,
    1950520021                            {(char_u *)0L, (char_u *)0L}
     
    1951020026 #ifdef FEAT_SPELL
    1951120027                            (char_u *)&p_spl, PV_SPL,
    19512 @@ -2314,7 +2332,7 @@
     20028@@ -2314,7 +2333,7 @@
    1951320029                            (char_u *)NULL, PV_NONE,
    1951420030                            {(char_u *)0L, (char_u *)0L}
     
    1951920035 #ifdef FEAT_SPELL
    1952020036                            (char_u *)&p_sps, PV_NONE,
    19521 @@ -2323,35 +2341,35 @@
     20037@@ -2323,35 +2342,35 @@
    1952220038                            (char_u *)NULL, PV_NONE,
    1952320039                            {(char_u *)0L, (char_u *)0L}
     
    1956120077 #ifdef FEAT_SEARCHPATH
    1956220078                            (char_u *)&p_sua, PV_SUA,
    19563 @@ -2360,16 +2378,16 @@
     20079@@ -2360,16 +2379,16 @@
    1956420080                            (char_u *)NULL, PV_NONE,
    1956520081                            {(char_u *)0L, (char_u *)0L}
     
    1958220098 #ifdef FEAT_SYN_HL
    1958320099                            (char_u *)&p_smc, PV_SMC,
    19584 @@ -2378,7 +2396,7 @@
     20100@@ -2378,7 +2397,7 @@
    1958520101                            (char_u *)NULL, PV_NONE,
    1958620102                            {(char_u *)0L, (char_u *)0L}
     
    1959120107 #ifdef FEAT_SYN_HL
    1959220108                            (char_u *)&p_syn, PV_SYN,
    19593 @@ -2387,24 +2405,24 @@
     20109@@ -2387,24 +2406,24 @@
    1959420110                            (char_u *)NULL, PV_NONE,
    1959520111                            {(char_u *)0L, (char_u *)0L}
     
    1962020136                            (char_u *)&p_tbs, PV_NONE,
    1962120137 #ifdef VMS     /* binary searching doesn't appear to work on VMS */
    19622 @@ -2412,13 +2430,13 @@
     20138@@ -2412,13 +2431,13 @@
    1962320139 #else
    1962420140                            {(char_u *)TRUE, (char_u *)0L}
     
    1963720153                            (char_u *)&p_tags, PV_TAGS,
    1963820154                            {
    19639 @@ -2427,20 +2445,20 @@
     20155@@ -2427,20 +2446,20 @@
    1964020156 #else
    1964120157                            (char_u *)"./tags,tags",
     
    1966220178 #ifdef FEAT_MBYTE
    1966320179                            (char_u *)&p_tenc, PV_NONE,
    19664 @@ -2449,13 +2467,14 @@
     20180@@ -2449,13 +2468,14 @@
    1966520181                            (char_u *)NULL, PV_NONE,
    1966620182                            {(char_u *)0L, (char_u *)0L}
     
    1968020196                            (char_u *)&p_tx, PV_TX,
    1968120197                            {
    19682 @@ -2464,40 +2483,40 @@
     20198@@ -2464,40 +2484,40 @@
    1968320199 #else
    1968420200                            (char_u *)FALSE,
     
    1972920245 #ifdef FEAT_TITLE
    1973020246                            (char_u *)&p_titleold, PV_NONE,
    19731 @@ -2507,49 +2526,50 @@
     20247@@ -2507,49 +2527,50 @@
    1973220248                            (char_u *)NULL, PV_NONE,
    1973320249                            {(char_u *)0L, (char_u *)0L}
     
    1979120307                            (char_u *)&p_ul, PV_NONE,
    1979220308                            {
    19793 @@ -2558,19 +2578,19 @@
     20309@@ -2558,19 +2579,19 @@
    1979420310 #else
    1979520311                            (char_u *)100L,
     
    1981620332 #ifdef FEAT_SESSION
    1981720333                            (char_u *)&p_vdir, PV_NONE,
    19818 @@ -2579,7 +2599,7 @@
     20334@@ -2579,7 +2600,7 @@
    1981920335                            (char_u *)NULL, PV_NONE,
    1982020336                            {(char_u *)0L, (char_u *)0L}
     
    1982520341 #ifdef FEAT_SESSION
    1982620342                            (char_u *)&p_vop, PV_NONE,
    19827 @@ -2588,25 +2608,25 @@
     20343@@ -2588,25 +2609,25 @@
    1982820344                            (char_u *)NULL, PV_NONE,
    1982920345                            {(char_u *)0L, (char_u *)0L}
     
    1985620372 #ifdef FEAT_VIRTUALEDIT
    1985720373                            (char_u *)&p_ve, PV_NONE,
    19858 @@ -2615,51 +2635,52 @@
     20374@@ -2615,51 +2636,52 @@
    1985920375                            (char_u *)NULL, PV_NONE,
    1986020376                            {(char_u *)0L, (char_u *)0L}
     
    1992220438 #ifdef FEAT_CMDL_COMPL
    1992320439                            (char_u *)&p_wop, PV_NONE,
    19924 @@ -2668,7 +2689,7 @@
     20440@@ -2668,7 +2690,7 @@
    1992520441                            (char_u *)NULL, PV_NONE,
    1992620442                            {(char_u *)NULL, (char_u *)0L}
     
    1993120447 #ifdef FEAT_WAK
    1993220448                            (char_u *)&p_wak, PV_NONE,
    19933 @@ -2677,67 +2698,67 @@
     20449@@ -2677,67 +2699,67 @@
    1993420450                            (char_u *)NULL, PV_NONE,
    1993520451                            {(char_u *)NULL, (char_u *)0L}
     
    2001220528                            (char_u *)&p_wb, PV_NONE,
    2001320529                            {
    20014 @@ -2746,15 +2767,15 @@
     20530@@ -2746,15 +2768,15 @@
    2001520531 #else
    2001620532                            (char_u *)FALSE,
     
    2003120547     p_term("t_AB", T_CAB)
    2003220548     p_term("t_AF", T_CAF)
    20033 @@ -2815,7 +2836,8 @@
     20549@@ -2815,7 +2837,8 @@
    2003420550 
    2003520551 /* terminal key codes are not in here */
     
    2004120557 
    2004220558 #define PARAM_COUNT (sizeof(options) / sizeof(struct vimoption))
    20043 @@ -3984,7 +4006,7 @@
     20559@@ -3984,7 +4007,7 @@
    2004420560        else
    2004520561        {
     
    2005020566                prefix = 0;
    2005120567                arg += 2;
    20052 @@ -4119,11 +4141,23 @@
     20568@@ -4119,11 +4142,23 @@
    2005320569                                           && options[opt_idx].var == VAR_WIN)
    2005420570                goto skip;
     
    2007820594 
    2007920595 #ifdef HAVE_SANDBOX
    20080 @@ -5268,6 +5302,21 @@
     20596@@ -5268,6 +5303,21 @@
    2008120597 }
    2008220598 #endif
     
    2010020616  * Set a string option to a new value (without checking the effect).
    2010120617  * The string is copied into allocated memory.
    20102 @@ -5275,14 +5324,13 @@
     20618@@ -5275,14 +5325,13 @@
    2010320619  * When "set_sid" is zero set the scriptID to current_SID.  When "set_sid" is
    2010420620  * SID_NONE don't set the scriptID.  Otherwise set the scriptID to "set_sid".
     
    2011620632     char_u     *s;
    2011720633     char_u     **varp;
    20118 @@ -5407,6 +5455,10 @@
     20634@@ -5407,6 +5456,10 @@
    2011920635     int                did_chartab = FALSE;
    2012020636     char_u     **gvarp;
     
    2012720643     /* Get the global option to compare with, otherwise we would have to check
    2012820644      * two values for all local options. */
    20129 @@ -5668,7 +5720,7 @@
     20645@@ -5668,7 +5721,7 @@
    2013020646            {
    2013120647 # ifdef FEAT_TITLE
     
    2013620652                /* Add 'fileencoding' to the swap file. */
    2013720653                ml_setflags(curbuf);
    20138 @@ -5687,7 +5739,7 @@
     20654@@ -5687,7 +5740,7 @@
    2013920655            {
    2014020656                errmsg = mb_init();
     
    2014520661            }
    2014620662        }
    20147 @@ -5766,14 +5818,28 @@
     20663@@ -5766,14 +5819,28 @@
    2014820664        /* load or unload key mapping tables */
    2014920665        errmsg = keymap_init();
     
    2018120697            status_redraw_curbuf();
    2018220698 # endif
    20183 @@ -5796,7 +5862,7 @@
     20699@@ -5796,7 +5863,7 @@
    2018420700            else
    2018520701                curbuf->b_p_tx = FALSE;
     
    2019020706            /* update flag in swap file */
    2019120707            ml_setflags(curbuf);
    20192 @@ -5977,15 +6043,23 @@
     20708@@ -5977,15 +6044,23 @@
    2019320709        /* ":set t_Co=0" and ":set t_Co=1" do ":set t_Co=" */
    2019420710        if (varp == &T_CCO)
     
    2022120737        ttest(FALSE);
    2022220738        if (varp == &T_ME)
    20223 @@ -6055,6 +6129,7 @@
     20739@@ -6055,6 +6130,7 @@
    2022420740                    errmsg = (char_u *)N_("E596: Invalid font(s)");
    2022520741            }
     
    2022920745 # ifdef FEAT_XFONTSET
    2023020746     else if (varp == &p_guifontset)
    20231 @@ -6063,6 +6138,7 @@
     20747@@ -6063,6 +6139,7 @@
    2023220748            errmsg = (char_u *)N_("E597: can't select fontset");
    2023320749        else if (gui.in_use && gui_init_font(p_guifontset, TRUE) != OK)
     
    2023720753 # endif
    2023820754 # ifdef FEAT_MBYTE
    20239 @@ -6072,6 +6148,7 @@
     20755@@ -6072,6 +6149,7 @@
    2024020756            errmsg = (char_u *)N_("E533: can't select wide font");
    2024120757        else if (gui_get_wide_font() == FAIL)
     
    2024520761 # endif
    2024620762 #endif
    20247 @@ -6133,13 +6210,24 @@
     20763@@ -6133,13 +6211,24 @@
    2024820764 #ifdef FEAT_GUI
    2024920765     /* 'guioptions' */
     
    2027020786 
    2027120787 #if defined(FEAT_MOUSE_TTY) && (defined(UNIX) || defined(VMS))
    20272 @@ -6717,7 +6805,11 @@
     20788@@ -6717,7 +6806,11 @@
    2027320789 
    2027420790     if (curwin->w_curswant != MAXCOL)
     
    2028320799     return errmsg;
    2028420800 }
    20285 @@ -6932,6 +7024,7 @@
     20801@@ -6932,6 +7025,7 @@
    2028620802     int                new_unnamed = FALSE;
    2028720803     int                new_autoselect = FALSE;
     
    2029120807     char_u     *errmsg = NULL;
    2029220808     char_u     *p;
    20293 @@ -6955,6 +7048,11 @@
     20809@@ -6955,6 +7049,11 @@
    2029420810            new_autoselectml = TRUE;
    2029520811            p += 12;
     
    2030320819        {
    2030420820            p += 8;
    20305 @@ -6976,6 +7074,7 @@
     20821@@ -6976,6 +7075,7 @@
    2030620822        clip_unnamed = new_unnamed;
    2030720823        clip_autoselect = new_autoselect;
     
    2031120827        clip_exclude_prog = new_exclude_prog;
    2031220828     }
    20313 @@ -7105,22 +7204,28 @@
     20829@@ -7094,6 +7194,14 @@
     20830        compatible_set();
     20831     }
     20832 
     20833+    /* 'list', 'number' */
     20834+    else if ((int *)varp == &curwin->w_p_list
     20835+         || (int *)varp == &curwin->w_p_nu)
     20836+    {
     20837+       if (curwin->w_curswant != MAXCOL)
     20838+           curwin->w_set_curswant = TRUE;
     20839+    }
     20840+
     20841     else if ((int *)varp == &curbuf->b_p_ro)
     20842     {
     20843        /* when 'readonly' is reset globally, also reset readonlymode */
     20844@@ -7105,22 +7213,28 @@
    2031420845            curbuf->b_did_warn = FALSE;
    2031520846 
     
    2034720878 
    2034820879     /* when 'bin' is set also set some other options */
    20349 @@ -7128,7 +7233,7 @@
     20880@@ -7128,7 +7242,7 @@
    2035020881     {
    2035120882        set_options_bin(old_value, curbuf->b_p_bin, opt_flags);
     
    2035620887     }
    2035720888 
    20358 @@ -7279,7 +7384,7 @@
     20889@@ -7279,7 +7393,7 @@
    2035920890        if (!value)
    2036020891            save_file_ff(curbuf);       /* Buffer is unchanged */
     
    2036520896 #ifdef FEAT_AUTOCMD
    2036620897        modified_was_set = value;
    20367 @@ -7486,9 +7591,13 @@
     20898@@ -7316,6 +7430,8 @@
     20899     {
     20900        if (curwin->w_p_wrap)
     20901            curwin->w_leftcol = 0;
     20902+       if (curwin->w_curswant != MAXCOL)
     20903+           curwin->w_set_curswant = TRUE;
     20904     }
     20905 
     20906 #ifdef FEAT_WINDOWS
     20907@@ -7486,9 +7602,13 @@
    2036820908             * set. */
    2036920909            if (STRCMP(p_enc, "utf-8") != 0)
     
    2038120921 
    2038220922 # ifdef FEAT_MBYTE
    20383 @@ -7714,7 +7823,7 @@
     20923@@ -7535,6 +7655,30 @@
     20924            curbuf->b_p_imsearch = B_IMODE_USE_INSERT;
     20925 # endif
     20926        }
     20927+       if (curwin->w_curswant != MAXCOL)
     20928+           curwin->w_set_curswant = TRUE;
     20929+    }
     20930+
     20931+    else if ((int *)varp == &p_arshape)
     20932+    {
     20933+       if (curwin->w_curswant != MAXCOL)
     20934+           curwin->w_set_curswant = TRUE;
     20935+    }
     20936+#endif
     20937+
     20938+#ifdef FEAT_LINEBREAK
     20939+    if ((int *)varp == &curwin->w_p_lbr)
     20940+    {
     20941+       if (curwin->w_curswant != MAXCOL)
     20942+           curwin->w_set_curswant = TRUE;
     20943+    }
     20944+#endif
     20945+
     20946+#ifdef FEAT_RIGHTLEFT
     20947+    if ((int *)varp == &curwin->w_p_rl)
     20948+    {
     20949+       if (curwin->w_curswant != MAXCOL)
     20950+           curwin->w_set_curswant = TRUE;
     20951     }
     20952 #endif
     20953 
     20954@@ -7545,8 +7689,7 @@
     20955     options[opt_idx].flags |= P_WAS_SET;
     20956 
     20957     comp_col();                            /* in case 'ruler' or 'showcmd' changed */
     20958-    if (curwin->w_curswant != MAXCOL)
     20959-       curwin->w_set_curswant = TRUE;  /* in case 'list' changed */
     20960+
     20961     check_redraw(options[opt_idx].flags);
     20962 
     20963     return NULL;
     20964@@ -7714,7 +7857,7 @@
    2038420965        newFoldLevel();
    2038520966     }
     
    2039020971     {
    2039120972        foldUpdateAll(curwin);
    20392 @@ -7974,6 +8083,11 @@
     20973@@ -7974,6 +8117,11 @@
    2039320974        else /* curwin->w_p_scr > curwin->w_height */
    2039420975            curwin->w_p_scr = curwin->w_height;
     
    2040220983     {
    2040320984        errmsg = e_positive;
    20404 @@ -8227,13 +8341,13 @@
     20985@@ -8227,13 +8375,13 @@
    2040520986            {
    2040620987                if (number == 0 && string != NULL)
     
    2041921000                        /* There's another character after zeros or the string
    2042021001                         * is empty.  In both cases, we are trying to set a
    20421 @@ -8323,7 +8437,7 @@
     21002@@ -8323,7 +8471,7 @@
    2042221003     {
    2042321004        --arg;                      /* put arg at the '<' */
     
    2042821009            key = 0;
    2042921010     }
    20430 @@ -9271,10 +9385,9 @@
     21011@@ -8813,6 +8961,28 @@
     21012 }
     21013 
     21014 /*
     21015+ * Free the string for one term option, if it was allocated.
     21016+ * Set the string to empty_option and clear allocated flag.
     21017+ * "var" points to the option value.
     21018+ */
     21019+    void
     21020+free_one_termoption(var)
     21021+    char_u *var;
     21022+{
     21023+    struct vimoption   *p;
     21024+
     21025+    for (p = &options[0]; p->fullname != NULL; p++)
     21026+       if (p->var == var)
     21027+       {
     21028+           if (p->flags & P_ALLOCED)
     21029+               free_string_option(*(char_u **)(p->var));
     21030+           *(char_u **)(p->var) = empty_option;
     21031+           p->flags &= ~P_ALLOCED;
     21032+           break;
     21033+       }
     21034+}
     21035+
     21036+/*
     21037  * Set the terminal option defaults to the current value.
     21038  * Used after setting the terminal name.
     21039  */
     21040@@ -9271,10 +9441,9 @@
    2043121041 /*
    2043221042  * Check for NULL pointers in a winopt_T and replace them with empty_option.
     
    2044021050 #ifdef FEAT_FOLDING
    2044121051     check_string_option(&wop->wo_fdi);
    20442 @@ -9296,10 +9409,9 @@
     21052@@ -9296,10 +9465,9 @@
    2044321053 /*
    2044421054  * Free the allocated memory inside a winopt_T.
     
    2045221062 #ifdef FEAT_FOLDING
    2045321063     clear_string_option(&wop->wo_fdi);
    20454 @@ -9645,7 +9757,7 @@
     21064@@ -9645,7 +9813,7 @@
    2045521065        }
    2045621066        --p;
     
    2046121071        xp->xp_context = EXPAND_BOOL_SETTINGS;
    2046221072        p += 2;
    20463 @@ -9834,7 +9946,8 @@
     21073@@ -9834,7 +10002,8 @@
    2046421074        regmatch->rm_ic = ic;
    2046521075        if (xp->xp_context != EXPAND_BOOL_SETTINGS)
     
    2047121081                {
    2047221082                    if (loop == 0)
    20473 @@ -10093,25 +10206,110 @@
     21083@@ -10093,25 +10262,110 @@
    2047421084 
    2047521085 #ifdef FEAT_LANGMAP
     
    2048921099+ * langmap_entry_T.  This does the same as langmap_mapchar[] for characters >=
    2049021100+ * 256.
    20491   */
     21101+ */
    2049221102+# ifdef FEAT_MBYTE
    2049321103+/*
    2049421104+ * With multi-byte support use growarray for 'langmap' chars >= 256
    20495 + */
     21105  */
    2049621106+typedef struct
    2049721107+{
     
    2059121201 
    2059221202 /*
    20593 @@ -10125,7 +10323,10 @@
     21203@@ -10125,7 +10379,10 @@
    2059421204     char_u  *p2;
    2059521205     int            from, to;
     
    2060321213     for (p = p_langmap; p[0] != NUL; )
    2060421214     {
    20605 @@ -10175,7 +10376,13 @@
     21215@@ -10175,7 +10432,13 @@
    2060621216                                                             transchar(from));
    2060721217                return;
     
    2062021230diff -Naur vim72.orig/src/os_unix.c vim72/src/os_unix.c
    2062121231--- vim72.orig/src/os_unix.c    2008-08-06 04:01:40.000000000 -0700
    20622 +++ vim72/src/os_unix.c 2009-07-19 15:18:55.000000000 -0700
     21232+++ vim72/src/os_unix.c 2009-09-12 08:41:32.000000000 -0700
    2062321233@@ -181,7 +181,8 @@
    2062421234        && defined(FEAT_TITLE) && !defined(FEAT_GUI_GTK)
     
    2088121491 #endif
    2088221492 
     21493@@ -1706,9 +1734,9 @@
     21494     if (oldicon == NULL && !test_only)
     21495     {
     21496        if (STRNCMP(T_NAME, "builtin_", 8) == 0)
     21497-           oldicon = T_NAME + 8;
     21498+           oldicon = vim_strsave(T_NAME + 8);
     21499        else
     21500-           oldicon = T_NAME;
     21501+           oldicon = vim_strsave(T_NAME);
     21502     }
     21503 
     21504     return retval;
    2088321505@@ -1897,10 +1925,9 @@
    2088421506 
     
    2089121513+    int            test_only UNUSED;
    2089221514 {
     21515     return FALSE;
     21516 }
     21517@@ -1912,9 +1939,9 @@
     21518     if (!test_only)
     21519     {
     21520        if (STRNCMP(T_NAME, "builtin_", 8) == 0)
     21521-           oldicon = T_NAME + 8;
     21522+           oldicon = vim_strsave(T_NAME + 8);
     21523        else
     21524-           oldicon = T_NAME;
     21525+           oldicon = vim_strsave(T_NAME);
     21526     }
    2089321527     return FALSE;
    2089421528 }
     
    2136021994diff -Naur vim72.orig/src/os_unix.h vim72/src/os_unix.h
    2136121995--- vim72.orig/src/os_unix.h    2008-06-17 11:01:17.000000000 -0700
    21362 +++ vim72/src/os_unix.h 2009-07-19 15:18:55.000000000 -0700
     21996+++ vim72/src/os_unix.h 2009-09-12 08:41:19.000000000 -0700
    2136321997@@ -124,7 +124,7 @@
    2136421998 #  define SIGDUMMYARG  0, 0, (struct sigcontext *)0
     
    2138422018diff -Naur vim72.orig/src/proto/buffer.pro vim72/src/proto/buffer.pro
    2138522019--- vim72.orig/src/proto/buffer.pro     2008-08-09 07:31:21.000000000 -0700
    21386 +++ vim72/src/proto/buffer.pro  2009-07-19 15:15:54.000000000 -0700
     22020+++ vim72/src/proto/buffer.pro  2009-09-12 08:38:11.000000000 -0700
    2138722021@@ -37,13 +37,12 @@
    2138822022 int otherfile __ARGS((char_u *ffname));
     
    2141422048diff -Naur vim72.orig/src/proto/edit.pro vim72/src/proto/edit.pro
    2141522049--- vim72.orig/src/proto/edit.pro       2008-08-09 07:31:24.000000000 -0700
    21416 +++ vim72/src/proto/edit.pro    2009-07-19 15:15:54.000000000 -0700
     22050+++ vim72/src/proto/edit.pro    2009-09-12 08:38:11.000000000 -0700
    2141722051@@ -8,7 +8,7 @@
    2141822052 void backspace_until_column __ARGS((int col));
     
    2142622060diff -Naur vim72.orig/src/proto/eval.pro vim72/src/proto/eval.pro
    2142722061--- vim72.orig/src/proto/eval.pro       2008-08-09 07:31:25.000000000 -0700
    21428 +++ vim72/src/proto/eval.pro    2009-07-19 15:10:37.000000000 -0700
     22062+++ vim72/src/proto/eval.pro    2009-09-12 08:32:50.000000000 -0700
    2142922063@@ -17,7 +17,7 @@
    2143022064 int eval_to_bool __ARGS((char_u *arg, int *error, char_u **nextcmd, int skip));
     
    2146822102diff -Naur vim72.orig/src/proto/ex_cmds.pro vim72/src/proto/ex_cmds.pro
    2146922103--- vim72.orig/src/proto/ex_cmds.pro    2008-08-09 07:31:25.000000000 -0700
    21470 +++ vim72/src/proto/ex_cmds.pro 2009-07-19 15:16:00.000000000 -0700
     22104+++ vim72/src/proto/ex_cmds.pro 2009-09-12 08:38:17.000000000 -0700
    2147122105@@ -9,9 +9,9 @@
    2147222106 void do_bang __ARGS((int addr_count, exarg_T *eap, int forceit, int do_in, int do_out));
     
    2149222126diff -Naur vim72.orig/src/proto/ex_getln.pro vim72/src/proto/ex_getln.pro
    2149322127--- vim72.orig/src/proto/ex_getln.pro   2008-08-09 07:31:28.000000000 -0700
    21494 +++ vim72/src/proto/ex_getln.pro        2009-07-19 15:14:20.000000000 -0700
     22128+++ vim72/src/proto/ex_getln.pro        2009-09-12 08:36:36.000000000 -0700
    2149522129@@ -4,6 +4,7 @@
    2149622130 int text_locked __ARGS((void));
     
    2151222146diff -Naur vim72.orig/src/proto/gui.pro vim72/src/proto/gui.pro
    2151322147--- vim72.orig/src/proto/gui.pro        2008-08-09 07:31:56.000000000 -0700
    21514 +++ vim72/src/proto/gui.pro     2009-07-19 15:17:39.000000000 -0700
     22148+++ vim72/src/proto/gui.pro     2009-09-12 08:39:58.000000000 -0700
    2151522149@@ -43,6 +43,7 @@
    2151622150 void gui_create_scrollbar __ARGS((scrollbar_T *sb, int type, win_T *wp));
     
    2152322157diff -Naur vim72.orig/src/proto/if_cscope.pro vim72/src/proto/if_cscope.pro
    2152422158--- vim72.orig/src/proto/if_cscope.pro  2008-08-09 07:31:33.000000000 -0700
    21525 +++ vim72/src/proto/if_cscope.pro       2009-07-19 15:15:24.000000000 -0700
     22159+++ vim72/src/proto/if_cscope.pro       2009-09-12 08:37:41.000000000 -0700
    2152622160@@ -1,4 +1,6 @@
    2152722161 /* if_cscope.c */
     
    2153322167diff -Naur vim72.orig/src/proto/mark.pro vim72/src/proto/mark.pro
    2153422168--- vim72.orig/src/proto/mark.pro       2008-08-09 07:31:36.000000000 -0700
    21535 +++ vim72/src/proto/mark.pro    2009-07-19 15:09:53.000000000 -0700
     22169+++ vim72/src/proto/mark.pro    2009-09-12 08:32:04.000000000 -0700
    2153622170@@ -26,5 +26,5 @@
    2153722171 void write_viminfo_filemarks __ARGS((FILE *fp));
     
    2154322177diff -Naur vim72.orig/src/proto/mbyte.pro vim72/src/proto/mbyte.pro
    2154422178--- vim72.orig/src/proto/mbyte.pro      2008-08-09 07:31:41.000000000 -0700
    21545 +++ vim72/src/proto/mbyte.pro   2009-07-19 15:17:30.000000000 -0700
     22179+++ vim72/src/proto/mbyte.pro   2009-09-12 08:39:49.000000000 -0700
    2154622180@@ -7,10 +7,12 @@
    2154722181 int latin_char2len __ARGS((int c));
     
    2156722201diff -Naur vim72.orig/src/proto/message.pro vim72/src/proto/message.pro
    2156822202--- vim72.orig/src/proto/message.pro    2008-08-09 07:31:39.000000000 -0700
    21569 +++ vim72/src/proto/message.pro 2009-07-19 15:15:14.000000000 -0700
     22203+++ vim72/src/proto/message.pro 2009-09-12 08:37:30.000000000 -0700
    2157022204@@ -54,6 +54,7 @@
    2157122205 void msg_clr_cmdline __ARGS((void));
     
    2157822212diff -Naur vim72.orig/src/proto/misc2.pro vim72/src/proto/misc2.pro
    2157922213--- vim72.orig/src/proto/misc2.pro      2008-08-09 07:31:40.000000000 -0700
    21580 +++ vim72/src/proto/misc2.pro   2009-07-19 15:11:46.000000000 -0700
     22214+++ vim72/src/proto/misc2.pro   2009-09-12 08:33:59.000000000 -0700
    2158122215@@ -59,7 +59,7 @@
    2158222216 int handle_x_keys __ARGS((int key));
     
    2159022224diff -Naur vim72.orig/src/proto/netbeans.pro vim72/src/proto/netbeans.pro
    2159122225--- vim72.orig/src/proto/netbeans.pro   2008-08-09 07:31:56.000000000 -0700
    21592 +++ vim72/src/proto/netbeans.pro        2009-07-19 15:12:02.000000000 -0700
     22226+++ vim72/src/proto/netbeans.pro        2009-09-12 08:34:15.000000000 -0700
    2159322227@@ -11,7 +11,7 @@
    2159422228 void netbeans_frame_moved __ARGS((int new_x, int new_y));
     
    2160222236diff -Naur vim72.orig/src/proto/option.pro vim72/src/proto/option.pro
    2160322237--- vim72.orig/src/proto/option.pro     2008-08-09 07:31:43.000000000 -0700
    21604 +++ vim72/src/proto/option.pro  2009-07-19 15:13:20.000000000 -0700
    21605 @@ -44,6 +44,7 @@
     22238+++ vim72/src/proto/option.pro  2009-09-12 08:41:35.000000000 -0700
     22239@@ -29,6 +29,7 @@
     22240 int makefoldset __ARGS((FILE *fd));
     22241 void clear_termoptions __ARGS((void));
     22242 void free_termoptions __ARGS((void));
     22243+void free_one_termoption __ARGS((char_u *var));
     22244 void set_term_defaults __ARGS((void));
     22245 void comp_col __ARGS((void));
     22246 char_u *get_equalprg __ARGS((void));
     22247@@ -44,6 +45,7 @@
    2160622248 void set_context_in_set_cmd __ARGS((expand_T *xp, char_u *arg, int opt_flags));
    2160722249 int ExpandSettings __ARGS((expand_T *xp, regmatch_T *regmatch, int *num_file, char_u ***file));
     
    2161322255diff -Naur vim72.orig/src/proto/os_unix.pro vim72/src/proto/os_unix.pro
    2161422256--- vim72.orig/src/proto/os_unix.pro    2008-08-09 07:31:44.000000000 -0700
    21615 +++ vim72/src/proto/os_unix.pro 2009-07-19 15:18:55.000000000 -0700
     22257+++ vim72/src/proto/os_unix.pro 2009-09-12 08:41:19.000000000 -0700
    2161622258@@ -1,4 +1,5 @@
    2161722259 /* os_unix.c */
     
    2162222264diff -Naur vim72.orig/src/proto/spell.pro vim72/src/proto/spell.pro
    2162322265--- vim72.orig/src/proto/spell.pro      2008-08-09 07:31:48.000000000 -0700
    21624 +++ vim72/src/proto/spell.pro   2009-07-19 15:16:00.000000000 -0700
     22266+++ vim72/src/proto/spell.pro   2009-09-12 08:38:17.000000000 -0700
    2162522267@@ -22,5 +22,5 @@
    2162622268 char_u *spell_to_word_end __ARGS((char_u *start, buf_T *buf));
     
    2163222274diff -Naur vim72.orig/src/proto/ui.pro vim72/src/proto/ui.pro
    2163322275--- vim72.orig/src/proto/ui.pro 2008-08-09 07:31:52.000000000 -0700
    21634 +++ vim72/src/proto/ui.pro      2009-07-19 15:18:26.000000000 -0700
     22276+++ vim72/src/proto/ui.pro      2009-09-12 08:40:50.000000000 -0700
    2163522277@@ -48,6 +48,7 @@
    2163622278 void open_app_context __ARGS((void));
     
    2164322285diff -Naur vim72.orig/src/proto/window.pro vim72/src/proto/window.pro
    2164422286--- vim72.orig/src/proto/window.pro     2008-08-09 07:31:54.000000000 -0700
    21645 +++ vim72/src/proto/window.pro  2009-07-19 15:18:10.000000000 -0700
     22287+++ vim72/src/proto/window.pro  2009-09-12 08:40:34.000000000 -0700
    2164622288@@ -1,6 +1,7 @@
    2164722289 /* window.c */
     
    2168522327diff -Naur vim72.orig/src/pty.c vim72/src/pty.c
    2168622328--- vim72.orig/src/pty.c        2008-06-21 11:52:58.000000000 -0700
    21687 +++ vim72/src/pty.c     2009-07-19 15:08:34.000000000 -0700
     22329+++ vim72/src/pty.c     2009-09-12 08:30:44.000000000 -0700
    2168822330@@ -270,9 +270,10 @@
    2168922331 }
     
    2170122343diff -Naur vim72.orig/src/quickfix.c vim72/src/quickfix.c
    2170222344--- vim72.orig/src/quickfix.c   2008-07-18 05:53:02.000000000 -0700
    21703 +++ vim72/src/quickfix.c        2009-07-19 15:18:10.000000000 -0700
     22345+++ vim72/src/quickfix.c        2009-09-12 08:40:34.000000000 -0700
    2170422346@@ -1419,6 +1419,7 @@
    2170522347     int                        opened_window = FALSE;
     
    2188822530diff -Naur vim72.orig/src/regexp.c vim72/src/regexp.c
    2188922531--- vim72.orig/src/regexp.c     2008-08-07 12:58:50.000000000 -0700
    21890 +++ vim72/src/regexp.c  2009-07-19 15:16:14.000000000 -0700
     22532+++ vim72/src/regexp.c  2009-09-12 08:38:31.000000000 -0700
    2189122533@@ -471,7 +471,7 @@
    2189222534 
     
    2194822590diff -Naur vim72.orig/src/screen.c vim72/src/screen.c
    2194922591--- vim72.orig/src/screen.c     2008-07-24 07:45:07.000000000 -0700
    21950 +++ vim72/src/screen.c  2009-07-19 15:17:49.000000000 -0700
     22592+++ vim72/src/screen.c  2009-09-12 08:41:48.000000000 -0700
    2195122593@@ -270,11 +270,10 @@
    2195222594  * Note that when also inserting/deleting lines w_redraw_top and w_redraw_bot
     
    2232122963      * Allocation of the screen buffers is done only when the size changes and
    2232222964      * when Rows and Columns have been set and we have started doing full
    22323 @@ -7440,10 +7499,17 @@
     22965@@ -7408,6 +7467,10 @@
     22966      */
     22967     FOR_ALL_TAB_WINDOWS(tp, wp)
     22968        win_free_lsize(wp);
     22969+#ifdef FEAT_AUTOCMD
     22970+    if (aucmd_win != NULL)
     22971+       win_free_lsize(aucmd_win);
     22972+#endif
     22973 
     22974     new_ScreenLines = (schar_T *)lalloc((long_u)(
     22975                              (Rows + 1) * Columns * sizeof(schar_T)), FALSE);
     22976@@ -7440,10 +7503,18 @@
    2232422977        {
    2232522978            outofmem = TRUE;
     
    2233122984     }
    2233222985+#ifdef FEAT_AUTOCMD
    22333 +    if (aucmd_win != NULL && win_alloc_lines(aucmd_win) == FAIL)
     22986+    if (aucmd_win != NULL && aucmd_win->w_lines == NULL
     22987+                                       && win_alloc_lines(aucmd_win) == FAIL)
    2233422988+       outofmem = TRUE;
    2233522989+#endif
     
    2234022994 #ifdef FEAT_MBYTE
    2234122995     for (i = 0; i < p_mco; ++i)
    22342 @@ -7628,8 +7694,17 @@
     22996@@ -7628,8 +7699,17 @@
    2234322997     --RedrawingDisabled;
    2234422998 
     
    2235923013 }
    2236023014 
    22361 @@ -8590,7 +8665,6 @@
     23015@@ -8590,7 +8670,6 @@
    2236223016  *
    2236323017  * Return OK for success, FAIL if the lines are not deleted.
     
    2236723021 screen_del_lines(off, row, line_count, end, force, wp)
    2236823022     int                off;
    22369 @@ -8598,7 +8672,7 @@
     23023@@ -8598,7 +8677,7 @@
    2237023024     int                line_count;
    2237123025     int                end;
     
    2237623030     int                j;
    2237723031     int                i;
    22378 @@ -9416,13 +9490,15 @@
     23032@@ -9416,13 +9495,15 @@
    2237923033     win_T      *wp;
    2238023034     int                always;
     
    2239323047 #ifdef FEAT_VERTSPLIT
    2239423048     int                this_ru_col;
    22395 @@ -9537,11 +9613,12 @@
     23049@@ -9537,11 +9618,12 @@
    2239623050         * Some sprintfs return the length, some return a pointer.
    2239723051         * To avoid portability problems we use strlen() here.
     
    2240823062                        (int)virtcol + 1);
    2240923063 
    22410 @@ -9551,7 +9628,7 @@
     23064@@ -9551,7 +9633,7 @@
    2241123065         * screen up on some terminals).
    2241223066         */
     
    2241723071 #ifdef FEAT_WINDOWS
    2241823072        if (wp->w_status_height == 0)   /* can't use last char of screen */
    22419 @@ -9578,7 +9655,7 @@
     23073@@ -9578,7 +9660,7 @@
    2242023074                    buffer[i++] = fillchar;
    2242123075                ++o;
     
    2242823082diff -Naur vim72.orig/src/search.c vim72/src/search.c
    2242923083--- vim72.orig/src/search.c     2008-07-13 11:18:27.000000000 -0700
    22430 +++ vim72/src/search.c  2009-07-19 15:16:33.000000000 -0700
     23084+++ vim72/src/search.c  2009-09-12 08:38:51.000000000 -0700
    2243123085@@ -345,6 +345,15 @@
    2243223086 {
     
    2256923223diff -Naur vim72.orig/src/spell.c vim72/src/spell.c
    2257023224--- vim72.orig/src/spell.c      2008-07-12 12:20:55.000000000 -0700
    22571 +++ vim72/src/spell.c   2009-07-19 15:16:33.000000000 -0700
     23225+++ vim72/src/spell.c   2009-09-12 08:41:27.000000000 -0700
    2257223226@@ -77,7 +77,7 @@
    2257323227 
     
    2342624080            totlen += len;
    2342724081        }
    23428 @@ -10343,10 +10541,9 @@
     24082@@ -10054,6 +10252,7 @@
     24083     int                limit;
     24084     int                selected = count;
     24085     int                badlen = 0;
     24086+    int                msg_scroll_save = msg_scroll;
     24087 
     24088     if (no_spell_checking(curwin))
     24089        return;
     24090@@ -10218,7 +10417,9 @@
     24091        selected = prompt_for_number(&mouse_used);
     24092        if (mouse_used)
     24093            selected -= lines_left;
     24094-       lines_left = Rows;      /* avoid more prompt */
     24095+       lines_left = Rows;              /* avoid more prompt */
     24096+       /* don't delay for 'smd' in normal_cmd() */
     24097+       msg_scroll = msg_scroll_save;
     24098     }
     24099 
     24100     if (selected > 0 && selected <= sug.su_ga.ga_len && u_save_cursor() == OK)
     24101@@ -10243,7 +10444,8 @@
     24102        }
     24103 
     24104        /* Replace the word. */
     24105-       p = alloc((unsigned)STRLEN(line) - stp->st_orglen + stp->st_wordlen + 1);
     24106+       p = alloc((unsigned)STRLEN(line) - stp->st_orglen
     24107+                                                      + stp->st_wordlen + 1);
     24108        if (p != NULL)
     24109        {
     24110            c = (int)(sug.su_badptr - line);
     24111@@ -10343,10 +10545,9 @@
    2342924112 /*
    2343024113  * ":spellrepall"
     
    2343824121     pos_T      pos = curwin->w_cursor;
    2343924122     char_u     *frompat;
    23440 @@ -11480,15 +11677,24 @@
     24123@@ -11480,15 +11681,24 @@
    2344124124                    vim_strncpy(preword + sp->ts_prewordlen,
    2344224125                            tword + sp->ts_splitoff,
     
    2347024153                    p = preword + sp->ts_prewordlen;
    2347124154                    mb_ptr_back(preword, p);
    23472 @@ -11685,10 +11891,9 @@
     24155@@ -11685,10 +11895,9 @@
    2347324156                        && (slang->sl_compsylmax < MAXWLEN
    2347424157                            || sp->ts_complen + 1 - sp->ts_compsplit
     
    2348424167                    try_compound = TRUE;
    2348524168                    compflags[sp->ts_complen] = ((unsigned)flags >> 24);
    23486 @@ -14808,7 +15013,7 @@
     24169@@ -14808,7 +15017,7 @@
    2348724170 
    2348824171        case 0:
     
    2349324176             * 1: check if for identical strings
    2349424177             */
    23495 @@ -15398,10 +15603,9 @@
     24178@@ -15398,10 +15607,9 @@
    2349624179 /*
    2349724180  * ":spellinfo"
     
    2350524188     int                lpi;
    2350624189     langp_T    *lp;
    23507 @@ -15945,11 +16149,9 @@
     24190@@ -15945,11 +16153,9 @@
    2350824191  * Returns the number of matches.  The matches are in "matchp[]", array of
    2350924192  * allocated strings.
     
    2352124204diff -Naur vim72.orig/src/structs.h vim72/src/structs.h
    2352224205--- vim72.orig/src/structs.h    2008-07-30 13:02:50.000000000 -0700
    23523 +++ vim72/src/structs.h 2009-07-19 15:18:36.000000000 -0700
     24206+++ vim72/src/structs.h 2009-09-12 08:41:43.000000000 -0700
    2352424207@@ -16,7 +16,7 @@
    2352524208  */
     
    2361224295     int                w_topfill;          /* number of filler lines above w_topline */
    2361324296     int                w_old_topfill;      /* w_topfill at last redraw */
    23614 @@ -2270,16 +2286,11 @@
     24297@@ -2270,16 +2286,13 @@
    2361524298  */
    2361624299 typedef struct
     
    2362724310-    int                save_topfill;   /* saved topfill of save_curwin */
    2362824311-# endif
     24312+    int                use_aucmd_win;  /* using aucmd_win */
    2362924313+    win_T      *save_curwin;   /* saved curwin */
    2363024314+    win_T      *new_curwin;    /* new curwin */
    2363124315+    buf_T      *new_curbuf;    /* new curbuf */
     24316+    char_u     *globaldir;     /* saved value of globaldir */
    2363224317 #endif
    2363324318 } aco_save_T;
     
    2363524320diff -Naur vim72.orig/src/syntax.c vim72/src/syntax.c
    2363624321--- vim72.orig/src/syntax.c     2008-08-08 14:47:48.000000000 -0700
    23637 +++ vim72/src/syntax.c  2009-07-19 15:16:33.000000000 -0700
     24322+++ vim72/src/syntax.c  2009-09-12 08:38:51.000000000 -0700
    2363824323@@ -3224,11 +3224,10 @@
    2363924324 /*
     
    2382324508diff -Naur vim72.orig/src/tag.c vim72/src/tag.c
    2382424509--- vim72.orig/src/tag.c        2008-07-16 14:31:30.000000000 -0700
    23825 +++ vim72/src/tag.c     2009-07-19 15:16:33.000000000 -0700
     24510+++ vim72/src/tag.c     2009-09-12 08:38:51.000000000 -0700
    2382624511@@ -100,7 +100,7 @@
    2382724512  * Tag for preview window is remembered separately, to avoid messing up the
     
    2399724682diff -Naur vim72.orig/src/term.c vim72/src/term.c
    2399824683--- vim72.orig/src/term.c       2008-07-27 04:48:06.000000000 -0700
    23999 +++ vim72/src/term.c    2009-07-19 15:17:27.000000000 -0700
     24684+++ vim72/src/term.c    2009-09-12 08:41:35.000000000 -0700
     24685@@ -2881,7 +2881,7 @@
     24686 
     24687        /* if 'Sb' and 'AB' are not defined, reset "Co" */
     24688        if (*T_CSB == NUL && *T_CAB == NUL)
     24689-           T_CCO = empty_option;
     24690+           free_one_termoption(T_CCO);
     24691 
     24692        /* Set 'weirdinvert' according to value of 't_xs' */
     24693        p_wiv = (*T_XS != NUL);
    2400024694@@ -2906,7 +2906,7 @@
    2400124695     int            i;
     
    2404424738diff -Naur vim72.orig/src/testdir/Makefile vim72/src/testdir/Makefile
    2404524739--- vim72.orig/src/testdir/Makefile     2008-06-19 13:29:46.000000000 -0700
    24046 +++ vim72/src/testdir/Makefile  2009-07-19 15:18:15.000000000 -0700
     24740+++ vim72/src/testdir/Makefile  2009-09-12 08:42:30.000000000 -0700
    2404724741@@ -4,9 +4,11 @@
    2404824742 
     
    2406524759                test59.out test60.out test61.out test62.out test63.out \
    2406624760-               test64.out test65.out
    24067 +               test64.out test65.out test66.out
     24761+               test64.out test65.out test66.out test67.out
    2406824762 
    2406924763 SCRIPTS_GUI = test16.out
     
    2410024794diff -Naur vim72.orig/src/testdir/Make_ming.mak vim72/src/testdir/Make_ming.mak
    2410124795--- vim72.orig/src/testdir/Make_ming.mak        1969-12-31 16:00:00.000000000 -0800
    24102 +++ vim72/src/testdir/Make_ming.mak     2009-07-19 15:09:28.000000000 -0700
     24796+++ vim72/src/testdir/Make_ming.mak     2009-09-12 08:31:40.000000000 -0700
    2410324797@@ -0,0 +1,91 @@
    2410424798+# Makefile to run tests for Vim, on Dos-like machines
     
    2419524889diff -Naur vim72.orig/src/testdir/test42.ok vim72/src/testdir/test42.ok
    2419624890--- vim72.orig/src/testdir/test42.ok    2008-02-20 04:27:37.000000000 -0800
    24197 +++ vim72/src/testdir/test42.ok 2009-07-19 15:09:58.000000000 -0700
     24891+++ vim72/src/testdir/test42.ok 2009-09-12 08:32:10.000000000 -0700
    2419824892@@ -20,7 +20,7 @@
    2419924893 ucs-2
     
    2420724901diff -Naur vim72.orig/src/testdir/test66.in vim72/src/testdir/test66.in
    2420824902--- vim72.orig/src/testdir/test66.in    1969-12-31 16:00:00.000000000 -0800
    24209 +++ vim72/src/testdir/test66.in 2009-07-19 15:14:34.000000000 -0700
     24903+++ vim72/src/testdir/test66.in 2009-09-12 08:36:49.000000000 -0700
    2421024904@@ -0,0 +1,25 @@
    2421124905+
     
    2423624930diff -Naur vim72.orig/src/testdir/test66.ok vim72/src/testdir/test66.ok
    2423724931--- vim72.orig/src/testdir/test66.ok    1969-12-31 16:00:00.000000000 -0800
    24238 +++ vim72/src/testdir/test66.ok 2009-07-19 15:14:34.000000000 -0700
     24932+++ vim72/src/testdir/test66.ok 2009-09-12 08:36:49.000000000 -0700
    2423924933@@ -0,0 +1,10 @@
    2424024934+    abcdefghijklmnopqrstuvwxyz
     
    2424824942+    abc                defghijklmnopqrstuvwxyz
    2424924943+    abc            defghijklmnopqrstuvwxyz
     24944diff -Naur vim72.orig/src/testdir/test67.in vim72/src/testdir/test67.in
     24945--- vim72.orig/src/testdir/test67.in    1969-12-31 16:00:00.000000000 -0800
     24946+++ vim72/src/testdir/test67.in 2009-09-12 08:42:30.000000000 -0700
     24947@@ -0,0 +1,33 @@
     24948+Test that groups and patterns are tested correctly when calling exists() for
     24949+autocommands.
     24950+
     24951+STARTTEST
     24952+:so small.vim
     24953+:let results=[]
     24954+:augroup auexists
     24955+:augroup END
     24956+:call add(results, "##BufEnter: " . exists("##BufEnter"))
     24957+:call add(results, "#BufEnter: " . exists("#BufEnter"))
     24958+:au BufEnter * let g:entered=1
     24959+:call add(results, "#BufEnter: " . exists("#BufEnter"))
     24960+:call add(results, "#auexists#BufEnter: " . exists("#auexists#BufEnter"))
     24961+:augroup auexists
     24962+:au BufEnter * let g:entered=1
     24963+:augroup END
     24964+:call add(results, "#auexists#BufEnter: " . exists("#auexists#BufEnter"))
     24965+:call add(results, "#BufEnter#*.test: " . exists("#BufEnter#*.test"))
     24966+:au BufEnter *.test let g:entered=1
     24967+:call add(results, "#BufEnter#*.test: " . exists("#BufEnter#*.test"))
     24968+:edit testfile.test
     24969+:call add(results, "#BufEnter#<buffer>: " . exists("#BufEnter#<buffer>"))
     24970+:au BufEnter <buffer> let g:entered=1
     24971+:call add(results, "#BufEnter#<buffer>: " . exists("#BufEnter#<buffer>"))
     24972+:edit testfile2.test
     24973+:call add(results, "#BufEnter#<buffer>: " . exists("#BufEnter#<buffer>"))
     24974+:e test.out
     24975+:call append(0, results)
     24976+:$d
     24977+:w
     24978+:qa!
     24979+ENDTEST
     24980+
     24981diff -Naur vim72.orig/src/testdir/test67.ok vim72/src/testdir/test67.ok
     24982--- vim72.orig/src/testdir/test67.ok    1969-12-31 16:00:00.000000000 -0800
     24983+++ vim72/src/testdir/test67.ok 2009-09-12 08:42:30.000000000 -0700
     24984@@ -0,0 +1,10 @@
     24985+##BufEnter: 1
     24986+#BufEnter: 0
     24987+#BufEnter: 1
     24988+#auexists#BufEnter: 0
     24989+#auexists#BufEnter: 1
     24990+#BufEnter#*.test: 0
     24991+#BufEnter#*.test: 1
     24992+#BufEnter#<buffer>: 0
     24993+#BufEnter#<buffer>: 1
     24994+#BufEnter#<buffer>: 0
    2425024995diff -Naur vim72.orig/src/ui.c vim72/src/ui.c
    2425124996--- vim72.orig/src/ui.c 2008-07-14 11:14:56.000000000 -0700
    24252 +++ vim72/src/ui.c      2009-07-19 15:18:26.000000000 -0700
     24997+++ vim72/src/ui.c      2009-09-12 08:42:28.000000000 -0700
    2425324998@@ -320,10 +320,9 @@
    2425424999  * The gui_set_shellsize() or mch_set_shellsize() function will try to set the
     
    2444125186 {
    2444225187     if (*sel_atom == clip_plus.sel_atom)
    24443 @@ -2344,14 +2352,67 @@
     25188@@ -2344,11 +2352,64 @@
    2444425189  * Send the current selection to the clipboard.  Do nothing for X because we
    2444525190  * will fill in the selection only when requested by another app.
     
    2445025195-    VimClipboard *cbd;
    2445125196+    VimClipboard *cbd UNUSED;
    24452  {
    24453  }
    24454  #endif
    24455  
     25197+{
     25198+}
     25199+#endif
     25200+
    2445625201+#if defined(FEAT_XCLIPBOARD) || defined(FEAT_GUI_X11) \
    2445725202+    || defined(FEAT_GUI_GTK) || defined(PROTO)
     
    2446325208+    Display            *dpy;
    2446425209+    VimClipboard       *cbd;
    24465 +{
     25210 {
    2446625211+    int                nbytes = 0;
    2446725212+    char_u     *buffer = (char_u *)XFetchBuffer(dpy, &nbytes, 0);
     
    2450525250+       }
    2450625251+    }
    24507 +}
    24508 +#endif
    24509 +
    24510  #if defined(FEAT_MOUSE) || defined(PROTO)
    24511  
    24512  /*
     25252 }
     25253 #endif
     25254 
    2451325255@@ -2898,11 +2959,10 @@
    2451425256  * Find the window at screen position "*rowp" and "*colp".  The positions are
     
    2452425266     frame_T    *fp;
    2452525267 
     25268@@ -2995,18 +3055,17 @@
     25269     int                vcol;
     25270 {
     25271     /* try to advance to the specified column */
     25272-    int                col = 0;
     25273     int                count = 0;
     25274     char_u     *ptr;
     25275+    char_u     *start;
     25276 
     25277-    ptr = ml_get_buf(wp->w_buffer, lnum, FALSE);
     25278+    start = ptr = ml_get_buf(wp->w_buffer, lnum, FALSE);
     25279     while (count <= vcol && *ptr != NUL)
     25280     {
     25281-       ++col;
     25282        count += win_lbr_chartabsize(wp, ptr, count, NULL);
     25283        mb_ptr_adv(ptr);
     25284     }
     25285-    return col;
     25286+    return (int)(ptr - start);
     25287 }
     25288 #endif
     25289 
    2452625290diff -Naur vim72.orig/src/version.c vim72/src/version.c
    2452725291--- vim72.orig/src/version.c    2008-08-09 07:24:52.000000000 -0700
    24528 +++ vim72/src/version.c 2009-07-19 15:19:00.000000000 -0700
    24529 @@ -677,9 +677,444 @@
     25292+++ vim72/src/version.c 2009-09-12 08:42:30.000000000 -0700
     25293@@ -677,9 +677,486 @@
    2453025294 static int included_patches[] =
    2453125295 {   /* Add new patch number below this line */
    2453225296 /**/
     25297+    259,
     25298+/**/
     25299+    258,
     25300+/**/
     25301+    257,
     25302+/**/
     25303+    256,
     25304+/**/
     25305+    255,
     25306+/**/
     25307+    254,
     25308+/**/
     25309+    253,
     25310+/**/
     25311+    252,
     25312+/**/
     25313+    251,
     25314+/**/
     25315+    246,
     25316+/**/
     25317+    245,
     25318+/**/
     25319+    244,
     25320+/**/
     25321+    243,
     25322+/**/
     25323+    242,
     25324+/**/
     25325+    241,
     25326+/**/
     25327+    240,
     25328+/**/
     25329+    239,
     25330+/**/
     25331+    238,
     25332+/**/
     25333+    237,
     25334+/**/
     25335+    236,
     25336+/**/
     25337+    235,
     25338+/**/
    2453325339+    234,
    2453425340+/**/
     
    2497225778 highest_patch()
    2497325779 {
    24974 @@ -786,7 +1221,7 @@
     25780@@ -786,7 +1263,7 @@
    2497525781     MSG_PUTS(_("\nRISC OS version"));
    2497625782 #endif
     
    2498125787     if (*compiled_arch != NUL)
    2498225788     {
    24983 @@ -825,6 +1260,19 @@
     25789@@ -825,6 +1302,19 @@
    2498425790        }
    2498525791     }
     
    2500325809diff -Naur vim72.orig/src/vim.h vim72/src/vim.h
    2500425810--- vim72.orig/src/vim.h        2008-08-09 09:03:38.000000000 -0700
    25005 +++ vim72/src/vim.h     2009-07-19 15:17:25.000000000 -0700
     25811+++ vim72/src/vim.h     2009-09-12 08:39:43.000000000 -0700
    2500625812@@ -341,8 +341,14 @@
    2500725813 #ifdef BACKSLASH_IN_FILENAME
     
    2510825914diff -Naur vim72.orig/src/window.c vim72/src/window.c
    2510925915--- vim72.orig/src/window.c     2008-08-06 04:00:30.000000000 -0700
    25110 +++ vim72/src/window.c  2009-07-19 15:18:10.000000000 -0700
     25916+++ vim72/src/window.c  2009-09-12 08:40:34.000000000 -0700
    2511125917@@ -11,8 +11,8 @@
    2511225918 
     
    2590326709diff -Naur vim72.orig/src/workshop.c vim72/src/workshop.c
    2590426710--- vim72.orig/src/workshop.c   2008-06-21 11:53:26.000000000 -0700
    25905 +++ vim72/src/workshop.c        2009-07-19 15:16:46.000000000 -0700
     26711+++ vim72/src/workshop.c        2009-09-12 08:39:05.000000000 -0700
    2590626712@@ -204,12 +204,11 @@
    2590726713  * Function:
     
    2604126847diff -Naur vim72.orig/src/xxd/xxd.c vim72/src/xxd/xxd.c
    2604226848--- vim72.orig/src/xxd/xxd.c    2007-11-29 12:05:16.000000000 -0800
    26043 +++ vim72/src/xxd/xxd.c 2009-07-19 15:17:54.000000000 -0700
     26849+++ vim72/src/xxd/xxd.c 2009-09-12 08:40:18.000000000 -0700
    2604426850@@ -64,6 +64,9 @@
    2604526851 # define _CRT_SECURE_NO_DEPRECATE
Note: See TracChangeset for help on using the changeset viewer.