diff options
author | Thiago de Arruda <tpadilha84@gmail.com> | 2014-05-28 09:05:13 -0300 |
---|---|---|
committer | Thiago de Arruda <tpadilha84@gmail.com> | 2014-05-28 09:05:13 -0300 |
commit | e4fe2dbd777a59a9a9b386d960eb9dddc459e84e (patch) | |
tree | aa99bd39c8a87c95f93457dcf4456caab45f7310 /src/nvim/api/vim.c | |
parent | 1faf546ea286ae324c79cfef3b5613a0004182bb (diff) | |
parent | cd8421537034d0b5cc567d81afc4fa5316da171e (diff) | |
download | rneovim-e4fe2dbd777a59a9a9b386d960eb9dddc459e84e.tar.gz rneovim-e4fe2dbd777a59a9a9b386d960eb9dddc459e84e.tar.bz2 rneovim-e4fe2dbd777a59a9a9b386d960eb9dddc459e84e.zip |
Merge 'Refactor WStream to enable writing the same buffer to multiple targets'
Diffstat (limited to 'src/nvim/api/vim.c')
-rw-r--r-- | src/nvim/api/vim.c | 19 |
1 files changed, 19 insertions, 0 deletions
diff --git a/src/nvim/api/vim.c b/src/nvim/api/vim.c index 694781e0a3..39e2c32d6d 100644 --- a/src/nvim/api/vim.c +++ b/src/nvim/api/vim.c @@ -7,6 +7,7 @@ #include "nvim/api/private/helpers.h" #include "nvim/api/private/defs.h" #include "nvim/api/buffer.h" +#include "nvim/os/channel.h" #include "nvim/vim.h" #include "nvim/buffer.h" #include "nvim/window.h" @@ -327,6 +328,24 @@ void vim_set_current_tabpage(Tabpage tabpage, Error *err) try_end(err); } +void vim_subscribe(uint64_t channel_id, String event) +{ + size_t length = (event.size < EVENT_MAXLEN ? event.size : EVENT_MAXLEN); + char e[EVENT_MAXLEN + 1]; + memcpy(e, event.data, length); + e[length] = NUL; + channel_subscribe(channel_id, e); +} + +void vim_unsubscribe(uint64_t channel_id, String event) +{ + size_t length = (event.size < EVENT_MAXLEN ? event.size : EVENT_MAXLEN); + char e[EVENT_MAXLEN + 1]; + memcpy(e, event.data, length); + e[length] = NUL; + channel_unsubscribe(channel_id, e); +} + static void write_msg(String message, bool to_err) { static int pos = 0; |