vim-patch:7.4.946

Problem:    Missing changes in source file.
Solution:   Include changes to the eval.c file.

bbfbaf9741
This commit is contained in:
watiko
2015-12-13 21:31:34 +09:00
parent 008c014cbe
commit 588b09277b
2 changed files with 63 additions and 48 deletions

View File

@@ -7101,9 +7101,9 @@ static struct fst {
{"arglistid", 0, 2, f_arglistid}, {"arglistid", 0, 2, f_arglistid},
{"argv", 0, 1, f_argv}, {"argv", 0, 1, f_argv},
{"asin", 1, 1, f_asin}, // WJMc {"asin", 1, 1, f_asin}, // WJMc
{"assertEqual", 2, 3, f_assertEqual}, {"assert_equal", 2, 3, f_assert_equal},
{"assertFalse", 1, 2, f_assertFalse}, {"assert_false", 1, 2, f_assert_false},
{"assertTrue", 1, 2, f_assertTrue}, {"assert_true", 1, 2, f_assert_true},
{"atan", 1, 1, f_atan}, {"atan", 1, 1, f_atan},
{"atan2", 2, 2, f_atan2}, {"atan2", 2, 2, f_atan2},
{"browse", 4, 4, f_browse}, {"browse", 4, 4, f_browse},
@@ -7985,8 +7985,47 @@ static void f_argv(typval_T *argvars, typval_T *rettv)
} }
} }
// Prepare "gap" for an assert error and add the sourcing position.
static void prepare_assert_error(garray_T *gap)
{
char buf[NUMBUFLEN];
ga_init(gap, 1, 100);
ga_concat(gap, sourcing_name);
vim_snprintf(buf, ARRAY_SIZE(buf), " line %ld", (long)sourcing_lnum);
ga_concat(gap, (char_u *)buf);
ga_concat(gap, (char_u *)": ");
}
// Fill "gap" with information about an assert error.
static void fill_assert_error(garray_T *gap, typval_T *opt_msg_tv,
char_u *exp_str, typval_T *exp_tv,
typval_T *got_tv)
{
char_u *tofree;
if (opt_msg_tv->v_type != VAR_UNKNOWN) {
tofree = (char_u *) tv2string(opt_msg_tv, NULL);
ga_concat(gap, tofree);
xfree(tofree);
} else {
ga_concat(gap, (char_u *)"Expected ");
if (exp_str == NULL) {
tofree = (char_u *) tv2string(exp_tv, NULL);
ga_concat(gap, tofree);
xfree(tofree);
} else {
ga_concat(gap, exp_str);
}
tofree = (char_u *) tv2string(got_tv, NULL);
ga_concat(gap, (char_u *)" but got ");
ga_concat(gap, tofree);
xfree(tofree);
}
}
// Add an assert error to v:errors. // Add an assert error to v:errors.
static void assertError(garray_T *gap) static void assert_error(garray_T *gap)
{ {
struct vimvar *vp = &vimvars[VV_ERRORS]; struct vimvar *vp = &vimvars[VV_ERRORS];
@@ -7998,71 +8037,47 @@ static void assertError(garray_T *gap)
gap->ga_data, gap->ga_len); gap->ga_data, gap->ga_len);
} }
static void prepareForAssertError(garray_T *gap) // "assert_equal(expected, actual[, msg])" function
{ static void f_assert_equal(typval_T *argvars, typval_T *rettv)
char buf[NUMBUFLEN];
ga_init(gap, 1, 100);
ga_concat(gap, sourcing_name);
vim_snprintf(buf, ARRAY_SIZE(buf), " line %ld", (long)sourcing_lnum);
ga_concat(gap, (char_u *)buf);
}
// "assertEqual(expected, actual[, msg])" function
static void f_assertEqual(typval_T *argvars, typval_T *rettv)
{ {
garray_T ga; garray_T ga;
char_u *tofree;
if (!tv_equal(&argvars[0], &argvars[1], false, false)) { if (!tv_equal(&argvars[0], &argvars[1], false, false)) {
prepareForAssertError(&ga); prepare_assert_error(&ga);
ga_concat(&ga, (char_u *)": Expected "); fill_assert_error(&ga, &argvars[2], NULL,
tofree = (char_u *) tv2string(&argvars[0], NULL); &argvars[0], &argvars[1]);
ga_concat(&ga, tofree); assert_error(&ga);
xfree(tofree);
ga_concat(&ga, (char_u *)" but got ");
tofree = (char_u *) tv2string(&argvars[1], NULL);
ga_concat(&ga, tofree);
xfree(tofree);
assertError(&ga);
ga_clear(&ga); ga_clear(&ga);
} }
} }
static void assertBool(typval_T *argvars, bool isTrue) // Common for assert_true() and assert_false().
static void assert_bool(typval_T *argvars, bool isTrue)
{ {
int error = (int)false; int error = (int)false;
garray_T ga; garray_T ga;
char_u *tofree;
if (argvars[0].v_type != VAR_NUMBER || if (argvars[0].v_type != VAR_NUMBER ||
(get_tv_number_chk(&argvars[0], &error) == 0) == isTrue || error) { (get_tv_number_chk(&argvars[0], &error) == 0) == isTrue || error) {
prepareForAssertError(&ga); prepare_assert_error(&ga);
ga_concat(&ga, (char_u *)": Expected "); fill_assert_error(&ga, &argvars[1],
if (isTrue) { (char_u *)(isTrue ? "True " : "False "),
ga_concat(&ga, (char_u *)"True "); NULL, &argvars[0]);
} else { assert_error(&ga);
ga_concat(&ga, (char_u *)"False ");
}
ga_concat(&ga, (char_u *)"but got ");
tofree = (char_u *) tv2string(&argvars[0], NULL);
ga_concat(&ga, tofree);
xfree(tofree);
assertError(&ga);
ga_clear(&ga); ga_clear(&ga);
} }
} }
// "assertFalse(actual[, msg])" function // "assert_false(actual[, msg])" function
static void f_assertFalse(typval_T *argvars, typval_T *rettv) static void f_assert_false(typval_T *argvars, typval_T *rettv)
{ {
assertBool(argvars, false); assert_bool(argvars, false);
} }
// "assertTrue(actual[, msg])" function // "assert_true(actual[, msg])" function
static void f_assertTrue(typval_T *argvars, typval_T *rettv) static void f_assert_true(typval_T *argvars, typval_T *rettv)
{ {
assertBool(argvars, true); assert_bool(argvars, true);
} }
/* /*

View File

@@ -123,7 +123,7 @@ static int included_patches[] = {
// 949, // 949,
// 948 NA // 948 NA
// 947, // 947,
// 946, 946,
945, 945,
944, 944,
// 943, // 943,