diff options
| author | Thiago de Arruda <tpadilha84@gmail.com> | 2014-05-26 13:39:10 -0300 | 
|---|---|---|
| committer | Thiago de Arruda <tpadilha84@gmail.com> | 2014-05-26 14:02:12 -0300 | 
| commit | f3dc04bf7f658f7d5d15047494fd15e286b4c7b6 (patch) | |
| tree | 15a3471f10989c2877211447903fb9a2df66732f /src/nvim/eval.c | |
| parent | 139c7ffdc785b19297e8c3b2d2586dfa284f97a5 (diff) | |
| download | rneovim-f3dc04bf7f658f7d5d15047494fd15e286b4c7b6.tar.gz rneovim-f3dc04bf7f658f7d5d15047494fd15e286b4c7b6.tar.bz2 rneovim-f3dc04bf7f658f7d5d15047494fd15e286b4c7b6.zip | |
API: Events: Implement channel_send_event and vimscript wrapper
This function can be used to send arbitrary objects via the API channel back to
connected clients, identified by channel id.
Diffstat (limited to 'src/nvim/eval.c')
| -rw-r--r-- | src/nvim/eval.c | 34 | 
1 files changed, 33 insertions, 1 deletions
| diff --git a/src/nvim/eval.c b/src/nvim/eval.c index d09a83abcd..87054aa9df 100644 --- a/src/nvim/eval.c +++ b/src/nvim/eval.c @@ -12,7 +12,6 @@  #include <string.h>  #include <stdlib.h> -  #include "nvim/vim.h"  #include "nvim/eval.h"  #include "nvim/buffer.h" @@ -67,6 +66,7 @@  #include "nvim/os/rstream.h"  #include "nvim/os/rstream_defs.h"  #include "nvim/os/time.h" +#include "nvim/os/channel.h"  #if defined(FEAT_FLOAT)  # include <math.h> @@ -695,6 +695,7 @@ static void f_searchdecl(typval_T *argvars, typval_T *rettv);  static void f_searchpair(typval_T *argvars, typval_T *rettv);  static void f_searchpairpos(typval_T *argvars, typval_T *rettv);  static void f_searchpos(typval_T *argvars, typval_T *rettv); +static void f_send_event(typval_T *argvars, typval_T *rettv);  static void f_setbufvar(typval_T *argvars, typval_T *rettv);  static void f_setcmdpos(typval_T *argvars, typval_T *rettv);  static void f_setline(typval_T *argvars, typval_T *rettv); @@ -6944,6 +6945,7 @@ static struct fst {    {"searchpair",      3, 7, f_searchpair},    {"searchpairpos",   3, 7, f_searchpairpos},    {"searchpos",       1, 4, f_searchpos}, +  {"send_event",      3, 3, f_send_event},    {"setbufvar",       3, 3, f_setbufvar},    {"setcmdpos",       1, 1, f_setcmdpos},    {"setline",         2, 2, f_setline}, @@ -13057,6 +13059,36 @@ do_searchpair (    return retval;  } +// "send_event()" function +static void f_send_event(typval_T *argvars, typval_T *rettv) +{ +  rettv->v_type = VAR_NUMBER; +  rettv->vval.v_number = 0; + +  if (check_restricted() || check_secure()) { +    return; +  } + +  if (argvars[0].v_type != VAR_NUMBER || argvars[0].vval.v_number <= 0) { +    EMSG2(_(e_invarg2), "Channel id must be a positive integer"); +    return; +  } + +  if (argvars[1].v_type != VAR_STRING) { +    EMSG2(_(e_invarg2), "Event type must be a string"); +    return; +  } + +  if (!channel_send_event((uint64_t)argvars[0].vval.v_number, +                          (char *)argvars[1].vval.v_string, +                          &argvars[2])) { +    EMSG2(_(e_invarg2), "Channel doesn't exist"); +    return; +  } + +  rettv->vval.v_number = 1; +} +  /*   * "searchpos()" function   */ | 
