From: Bram Moolenaar Date: Tue, 27 Jan 2015 14:58:40 +0000 (+0100) Subject: updated for version 7.4.602 X-Git-Tag: v7.4.602 X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=18400e6430755c97eb7e31525ab4744502603731;p=vim updated for version 7.4.602 Problem: ":set" does not accept hex numbers as documented. Solution: Use vim_str2nr(). (ZyX) --- diff --git a/runtime/doc/options.txt b/runtime/doc/options.txt index d62bb4e8e..918e1b7e4 100644 --- a/runtime/doc/options.txt +++ b/runtime/doc/options.txt @@ -59,9 +59,7 @@ achieve special effects. These options come in three forms: :se[t] {option}:{value} Set string or number option to {value}. For numeric options the value can be given in decimal, - hex (preceded with 0x) or octal (preceded with '0') - (hex and octal are only available for machines which - have the strtol() function). + hex (preceded with 0x) or octal (preceded with '0'). The old value can be inserted by typing 'wildchar' (by default this is a or CTRL-E if 'compatible' is set). See |cmdline-completion|. diff --git a/src/option.c b/src/option.c index 3195fa8d9..e5887366b 100644 --- a/src/option.c +++ b/src/option.c @@ -4540,21 +4540,11 @@ do_set(arg, opt_flags) goto skip; } } - /* allow negative numbers (for 'undolevels') */ else if (*arg == '-' || VIM_ISDIGIT(*arg)) { - i = 0; - if (*arg == '-') - i = 1; -#ifdef HAVE_STRTOL - value = strtol((char *)arg, NULL, 0); - if (arg[i] == '0' && TOLOWER_ASC(arg[i + 1]) == 'x') - i += 2; -#else - value = atol((char *)arg); -#endif - while (VIM_ISDIGIT(arg[i])) - ++i; + /* Allow negative (for 'undolevels'), octal and + * hex numbers. */ + vim_str2nr(arg, NULL, &i, TRUE, TRUE, &value, NULL); if (arg[i] != NUL && !vim_iswhite(arg[i])) { errmsg = e_invarg; diff --git a/src/version.c b/src/version.c index 20291a789..2b4b680fb 100644 --- a/src/version.c +++ b/src/version.c @@ -741,6 +741,8 @@ static char *(features[]) = static int included_patches[] = { /* Add new patch number below this line */ +/**/ + 602, /**/ 601, /**/