diff options
| -rw-r--r-- | src/nvim/api/helpers.c | 11 | 
1 files changed, 6 insertions, 5 deletions
| diff --git a/src/nvim/api/helpers.c b/src/nvim/api/helpers.c index aa76a5dc24..2f79bebeef 100644 --- a/src/nvim/api/helpers.c +++ b/src/nvim/api/helpers.c @@ -14,14 +14,15 @@  #include "nvim/lib/khash.h" +  #if defined(ARCH_64) -typedef uint64_t ptr_int_t; -KHASH_SET_INIT_INT64(Lookup) +#define ptr_hash_func(key) kh_int64_hash_func(key)  #elif defined(ARCH_32) -typedef uint32_t ptr_int_t; -KHASH_SET_INIT_INT(Lookup) +#define ptr_hash_func(key) kh_int_hash_func(key)  #endif +KHASH_INIT(Lookup, uintptr_t, char, 0, ptr_hash_func, kh_int_hash_equal) +  /// Recursion helper for the `vim_to_object`. This uses a pointer table  /// to avoid infinite recursion due to cyclic references  /// @@ -412,7 +413,7 @@ static Object vim_to_object_rec(typval_T *obj, khash_t(Lookup) *lookup)    if (obj->v_type == VAR_LIST || obj->v_type == VAR_DICT) {      int ret;      // Container object, add it to the lookup table -    kh_put(Lookup, lookup, (ptr_int_t)obj, &ret); +    kh_put(Lookup, lookup, (uintptr_t)obj, &ret);      if (!ret) {        // It's already present, meaning we alredy processed it so just return        // nil instead. | 
