# HG changeset patch
# User ZyX <[email protected]>
# Date 1369490340 -14400
# Node ID eb95fd146cc21c49103af9ff9fcb250827b83ba4
# Parent  920b38ba610a4b9b874a18828a5b13c1a560a583
Rename d to dict and lookupDict to lookup_dict

diff -r 920b38ba610a -r eb95fd146cc2 src/if_py_both.h
--- a/src/if_py_both.h  Sat May 25 14:55:01 2013 +0400
+++ b/src/if_py_both.h  Sat May 25 17:59:00 2013 +0400
@@ -475,7 +475,7 @@
  * you call VimToPython.
  */
     static PyObject *
-VimToPython(typval_T *our_tv, int depth, PyObject *lookupDict)
+VimToPython(typval_T *our_tv, int depth, PyObject *lookup_dict)
 {
     PyObject   *result;
     PyObject   *newObj;
@@ -489,7 +489,7 @@
        return result;
     }
 
-    /* Check if we run into a recursive loop.  The item must be in lookupDict
+    /* Check if we run into a recursive loop.  The item must be in lookup_dict
      * then and we can use it again. */
     if ((our_tv->v_type == VAR_LIST && our_tv->vval.v_list != NULL)
            || (our_tv->v_type == VAR_DICT && our_tv->vval.v_dict != NULL))
@@ -498,7 +498,7 @@
                our_tv->v_type == VAR_LIST ? (void *)our_tv->vval.v_list
                                           : (void *)our_tv->vval.v_dict);
 
