summaryrefslogtreecommitdiff
path: root/script/brave
diff options
context:
space:
mode:
author最萌小汐 <sumneko@hotmail.com>2023-10-24 12:18:45 +0800
committer最萌小汐 <sumneko@hotmail.com>2023-10-24 12:18:45 +0800
commitadf8d529e0110f5b40a97ce02afd08822aeefe25 (patch)
treec7e1581b9f204766bc7794b52cbff7cdf2e6bdb1 /script/brave
parent2d4143cc1c5dd6a117264e0b6f4119b6f97b3d0b (diff)
downloadlua-language-server-adf8d529e0110f5b40a97ce02afd08822aeefe25.zip
update socket mode
#2382
Diffstat (limited to 'script/brave')
-rw-r--r--script/brave/work.lua44
1 files changed, 18 insertions, 26 deletions
diff --git a/script/brave/work.lua b/script/brave/work.lua
index 9eb756eb..47cc9459 100644
--- a/script/brave/work.lua
+++ b/script/brave/work.lua
@@ -15,10 +15,7 @@ end)
brave.on('loadProtoBySocket', function (param)
local jsonrpc = require 'jsonrpc'
- local socket = require 'bee.socket'
- local util = require 'utility'
- local rfd = socket.fd(param.rfd)
- local wfd = socket.fd(param.wfd)
+ local net = require 'service.net'
local buf = ''
---@async
@@ -44,29 +41,24 @@ brave.on('loadProtoBySocket', function (param)
end
end)
+ local lsclient = net.connect('tcp', '127.0.0.1', param.port)
+ local lsmaster = net.connect('unix', param.unixPath)
+
+ assert(lsclient)
+ assert(lsmaster)
+
+ function lsclient:on_data(data)
+ buf = buf .. data
+ coroutine.resume(parser)
+ end
+
+ function lsmaster:on_data(data)
+ lsclient:write(data)
+ lsclient:update()
+ end
+
while true do
- local rd = socket.select({rfd, wfd}, nil, 10)
- if not rd or #rd == 0 then
- goto continue
- end
- if util.arrayHas(rd, wfd) then
- local needSend = wfd:recv()
- if needSend then
- rfd:send(needSend)
- elseif needSend == nil then
- error('socket closed!')
- end
- end
- if util.arrayHas(rd, rfd) then
- local recved = rfd:recv()
- if recved then
- buf = buf .. recved
- elseif recved == nil then
- error('socket closed!')
- end
- coroutine.resume(parser)
- end
- ::continue::
+ net.update(10)
end
end)