diff options
author | Thiago de Arruda <tpadilha84@gmail.com> | 2014-08-28 17:01:58 -0300 |
---|---|---|
committer | Thiago de Arruda <tpadilha84@gmail.com> | 2014-08-29 22:08:58 -0300 |
commit | a66d2d15382fb153bfa860c0b3ea7cb9630c8afa (patch) | |
tree | 6790fb6db9b1cccf006dacb4df175a28eb1dea6f /src/nvim/ex_cmds2.c | |
parent | aa23d2f835e32c01b318712459ba7b9f55922469 (diff) | |
download | rneovim-a66d2d15382fb153bfa860c0b3ea7cb9630c8afa.tar.gz rneovim-a66d2d15382fb153bfa860c0b3ea7cb9630c8afa.tar.bz2 rneovim-a66d2d15382fb153bfa860c0b3ea7cb9630c8afa.zip |
msgpack-rpc: Always use arrays when sending events or calls
This is required by the msgpack-RPC specification. Also, the
send_call/send_event functions were refactored to accept a variable number of
arguments
Diffstat (limited to 'src/nvim/ex_cmds2.c')
-rw-r--r-- | src/nvim/ex_cmds2.c | 20 |
1 files changed, 11 insertions, 9 deletions
diff --git a/src/nvim/ex_cmds2.c b/src/nvim/ex_cmds2.c index e0b0b55f41..3809858875 100644 --- a/src/nvim/ex_cmds2.c +++ b/src/nvim/ex_cmds2.c @@ -3251,8 +3251,9 @@ static void script_host_execute(char *method, exarg_T *eap) char *script = (char *)script_get(eap, eap->arg); if (!eap->skip) { - String str = cstr_to_string(script ? script : (char *)eap->arg); - Object result = provider_call(method, STRING_OBJ(str)); + Array args = ARRAY_DICT_INIT; + ADD(args, STRING_OBJ(cstr_to_string(script ? script : (char *)eap->arg))); + Object result = provider_call(method, args); // We don't care about the result, so free it just in case a bad provider // returned something msgpack_rpc_free_object(result); @@ -3266,18 +3267,19 @@ static void script_host_execute_file(char *method, exarg_T *eap) char buffer[MAXPATHL]; vim_FullName(eap->arg, (uint8_t *)buffer, sizeof(buffer), false); - String file = cstr_to_string(buffer); - Object result = provider_call(method, STRING_OBJ(file)); + Array args = ARRAY_DICT_INIT; + ADD(args, STRING_OBJ(cstr_to_string(buffer))); + Object result = provider_call(method, args); msgpack_rpc_free_object(result); } static void script_host_do_range(char *method, exarg_T *eap) { - Array arg = {0, 0, 0}; - ADD(arg, INTEGER_OBJ(eap->line1)); - ADD(arg, INTEGER_OBJ(eap->line2)); - ADD(arg, STRING_OBJ(cstr_to_string((char *)eap->arg))); - Object result = provider_call(method, ARRAY_OBJ(arg)); + Array args = ARRAY_DICT_INIT; + ADD(args, INTEGER_OBJ(eap->line1)); + ADD(args, INTEGER_OBJ(eap->line2)); + ADD(args, STRING_OBJ(cstr_to_string((char *)eap->arg))); + Object result = provider_call(method, args); msgpack_rpc_free_object(result); } |