Author: delphij
Date: Sat Dec  7 19:02:09 2019
New Revision: 355503
URL: https://svnweb.freebsd.org/changeset/base/355503

Log:
  MFC r349549: MFV r349535: less v551.
  
  Relnotes:     yes

Modified:
  stable/12/contrib/less/LICENSE
  stable/12/contrib/less/NEWS
  stable/12/contrib/less/README
  stable/12/contrib/less/brac.c
  stable/12/contrib/less/ch.c
  stable/12/contrib/less/charset.c
  stable/12/contrib/less/charset.h
  stable/12/contrib/less/cmd.h
  stable/12/contrib/less/cmdbuf.c
  stable/12/contrib/less/command.c
  stable/12/contrib/less/compose.uni
  stable/12/contrib/less/cvt.c
  stable/12/contrib/less/decode.c
  stable/12/contrib/less/edit.c
  stable/12/contrib/less/filename.c
  stable/12/contrib/less/fmt.uni
  stable/12/contrib/less/forwback.c
  stable/12/contrib/less/funcs.h
  stable/12/contrib/less/help.c
  stable/12/contrib/less/ifile.c
  stable/12/contrib/less/input.c
  stable/12/contrib/less/jump.c
  stable/12/contrib/less/less.h
  stable/12/contrib/less/less.hlp
  stable/12/contrib/less/less.nro
  stable/12/contrib/less/lessecho.c
  stable/12/contrib/less/lessecho.nro
  stable/12/contrib/less/lesskey.c
  stable/12/contrib/less/lesskey.h
  stable/12/contrib/less/lesskey.nro
  stable/12/contrib/less/lglob.h
  stable/12/contrib/less/line.c
  stable/12/contrib/less/linenum.c
  stable/12/contrib/less/lsystem.c
  stable/12/contrib/less/main.c
  stable/12/contrib/less/mark.c
  stable/12/contrib/less/mkutable
  stable/12/contrib/less/optfunc.c
  stable/12/contrib/less/option.c
  stable/12/contrib/less/option.h
  stable/12/contrib/less/opttbl.c
  stable/12/contrib/less/os.c
  stable/12/contrib/less/output.c
  stable/12/contrib/less/pattern.c
  stable/12/contrib/less/pattern.h
  stable/12/contrib/less/pckeys.h
  stable/12/contrib/less/position.c
  stable/12/contrib/less/position.h
  stable/12/contrib/less/prompt.c
  stable/12/contrib/less/screen.c
  stable/12/contrib/less/scrsize.c
  stable/12/contrib/less/search.c
  stable/12/contrib/less/signal.c
  stable/12/contrib/less/tags.c
  stable/12/contrib/less/ttyin.c
  stable/12/contrib/less/ubin.uni
  stable/12/contrib/less/version.c
  stable/12/contrib/less/wide.uni
  stable/12/usr.bin/less/defines.h
Directory Properties:
  stable/12/   (props changed)

Modified: stable/12/contrib/less/LICENSE
==============================================================================
--- stable/12/contrib/less/LICENSE      Sat Dec  7 18:40:46 2019        
(r355502)
+++ stable/12/contrib/less/LICENSE      Sat Dec  7 19:02:09 2019        
(r355503)
@@ -2,7 +2,7 @@
                           ------------
 
 Less
-Copyright (C) 1984-2016  Mark Nudelman
+Copyright (C) 1984-2018  Mark Nudelman
 
 Redistribution and use in source and binary forms, with or without
 modification, are permitted provided that the following conditions

Modified: stable/12/contrib/less/NEWS
==============================================================================
--- stable/12/contrib/less/NEWS Sat Dec  7 18:40:46 2019        (r355502)
+++ stable/12/contrib/less/NEWS Sat Dec  7 19:02:09 2019        (r355503)
@@ -11,6 +11,38 @@
 
 ======================================================================
 
+       Major changes between "less" versions 530 and 551
+
+* Add --mouse option.
+
+* Add --wheel-lines option.
+
+* Add --no-histdups option.
+
+* Add --save-marks option.
+
+* Support PCRE2 regular expression library.
+
+* Redraw screen on SIGWINCH even if screen size doesn't change.
+
+* Shell-escape filenames in history so they can be used again.
+
+* Ring bell if user enters invalid long option name.
+
+* Use PCRE_UTF8 flag for pcre regular expressions when in UTF-8 mode.
+
+* Windows: use wide-char string to set console title.
+
+* Don't count lines in initial screen if using -X with -F.
+
+* Support mingw build system.
+
+* Fix bug in v command on empty file.
+
+* Fix bug in v command when filename contains shell metacharacters.
+
+======================================================================
+
        Major changes between "less" versions 487 and 530
 
 * Don't output terminal init sequence if using -F and file fits on one screen.

