|
|
3ef2ca |
To: vim_dev@googlegroups.com
|
|
|
3ef2ca |
Subject: Patch 7.4.278
|
|
|
3ef2ca |
Fcc: outbox
|
|
|
3ef2ca |
From: Bram Moolenaar <Bram@moolenaar.net>
|
|
|
3ef2ca |
Mime-Version: 1.0
|
|
|
3ef2ca |
Content-Type: text/plain; charset=UTF-8
|
|
|
3ef2ca |
Content-Transfer-Encoding: 8bit
|
|
|
3ef2ca |
------------
|
|
|
3ef2ca |
|
|
|
3ef2ca |
Patch 7.4.278
|
|
|
3ef2ca |
Problem: list_remove() conflicts with function defined in Sun header file.
|
|
|
3ef2ca |
Solution: Rename the function. (Richard Palo)
|
|
|
3ef2ca |
Files: src/eval.c, src/if_lua.c, src/if_py_both.h, src/proto/eval.pro
|
|
|
3ef2ca |
|
|
|
3ef2ca |
|
|
|
3ef2ca |
*** ../vim-7.4.277/src/eval.c 2014-04-29 17:41:18.351689927 +0200
|
|
|
3ef2ca |
--- src/eval.c 2014-05-07 17:28:56.037181128 +0200
|
|
|
3ef2ca |
***************
|
|
|
3ef2ca |
*** 5998,6004 ****
|
|
|
3ef2ca |
list_T *l;
|
|
|
3ef2ca |
listitem_T *item;
|
|
|
3ef2ca |
{
|
|
|
3ef2ca |
! list_remove(l, item, item);
|
|
|
3ef2ca |
listitem_free(item);
|
|
|
3ef2ca |
}
|
|
|
3ef2ca |
|
|
|
3ef2ca |
--- 5998,6004 ----
|
|
|
3ef2ca |
list_T *l;
|
|
|
3ef2ca |
listitem_T *item;
|
|
|
3ef2ca |
{
|
|
|
3ef2ca |
! vimlist_remove(l, item, item);
|
|
|
3ef2ca |
listitem_free(item);
|
|
|
3ef2ca |
}
|
|
|
3ef2ca |
|
|
|
3ef2ca |
***************
|
|
|
3ef2ca |
*** 6577,6585 ****
|
|
|
3ef2ca |
/*
|
|
|
3ef2ca |
* Remove items "item" to "item2" from list "l".
|
|
|
3ef2ca |
* Does not free the listitem or the value!
|
|
|
3ef2ca |
*/
|
|
|
3ef2ca |
void
|
|
|
3ef2ca |
! list_remove(l, item, item2)
|
|
|
3ef2ca |
list_T *l;
|
|
|
3ef2ca |
listitem_T *item;
|
|
|
3ef2ca |
listitem_T *item2;
|
|
|
3ef2ca |
--- 6577,6587 ----
|
|
|
3ef2ca |
/*
|
|
|
3ef2ca |
* Remove items "item" to "item2" from list "l".
|
|
|
3ef2ca |
* Does not free the listitem or the value!
|
|
|
3ef2ca |
+ * This used to be called list_remove, but that conflicts with a Sun header
|
|
|
3ef2ca |
+ * file.
|
|
|
3ef2ca |
*/
|
|
|
3ef2ca |
void
|
|
|
3ef2ca |
! vimlist_remove(l, item, item2)
|
|
|
3ef2ca |
list_T *l;
|
|
|
3ef2ca |
listitem_T *item;
|
|
|
3ef2ca |
listitem_T *item2;
|
|
|
3ef2ca |
***************
|
|
|
3ef2ca |
*** 15435,15441 ****
|
|
|
3ef2ca |
if (argvars[2].v_type == VAR_UNKNOWN)
|
|
|
3ef2ca |
{
|
|
|
3ef2ca |
/* Remove one item, return its value. */
|
|
|
3ef2ca |
! list_remove(l, item, item);
|
|
|
3ef2ca |
*rettv = item->li_tv;
|
|
|
3ef2ca |
vim_free(item);
|
|
|
3ef2ca |
}
|
|
|
3ef2ca |
--- 15437,15443 ----
|
|
|
3ef2ca |
if (argvars[2].v_type == VAR_UNKNOWN)
|
|
|
3ef2ca |
{
|
|
|
3ef2ca |
/* Remove one item, return its value. */
|
|
|
3ef2ca |
! vimlist_remove(l, item, item);
|
|
|
3ef2ca |
*rettv = item->li_tv;
|
|
|
3ef2ca |
vim_free(item);
|
|
|
3ef2ca |
}
|
|
|
3ef2ca |
***************
|
|
|
3ef2ca |
*** 15461,15467 ****
|
|
|
3ef2ca |
EMSG(_(e_invrange));
|
|
|
3ef2ca |
else
|
|
|
3ef2ca |
{
|
|
|
3ef2ca |
! list_remove(l, item, item2);
|
|
|
3ef2ca |
if (rettv_list_alloc(rettv) == OK)
|
|
|
3ef2ca |
{
|
|
|
3ef2ca |
l = rettv->vval.v_list;
|
|
|
3ef2ca |
--- 15463,15469 ----
|
|
|
3ef2ca |
EMSG(_(e_invrange));
|
|
|
3ef2ca |
else
|
|
|
3ef2ca |
{
|
|
|
3ef2ca |
! vimlist_remove(l, item, item2);
|
|
|
3ef2ca |
if (rettv_list_alloc(rettv) == OK)
|
|
|
3ef2ca |
{
|
|
|
3ef2ca |
l = rettv->vval.v_list;
|
|
|
3ef2ca |
*** ../vim-7.4.277/src/if_lua.c 2013-06-23 12:55:02.000000000 +0200
|
|
|
3ef2ca |
--- src/if_lua.c 2014-05-07 17:29:08.913181240 +0200
|
|
|
3ef2ca |
***************
|
|
|
3ef2ca |
*** 734,740 ****
|
|
|
3ef2ca |
if (li == NULL) return 0;
|
|
|
3ef2ca |
if (lua_isnil(L, 3)) /* remove? */
|
|
|
3ef2ca |
{
|
|
|
3ef2ca |
! list_remove(l, li, li);
|
|
|
3ef2ca |
clear_tv(&li->li_tv);
|
|
|
3ef2ca |
vim_free(li);
|
|
|
3ef2ca |
}
|
|
|
3ef2ca |
--- 734,740 ----
|
|
|
3ef2ca |
if (li == NULL) return 0;
|
|
|
3ef2ca |
if (lua_isnil(L, 3)) /* remove? */
|
|
|
3ef2ca |
{
|
|
|
3ef2ca |
! vimlist_remove(l, li, li);
|
|
|
3ef2ca |
clear_tv(&li->li_tv);
|
|
|
3ef2ca |
vim_free(li);
|
|
|
3ef2ca |
}
|
|
|
3ef2ca |
*** ../vim-7.4.277/src/if_py_both.h 2014-03-30 16:11:37.176530823 +0200
|
|
|
3ef2ca |
--- src/if_py_both.h 2014-05-07 17:29:26.497181394 +0200
|
|
|
3ef2ca |
***************
|
|
|
3ef2ca |
*** 2494,2500 ****
|
|
|
3ef2ca |
if (numreplaced < slicelen)
|
|
|
3ef2ca |
{
|
|
|
3ef2ca |
lis[slicelen + numreplaced] = lis[numreplaced]->li_prev;
|
|
|
3ef2ca |
! list_remove(l, lis[numreplaced], lis[numreplaced]);
|
|
|
3ef2ca |
numreplaced++;
|
|
|
3ef2ca |
}
|
|
|
3ef2ca |
else
|
|
|
3ef2ca |
--- 2494,2500 ----
|
|
|
3ef2ca |
if (numreplaced < slicelen)
|
|
|
3ef2ca |
{
|
|
|
3ef2ca |
lis[slicelen + numreplaced] = lis[numreplaced]->li_prev;
|
|
|
3ef2ca |
! vimlist_remove(l, lis[numreplaced], lis[numreplaced]);
|
|
|
3ef2ca |
numreplaced++;
|
|
|
3ef2ca |
}
|
|
|
3ef2ca |
else
|
|
|
3ef2ca |
***************
|
|
|
3ef2ca |
*** 2570,2576 ****
|
|
|
3ef2ca |
if (obj == NULL)
|
|
|
3ef2ca |
{
|
|
|
3ef2ca |
li = list_find(l, (long) index);
|
|
|
3ef2ca |
! list_remove(l, li, li);
|
|
|
3ef2ca |
clear_tv(&li->li_tv);
|
|
|
3ef2ca |
vim_free(li);
|
|
|
3ef2ca |
return 0;
|
|
|
3ef2ca |
--- 2570,2576 ----
|
|
|
3ef2ca |
if (obj == NULL)
|
|
|
3ef2ca |
{
|
|
|
3ef2ca |
li = list_find(l, (long) index);
|
|
|
3ef2ca |
! vimlist_remove(l, li, li);
|
|
|
3ef2ca |
clear_tv(&li->li_tv);
|
|
|
3ef2ca |
vim_free(li);
|
|
|
3ef2ca |
return 0;
|
|
|
3ef2ca |
*** ../vim-7.4.277/src/proto/eval.pro 2014-01-14 16:36:40.000000000 +0100
|
|
|
3ef2ca |
--- src/proto/eval.pro 2014-05-07 17:30:02.517181710 +0200
|
|
|
3ef2ca |
***************
|
|
|
3ef2ca |
*** 59,65 ****
|
|
|
3ef2ca |
int list_append_dict __ARGS((list_T *list, dict_T *dict));
|
|
|
3ef2ca |
int list_append_string __ARGS((list_T *l, char_u *str, int len));
|
|
|
3ef2ca |
int list_insert_tv __ARGS((list_T *l, typval_T *tv, listitem_T *item));
|
|
|
3ef2ca |
! void list_remove __ARGS((list_T *l, listitem_T *item, listitem_T *item2));
|
|
|
3ef2ca |
void list_insert __ARGS((list_T *l, listitem_T *ni, listitem_T *item));
|
|
|
3ef2ca |
int garbage_collect __ARGS((void));
|
|
|
3ef2ca |
void set_ref_in_ht __ARGS((hashtab_T *ht, int copyID));
|
|
|
3ef2ca |
--- 59,65 ----
|
|
|
3ef2ca |
int list_append_dict __ARGS((list_T *list, dict_T *dict));
|
|
|
3ef2ca |
int list_append_string __ARGS((list_T *l, char_u *str, int len));
|
|
|
3ef2ca |
int list_insert_tv __ARGS((list_T *l, typval_T *tv, listitem_T *item));
|
|
|
3ef2ca |
! void vimlist_remove __ARGS((list_T *l, listitem_T *item, listitem_T *item2));
|
|
|
3ef2ca |
void list_insert __ARGS((list_T *l, listitem_T *ni, listitem_T *item));
|
|
|
3ef2ca |
int garbage_collect __ARGS((void));
|
|
|
3ef2ca |
void set_ref_in_ht __ARGS((hashtab_T *ht, int copyID));
|
|
|
3ef2ca |
*** ../vim-7.4.277/src/version.c 2014-05-07 16:35:05.029152844 +0200
|
|
|
3ef2ca |
--- src/version.c 2014-05-07 17:30:43.449182068 +0200
|
|
|
3ef2ca |
***************
|
|
|
3ef2ca |
*** 736,737 ****
|
|
|
3ef2ca |
--- 736,739 ----
|
|
|
3ef2ca |
{ /* Add new patch number below this line */
|
|
|
3ef2ca |
+ /**/
|
|
|
3ef2ca |
+ 278,
|
|
|
3ef2ca |
/**/
|
|
|
3ef2ca |
|
|
|
3ef2ca |
--
|
|
|
3ef2ca |
"Computers in the future may weigh no more than 1.5 tons."
|
|
|
3ef2ca |
Popular Mechanics, 1949
|
|
|
3ef2ca |
|
|
|
3ef2ca |
/// Bram Moolenaar -- Bram@Moolenaar.net -- http://www.Moolenaar.net \\\
|
|
|
3ef2ca |
/// sponsor Vim, vote for features -- http://www.Vim.org/sponsor/ \\\
|
|
|
3ef2ca |
\\\ an exciting new programming language -- http://www.Zimbu.org ///
|
|
|
3ef2ca |
\\\ help me help AIDS victims -- http://ICCF-Holland.org ///
|