From 1c7f461c70fbcf6937097e55aae0fc1ff0645f65 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E6=9C=80=E8=90=8C=E5=B0=8F=E6=B1=90?= Date: Wed, 28 Aug 2019 20:49:54 +0800 Subject: =?UTF-8?q?=E6=B5=8B=E8=AF=95=E6=94=BE=E5=88=B0=E5=A4=96=E9=9D=A2?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- server/build_package.lua | 258 ++++++++++++++++++++++++++++++++++++++++++ server/main.lua | 2 +- server/publish.lua | 2 +- server/test.lua | 76 +++++++++---- server/test/build_package.lua | 258 ------------------------------------------ server/test/main.lua | 58 ---------- 6 files changed, 311 insertions(+), 343 deletions(-) create mode 100644 server/build_package.lua delete mode 100644 server/test/build_package.lua delete mode 100644 server/test/main.lua (limited to 'server') diff --git a/server/build_package.lua b/server/build_package.lua new file mode 100644 index 00000000..0abfc267 --- /dev/null +++ b/server/build_package.lua @@ -0,0 +1,258 @@ +local json = require 'json' +local diagDefault = require 'constant.DiagnosticDefaultSeverity' + +local VERSION = "0.12.0" + +local package = { + name = "lua", + displayName = "Lua", + description = "Lua Language Server coded by Lua", + author = "sumneko", + icon = "images/logo.png", + license = "MIT", + repository = { + type = "git", + url = "https://github.com/sumneko/lua-language-server" + }, + publisher = "sumneko", + categories = { + "Linters", + "Programming Languages", + "Snippets" + }, + keywords = { + "Lua", + "LSP", + "GoTo Definition", + "IntelliSense" + }, + engines = { + vscode = "^1.23.0" + }, + activationEvents = { + "onLanguage:lua" + }, + main = "./client/out/extension", + contributes = { + configuration = { + type = "object", + title = "Lua", + properties = { + ["Lua.runtime.version"] = { + scope = "resource", + type = "string", + default = "Lua 5.3", + enum = { + "Lua 5.1", + "Lua 5.2", + "Lua 5.3", + "Lua 5.4", + "LuaJIT" + }, + markdownDescription = "%config.runtime.version%" + }, + ["Lua.runtime.path"] = { + scope = "resource", + type = "array", + items = { + type = 'string', + }, + markdownDescription = "%config.runtime.path%", + default = { + "?.lua", + "?/init.lua", + "?/?.lua" + } + }, + ["Lua.diagnostics.enable"] = { + scope = 'resource', + type = 'boolean', + default = true, + markdownDescription = "%config.diagnostics.enable%" + }, + ["Lua.diagnostics.disable"] = { + scope = "resource", + type = "array", + items = { + type = 'string', + }, + markdownDescription = "%config.diagnostics.disable%" + }, + ["Lua.diagnostics.globals"] = { + scope = "resource", + type = "array", + items = { + type = 'string', + }, + markdownDescription = "%config.diagnostics.globals%" + }, + ["Lua.diagnostics.severity"] = { + scope = "resource", + type = 'object', + markdownDescription = "%config.diagnostics.severity%", + title = "severity", + properties = {} + }, + ["Lua.workspace.ignoreDir"] = { + scope = "resource", + type = "array", + items = { + type = 'string', + }, + markdownDescription = "%config.workspace.ignoreDir%" + }, + ["Lua.workspace.ignoreSubmodules"] = { + scope = "resource", + type = "boolean", + default = true, + markdownDescription = "%config.workspace.ignoreSubmodules%" + }, + ["Lua.workspace.useGitIgnore"] = { + scope = "resource", + type = "boolean", + default = true, + markdownDescription = "%config.workspace.useGitIgnore%" + }, + ["Lua.workspace.maxPreload"] = { + scope = "resource", + type = "integer", + default = 300, + markdownDescription = "%config.workspace.maxPreload%" + }, + ["Lua.workspace.preloadFileSize"] = { + scope = "resource", + type = "integer", + default = 100, + markdownDescription = "%config.workspace.preloadFileSize%" + }, + ["Lua.workspace.library"] = { + scope = 'resource', + type = 'object', + markdownDescription = "%config.workspace.library%" + }, + ["Lua.completion.callSnippet"] = { + scope = "resource", + type = "boolean", + default = true, + markdownDescription = "%config.completion.callSnippet%" + }, + } + }, + grammars = { + { + language = "lua", + scopeName = "source.lua", + path = "syntaxes/lua.tmLanguage.json" + } + } + }, + __metadata = { + id = "3a15b5a7-be12-47e3-8445-88ee3eabc8b2", + publisherDisplayName = "sumneko", + publisherId = "fb626675-24cf-4881-8c13-b465f29bec2f", + }, +} + +local DiagSeverity = package.contributes.configuration.properties["Lua.diagnostics.severity"].properties +for name, level in pairs(diagDefault) do + DiagSeverity[name] = { + scope = 'resource', + type = 'string', + default = level, + enum = { + 'Error', + 'Warning', + 'Information', + 'Hint', + } + } +end + +package.version = VERSION + +io.save(ROOT:parent_path() / 'package.json', json.encode(package)) + +local example = { + library = [[ +```json +"Lua.workspace.library": { + "C:/lua": true, + "../lib": [ + "temp/*" + ] +} +``` +]], + disable = [[ +```json +"Lua.diagnostics.disable" : [ + "unused-local", + "lowercase-global" +] +``` +]], + globals = [[ +```json +"Lua.diagnostics.globals" : [ + "GLOBAL1", + "GLOBAL2" +] +``` +]], + severity = [[ +```json +"Lua.diagnostics.severity" : { + "redefined-local" : "Warning", + "emmy-lua" : "Hint" +} +``` +]], + ignoreDir = [[ +```json +"Lua.workspace.ignoreDir" : [ + "temp/*.*", + "!temp/*.lua" +] +``` +]] +} + +io.save(ROOT:parent_path() / 'package.nls.json', json.encode { + ["config.runtime.version"] = "Lua runtime version.", + ["config.runtime.path"] = "`package.path`", + ["config.diagnostics.enable"] = "Enable diagnostics.", + ["config.diagnostics.disable"] = "Disabled diagnostic (Use code in hover brackets).\n" .. example.disable, + ["config.diagnostics.globals"] = "Defined global variables.\n" .. example.globals, + ["config.diagnostics.severity"] = "Modified diagnostic severity.\n" .. example.severity, + ["config.workspace.ignoreDir"] = "Ignored directories (Use `.gitignore` grammar).\n" .. example.ignoreDir, + ["config.workspace.ignoreSubmodules"] = "Ignore submodules.", + ["config.workspace.useGitIgnore"] = "Ignore files list in `.gitignore` .", + ["config.workspace.maxPreload"] = "Max preloaded files.", + ["config.workspace.preloadFileSize"] = "Skip files larger than this value (KB) when preloading.", + ["config.workspace.library"] = [[ +Load external library. +This feature can load external Lua files, which can be used for definition, automatic completion and other functions. Note that the language server does not monitor changes in external files and needs to restart if the external files are modified. +The following example shows loaded files in `C:/lua` and `../lib` ,exclude `../lib/temp`. +]] .. example.library, + ['config.completion.callSnippet'] = 'Show function call snippets.', +}) + +io.save(ROOT:parent_path() / 'package.nls.zh-cn.json', json.encode { + ["config.runtime.version"] = "Lua运行版本。", + ["config.runtime.path"] = "`package.path`", + ["config.diagnostics.enable"] = "启用诊断。", + ["config.diagnostics.disable"] = "禁用的诊断(使用浮框括号内的代码)。\n" .. example.disable, + ["config.diagnostics.globals"] = "已定义的全局变量。\n" .. example.globals, + ["config.diagnostics.severity"] = "修改诊断等级。\n" .. example.severity, + ["config.workspace.ignoreDir"] = "忽略的目录(使用 `.gitignore` 语法)。\n" .. example.ignoreDir, + ["config.workspace.ignoreSubmodules"] = "忽略子模块。", + ["config.workspace.useGitIgnore"] = "忽略 `.gitignore` 中列举的文件。", + ["config.workspace.maxPreload"] = "最大预加载文件数。", + ["config.workspace.preloadFileSize"] = "预加载时跳过大小大于该值(KB)的文件。", + ["config.workspace.library"] = [[ +加载外部函数库。 +该功能可以加载外部的Lua文件,用于函数定义、自动完成等功能。注意,语言服务不会监视外部文件的变化,如果修改了外部文件需要重启。 +下面这个例子表示加载`C:/lua`与`../lib`中的所有文件,但不加载`../lib/temp`中的文件。 +]] .. example.library, + ['config.completion.callSnippet'] = '显示函数调用片段。', +}) diff --git a/server/main.lua b/server/main.lua index 61f17f2f..754e3759 100644 --- a/server/main.lua +++ b/server/main.lua @@ -9,7 +9,7 @@ package.path = rootPath .. 'src/?.lua' .. ';' .. rootPath .. 'src/?/init.lua' local fs = require 'bee.filesystem' -ROOT = fs.absolute(fs.path(rootPath)) +ROOT = fs.absolute(fs.path(rootPath):parent_path()) LANG = LANG or 'en-US' --collectgarbage('generational') diff --git a/server/publish.lua b/server/publish.lua index b0040641..149d54d6 100644 --- a/server/publish.lua +++ b/server/publish.lua @@ -10,7 +10,7 @@ package.path = rootPath .. 'src/?.lua' local fs = require 'bee.filesystem' local subprocess = require 'bee.subprocess' -ROOT = fs.absolute(fs.path(rootPath)) +ROOT = fs.absolute(fs.path(rootPath):parent_path()) EXTENSION = fs.absolute(fs.path(rootPath .. '..')) require 'utility' diff --git a/server/test.lua b/server/test.lua index 05f1fcfd..b1945a0e 100644 --- a/server/test.lua +++ b/server/test.lua @@ -5,34 +5,60 @@ if rootPath == '' then end package.cpath = rootPath .. 'bin/?.so' .. ';' .. rootPath .. 'bin/?.dll' -package.path = rootPath .. 'src/?.lua' +package.path = rootPath .. 'test/?.lua' + .. ';' .. rootPath .. 'test/?/init.lua' + .. ';' .. rootPath .. 'src/?.lua' .. ';' .. rootPath .. 'src/?/init.lua' local fs = require 'bee.filesystem' -local subprocess = require 'bee.subprocess' -local platform = require 'bee.platform' -ROOT = fs.absolute(fs.path(rootPath)) - -local function runTest(root) - local ext = platform.OS == 'Windows' and '.exe' or '' - local exe = root / 'bin' / 'lua-language-server' .. ext - local test = root / 'test' / 'main.lua' - local lua = subprocess.spawn { - exe, - test, - '-E', - cwd = root, - stdout = true, - stderr = true, - } - for line in lua.stdout:lines 'l' do - print(line) - end - lua:wait() - local err = lua.stderr:read 'a' - if err ~= '' then - error(err) +ROOT = fs.absolute(fs.path(rootPath):parent_path()) +LANG = 'en-US' + +log = require 'log' +log.init(ROOT, ROOT / 'log' / 'test.log') +log.debug('测试开始') +ac = {} + +require 'utility' +require 'global_protect' +dofile((ROOT / 'build_package.lua'):string()) + +local function loadAllLibs() + assert(require 'bee.filesystem') + assert(require 'bee.subprocess') + assert(require 'bee.thread') + assert(require 'bee.socket') + assert(require 'lni') + assert(require 'lpeglabel') +end + +local function main() + local function test(name) + local clock = os.clock() + print(('测试[%s]...'):format(name)) + require(name) + print(('测试[%s]用时[%.3f]'):format(name, os.clock() - clock)) end + + test 'core' + test 'definition' + test 'rename' + test 'highlight' + test 'references' + test 'diagnostics' + test 'type_inference' + test 'find_lib' + test 'hover' + test 'completion' + test 'signature' + test 'document_symbol' + test 'crossfile' + test 'full' + + print('测试完成') end -runTest(ROOT) +loadAllLibs() +main() + +log.debug('测试完成') diff --git a/server/test/build_package.lua b/server/test/build_package.lua deleted file mode 100644 index 0abfc267..00000000 --- a/server/test/build_package.lua +++ /dev/null @@ -1,258 +0,0 @@ -local json = require 'json' -local diagDefault = require 'constant.DiagnosticDefaultSeverity' - -local VERSION = "0.12.0" - -local package = { - name = "lua", - displayName = "Lua", - description = "Lua Language Server coded by Lua", - author = "sumneko", - icon = "images/logo.png", - license = "MIT", - repository = { - type = "git", - url = "https://github.com/sumneko/lua-language-server" - }, - publisher = "sumneko", - categories = { - "Linters", - "Programming Languages", - "Snippets" - }, - keywords = { - "Lua", - "LSP", - "GoTo Definition", - "IntelliSense" - }, - engines = { - vscode = "^1.23.0" - }, - activationEvents = { - "onLanguage:lua" - }, - main = "./client/out/extension", - contributes = { - configuration = { - type = "object", - title = "Lua", - properties = { - ["Lua.runtime.version"] = { - scope = "resource", - type = "string", - default = "Lua 5.3", - enum = { - "Lua 5.1", - "Lua 5.2", - "Lua 5.3", - "Lua 5.4", - "LuaJIT" - }, - markdownDescription = "%config.runtime.version%" - }, - ["Lua.runtime.path"] = { - scope = "resource", - type = "array", - items = { - type = 'string', - }, - markdownDescription = "%config.runtime.path%", - default = { - "?.lua", - "?/init.lua", - "?/?.lua" - } - }, - ["Lua.diagnostics.enable"] = { - scope = 'resource', - type = 'boolean', - default = true, - markdownDescription = "%config.diagnostics.enable%" - }, - ["Lua.diagnostics.disable"] = { - scope = "resource", - type = "array", - items = { - type = 'string', - }, - markdownDescription = "%config.diagnostics.disable%" - }, - ["Lua.diagnostics.globals"] = { - scope = "resource", - type = "array", - items = { - type = 'string', - }, - markdownDescription = "%config.diagnostics.globals%" - }, - ["Lua.diagnostics.severity"] = { - scope = "resource", - type = 'object', - markdownDescription = "%config.diagnostics.severity%", - title = "severity", - properties = {} - }, - ["Lua.workspace.ignoreDir"] = { - scope = "resource", - type = "array", - items = { - type = 'string', - }, - markdownDescription = "%config.workspace.ignoreDir%" - }, - ["Lua.workspace.ignoreSubmodules"] = { - scope = "resource", - type = "boolean", - default = true, - markdownDescription = "%config.workspace.ignoreSubmodules%" - }, - ["Lua.workspace.useGitIgnore"] = { - scope = "resource", - type = "boolean", - default = true, - markdownDescription = "%config.workspace.useGitIgnore%" - }, - ["Lua.workspace.maxPreload"] = { - scope = "resource", - type = "integer", - default = 300, - markdownDescription = "%config.workspace.maxPreload%" - }, - ["Lua.workspace.preloadFileSize"] = { - scope = "resource", - type = "integer", - default = 100, - markdownDescription = "%config.workspace.preloadFileSize%" - }, - ["Lua.workspace.library"] = { - scope = 'resource', - type = 'object', - markdownDescription = "%config.workspace.library%" - }, - ["Lua.completion.callSnippet"] = { - scope = "resource", - type = "boolean", - default = true, - markdownDescription = "%config.completion.callSnippet%" - }, - } - }, - grammars = { - { - language = "lua", - scopeName = "source.lua", - path = "syntaxes/lua.tmLanguage.json" - } - } - }, - __metadata = { - id = "3a15b5a7-be12-47e3-8445-88ee3eabc8b2", - publisherDisplayName = "sumneko", - publisherId = "fb626675-24cf-4881-8c13-b465f29bec2f", - }, -} - -local DiagSeverity = package.contributes.configuration.properties["Lua.diagnostics.severity"].properties -for name, level in pairs(diagDefault) do - DiagSeverity[name] = { - scope = 'resource', - type = 'string', - default = level, - enum = { - 'Error', - 'Warning', - 'Information', - 'Hint', - } - } -end - -package.version = VERSION - -io.save(ROOT:parent_path() / 'package.json', json.encode(package)) - -local example = { - library = [[ -```json -"Lua.workspace.library": { - "C:/lua": true, - "../lib": [ - "temp/*" - ] -} -``` -]], - disable = [[ -```json -"Lua.diagnostics.disable" : [ - "unused-local", - "lowercase-global" -] -``` -]], - globals = [[ -```json -"Lua.diagnostics.globals" : [ - "GLOBAL1", - "GLOBAL2" -] -``` -]], - severity = [[ -```json -"Lua.diagnostics.severity" : { - "redefined-local" : "Warning", - "emmy-lua" : "Hint" -} -``` -]], - ignoreDir = [[ -```json -"Lua.workspace.ignoreDir" : [ - "temp/*.*", - "!temp/*.lua" -] -``` -]] -} - -io.save(ROOT:parent_path() / 'package.nls.json', json.encode { - ["config.runtime.version"] = "Lua runtime version.", - ["config.runtime.path"] = "`package.path`", - ["config.diagnostics.enable"] = "Enable diagnostics.", - ["config.diagnostics.disable"] = "Disabled diagnostic (Use code in hover brackets).\n" .. example.disable, - ["config.diagnostics.globals"] = "Defined global variables.\n" .. example.globals, - ["config.diagnostics.severity"] = "Modified diagnostic severity.\n" .. example.severity, - ["config.workspace.ignoreDir"] = "Ignored directories (Use `.gitignore` grammar).\n" .. example.ignoreDir, - ["config.workspace.ignoreSubmodules"] = "Ignore submodules.", - ["config.workspace.useGitIgnore"] = "Ignore files list in `.gitignore` .", - ["config.workspace.maxPreload"] = "Max preloaded files.", - ["config.workspace.preloadFileSize"] = "Skip files larger than this value (KB) when preloading.", - ["config.workspace.library"] = [[ -Load external library. -This feature can load external Lua files, which can be used for definition, automatic completion and other functions. Note that the language server does not monitor changes in external files and needs to restart if the external files are modified. -The following example shows loaded files in `C:/lua` and `../lib` ,exclude `../lib/temp`. -]] .. example.library, - ['config.completion.callSnippet'] = 'Show function call snippets.', -}) - -io.save(ROOT:parent_path() / 'package.nls.zh-cn.json', json.encode { - ["config.runtime.version"] = "Lua运行版本。", - ["config.runtime.path"] = "`package.path`", - ["config.diagnostics.enable"] = "启用诊断。", - ["config.diagnostics.disable"] = "禁用的诊断(使用浮框括号内的代码)。\n" .. example.disable, - ["config.diagnostics.globals"] = "已定义的全局变量。\n" .. example.globals, - ["config.diagnostics.severity"] = "修改诊断等级。\n" .. example.severity, - ["config.workspace.ignoreDir"] = "忽略的目录(使用 `.gitignore` 语法)。\n" .. example.ignoreDir, - ["config.workspace.ignoreSubmodules"] = "忽略子模块。", - ["config.workspace.useGitIgnore"] = "忽略 `.gitignore` 中列举的文件。", - ["config.workspace.maxPreload"] = "最大预加载文件数。", - ["config.workspace.preloadFileSize"] = "预加载时跳过大小大于该值(KB)的文件。", - ["config.workspace.library"] = [[ -加载外部函数库。 -该功能可以加载外部的Lua文件,用于函数定义、自动完成等功能。注意,语言服务不会监视外部文件的变化,如果修改了外部文件需要重启。 -下面这个例子表示加载`C:/lua`与`../lib`中的所有文件,但不加载`../lib/temp`中的文件。 -]] .. example.library, - ['config.completion.callSnippet'] = '显示函数调用片段。', -}) diff --git a/server/test/main.lua b/server/test/main.lua deleted file mode 100644 index 85885783..00000000 --- a/server/test/main.lua +++ /dev/null @@ -1,58 +0,0 @@ -local fs = require 'bee.filesystem' - -ROOT = fs.current_path() -LANG = 'en-US' - -package.path = (ROOT / 'src' / '?.lua'):string() - .. ';' .. (ROOT / 'src' / '?' / 'init.lua'):string() - .. ';' .. (ROOT / 'test' / '?.lua'):string() - .. ';' .. (ROOT / 'test' / '?' / 'init.lua'):string() - -log = require 'log' -log.init(ROOT, ROOT / 'log' / 'test.log') -log.debug('测试开始') -ac = {} -error '测试' -require 'utility' -require 'global_protect' -require 'build_package' - -local function loadAllLibs() - assert(require 'bee.filesystem') - assert(require 'bee.subprocess') - assert(require 'bee.thread') - assert(require 'bee.socket') - assert(require 'lni') - assert(require 'lpeglabel') -end - -local function main() - local function test(name) - local clock = os.clock() - print(('测试[%s]...'):format(name)) - require(name) - print(('测试[%s]用时[%.3f]'):format(name, os.clock() - clock)) - end - - test 'core' - test 'definition' - test 'rename' - test 'highlight' - test 'references' - test 'diagnostics' - test 'type_inference' - test 'find_lib' - test 'hover' - test 'completion' - test 'signature' - test 'document_symbol' - test 'crossfile' - test 'full' - - print('测试完成') -end - -loadAllLibs() -main() - -log.debug('测试完成') -- cgit v1.2.3