patch 9.1.0560: bindtextdomain() does not indicate an error

Problem:  bindtextdomain() does not indicate an error
          (after v9.1.509)
Solution: return false on failure (OOM).
          (Chris van Willegen)

closes: #15116

Signed-off-by: Christ van Willegen <cvwillegen@gmail.com>
Signed-off-by: Christian Brabandt <cb@256bit.org>
This commit is contained in:
Christ van Willegen
2024-07-11 21:36:21 +02:00
committed by Christian Brabandt
parent 965091001f
commit 8252ef134f
7 changed files with 64 additions and 28 deletions

View File

@ -68,7 +68,7 @@ balloon_gettext() String current text in the balloon
balloon_show({expr}) none show {expr} inside the balloon balloon_show({expr}) none show {expr} inside the balloon
balloon_split({msg}) List split {msg} as used for a balloon balloon_split({msg}) List split {msg} as used for a balloon
bindtextdomain({package}, {path}) bindtextdomain({package}, {path})
none bind text domain to specied path Bool bind text domain to specified path
blob2list({blob}) List convert {blob} into a list of numbers blob2list({blob}) List convert {blob} into a list of numbers
browse({save}, {title}, {initdir}, {default}) browse({save}, {title}, {initdir}, {default})
String put up a file requester String put up a file requester
@ -1228,7 +1228,10 @@ bindtextdomain({package}, {path}) *bindtextdomain()*
translations for a package. {path} is the directory name translations for a package. {path} is the directory name
for the translations. See |package-translation|. for the translations. See |package-translation|.
Return type: none Returns v:true on success and v:false on failure (out of
memory).
Return type: |vim9-boolean|
blob2list({blob}) *blob2list()* blob2list({blob}) *blob2list()*
Return a List containing the number value of each byte in Blob Return a List containing the number value of each byte in Blob

View File

