diff options
author | Josh Rahm <joshuarahm@gmail.com> | 2025-02-05 23:09:29 +0000 |
---|---|---|
committer | Josh Rahm <joshuarahm@gmail.com> | 2025-02-05 23:09:29 +0000 |
commit | d5f194ce780c95821a855aca3c19426576d28ae0 (patch) | |
tree | d45f461b19f9118ad2bb1f440a7a08973ad18832 /test/client/msgpack_rpc_stream.lua | |
parent | c5d770d311841ea5230426cc4c868e8db27300a8 (diff) | |
parent | 44740e561fc93afe3ebecfd3618bda2d2abeafb0 (diff) | |
download | rneovim-rahm.tar.gz rneovim-rahm.tar.bz2 rneovim-rahm.zip |
Diffstat (limited to 'test/client/msgpack_rpc_stream.lua')
-rw-r--r-- | test/client/msgpack_rpc_stream.lua | 105 |
1 files changed, 0 insertions, 105 deletions
diff --git a/test/client/msgpack_rpc_stream.lua b/test/client/msgpack_rpc_stream.lua deleted file mode 100644 index 7131940a58..0000000000 --- a/test/client/msgpack_rpc_stream.lua +++ /dev/null @@ -1,105 +0,0 @@ -local mpack = vim.mpack - -local Response = {} -Response.__index = Response - -function Response.new(msgpack_rpc_stream, request_id) - return setmetatable({ - _msgpack_rpc_stream = msgpack_rpc_stream, - _request_id = request_id, - }, Response) -end - -function Response:send(value, is_error) - local data = self._msgpack_rpc_stream._session:reply(self._request_id) - if is_error then - data = data .. self._msgpack_rpc_stream._pack(value) - data = data .. self._msgpack_rpc_stream._pack(mpack.NIL) - else - data = data .. self._msgpack_rpc_stream._pack(mpack.NIL) - data = data .. self._msgpack_rpc_stream._pack(value) - end - self._msgpack_rpc_stream._stream:write(data) -end - ---- @class test.MsgpackRpcStream ---- @field private _stream test.Stream ---- @field private __pack table -local MsgpackRpcStream = {} -MsgpackRpcStream.__index = MsgpackRpcStream - -function MsgpackRpcStream.new(stream) - return setmetatable({ - _stream = stream, - _pack = mpack.Packer(), - _session = mpack.Session({ - unpack = mpack.Unpacker({ - ext = { - -- Buffer - [0] = function(_c, s) - return mpack.decode(s) - end, - -- Window - [1] = function(_c, s) - return mpack.decode(s) - end, - -- Tabpage - [2] = function(_c, s) - return mpack.decode(s) - end, - }, - }), - }), - }, MsgpackRpcStream) -end - -function MsgpackRpcStream:write(method, args, response_cb) - local data - if response_cb then - assert(type(response_cb) == 'function') - data = self._session:request(response_cb) - else - data = self._session:notify() - end - - data = data .. self._pack(method) .. self._pack(args) - self._stream:write(data) -end - -function MsgpackRpcStream:read_start(request_cb, notification_cb, eof_cb) - self._stream:read_start(function(data) - if not data then - return eof_cb() - end - local type, id_or_cb, method_or_error, args_or_result - local pos = 1 - local len = #data - while pos <= len do - type, id_or_cb, method_or_error, args_or_result, pos = self._session:receive(data, pos) - if type == 'request' or type == 'notification' then - if type == 'request' then - request_cb(method_or_error, args_or_result, Response.new(self, id_or_cb)) - else - notification_cb(method_or_error, args_or_result) - end - elseif type == 'response' then - if method_or_error == mpack.NIL then - method_or_error = nil - else - args_or_result = nil - end - id_or_cb(method_or_error, args_or_result) - end - end - end) -end - -function MsgpackRpcStream:read_stop() - self._stream:read_stop() -end - -function MsgpackRpcStream:close(signal) - self._stream:close(signal) -end - -return MsgpackRpcStream |