patch 8.1.0743: giving error messages is not flexible
Problem: Giving error messages is not flexible.
Solution: Add semsg(). Change argument from "char_u *" to "char *", also
for msg() and get rid of most MSG macros. (Ozaki Kiichi, closes
#3302) Also make emsg() accept a "char *" argument. Get rid of
an enormous number of type casts.
diff --git a/src/list.c b/src/list.c
index 2a82023..0c21c41 100644
--- a/src/list.c
+++ b/src/list.c
@@ -417,7 +417,7 @@
li = list_find(l, idx - 1);
if (li == NULL)
{
- EMSGN(_(e_listidx), idx);
+ semsg(_(e_listidx), idx);
return NULL;
}
return tv_get_string(&li->li_tv);
@@ -914,7 +914,7 @@
break;
if (**arg != ',')
{
- EMSG2(_("E696: Missing comma in List: %s"), *arg);
+ semsg(_("E696: Missing comma in List: %s"), *arg);
goto failret;
}
*arg = skipwhite(*arg + 1);
@@ -922,7 +922,7 @@
if (**arg != ']')
{
- EMSG2(_("E697: Missing end of List ']': %s"), *arg);
+ semsg(_("E697: Missing end of List ']': %s"), *arg);
failret:
if (evaluate)
list_free(l);
@@ -969,7 +969,7 @@
}
if (ret == FAIL)
{
- EMSG(_(e_write));
+ emsg(_(e_write));
break;
}
}