@ -1827,7 +1827,7 @@ static funcentry_T global_functions[] =
#endif #endif
}, },
{"bindtextdomain", 2, 2, 0, arg2_string, {"bindtextdomain", 2, 2, 0, arg2_string,
ret_void, f_bindtextdomain}, ret_bool, f_bindtextdomain},
{"blob2list", 1, 1, FEARG_1, arg1_blob, {"blob2list", 1, 1, FEARG_1, arg1_blob,
ret_list_number, f_blob2list}, ret_list_number, f_blob2list},
{"browse", 4, 4, 0, arg4_browse, {"browse", 4, 4, 0, arg4_browse,
@ -3486,8 +3486,11 @@ get_buf_arg(typval_T *arg)
* "bindtextdomain(package, path)" function * "bindtextdomain(package, path)" function
*/ */
static void static void
f_bindtextdomain(typval_T *argvars UNUSED, typval_T *rettv UNUSED) f_bindtextdomain(typval_T *argvars, typval_T *rettv)
{ {
rettv->v_type = VAR_BOOL;
rettv->vval.v_number = VVAL_TRUE;
if (check_for_nonempty_string_arg(argvars, 0) == FAIL if (check_for_nonempty_string_arg(argvars, 0) == FAIL
|| check_for_nonempty_string_arg(argvars, 1) == FAIL) || check_for_nonempty_string_arg(argvars, 1) == FAIL)
return; return;
@ -3495,7 +3498,13 @@ f_bindtextdomain(typval_T *argvars UNUSED, typval_T *rettv UNUSED)
if (strcmp((const char *)argvars[0].vval.v_string, VIMPACKAGE) == 0) if (strcmp((const char *)argvars[0].vval.v_string, VIMPACKAGE) == 0)
semsg(_(e_invalid_argument_str), tv_get_string(&argvars[0])); semsg(_(e_invalid_argument_str), tv_get_string(&argvars[0]));
else else
bindtextdomain((const char *)argvars[0].vval.v_string, (const char *)argvars[1].vval.v_string); {
if (bindtextdomain((const char *)argvars[0].vval.v_string, (const char *)argvars[1].vval.v_string) == NULL)
{
do_outofmem_msg((long)0);
rettv->vval.v_number = VVAL_FALSE;
}
}
return; return;
} }

View File

@ -1,5 +1,7 @@
source check.vim source check.vim
CheckFeature gettext
" Test for gettext() " Test for gettext()
func Test_gettext() func Test_gettext()
call assert_fails('call bindtextdomain("test")', 'E119:') call assert_fails('call bindtextdomain("test")', 'E119:')

View File

@ -2,22 +2,32 @@ source check.vim
" This fail on CI MacOS 14 because bindtextdomain() is not available there " This fail on CI MacOS 14 because bindtextdomain() is not available there
" (missing library?) " (missing library?)
CheckNotMac CheckNotMac
CheckFeature gettext
" Test for gettext() " Test for gettext()
func Test_gettext() func Test_gettext()
set encoding=cp1251 set encoding=cp1251
call bindtextdomain("__PACKAGE__", getcwd()) call assert_equal('ERROR: ', gettext("ERROR: ", "__PACKAGE__"))
try try
language messages ru_RU call assert_true(bindtextdomain("__PACKAGE__", getcwd()))
call assert_equal('<27><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>: ', gettext("ERROR: ", "__PACKAGE__"))
catch /^Vim\%((\a\+)\)\=:E197:/ try
throw "Skipped: not possible to set locale to ru (missing?)" language messages ru_RU
endtry call assert_equal('<27><><EFBFBD><EFBFBD><EFBFBD><EFBFBD>: ', gettext("ERROR: ", "__PACKAGE__"))
try catch /^Vim\%((\a\+)\)\=:E197:/
language messages en_GB.UTF-8 throw "Skipped: not possible to set locale to ru (missing?)"
call assert_equal('ERROR: ', gettext("ERROR: ", "__PACKAGE__")) endtry
catch /^Vim\%((\a\+)\)\=:E197:/
throw "Skipped: not possible to set locale to en (missing?)" try
language messages en_GB.UTF-8
call assert_equal('ERROR: ', gettext("ERROR: ", "__PACKAGE__"))
catch /^Vim\%((\a\+)\)\=:E197:/
throw "Skipped: not possible to set locale to en (missing?)"
endtry
catch /^Vim\%((\a\+)\)\=:E342:/
throw "Skipped: out of memory executing bindtextdomain()"
endtry endtry
set encoding& set encoding&
endfunc endfunc

View File

@ -2,22 +2,32 @@ source check.vim
" This fail on CI MacOS 14 because bindtextdomain() is not available there " This fail on CI MacOS 14 because bindtextdomain() is not available there
" (missing library?) " (missing library?)
CheckNotMac CheckNotMac
CheckFeature gettext
" Test for gettext() " Test for gettext()
func Test_gettext() func Test_gettext()
set encoding=utf-8 set encoding=utf-8
call bindtextdomain("__PACKAGE__", getcwd()) call assert_equal('ERROR: ', gettext("ERROR: ", "__PACKAGE__"))
try try
language messages ru_RU call assert_true(bindtextdomain("__PACKAGE__", getcwd()))
call assert_equal('ОШИБКА: ', gettext("ERROR: ", "__PACKAGE__"))
catch /^Vim\%((\a\+)\)\=:E197:/ try
throw "Skipped: not possible to set locale to ru (missing?)" language messages ru_RU
endtry call assert_equal('ОШИБКА: ', gettext("ERROR: ", "__PACKAGE__"))
try catch /^Vim\%((\a\+)\)\=:E197:/
language messages en_GB.UTF-8 throw "Skipped: not possible to set locale to ru (missing?)"
call assert_equal('ERROR: ', gettext("ERROR: ", "__PACKAGE__")) endtry
catch /^Vim\%((\a\+)\)\=:E197:/
throw "Skipped: not possible to set locale to en (missing?)" try
language messages en_GB.UTF-8
call assert_equal('ERROR: ', gettext("ERROR: ", "__PACKAGE__"))
catch /^Vim\%((\a\+)\)\=:E197:/
throw "Skipped: not possible to set locale to en (missing?)"
endtry
catch /^Vim\%((\a\+)\)\=:E342:/
throw "Skipped: out of memory executing bindtextdomain()"
endtry endtry
set encoding& set encoding&
endfunc endfunc

View File

@ -704,6 +704,8 @@ static char *(features[]) =
static int included_patches[] = static int included_patches[] =
{ /* Add new patch number below this line */ { /* Add new patch number below this line */
/**/
560,
/**/ /**/
559, 559,
/**/ /**/

View File

@ -598,7 +598,7 @@ extern int (*dyn_libintl_wputenv)(const wchar_t *envstring);
# ifdef bindtextdomain # ifdef bindtextdomain
# undef bindtextdomain # undef bindtextdomain
# endif # endif
# define bindtextdomain(x, y) // empty # define bindtextdomain(x, y) ""
# ifdef bind_textdomain_codeset # ifdef bind_textdomain_codeset
# undef bind_textdomain_codeset # undef bind_textdomain_codeset
# endif # endif