Modified: stable/12/contrib/less/README
==============================================================================
--- stable/12/contrib/less/README       Sat Dec  7 18:40:46 2019        
(r355502)
+++ stable/12/contrib/less/README       Sat Dec  7 19:02:09 2019        
(r355503)
@@ -7,9 +7,9 @@
 **************************************************************************
 **************************************************************************
 
-                            Less, version 530
+                            Less, version 551
 
-    This is the distribution of less, version 530, released 05 Dec 2017.
+    This is the distribution of less, version 551, released 11 Jun 2019.
     This program is part of the GNU project (http://www.gnu.org).
 
     This program is free software.  You may redistribute it and/or
@@ -56,6 +56,7 @@ INSTALLATION (Unix systems only):
      finds a regular expression library automatically.  Other values are:
         gnu            Use the GNU regex library.
         pcre           Use the PCRE library.
+        pcre2          Use the PCRE2 library.
         posix          Use the POSIX-compatible regcomp.
         regcmp         Use the regcmp library.
         re_comp        Use the re_comp library.
@@ -63,6 +64,7 @@ INSTALLATION (Unix systems only):
         regcomp-local  Use Henry Spencer's V8-compatible regcomp
                        (source is supplied with less).
         none           No regular expressions, only simple string matching.
+
    --with-secure
      Builds a "secure" version of less, with some features disabled
      to prevent users from viewing other files, accessing shell

Modified: stable/12/contrib/less/brac.c
==============================================================================
--- stable/12/contrib/less/brac.c       Sat Dec  7 18:40:46 2019        
(r355502)
+++ stable/12/contrib/less/brac.c       Sat Dec  7 19:02:09 2019        
(r355503)
@@ -1,5 +1,5 @@
 /*
- * Copyright (C) 1984-2017  Mark Nudelman
+ * Copyright (C) 1984-2019  Mark Nudelman
  *
  * You may distribute under the terms of either the GNU General Public
  * License or the Less License, as specified in the README file.

Modified: stable/12/contrib/less/ch.c
==============================================================================
--- stable/12/contrib/less/ch.c Sat Dec  7 18:40:46 2019        (r355502)
+++ stable/12/contrib/less/ch.c Sat Dec  7 19:02:09 2019        (r355503)
@@ -1,5 +1,5 @@
 /*
- * Copyright (C) 1984-2017  Mark Nudelman
+ * Copyright (C) 1984-2019  Mark Nudelman
  *
  * You may distribute under the terms of either the GNU General Public
  * License or the Less License, as specified in the README file.
@@ -144,7 +144,7 @@ static int ch_addbuf();
  * Get the character pointed to by the read pointer.
  */
        int
-ch_get()
+ch_get(VOID_PARAM)
 {
        struct buf *bp;
        struct bufnode *bn;
@@ -392,7 +392,7 @@ ch_ungetchar(c)
  * If we haven't read all of standard input into it, do that now.
  */
        public void
-end_logfile()
+end_logfile(VOID_PARAM)
 {
        static int tried = FALSE;
 
@@ -417,7 +417,7 @@ end_logfile()
  * Write all the existing buffered data to the log file.
  */
        public void
-sync_logfile()
+sync_logfile(VOID_PARAM)
 {
        struct buf *bp;
        struct bufnode *bn;
@@ -515,7 +515,7 @@ ch_seek(pos)
  * Seek to the end of the file.
  */
        public int
-ch_end_seek()
+ch_end_seek(VOID_PARAM)
 {
        POSITION len;
 
@@ -542,7 +542,7 @@ ch_end_seek()
  * Seek to the last position in the file that is currently buffered.
  */
        public int
-ch_end_buffer_seek()
+ch_end_buffer_seek(VOID_PARAM)
 {
        struct buf *bp;
        struct bufnode *bn;
@@ -570,7 +570,7 @@ ch_end_buffer_seek()
  * beginning of the pipe is no longer buffered.
  */
        public int
-ch_beg_seek()
+ch_beg_seek(VOID_PARAM)
 {
        struct bufnode *bn;
        struct bufnode *firstbn;
@@ -602,7 +602,7 @@ ch_beg_seek()
  * Return the length of the file, if known.
  */
        public POSITION
-ch_length()
+ch_length(VOID_PARAM)
 {
        if (thisfile == NULL)
                return (NULL_POSITION);
@@ -619,7 +619,7 @@ ch_length()
  * Return the current position in the file.
  */
        public POSITION
-ch_tell()
+ch_tell(VOID_PARAM)
 {
        if (thisfile == NULL)
                return (NULL_POSITION);
@@ -630,7 +630,7 @@ ch_tell()
  * Get the current char and post-increment the read pointer.
  */
        public int
-ch_forw_get()
+ch_forw_get(VOID_PARAM)
 {
        int c;
 
@@ -653,7 +653,7 @@ ch_forw_get()
  * Pre-decrement the read pointer and get the new current char.
  */
        public int
-ch_back_get()
+ch_back_get(VOID_PARAM)
 {
        if (thisfile == NULL)
                return (EOI);
@@ -693,7 +693,7 @@ ch_setbufspace(bufspace)
  * Flush (discard) any saved file state, including buffer contents.
  */
        public void
-ch_flush()
+ch_flush(VOID_PARAM)
 {
        struct bufnode *bn;
 
@@ -760,7 +760,7 @@ ch_flush()
  * The buffer is added to the tail of the buffer chain.
  */
        static int
-ch_addbuf()
+ch_addbuf(VOID_PARAM)
 {
        struct buf *bp;
        struct bufnode *bn;
@@ -785,7 +785,7 @@ ch_addbuf()
  *
  */
        static void
-init_hashtbl()
+init_hashtbl(VOID_PARAM)
 {
        int h;
 
@@ -800,7 +800,7 @@ init_hashtbl()
  * Delete all buffers for this file.
  */
        static void
-ch_delbufs()
+ch_delbufs(VOID_PARAM)
 {
        struct bufnode *bn;
 
@@ -840,7 +840,7 @@ seekable(f)
  * This is used after an ignore_eof read, during which the EOF may change.
  */
        public void
-ch_set_eof()
+ch_set_eof(VOID_PARAM)
 {
        ch_fsize = ch_fpos;
 }
@@ -890,7 +890,7 @@ ch_init(f, flags)
  * Close a filestate.
  */
        public void
-ch_close()
+ch_close(VOID_PARAM)
 {
        int keepstate = FALSE;
 
@@ -933,7 +933,7 @@ ch_close()
  * Return ch_flags for the current file.
  */
        public int
-ch_getflags()
+ch_getflags(VOID_PARAM)
 {
        if (thisfile == NULL)
                return (0);

Modified: stable/12/contrib/less/charset.c
==============================================================================
--- stable/12/contrib/less/charset.c    Sat Dec  7 18:40:46 2019        
(r355502)
+++ stable/12/contrib/less/charset.c    Sat Dec  7 19:02:09 2019        
(r355503)
@@ -1,5 +1,5 @@
 /*
- * Copyright (C) 1984-2017  Mark Nudelman
+ * Copyright (C) 1984-2019  Mark Nudelman
  *
  * You may distribute under the terms of either the GNU General Public
  * License or the Less License, as specified in the README file.
@@ -245,7 +245,7 @@ icharset(name, no_error)
  * Define a charset, given a locale name.
  */
        static void
-ilocale()
+ilocale(VOID_PARAM)
 {
        int c;
 
@@ -315,7 +315,7 @@ setfmt(s, fmtvarptr, attrptr, default_fmt)
  *
  */
        static void
-set_charset()
+set_charset(VOID_PARAM)
 {
        char *s;
 
@@ -338,7 +338,7 @@ set_charset()
         * LESSCHARSET is not defined: try LESSCHARDEF.
         */
        s = lgetenv("LESSCHARDEF");
-       if (s != NULL && *s != '\0')
+       if (!isnullenv(s))
        {
                ichardef(s);
                return;
@@ -395,7 +395,7 @@ set_charset()
  * Initialize charset data structures.
  */
        public void
-init_charset()
+init_charset(VOID_PARAM)
 {
        char *s;
 

Modified: stable/12/contrib/less/charset.h
==============================================================================
--- stable/12/contrib/less/charset.h    Sat Dec  7 18:40:46 2019        
(r355502)
+++ stable/12/contrib/less/charset.h    Sat Dec  7 19:02:09 2019        
(r355503)
@@ -1,5 +1,5 @@
 /*
- * Copyright (C) 1984-2017  Mark Nudelman
+ * Copyright (C) 1984-2019  Mark Nudelman
  *
  * You may distribute under the terms of either the GNU General Public
  * License or the Less License, as specified in the README file.

Modified: stable/12/contrib/less/cmd.h
==============================================================================
--- stable/12/contrib/less/cmd.h        Sat Dec  7 18:40:46 2019        
(r355502)
+++ stable/12/contrib/less/cmd.h        Sat Dec  7 19:02:09 2019        
(r355503)
@@ -1,5 +1,5 @@
 /*
- * Copyright (C) 1984-2017  Mark Nudelman
+ * Copyright (C) 1984-2019  Mark Nudelman
  *
  * You may distribute under the terms of either the GNU General Public
  * License or the Less License, as specified in the README file.
@@ -71,6 +71,13 @@
 #define A_RRSHIFT              59
 #define A_CLRMARK              62
 #define A_SETMARKBOT           63
+#define A_X11MOUSE_IN          64
+#define A_X11MOUSE_IGNORE      65
+#define A_F_MOUSE              66
+#define A_B_MOUSE              67
+/* Note "X116" refers to extended (1006) X11 mouse reporting. */
+#define A_X116MOUSE_IN         68
+#define A_X116MOUSE_IGNORE     69
 
 #define A_INVALID              100
 #define A_NOACTION             101

Modified: stable/12/contrib/less/cmdbuf.c
==============================================================================
--- stable/12/contrib/less/cmdbuf.c     Sat Dec  7 18:40:46 2019        
(r355502)
+++ stable/12/contrib/less/cmdbuf.c     Sat Dec  7 19:02:09 2019        
(r355503)
@@ -1,5 +1,5 @@
 /*
- * Copyright (C) 1984-2017  Mark Nudelman
+ * Copyright (C) 1984-2019  Mark Nudelman
  *
  * You may distribute under the terms of either the GNU General Public
  * License or the Less License, as specified in the README file.
@@ -22,6 +22,8 @@
 
 extern int sc_width;
 extern int utf_mode;
+extern int no_hist_dups;
+extern int marks_modified;
 
 static char cmdbuf[CMDBUF_SIZE]; /* Buffer for holding a multi-char command */
 static int cmd_col;            /* Current column of the cursor */
@@ -58,6 +60,7 @@ public char closequote = '"';
 #define HISTFILE_FIRST_LINE      ".less-history-file:"
 #define HISTFILE_SEARCH_SECTION  ".search"
 #define HISTFILE_SHELL_SECTION   ".shell"
+#define HISTFILE_MARK_SECTION    ".mark"
 
 /*
  * A mlist structure represents a command history.
@@ -114,7 +117,7 @@ static int cmd_mbc_buf_index;
  * Reset command buffer (to empty).
  */
        public void
-cmd_reset()
+cmd_reset(VOID_PARAM)
 {
        cp = cmdbuf;
        *cp = '\0';
@@ -129,7 +132,7 @@ cmd_reset()
  * Clear command line.
  */
        public void
-clear_cmd()
+clear_cmd(VOID_PARAM)
 {
        cmd_col = prompt_col = 0;
        cmd_mbc_buf_len = 0;
@@ -169,7 +172,7 @@ cmd_putstr(s)
  * How many characters are in the command buffer?
  */
        public int
-len_cmdbuf()
+len_cmdbuf(VOID_PARAM)
 {
        char *s = cmdbuf;
        char *endline = s + strlen(s);
@@ -302,7 +305,7 @@ cmd_repaint(old_cp)
  * and set cp to the corresponding char in cmdbuf.
  */
        static void
-cmd_home()
+cmd_home(VOID_PARAM)
 {
        while (cmd_col > prompt_col)
        {
@@ -321,7 +324,7 @@ cmd_home()
  * Shift the cmdbuf display left a half-screen.
  */
        static void
-cmd_lshift()
+cmd_lshift(VOID_PARAM)
 {
        char *s;
        char *save_cp;
@@ -359,7 +362,7 @@ cmd_lshift()
  * Shift the cmdbuf display right a half-screen.
  */
        static void
-cmd_rshift()
+cmd_rshift(VOID_PARAM)
 {
        char *s;
        char *save_cp;
@@ -389,7 +392,7 @@ cmd_rshift()
  * Move cursor right one character.
  */
        static int
-cmd_right()
+cmd_right(VOID_PARAM)
 {
        char *pr;
        char *ncp;
@@ -424,7 +427,7 @@ cmd_right()
  * Move cursor left one character.
  */
        static int
-cmd_left()
+cmd_left(VOID_PARAM)
 {
        char *ncp;
        int width = 0;
@@ -492,7 +495,7 @@ cmd_ichar(cs, clen)
  * Delete the char to the left of the cursor.
  */
        static int
-cmd_erase()
+cmd_erase(VOID_PARAM)
 {
        char *s;
        int clen;
@@ -541,7 +544,7 @@ cmd_erase()
  * Delete the char under the cursor.
  */
        static int
-cmd_delete()
+cmd_delete(VOID_PARAM)
 {
        if (*cp == '\0')
        {
@@ -560,7 +563,7 @@ cmd_delete()
  * Delete the "word" to the left of the cursor.
  */
        static int
-cmd_werase()
+cmd_werase(VOID_PARAM)
 {
        if (cp > cmdbuf && cp[-1] == ' ')
        {
@@ -586,7 +589,7 @@ cmd_werase()
  * Delete the "word" under the cursor.
  */
        static int
-cmd_wdelete()
+cmd_wdelete(VOID_PARAM)
 {
        if (*cp == ' ')
        {
@@ -612,7 +615,7 @@ cmd_wdelete()
  * Delete all chars in the command buffer.
  */
        static int
-cmd_kill()
+cmd_kill(VOID_PARAM)
 {
        if (cmdbuf[0] == '\0')
        {
@@ -702,6 +705,7 @@ cmd_updown(action)
                        s = ml->string;
                        if (s == NULL)
                                s = "";
+                       cmd_offset = 0;
                        cmd_home();
                        clear_eol();
                        strcpy(cmdbuf, s);
@@ -719,6 +723,31 @@ cmd_updown(action)
 #endif
 
 /*
+ *
+ */
+       static void
+ml_link(mlist, ml)
+       struct mlist *mlist;
+       struct mlist *ml;
+{
+       ml->next = mlist;
+       ml->prev = mlist->prev;
+       mlist->prev->next = ml;
+       mlist->prev = ml;
+}
+
+/*
+ *
+ */
+       static void
+ml_unlink(ml)
+       struct mlist *ml;
+{
+       ml->prev->next = ml->next;
+       ml->next->prev = ml->prev;
+}
+
+/*
  * Add a string to an mlist.
  */
        public void
@@ -736,6 +765,21 @@ cmd_addhist(mlist, cmd, modified)
        if (strlen(cmd) == 0)
                return;
 
+       if (no_hist_dups)
+       {
+               struct mlist *next = NULL;
+               for (ml = mlist->next;  ml->string != NULL;  ml = next)
+               {
+                       next = ml->next;
+                       if (strcmp(ml->string, cmd) == 0)
+                       {
+                               ml_unlink(ml);
+                               free(ml->string);
+                               free(ml);
+                       }
+               }
+       }
+
        /*
         * Save the command unless it's a duplicate of the
         * last command in the history.
@@ -750,10 +794,7 @@ cmd_addhist(mlist, cmd, modified)
                ml = (struct mlist *) ecalloc(1, sizeof(struct mlist));
                ml->string = save(cmd);
                ml->modified = modified;
-               ml->next = mlist;
-               ml->prev = mlist->prev;
-               mlist->prev->next = ml;
-               mlist->prev = ml;
+               ml_link(mlist, ml);
        }
        /*
         * Point to the cmd just after the just-accepted command.
@@ -768,13 +809,13 @@ cmd_addhist(mlist, cmd, modified)
  * Add it to the currently selected history list.
  */
        public void
-cmd_accept()
+cmd_accept(VOID_PARAM)
 {
 #if CMD_HISTORY
        /*
         * Nothing to do if there is no currently selected history list.
         */
-       if (curr_mlist == NULL)
+       if (curr_mlist == NULL || curr_mlist == ml_examine)
                return;
        cmd_addhist(curr_mlist, cmdbuf, 1);
        curr_mlist->modified = 1;
@@ -799,7 +840,7 @@ cmd_edit(c)
 #if TAB_COMPLETE_FILENAME
 #define        not_in_completion()     in_completion = 0
 #else
-#define        not_in_completion()
+#define        not_in_completion(VOID_PARAM)
 #endif
        
        /*
@@ -934,7 +975,7 @@ cmd_istr(str)
  * cursor at the end of the word.
  */
        static char *
-delimit_word()
+delimit_word(VOID_PARAM)
 {
        char *word;
 #if SPACES_IN_FILENAMES
@@ -1021,7 +1062,7 @@ delimit_word()
  * which start with that word, and set tk_text to that list.
  */
        static void
-init_compl()
+init_compl(VOID_PARAM)
 {
        char *word;
        char c;
@@ -1148,9 +1189,9 @@ cmd_complete(action)
                tk_trial = next_compl(action, tk_trial);
        }
        
-       /*
-        * Remove the original word, or the previous trial completion.
-        */
+       /*
+        * Remove the original word, or the previous trial completion.
+        */
        while (cp > tk_ipoint)
                (void) cmd_erase();
        
@@ -1323,7 +1364,7 @@ cmd_int(frac)
  * Return a pointer to the command buffer.
  */
        public char *
-get_cmdbuf()
+get_cmdbuf(VOID_PARAM)
 {
        return (cmdbuf);
 }
@@ -1333,7 +1374,7 @@ get_cmdbuf()
  * Return the last (most recent) string in the current command history.
  */
        public char *
-cmd_lastpattern()
+cmd_lastpattern(VOID_PARAM)
 {
        if (curr_mlist == NULL)
                return (NULL);
@@ -1358,7 +1399,7 @@ mlist_size(ml)
  * Get the name of the history file.
  */
        static char *
-histfile_name()
+histfile_name(VOID_PARAM)
 {
        char *home;
        char *name;
@@ -1366,7 +1407,7 @@ histfile_name()
        
        /* See if filename is explicitly specified by $LESSHISTFILE. */
        name = lgetenv("LESSHISTFILE");
-       if (name != NULL && *name != '\0')
+       if (!isnullenv(name))
        {
                if (strcmp(name, "-") == 0 || strcmp(name, "/dev/null") == 0)
                        /* $LESSHISTFILE == "-" means don't use a history file. 
*/
@@ -1380,11 +1421,11 @@ histfile_name()
 
        /* Otherwise, file is in $HOME. */
        home = lgetenv("HOME");
-       if (home == NULL || *home == '\0')
+       if (isnullenv(home))
        {
 #if OS2
                home = lgetenv("INIT");
-               if (home == NULL || *home == '\0')
+               if (isnullenv(home))
 #endif
                        return (NULL);
        }
@@ -1447,6 +1488,9 @@ read_cmdhist2(action, uparam, skip_search, skip_shell)
                        ml = NULL;
                        skip = NULL;
 #endif
+               } else if (strcmp(line, HISTFILE_MARK_SECTION) == 0)
+               {
+                       ml = NULL;
                } else if (*line == '"')
                {
                        if (ml != NULL)
@@ -1456,6 +1500,9 @@ read_cmdhist2(action, uparam, skip_search, skip_shell)
                                else
                                        (*action)(uparam, ml, line+1);
                        }
+               } else if (*line == 'm')
+               {
+                       (*action)(uparam, NULL, line);
                }
        }
        fclose(f);
@@ -1475,9 +1522,10 @@ read_cmdhist(action, uparam, skip_search, skip_shell)
        static void
 addhist_init(void *uparam, struct mlist *ml, char *string)
 {
-       if (ml == NULL || string == NULL)
-               return;
-       cmd_addhist(ml, string, 0);
+       if (ml != NULL)
+               cmd_addhist(ml, string, 0);
+       else if (string != NULL)
+               restore_mark(string);
 }
 #endif /* CMD_HISTORY */
 
@@ -1485,7 +1533,7 @@ addhist_init(void *uparam, struct mlist *ml, char *str
  * Initialize history from a .lesshist file.
  */
        public void
-init_cmdhist()
+init_cmdhist(VOID_PARAM)
 {
 #if CMD_HISTORY
        read_cmdhist(&addhist_init, NULL, 0, 0);
@@ -1558,7 +1606,7 @@ copy_hist(void *uparam, struct mlist *ml, char *string
 {
        struct save_ctx *ctx = (struct save_ctx *) uparam;
 
-       if (ml != ctx->mlist) {
+       if (ml != NULL && ml != ctx->mlist) {
                /* We're changing mlists. */
                if (ctx->mlist)
                        /* Append any new entries to the end of the current 
mlist. */
@@ -1567,13 +1615,9 @@ copy_hist(void *uparam, struct mlist *ml, char *string
                ctx->mlist = ml;
                write_mlist_header(ctx->mlist, ctx->fout);
        }
-       if (string != NULL)
+
+       if (string == NULL) /* End of file */
        {
-               /* Copy the entry. */
-               fprintf(ctx->fout, "\"%s\n", string);
-       }
-       if (ml == NULL) /* End of file */
-       {
                /* Write any sections that were not in the original file. */
                if (mlist_search.modified)
                {
@@ -1587,7 +1631,12 @@ copy_hist(void *uparam, struct mlist *ml, char *string
                        write_mlist(&mlist_shell, ctx->fout);
                }
 #endif
+       } else if (ml != NULL)
+       {
+               /* Copy mlist entry. */
+               fprintf(ctx->fout, "\"%s\n", string);
        }
+       /* Skip marks */
 }
 #endif /* CMD_HISTORY */
 
@@ -1616,7 +1665,7 @@ make_file_private(f)
  * Does the history file need to be updated?
  */
        static int
-histfile_modified()
+histfile_modified(VOID_PARAM)
 {
        if (mlist_search.modified)
                return 1;
@@ -1624,6 +1673,10 @@ histfile_modified()
        if (mlist_shell.modified)
                return 1;
 #endif
+#if CMD_HISTORY
+       if (marks_modified)
+               return 1;
+#endif
        return 0;
 }
 
@@ -1631,7 +1684,7 @@ histfile_modified()
  * Update the .lesshst file.
  */
        public void
-save_cmdhist()
+save_cmdhist(VOID_PARAM)
 {
 #if CMD_HISTORY
        char *histname;
@@ -1665,7 +1718,8 @@ save_cmdhist()
                fprintf(fout, "%s\n", HISTFILE_FIRST_LINE);
                ctx.fout = fout;
                ctx.mlist = NULL;
-               read_cmdhist(copy_hist, &ctx, skip_search, skip_shell);
+               read_cmdhist(&copy_hist, &ctx, skip_search, skip_shell);
+               save_marks(fout, HISTFILE_MARK_SECTION);
                fclose(fout);
 #if MSDOS_COMPILER==WIN32C
                /*

Modified: stable/12/contrib/less/command.c
==============================================================================
--- stable/12/contrib/less/command.c    Sat Dec  7 18:40:46 2019        
(r355502)
+++ stable/12/contrib/less/command.c    Sat Dec  7 19:02:09 2019        
(r355503)
@@ -1,6 +1,6 @@
 /* $FreeBSD$ */
 /*
- * Copyright (C) 1984-2017  Mark Nudelman
+ * Copyright (C) 1984-2019  Mark Nudelman
  *
  * You may distribute under the terms of either the GNU General Public
  * License or the Less License, as specified in the README file.
@@ -49,6 +49,7 @@ extern struct scrpos initial_scrpos;
 extern IFILE curr_ifile;
 extern void *ml_search;
 extern void *ml_examine;
+extern int wheel_lines;
 #if SHELL_ESCAPE || PIPEC
 extern void *ml_shell;
 #endif
@@ -60,6 +61,9 @@ extern int screen_trashed;    /* The screen has been over
 extern int shift_count;
 extern int oldbot;
 extern int forw_prompt;
+#if MSDOS_COMPILER==WIN32C
+extern int utf_mode;
+#endif
 
 #if SHELL_ESCAPE
 static char *shellcmd = NULL;  /* For holding last shell command for "!!" */
@@ -94,14 +98,39 @@ static void multi_search();
  * updating the screen.
  */
        static void
-cmd_exec()
+cmd_exec(VOID_PARAM)
 {
-    clear_attn();
+       clear_attn();
        clear_bot();
        flush();
 }
 
 /*
+ * Indicate we are reading a multi-character command.
+ */
+       static void
+set_mca(action)
+       int action;
+{
+       mca = action;
+       deinit_mouse(); /* we don't want mouse events while entering a cmd */
+       clear_bot();
+       clear_cmd();
+}
+
+/*
+ * Indicate we are not reading a multi-character command.
+ */
+       static void
+clear_mca(VOID_PARAM)
+{
+       if (mca == 0)
+               return;
+       mca = 0;
+       init_mouse();
+}
+
+/*
  * Set up the display to start a new multi-character command.
  */
        static void
@@ -111,15 +140,13 @@ start_mca(action, prompt, mlist, cmdflags)
        void *mlist;
        int cmdflags;
 {
-       mca = action;
-       clear_bot();
-       clear_cmd();
+       set_mca(action);
        cmd_putstr(prompt);
        set_mlist(mlist, cmdflags);
 }
 
        public int
-in_mca()
+in_mca(VOID_PARAM)
 {
        return (mca != 0 && mca != A_PREFIX);
 }
@@ -128,21 +155,18 @@ in_mca()
  * Set up the display to start a new search command.
  */
        static void
-mca_search()
+mca_search(VOID_PARAM)
 {
 #if HILITE_SEARCH
        if (search_type & SRCH_FILTER)
-               mca = A_FILTER;
+               set_mca(A_FILTER);
        else 
 #endif
        if (search_type & SRCH_FORW)
-               mca = A_F_SEARCH;
+               set_mca(A_F_SEARCH);
        else
-               mca = A_B_SEARCH;
+               set_mca(A_B_SEARCH);
 
-       clear_bot();
-       clear_cmd();
-
        if (search_type & SRCH_NO_MATCH)
                cmd_putstr("Non-match ");
        if (search_type & SRCH_FIRST_FILE)
@@ -171,7 +195,7 @@ mca_search()
  * Set up the display to start a new toggle-option command.
  */
        static void
-mca_opt_toggle()
+mca_opt_toggle(VOID_PARAM)
 {
        int no_prompt;
        int flag;
@@ -181,9 +205,7 @@ mca_opt_toggle()
        flag = (optflag & ~OPT_NO_PROMPT);
        dash = (flag == OPT_NO_TOGGLE) ? "_" : "-";
 
-       mca = A_OPT_TOGGLE;
-       clear_bot();
-       clear_cmd();
+       set_mca(A_OPT_TOGGLE);
        cmd_putstr(dash);
        if (optgetname)
                cmd_putstr(dash);
@@ -206,7 +228,7 @@ mca_opt_toggle()
  * Execute a multicharacter command.
  */
        static void
-exec_mca()
+exec_mca(VOID_PARAM)
 {
        char *cbuf;
 
@@ -373,6 +395,7 @@ mca_opt_nonfirst_char(c)
 {
        char *p;
        char *oname;
+       int err;
 
        if (curropt != NULL)
        {
@@ -392,7 +415,8 @@ mca_opt_nonfirst_char(c)
                return (MCA_DONE);
        p = get_cmdbuf();
        opt_lower = ASCII_IS_LOWER(p[0]);
-       curropt = findopt_name(&p, &oname, NULL);
+       err = 0;
+       curropt = findopt_name(&p, &oname, &err);
        if (curropt != NULL)
        {
                /*
@@ -410,6 +434,9 @@ mca_opt_nonfirst_char(c)
                        if (cmd_char(c) != CC_OK)
                                return (MCA_DONE);
                }
+       } else if (err != OPT_AMBIG)
+       {
+               bell();
        }
        return (MCA_MORE);
 }
@@ -461,6 +488,7 @@ mca_opt_char(c)
                        error("There is no %s option", &parg);
                        return (MCA_DONE);
                }
+               opt_lower = ASCII_IS_LOWER(c);
        }
        /*
         * If the option which was entered does not take a 
@@ -470,7 +498,7 @@ mca_opt_char(c)
        if ((optflag & ~OPT_NO_PROMPT) != OPT_TOGGLE ||
            !opt_has_param(curropt))
        {
-               toggle_option(curropt, ASCII_IS_LOWER(c), "", optflag);
+               toggle_option(curropt, opt_lower, "", optflag);
                return (MCA_DONE);
        }
        /*
@@ -577,7 +605,7 @@ mca_char(c)
                         * as a normal command character.
                         */
                        number = cmd_int(&fraction);
-                       mca = 0;
+                       clear_mca();
                        cmd_accept();
                        return (NO_MCA);
                }
@@ -644,7 +672,7 @@ mca_char(c)
  * Discard any buffered file data.
  */
        static void
-clear_buffers()
+clear_buffers(VOID_PARAM)
 {
        if (!(ch_getflags() & CH_CANSEEK))
                return;
@@ -659,7 +687,7 @@ clear_buffers()
  * Make sure the screen is displayed.
  */
        static void
-make_display()
+make_display(VOID_PARAM)
 {
        /*
         * If nothing is displayed yet, display starting from initial_scrpos.
@@ -699,7 +727,7 @@ make_display()
  * Display the appropriate prompt.
  */
        static void
-prompt()
+prompt(VOID_PARAM)
 {
        constant char *p;
 
@@ -739,8 +767,14 @@ prompt()
         * In Win32, display the file name in the window title.
         */

*** DIFF OUTPUT TRUNCATED AT 1000 LINES ***
_______________________________________________
svn-src-all@freebsd.org mailing list
https://lists.freebsd.org/mailman/listinfo/svn-src-all
To unsubscribe, send any mail to "svn-src-all-unsubscr...@freebsd.org"

Reply via email to