]> granicus.if.org Git - vim/commitdiff
patch 7.4.1464 v7.4.1464
authorBram Moolenaar <Bram@vim.org>
Mon, 29 Feb 2016 21:05:26 +0000 (22:05 +0100)
committerBram Moolenaar <Bram@vim.org>
Mon, 29 Feb 2016 21:05:26 +0000 (22:05 +0100)
Problem:    When the argument of sort() is zero or empty it fails.
Solution:   Make zero work as documented. (suggested by Yasuhiro Matsumoto)

src/eval.c
src/testdir/test_sort.vim
src/version.c

index a45b71de5429b0a0d5557a338d1fd75d95133eaf..7d28e71372f3b5cb7dd9f1a1bb4da32a7a9e3288 100644 (file)
@@ -19195,11 +19195,21 @@ do_sort_uniq(typval_T *argvars, typval_T *rettv, int sort)
                    goto theend;        /* type error; errmsg already given */
                if (i == 1)
                    info.item_compare_ic = TRUE;
-               else
+               else if (argvars[1].v_type != VAR_NUMBER)
                    info.item_compare_func = get_tv_string(&argvars[1]);
+               else if (i != 0)
+               {
+                   EMSG(_(e_invarg));
+                   goto theend;
+               }
                if (info.item_compare_func != NULL)
                {
-                   if (STRCMP(info.item_compare_func, "n") == 0)
+                   if (*info.item_compare_func == NUL)
+                   {
+                       /* empty string means default sort */
+                       info.item_compare_func = NULL;
+                   }
+                   else if (STRCMP(info.item_compare_func, "n") == 0)
                    {
                        info.item_compare_func = NULL;
                        info.item_compare_numeric = TRUE;
index 2b097ceb96374cd0126fa8f03beadc09873f483c..819514a97107e4d9ddc666ba66e5b5bcce1a00d6 100644 (file)
@@ -35,3 +35,11 @@ func Test_sort_nested()
   " test ability to call sort() from a compare function
   call assert_equal([1, 3, 5], sort([3, 1, 5], 'Compare1'))
 endfunc
+
+func Test_sort_default()
+  " docs say omitted, empty or zero argument sorts on string representation.
+  call assert_equal(["2", 1, 3.3], sort([3.3, 1, "2"]))
+  call assert_equal(["2", 1, 3.3], sort([3.3, 1, "2"], ''))
+  call assert_equal(["2", 1, 3.3], sort([3.3, 1, "2"], 0))
+  call assert_fails('call sort([3.3, 1, "2"], 3)', "E474")
+endfunc
index f4ffb8fc6b077de61bdad8858f892e8641e36057..24a27cc7cd2a193af728e43bd737556c660c54b5 100644 (file)
@@ -743,6 +743,8 @@ static char *(features[]) =
 
 static int included_patches[] =
 {   /* Add new patch number below this line */
+/**/
+    1464,
 /**/
     1463,
 /**/