mirror of
https://github.com/neovim/neovim.git
synced 2025-10-16 06:46:07 +00:00

This is how API dispatching worked before this commit: - The generated `msgpack_rpc_dispatch` function receives a the `msgpack_packer` argument. - The response is incrementally built while validating/calling the API. - Return values/errors are also packed into the `msgpack_packer` while the final response is being calculated. Now the `msgpack_packer` argument is no longer provided, and the `msgpack_rpc_dispatch` function returns `Object`/`Error` values to `msgpack_rpc_call`, which will use those values to build the response in a single pass. This was done because the new `channel_send_call` function created the possibility of having recursive API invocations, and this wasn't possible when sharing a single `msgpack_sbuffer` across call frames(it was shared implicitly through the `msgpack_packer` instance). Since we only start to build the response when the necessary information has been computed, it's now safe to share a single `msgpack_sbuffer` instance across all channels and API invocations. Some other changes also had to be performed: - Handling of the metadata discover was moved to `msgpack_rpc_call` - Expose more types as subtypes of `Object`, this was required to forward the return value from `msgpack_rpc_dispatch` to `msgpack_rpc_call` - Added more helper macros for casting API types to `Object` any
98 lines
4.2 KiB
C
98 lines
4.2 KiB
C
#ifndef NVIM_API_PRIVATE_HELPERS_H
|
|
#define NVIM_API_PRIVATE_HELPERS_H
|
|
|
|
#include <stdbool.h>
|
|
|
|
#include "nvim/api/private/defs.h"
|
|
#include "nvim/vim.h"
|
|
#include "nvim/memory.h"
|
|
#include "nvim/lib/kvec.h"
|
|
|
|
#define set_api_error(message, err) \
|
|
do { \
|
|
xstrlcpy(err->msg, message, sizeof(err->msg)); \
|
|
err->set = true; \
|
|
} while (0)
|
|
|
|
#define OBJECT_OBJ(o) o
|
|
|
|
#define BOOLEAN_OBJ(b) ((Object) { \
|
|
.type = kObjectTypeBoolean, \
|
|
.data.boolean = b \
|
|
})
|
|
|
|
#define INTEGER_OBJ(i) ((Object) { \
|
|
.type = kObjectTypeInteger, \
|
|
.data.integer = i \
|
|
})
|
|
|
|
#define STRING_OBJ(s) ((Object) { \
|
|
.type = kObjectTypeString, \
|
|
.data.string = s \
|
|
})
|
|
|
|
#define BUFFER_OBJ(s) ((Object) { \
|
|
.type = kObjectTypeBuffer, \
|
|
.data.buffer = s \
|
|
})
|
|
|
|
#define WINDOW_OBJ(s) ((Object) { \
|
|
.type = kObjectTypeWindow, \
|
|
.data.window = s \
|
|
})
|
|
|
|
#define TABPAGE_OBJ(s) ((Object) { \
|
|
.type = kObjectTypeTabpage, \
|
|
.data.tabpage = s \
|
|
})
|
|
|
|
#define ARRAY_OBJ(a) ((Object) { \
|
|
.type = kObjectTypeArray, \
|
|
.data.array = a \
|
|
})
|
|
|
|
#define STRINGARRAY_OBJ(a) ((Object) { \
|
|
.type = kObjectTypeStringArray, \
|
|
.data.stringarray = a \
|
|
})
|
|
|
|
#define BUFFERARRAY_OBJ(a) ((Object) { \
|
|
.type = kObjectTypeBufferArray, \
|
|
.data.bufferarray = a \
|
|
})
|
|
|
|
#define WINDOWARRAY_OBJ(a) ((Object) { \
|
|
.type = kObjectTypeWindowArray, \
|
|
.data.windowarray = a \
|
|
})
|
|
|
|
#define TABPAGEARRAY_OBJ(a) ((Object) { \
|
|
.type = kObjectTypeTabpageArray, \
|
|
.data.tabpagearray = a \
|
|
})
|
|
|
|
#define DICTIONARY_OBJ(d) ((Object) { \
|
|
.type = kObjectTypeDictionary, \
|
|
.data.dictionary = d \
|
|
})
|
|
|
|
#define POSITION_OBJ(p) ((Object) { \
|
|
.type = kObjectTypePosition, \
|
|
.data.position = p \
|
|
})
|
|
|
|
#define NIL ((Object) {.type = kObjectTypeNil})
|
|
|
|
#define PUT(dict, k, v) \
|
|
kv_push(KeyValuePair, \
|
|
dict, \
|
|
((KeyValuePair) {.key = cstr_to_string(k), .value = v}))
|
|
|
|
#define ADD(array, item) \
|
|
kv_push(Object, array, item)
|
|
|
|
#ifdef INCLUDE_GENERATED_DECLARATIONS
|
|
# include "api/private/helpers.h.generated.h"
|
|
#endif
|
|
#endif // NVIM_API_PRIVATE_HELPERS_H
|