summaryrefslogtreecommitdiff
path: root/server-beta/src
diff options
context:
space:
mode:
Diffstat (limited to 'server-beta/src')
-rw-r--r--server-beta/src/files.lua6
-rw-r--r--server-beta/src/proto/provider.lua3
-rw-r--r--server-beta/src/pub/pub.lua2
-rw-r--r--server-beta/src/task.lua5
4 files changed, 12 insertions, 4 deletions
diff --git a/server-beta/src/files.lua b/server-beta/src/files.lua
index 0d8bd526..15190630 100644
--- a/server-beta/src/files.lua
+++ b/server-beta/src/files.lua
@@ -41,9 +41,11 @@ function m.setText(uri, text)
pub.removeTask(file.compiling)
end
file.compiling = pub.syncTask('compile', text, function (ast)
- ast.uri = originUri
- file.ast = ast
file.compiling = nil
+ file.ast = ast
+ if ast then
+ ast.uri = originUri
+ end
local onCompiledList = file.onCompiledList
if onCompiledList then
file.onCompiledList = nil
diff --git a/server-beta/src/proto/provider.lua b/server-beta/src/proto/provider.lua
index 3e89a50c..01121a15 100644
--- a/server-beta/src/proto/provider.lua
+++ b/server-beta/src/proto/provider.lua
@@ -68,6 +68,9 @@ proto.on('textDocument/definition', function (params)
local core = require 'core.definition'
local uri = params.textDocument.uri
local ast = files.getAst(uri)
+ if not ast then
+ return nil
+ end
local text = files.getText(uri)
local offset = inte.offset(ast.lines, text, params.position)
local result = core(ast, text, offset)
diff --git a/server-beta/src/pub/pub.lua b/server-beta/src/pub/pub.lua
index f5ed9e8f..b077ad9f 100644
--- a/server-beta/src/pub/pub.lua
+++ b/server-beta/src/pub/pub.lua
@@ -90,7 +90,7 @@ function m.popTask(brave, id, result)
m.checkWaitingTask(brave)
if not info.removed then
info.removed = true
- info.callback(result)
+ xpcall(info.callback, log.error, result)
end
end
diff --git a/server-beta/src/task.lua b/server-beta/src/task.lua
index 9219a6a2..5b7fb8dd 100644
--- a/server-beta/src/task.lua
+++ b/server-beta/src/task.lua
@@ -13,7 +13,10 @@ end
--- 创建一个任务
function m.create(callback)
local co = coroutine.create(callback)
- coroutine.resume(co)
+ local suc, err = coroutine.resume(co)
+ if not suc and m.errHandle then
+ m.errHandle(debug.traceback(co, err))
+ end
end
--- 休眠一段时间