-       if ((result = PyDict_GetItemString(lookupDict, ptrBuf)))
+       if ((result = PyDict_GetItemString(lookup_dict, ptrBuf)))
        {
            Py_INCREF(result);
            return result;
@@ -538,7 +538,7 @@
        if (!(result = PyList_New(0)))
            return NULL;
 
-       if (PyDict_SetItemString(lookupDict, ptrBuf, result))
+       if (PyDict_SetItemString(lookup_dict, ptrBuf, result))
        {
            Py_DECREF(result);
            return NULL;
@@ -546,7 +546,7 @@
 
        for (curr = list->lv_first; curr != NULL; curr = curr->li_next)
        {
-           if (!(newObj = VimToPython(&curr->li_tv, depth + 1, lookupDict)))
+           if (!(newObj = VimToPython(&curr->li_tv, depth + 1, lookup_dict)))
            {
                Py_DECREF(result);
                return NULL;
@@ -573,7 +573,7 @@
        if (!(result = PyDict_New()))
            return NULL;
 
-       if (PyDict_SetItemString(lookupDict, ptrBuf, result))
+       if (PyDict_SetItemString(lookup_dict, ptrBuf, result))
        {
            Py_DECREF(result);
            return NULL;
@@ -586,7 +586,7 @@
                --todo;
 
                di = dict_lookup(hi);
-               if (!(newObj = VimToPython(&di->di_tv, depth + 1, lookupDict)))
+               if (!(newObj = VimToPython(&di->di_tv, depth + 1, lookup_dict)))
                {
                    Py_DECREF(result);
                    return NULL;
@@ -970,11 +970,11 @@
 {
     char_u     *key;
     typval_T   tv;
-    dict_T     *d = self->dict;
+    dict_T     *dict = self->dict;
     dictitem_T *di;
     DICTKEY_DECL
 
-    if (d->dv_lock)
+    if (dict->dv_lock)
     {
        PyErr_SetVim(_("dict is locked"));
        return -1;
@@ -982,7 +982,7 @@
 
     DICTKEY_GET_NOTEMPTY(-1)
 
-    di = dict_find(d, key, -1);
+    di = dict_find(dict, key, -1);
 
     if (valObject == NULL)
     {
@@ -994,8 +994,8 @@
            PyErr_SetObject(PyExc_KeyError, keyObject);
            return -1;
        }
-       hi = hash_find(&d->dv_hashtab, di->di_key);
-       hash_remove(&d->dv_hashtab, hi);
+       hi = hash_find(&dict->dv_hashtab, di->di_key);
+       hash_remove(&dict->dv_hashtab, hi);
        dictitem_free(di);
        return 0;
     }
@@ -1013,7 +1013,7 @@
        }
        di->di_tv.v_lock = 0;
 
-       if (dict_add(d, di) == FAIL)
+       if (dict_add(dict, di) == FAIL)
        {
            DICTKEY_UNREF
            vim_free(di);
@@ -1102,7 +1102,7 @@
 }
 
     static int
-list_py_concat(list_T *l, PyObject *obj, PyObject *lookupDict)
+list_py_concat(list_T *l, PyObject *obj, PyObject *lookup_dict)
 {
     Py_ssize_t i;
     Py_ssize_t lsize = PySequence_Size(obj);
@@ -1122,7 +1122,7 @@
        litem = PySequence_GetItem(obj, i);
        if (litem == NULL)
            return -1;
-       if (_ConvertFromPyObject(litem, &li->li_tv, lookupDict) == -1)
+       if (_ConvertFromPyObject(litem, &li->li_tv, lookup_dict) == -1)
            return -1;
 
        list_append(l, li);
@@ -4008,24 +4008,24 @@
 }
 
     static int
-pydict_to_tv(PyObject *obj, typval_T *tv, PyObject *lookupDict)
+pydict_to_tv(PyObject *obj, typval_T *tv, PyObject *lookup_dict)
 {
-    dict_T     *d;
+    dict_T     *dict;
     char_u     *key;
     dictitem_T *di;
     PyObject   *keyObject;
     PyObject   *valObject;
     Py_ssize_t iter = 0;
 
-    d = dict_alloc();
-    if (d == NULL)
+    dict = dict_alloc();
+    if (dict == NULL)
     {
        PyErr_NoMemory();
        return -1;
     }
 
     tv->v_type = VAR_DICT;
-    tv->vval.v_dict = d;
+    tv->vval.v_dict = dict;
 
     while (PyDict_Next(obj, &iter, &keyObject, &valObject))
     {
@@ -4049,12 +4049,13 @@
        }
        di->di_tv.v_lock = 0;
 
-       if (_ConvertFromPyObject(valObject, &di->di_tv, lookupDict) == -1)
+       if (_ConvertFromPyObject(valObject, &di->di_tv, lookup_dict) == -1)
        {
            vim_free(di);
            return -1;
        }
-       if (dict_add(d, di) == FAIL)
+
+       if (dict_add(dict, di) == FAIL)
        {
            vim_free(di);
            PyErr_SetVim(_("failed to add key to dictionary"));
@@ -4065,9 +4066,9 @@
 }
 
     static int
-pymap_to_tv(PyObject *obj, typval_T *tv, PyObject *lookupDict)
+pymap_to_tv(PyObject *obj, typval_T *tv, PyObject *lookup_dict)
 {
-    dict_T     *d;
+    dict_T     *dict;
     char_u     *key;
     dictitem_T *di;
     PyObject   *list;
@@ -4076,15 +4077,15 @@
     PyObject   *valObject;
     Py_ssize_t lsize;
 
-    d = dict_alloc();
-    if (d == NULL)
+    dict = dict_alloc();
+    if (dict == NULL)
     {
        PyErr_NoMemory();
        return -1;
     }
 
     tv->v_type = VAR_DICT;
-    tv->vval.v_dict = d;
+    tv->vval.v_dict = dict;
 
     list = PyMapping_Items(obj);
     if (list == NULL)
@@ -4132,14 +4133,14 @@
        }
        di->di_tv.v_lock = 0;
 
-       if (_ConvertFromPyObject(valObject, &di->di_tv, lookupDict) == -1)
+       if (_ConvertFromPyObject(valObject, &di->di_tv, lookup_dict) == -1)
        {
            vim_free(di);
            Py_DECREF(list);
            Py_DECREF(litem);
            return -1;
        }
-       if (dict_add(d, di) == FAIL)
+       if (dict_add(dict, di) == FAIL)
        {
            vim_free(di);
            Py_DECREF(list);
@@ -4154,7 +4155,7 @@
 }
 
     static int
-pyseq_to_tv(PyObject *obj, typval_T *tv, PyObject *lookupDict)
+pyseq_to_tv(PyObject *obj, typval_T *tv, PyObject *lookup_dict)
 {
     list_T     *l;
 
@@ -4168,14 +4169,14 @@
     tv->v_type = VAR_LIST;
     tv->vval.v_list = l;
 
-    if (list_py_concat(l, obj, lookupDict) == -1)
+    if (list_py_concat(l, obj, lookup_dict) == -1)
        return -1;
 
     return 0;
 }
 
     static int
-pyiter_to_tv(PyObject *obj, typval_T *tv, PyObject *lookupDict)
+pyiter_to_tv(PyObject *obj, typval_T *tv, PyObject *lookup_dict)
 {
     PyObject   *iterator = PyObject_GetIter(obj);
     PyObject   *item;
@@ -4207,7 +4208,7 @@
        }
        li->li_tv.v_lock = 0;
 
-       if (_ConvertFromPyObject(item, &li->li_tv, lookupDict) == -1)
+       if (_ConvertFromPyObject(item, &li->li_tv, lookup_dict) == -1)
            return -1;
 
        list_append(l, li);
@@ -4223,7 +4224,7 @@
 
     static int
 convert_dl(PyObject *obj, typval_T *tv,
-                                   pytotvfunc py_to_tv, PyObject *lookupDict)
+                                   pytotvfunc py_to_tv, PyObject *lookup_dict)
 {
     PyObject   *capsule;
     char       hexBuf[sizeof(void *) * 2 + 3];
@@ -4231,9 +4232,9 @@
     sprintf(hexBuf, "%p", obj);
 
 # ifdef PY_USE_CAPSULE
-    capsule = PyDict_GetItemString(lookupDict, hexBuf);
+    capsule = PyDict_GetItemString(lookup_dict, hexBuf);
 # else
-    capsule = (PyObject *)PyDict_GetItemString(lookupDict, hexBuf);
+    capsule = (PyObject *)PyDict_GetItemString(lookup_dict, hexBuf);
 # endif
     if (capsule == NULL)
     {
@@ -4242,9 +4243,9 @@
 # else
        capsule = PyCObject_FromVoidPtr(tv, NULL);
 # endif
-       PyDict_SetItemString(lookupDict, hexBuf, capsule);
+       PyDict_SetItemString(lookup_dict, hexBuf, capsule);
        Py_DECREF(capsule);
-       if (py_to_tv(obj, tv, lookupDict) == -1)
+       if (py_to_tv(obj, tv, lookup_dict) == -1)
        {
            tv->v_type = VAR_UNKNOWN;
            return -1;
@@ -4284,7 +4285,7 @@
 }
 
     static int
-_ConvertFromPyObject(PyObject *obj, typval_T *tv, PyObject *lookupDict)
+_ConvertFromPyObject(PyObject *obj, typval_T *tv, PyObject *lookup_dict)
 {
     if (obj->ob_type == &DictionaryType)
     {
@@ -4356,7 +4357,7 @@
        tv->vval.v_number = (varnumber_T) PyLong_AsLong(obj);
     }
     else if (PyDict_Check(obj))
-       return convert_dl(obj, tv, pydict_to_tv, lookupDict);
+       return convert_dl(obj, tv, pydict_to_tv, lookup_dict);
 #ifdef FEAT_FLOAT
     else if (PyFloat_Check(obj))
     {
@@ -4365,11 +4366,11 @@
     }
 #endif
     else if (PyIter_Check(obj))
-       return convert_dl(obj, tv, pyiter_to_tv, lookupDict);
+       return convert_dl(obj, tv, pyiter_to_tv, lookup_dict);
     else if (PySequence_Check(obj))
-       return convert_dl(obj, tv, pyseq_to_tv, lookupDict);
+       return convert_dl(obj, tv, pyseq_to_tv, lookup_dict);
     else if (PyMapping_Check(obj))
-       return convert_dl(obj, tv, pymap_to_tv, lookupDict);
+       return convert_dl(obj, tv, pymap_to_tv, lookup_dict);
     else
     {
        PyErr_SetString(PyExc_TypeError,

-- 
-- 
You received this message from the "vim_dev" maillist.
Do not top-post! Type your reply below the text you are replying to.
For more information, visit http://www.vim.org/maillist.php

--- 
You received this message because you are subscribed to the Google Groups 
"vim_dev" group.
To unsubscribe from this group and stop receiving emails from it, send an email 
to [email protected].
For more options, visit https://groups.google.com/groups/opt_out.


*** /tmp/extdiff.GW4BK9/vim.920b38ba610a/src/if_py_both.h	2013-05-25 18:37:05.251978905 +0400
--- vim.eb95fd146cc2/src/if_py_both.h	2013-05-25 18:37:05.256976358 +0400
***************
*** 475,481 ****
   * you call VimToPython.
   */
      static PyObject *
! VimToPython(typval_T *our_tv, int depth, PyObject *lookupDict)
  {
      PyObject	*result;
      PyObject	*newObj;
--- 475,481 ----
   * you call VimToPython.
   */
      static PyObject *
! VimToPython(typval_T *our_tv, int depth, PyObject *lookup_dict)
  {
      PyObject	*result;
      PyObject	*newObj;
***************
*** 489,495 ****
  	return result;
      }
  
!     /* Check if we run into a recursive loop.  The item must be in lookupDict
       * then and we can use it again. */
      if ((our_tv->v_type == VAR_LIST && our_tv->vval.v_list != NULL)
  	    || (our_tv->v_type == VAR_DICT && our_tv->vval.v_dict != NULL))
--- 489,495 ----
  	return result;
      }
  
!     /* Check if we run into a recursive loop.  The item must be in lookup_dict
       * then and we can use it again. */
      if ((our_tv->v_type == VAR_LIST && our_tv->vval.v_list != NULL)
  	    || (our_tv->v_type == VAR_DICT && our_tv->vval.v_dict != NULL))
***************
*** 498,504 ****
  		our_tv->v_type == VAR_LIST ? (void *)our_tv->vval.v_list
  					   : (void *)our_tv->vval.v_dict);
  
! 	if ((result = PyDict_GetItemString(lookupDict, ptrBuf)))
  	{
  	    Py_INCREF(result);
  	    return result;
--- 498,504 ----
  		our_tv->v_type == VAR_LIST ? (void *)our_tv->vval.v_list
  					   : (void *)our_tv->vval.v_dict);
  
! 	if ((result = PyDict_GetItemString(lookup_dict, ptrBuf)))
  	{
  	    Py_INCREF(result);
  	    return result;
***************
*** 538,544 ****
  	if (!(result = PyList_New(0)))
  	    return NULL;
  
! 	if (PyDict_SetItemString(lookupDict, ptrBuf, result))
  	{
  	    Py_DECREF(result);
  	    return NULL;
--- 538,544 ----
  	if (!(result = PyList_New(0)))
  	    return NULL;
  
! 	if (PyDict_SetItemString(lookup_dict, ptrBuf, result))
  	{
  	    Py_DECREF(result);
  	    return NULL;
***************
*** 546,552 ****
  
  	for (curr = list->lv_first; curr != NULL; curr = curr->li_next)
  	{
! 	    if (!(newObj = VimToPython(&curr->li_tv, depth + 1, lookupDict)))
  	    {
  		Py_DECREF(result);
  		return NULL;
--- 546,552 ----
  
  	for (curr = list->lv_first; curr != NULL; curr = curr->li_next)
  	{
! 	    if (!(newObj = VimToPython(&curr->li_tv, depth + 1, lookup_dict)))
  	    {
  		Py_DECREF(result);
  		return NULL;
***************
*** 573,579 ****
  	if (!(result = PyDict_New()))
  	    return NULL;
  
! 	if (PyDict_SetItemString(lookupDict, ptrBuf, result))
  	{
  	    Py_DECREF(result);
  	    return NULL;
--- 573,579 ----
  	if (!(result = PyDict_New()))
  	    return NULL;
  
! 	if (PyDict_SetItemString(lookup_dict, ptrBuf, result))
  	{
  	    Py_DECREF(result);
  	    return NULL;
***************
*** 586,592 ****
  		--todo;
  
  		di = dict_lookup(hi);
! 		if (!(newObj = VimToPython(&di->di_tv, depth + 1, lookupDict)))
  		{
  		    Py_DECREF(result);
  		    return NULL;
--- 586,592 ----
  		--todo;
  
  		di = dict_lookup(hi);
! 		if (!(newObj = VimToPython(&di->di_tv, depth + 1, lookup_dict)))
  		{
  		    Py_DECREF(result);
  		    return NULL;
***************
*** 970,980 ****
  {
      char_u	*key;
      typval_T	tv;
!     dict_T	*d = self->dict;
      dictitem_T	*di;
      DICTKEY_DECL
  
!     if (d->dv_lock)
      {
  	PyErr_SetVim(_("dict is locked"));
  	return -1;
--- 970,980 ----
  {
      char_u	*key;
      typval_T	tv;
!     dict_T	*dict = self->dict;
      dictitem_T	*di;
      DICTKEY_DECL
  
!     if (dict->dv_lock)
      {
  	PyErr_SetVim(_("dict is locked"));
  	return -1;
***************
*** 982,988 ****
  
      DICTKEY_GET_NOTEMPTY(-1)
  
!     di = dict_find(d, key, -1);
  
      if (valObject == NULL)
      {
--- 982,988 ----
  
      DICTKEY_GET_NOTEMPTY(-1)
  
!     di = dict_find(dict, key, -1);
  
      if (valObject == NULL)
      {
***************
*** 994,1001 ****
  	    PyErr_SetObject(PyExc_KeyError, keyObject);
  	    return -1;
  	}
! 	hi = hash_find(&d->dv_hashtab, di->di_key);
! 	hash_remove(&d->dv_hashtab, hi);
  	dictitem_free(di);
  	return 0;
      }
--- 994,1001 ----
  	    PyErr_SetObject(PyExc_KeyError, keyObject);
  	    return -1;
  	}
! 	hi = hash_find(&dict->dv_hashtab, di->di_key);
! 	hash_remove(&dict->dv_hashtab, hi);
  	dictitem_free(di);
  	return 0;
      }
***************
*** 1013,1019 ****
  	}
  	di->di_tv.v_lock = 0;
  
! 	if (dict_add(d, di) == FAIL)
  	{
  	    DICTKEY_UNREF
  	    vim_free(di);
--- 1013,1019 ----
  	}
  	di->di_tv.v_lock = 0;
  
! 	if (dict_add(dict, di) == FAIL)
  	{
  	    DICTKEY_UNREF
  	    vim_free(di);
***************
*** 1102,1108 ****
  }
  
      static int
! list_py_concat(list_T *l, PyObject *obj, PyObject *lookupDict)
  {
      Py_ssize_t	i;
      Py_ssize_t	lsize = PySequence_Size(obj);
--- 1102,1108 ----
  }
  
      static int
! list_py_concat(list_T *l, PyObject *obj, PyObject *lookup_dict)
  {
      Py_ssize_t	i;
      Py_ssize_t	lsize = PySequence_Size(obj);
***************
*** 1122,1128 ****
  	litem = PySequence_GetItem(obj, i);
  	if (litem == NULL)
  	    return -1;
! 	if (_ConvertFromPyObject(litem, &li->li_tv, lookupDict) == -1)
  	    return -1;
  
  	list_append(l, li);
--- 1122,1128 ----
  	litem = PySequence_GetItem(obj, i);
  	if (litem == NULL)
  	    return -1;
! 	if (_ConvertFromPyObject(litem, &li->li_tv, lookup_dict) == -1)
  	    return -1;
  
  	list_append(l, li);
***************
*** 4008,4031 ****
  }
  
      static int
! pydict_to_tv(PyObject *obj, typval_T *tv, PyObject *lookupDict)
  {
!     dict_T	*d;
      char_u	*key;
      dictitem_T	*di;
      PyObject	*keyObject;
      PyObject	*valObject;
      Py_ssize_t	iter = 0;
  
!     d = dict_alloc();
!     if (d == NULL)
      {
  	PyErr_NoMemory();
  	return -1;
      }
  
      tv->v_type = VAR_DICT;
!     tv->vval.v_dict = d;
  
      while (PyDict_Next(obj, &iter, &keyObject, &valObject))
      {
--- 4008,4031 ----
  }
  
      static int
! pydict_to_tv(PyObject *obj, typval_T *tv, PyObject *lookup_dict)
  {
!     dict_T	*dict;
      char_u	*key;
      dictitem_T	*di;
      PyObject	*keyObject;
      PyObject	*valObject;
      Py_ssize_t	iter = 0;
  
!     dict = dict_alloc();
!     if (dict == NULL)
      {
  	PyErr_NoMemory();
  	return -1;
      }
  
      tv->v_type = VAR_DICT;
!     tv->vval.v_dict = dict;
  
      while (PyDict_Next(obj, &iter, &keyObject, &valObject))
      {
***************
*** 4049,4060 ****
  	}
  	di->di_tv.v_lock = 0;
  
! 	if (_ConvertFromPyObject(valObject, &di->di_tv, lookupDict) == -1)
  	{
  	    vim_free(di);
  	    return -1;
  	}
! 	if (dict_add(d, di) == FAIL)
  	{
  	    vim_free(di);
  	    PyErr_SetVim(_("failed to add key to dictionary"));
--- 4049,4061 ----
  	}
  	di->di_tv.v_lock = 0;
  
! 	if (_ConvertFromPyObject(valObject, &di->di_tv, lookup_dict) == -1)
  	{
  	    vim_free(di);
  	    return -1;
  	}
! 
! 	if (dict_add(dict, di) == FAIL)
  	{
  	    vim_free(di);
  	    PyErr_SetVim(_("failed to add key to dictionary"));
***************
*** 4065,4073 ****
  }
  
      static int
! pymap_to_tv(PyObject *obj, typval_T *tv, PyObject *lookupDict)
  {
!     dict_T	*d;
      char_u	*key;
      dictitem_T	*di;
      PyObject	*list;
--- 4066,4074 ----
  }
  
      static int
! pymap_to_tv(PyObject *obj, typval_T *tv, PyObject *lookup_dict)
  {
!     dict_T	*dict;
      char_u	*key;
      dictitem_T	*di;
      PyObject	*list;
***************
*** 4076,4090 ****
      PyObject	*valObject;
      Py_ssize_t	lsize;
  
!     d = dict_alloc();
!     if (d == NULL)
      {
  	PyErr_NoMemory();
  	return -1;
      }
  
      tv->v_type = VAR_DICT;
!     tv->vval.v_dict = d;
  
      list = PyMapping_Items(obj);
      if (list == NULL)
--- 4077,4091 ----
      PyObject	*valObject;
      Py_ssize_t	lsize;
  
!     dict = dict_alloc();
!     if (dict == NULL)
      {
  	PyErr_NoMemory();
  	return -1;
      }
  
      tv->v_type = VAR_DICT;
!     tv->vval.v_dict = dict;
  
      list = PyMapping_Items(obj);
      if (list == NULL)
***************
*** 4132,4145 ****
  	}
  	di->di_tv.v_lock = 0;
  
! 	if (_ConvertFromPyObject(valObject, &di->di_tv, lookupDict) == -1)
  	{
  	    vim_free(di);
  	    Py_DECREF(list);
  	    Py_DECREF(litem);
  	    return -1;
  	}
! 	if (dict_add(d, di) == FAIL)
  	{
  	    vim_free(di);
  	    Py_DECREF(list);
--- 4133,4146 ----
  	}
  	di->di_tv.v_lock = 0;
  
! 	if (_ConvertFromPyObject(valObject, &di->di_tv, lookup_dict) == -1)
  	{
  	    vim_free(di);
  	    Py_DECREF(list);
  	    Py_DECREF(litem);
  	    return -1;
  	}
! 	if (dict_add(dict, di) == FAIL)
  	{
  	    vim_free(di);
  	    Py_DECREF(list);
***************
*** 4154,4160 ****
  }
  
      static int
! pyseq_to_tv(PyObject *obj, typval_T *tv, PyObject *lookupDict)
  {
      list_T	*l;
  
--- 4155,4161 ----
  }
  
      static int
! pyseq_to_tv(PyObject *obj, typval_T *tv, PyObject *lookup_dict)
  {
      list_T	*l;
  
***************
*** 4168,4181 ****
      tv->v_type = VAR_LIST;
      tv->vval.v_list = l;
  
!     if (list_py_concat(l, obj, lookupDict) == -1)
  	return -1;
  
      return 0;
  }
  
      static int
! pyiter_to_tv(PyObject *obj, typval_T *tv, PyObject *lookupDict)
  {
      PyObject	*iterator = PyObject_GetIter(obj);
      PyObject	*item;
--- 4169,4182 ----
      tv->v_type = VAR_LIST;
      tv->vval.v_list = l;
  
!     if (list_py_concat(l, obj, lookup_dict) == -1)
  	return -1;
  
      return 0;
  }
  
      static int
! pyiter_to_tv(PyObject *obj, typval_T *tv, PyObject *lookup_dict)
  {
      PyObject	*iterator = PyObject_GetIter(obj);
      PyObject	*item;
***************
*** 4207,4213 ****
  	}
  	li->li_tv.v_lock = 0;
  
! 	if (_ConvertFromPyObject(item, &li->li_tv, lookupDict) == -1)
  	    return -1;
  
  	list_append(l, li);
--- 4208,4214 ----
  	}
  	li->li_tv.v_lock = 0;
  
! 	if (_ConvertFromPyObject(item, &li->li_tv, lookup_dict) == -1)
  	    return -1;
  
  	list_append(l, li);
***************
*** 4223,4229 ****
  
      static int
  convert_dl(PyObject *obj, typval_T *tv,
! 				    pytotvfunc py_to_tv, PyObject *lookupDict)
  {
      PyObject	*capsule;
      char	hexBuf[sizeof(void *) * 2 + 3];
--- 4224,4230 ----
  
      static int
  convert_dl(PyObject *obj, typval_T *tv,
! 				    pytotvfunc py_to_tv, PyObject *lookup_dict)
  {
      PyObject	*capsule;
      char	hexBuf[sizeof(void *) * 2 + 3];
***************
*** 4231,4239 ****
      sprintf(hexBuf, "%p", obj);
  
  # ifdef PY_USE_CAPSULE
!     capsule = PyDict_GetItemString(lookupDict, hexBuf);
  # else
!     capsule = (PyObject *)PyDict_GetItemString(lookupDict, hexBuf);
  # endif
      if (capsule == NULL)
      {
--- 4232,4240 ----
      sprintf(hexBuf, "%p", obj);
  
  # ifdef PY_USE_CAPSULE
!     capsule = PyDict_GetItemString(lookup_dict, hexBuf);
  # else
!     capsule = (PyObject *)PyDict_GetItemString(lookup_dict, hexBuf);
  # endif
      if (capsule == NULL)
      {
***************
*** 4242,4250 ****
  # else
  	capsule = PyCObject_FromVoidPtr(tv, NULL);
  # endif
! 	PyDict_SetItemString(lookupDict, hexBuf, capsule);
  	Py_DECREF(capsule);
! 	if (py_to_tv(obj, tv, lookupDict) == -1)
  	{
  	    tv->v_type = VAR_UNKNOWN;
  	    return -1;
--- 4243,4251 ----
  # else
  	capsule = PyCObject_FromVoidPtr(tv, NULL);
  # endif
! 	PyDict_SetItemString(lookup_dict, hexBuf, capsule);
  	Py_DECREF(capsule);
! 	if (py_to_tv(obj, tv, lookup_dict) == -1)
  	{
  	    tv->v_type = VAR_UNKNOWN;
  	    return -1;
***************
*** 4284,4290 ****
  }
  
      static int
! _ConvertFromPyObject(PyObject *obj, typval_T *tv, PyObject *lookupDict)
  {
      if (obj->ob_type == &DictionaryType)
      {
--- 4285,4291 ----
  }
  
      static int
! _ConvertFromPyObject(PyObject *obj, typval_T *tv, PyObject *lookup_dict)
  {
      if (obj->ob_type == &DictionaryType)
      {
***************
*** 4356,4362 ****
  	tv->vval.v_number = (varnumber_T) PyLong_AsLong(obj);
      }
      else if (PyDict_Check(obj))
! 	return convert_dl(obj, tv, pydict_to_tv, lookupDict);
  #ifdef FEAT_FLOAT
      else if (PyFloat_Check(obj))
      {
--- 4357,4363 ----
  	tv->vval.v_number = (varnumber_T) PyLong_AsLong(obj);
      }
      else if (PyDict_Check(obj))
! 	return convert_dl(obj, tv, pydict_to_tv, lookup_dict);
  #ifdef FEAT_FLOAT
      else if (PyFloat_Check(obj))
      {
***************
*** 4365,4375 ****
      }
  #endif
      else if (PyIter_Check(obj))
! 	return convert_dl(obj, tv, pyiter_to_tv, lookupDict);
      else if (PySequence_Check(obj))
! 	return convert_dl(obj, tv, pyseq_to_tv, lookupDict);
      else if (PyMapping_Check(obj))
! 	return convert_dl(obj, tv, pymap_to_tv, lookupDict);
      else
      {
  	PyErr_SetString(PyExc_TypeError,
--- 4366,4376 ----
      }
  #endif
      else if (PyIter_Check(obj))
! 	return convert_dl(obj, tv, pyiter_to_tv, lookup_dict);
      else if (PySequence_Check(obj))
! 	return convert_dl(obj, tv, pyseq_to_tv, lookup_dict);
      else if (PyMapping_Check(obj))
! 	return convert_dl(obj, tv, pymap_to_tv, lookup_dict);
      else
      {
  	PyErr_SetString(PyExc_TypeError,

Raspunde prin e-mail lui