summaryrefslogtreecommitdiff
path: root/script
diff options
context:
space:
mode:
Diffstat (limited to 'script')
-rw-r--r--script/config/config.lua47
-rw-r--r--script/config/loader.lua2
-rw-r--r--script/core/completion.lua22
-rw-r--r--script/core/diagnostics/deprecated.lua6
-rw-r--r--script/core/diagnostics/init.lua6
-rw-r--r--script/core/diagnostics/lowercase-global.lua2
-rw-r--r--script/core/diagnostics/undefined-global.lua4
-rw-r--r--script/core/hint.lua6
-rw-r--r--script/core/hover/description.lua4
-rw-r--r--script/core/hover/label.lua2
-rw-r--r--script/core/hover/table.lua2
-rw-r--r--script/core/infer.lua4
-rw-r--r--script/files.lua20
-rw-r--r--script/library.lua12
-rw-r--r--script/plugin.lua4
-rw-r--r--script/progress.lua4
-rw-r--r--script/provider/diagnostic.lua12
-rw-r--r--script/provider/provider.lua16
-rw-r--r--script/provider/semantic-tokens.lua2
-rw-r--r--script/service/telemetry.lua6
-rw-r--r--script/vm/getDocs.lua2
-rw-r--r--script/workspace/workspace.lua34
22 files changed, 108 insertions, 111 deletions
diff --git a/script/config/config.lua b/script/config/config.lua
index 27ce2e55..c8f848f9 100644
--- a/script/config/config.lua
+++ b/script/config/config.lua
@@ -143,8 +143,8 @@ end, function (self, ...)
end)
local Template = {
- ['Lua.runtime.verion'] = Type.String >> 'Lua 5.4',
- ['Lua.runtime.path'] = Type.String >> {
+ ['Lua.runtime.version'] = Type.String >> 'Lua 5.4',
+ ['Lua.runtime.path'] = Type.Array(Type.String) >> {
"?.lua",
"?/init.lua",
"?/?.lua"
@@ -199,39 +199,36 @@ local Template = {
['editor.acceptSuggestionOnEnter'] = Type.String >> 'on',
}
+local config = {}
+
local m = {}
-local function updateConfig(key, value)
- local current = m
- local strs = {}
- for str in key:gmatch('[^%.]+') do
- strs[#strs+1] = str
+function m.set(key, value)
+ local unit = Template[key]
+ if not unit then
+ return
end
- for i = 1, #strs - 1 do
- local str = strs[i]
- if not current[str] then
- current[str] = {}
- end
- current = current[str]
+ if unit:checker(value) then
+ config[key] = unit:loader(value)
+ else
+ config[key] = unit.default
end
- local lastStr = strs[#strs]
- current[lastStr] = value
end
-local function pushConfig(key, value)
- local config = Template[key]
- if not config then
- return
- end
- if config:checker(value) then
- updateConfig(key, config:loader(value))
- else
- updateConfig(key, config.default)
+function m.get(key)
+ return config[key]
+end
+
+function m.copy()
+ local t = {}
+ for k, v in pairs(config) do
+ t[k] = v
end
+ return t
end
for key in pairs(Template) do
- pushConfig(key)
+ m.set(key)
end
return m
diff --git a/script/config/loader.lua b/script/config/loader.lua
index 4159547e..8310edfe 100644
--- a/script/config/loader.lua
+++ b/script/config/loader.lua
@@ -3,7 +3,7 @@ local fsu = require 'fs-utility'
local json = require 'json'
local proto = require 'proto'
local lang = require 'language'
-local config = require 'config.Lua'
+local config = require 'config.config'
local function errorMessage(msg)
proto.notify('window/showMessage', {
diff --git a/script/core/completion.lua b/script/core/completion.lua
index 47155e57..01f83242 100644
--- a/script/core/completion.lua
+++ b/script/core/completion.lua
@@ -145,7 +145,7 @@ local function buildDetail(source)
end
local function getSnip(source)
- local context = config.Lua.completion.displayContext
+ local context = config.get 'Lua.completion.displayContext'
if context <= 0 then
return nil
end
@@ -187,7 +187,7 @@ local function buildDesc(source)
end
local function buildFunction(results, source, value, oop, data)
- local snipType = config.Lua.completion.callSnippet
+ local snipType = config.get 'Lua.completion.callSnippet'
if snipType == 'Disable' or snipType == 'Both' then
results[#results+1] = data
end
@@ -220,7 +220,7 @@ local function buildInsertRequire(ast, targetUri, stemName)
end
end
local path = furi.decode(targetUri)
- local visiblePaths = rpath.getVisiblePath(path, config.Lua.runtime.path, true)
+ local visiblePaths = rpath.getVisiblePath(path, config.get 'Lua.runtime.path', true)
if not visiblePaths or #visiblePaths == 0 then
return nil
end
@@ -311,7 +311,7 @@ local function checkLocal(ast, word, offset, results)
end
local function checkModule(ast, word, offset, results)
- if not config.Lua.completion.autoRequire then
+ if not config.get 'Lua.completion.autoRequire' then
return
end
local locals = guide.getVisibleLocals(ast.ast, offset)
@@ -325,7 +325,7 @@ local function checkModule(ast, word, offset, results)
local stemName = fileName:gsub('%..+', '')
if not locals[stemName]
and not vm.hasGlobalSets(stemName)
- and not config.Lua.diagnostics.globals[stemName]
+ and not config.get 'Lua.diagnostics.globals'[stemName]
and stemName:match '^[%a_][%w_]*$'
and matchKey(word, stemName) then
local targetAst = files.getState(uri)
@@ -409,8 +409,8 @@ local function checkFieldFromFieldToIndex(name, parent, word, start, offset)
}
end
else
- if config.Lua.runtime.version == 'Lua 5.1'
- or config.Lua.runtime.version == 'LuaJIT' then
+ if config.get 'Lua.runtime.version' == 'Lua 5.1'
+ or config.get 'Lua.runtime.version' == 'LuaJIT' then
textEdit.newText = '_G' .. textEdit.newText
else
textEdit.newText = '_ENV' .. textEdit.newText
@@ -494,7 +494,7 @@ local function checkFieldOfRefs(refs, ast, word, start, offset, parent, oop, res
goto CONTINUE
end
local funcLabel
- if config.Lua.completion.showParams then
+ if config.get 'Lua.completion.showParams' then
local value = searcher.getObjectValue(src) or src
if value.type == 'function'
or value.type == 'doc.type.function' then
@@ -594,7 +594,7 @@ local function checkCommon(myUri, word, text, offset, results)
for _, data in ipairs(keyWordMap) do
used[data[1]] = true
end
- if config.Lua.completion.workspaceWord and #word >= 2 then
+ if config.get 'Lua.completion.workspaceWord' and #word >= 2 then
local myHead = word:sub(1, 2)
for uri in files.eachFile() do
if #results >= 100 then
@@ -681,7 +681,7 @@ local function isInString(ast, offset)
end
local function checkKeyWord(ast, text, start, offset, word, hasSpace, afterLocal, results)
- local snipType = config.Lua.completion.keywordSnippet
+ local snipType = config.get 'Lua.completion.keywordSnippet'
local symbol = lookBackward.findSymbol(text, start - 1)
local isExp = symbol == '(' or symbol == ',' or symbol == '='
local info = {
@@ -865,7 +865,7 @@ local function checkUri(ast, text, offset, results)
goto CONTINUE
end
local path = workspace.getRelativePath(uri)
- local infos = rpath.getVisiblePath(path, config.Lua.runtime.path)
+ local infos = rpath.getVisiblePath(path, config.get 'Lua.runtime.path')
for _, info in ipairs(infos) do
if matchKey(literal, info.expect) then
if not collect[info.expect] then
diff --git a/script/core/diagnostics/deprecated.lua b/script/core/diagnostics/deprecated.lua
index 5c2933f9..22bf70c0 100644
--- a/script/core/diagnostics/deprecated.lua
+++ b/script/core/diagnostics/deprecated.lua
@@ -27,10 +27,10 @@ return function (uri, callback)
if not key then
return
end
- if config.Lua.diagnostics.globals[key] then
+ if config.get 'Lua.diagnostics.globals'[key] then
return
end
- if config.Lua.runtime.special[key] then
+ if config.get 'Lua.runtime.special'[key] then
return
end
end
@@ -75,7 +75,7 @@ return function (uri, callback)
end
table.sort(versions)
if #versions > 0 then
- message = ('%s(%s)'):format(message, lang.script('DIAG_DEFINED_VERSION', table.concat(versions, '/'), config.Lua.runtime.version))
+ message = ('%s(%s)'):format(message, lang.script('DIAG_DEFINED_VERSION', table.concat(versions, '/'), config.get 'Lua.runtime.version'))
end
end
diff --git a/script/core/diagnostics/init.lua b/script/core/diagnostics/init.lua
index 5a070360..09688f6e 100644
--- a/script/core/diagnostics/init.lua
+++ b/script/core/diagnostics/init.lua
@@ -20,13 +20,13 @@ table.sort(diagList, function (a, b)
end)
local function check(uri, name, results)
- if config.Lua.diagnostics.disable[name] then
+ if config.get 'Lua.diagnostics.disable'[name] then
return
end
- local level = config.Lua.diagnostics.severity[name]
+ local level = config.get 'Lua.diagnostics.severity'[name]
or define.DiagnosticDefaultSeverity[name]
- local neededFileStatus = config.Lua.diagnostics.neededFileStatus[name]
+ local neededFileStatus = config.get 'Lua.diagnostics.neededFileStatus'[name]
or define.DiagnosticDefaultNeededFileStatus[name]
if neededFileStatus == 'None' then
diff --git a/script/core/diagnostics/lowercase-global.lua b/script/core/diagnostics/lowercase-global.lua
index 967a9737..299ac110 100644
--- a/script/core/diagnostics/lowercase-global.lua
+++ b/script/core/diagnostics/lowercase-global.lua
@@ -24,7 +24,7 @@ return function (uri, callback)
end
local definedGlobal = {}
- for name in pairs(config.Lua.diagnostics.globals) do
+ for name in pairs(config.get 'Lua.diagnostics.globals') do
definedGlobal[name] = true
end
diff --git a/script/core/diagnostics/undefined-global.lua b/script/core/diagnostics/undefined-global.lua
index 01caa7d2..c7ddeac2 100644
--- a/script/core/diagnostics/undefined-global.lua
+++ b/script/core/diagnostics/undefined-global.lua
@@ -25,10 +25,10 @@ return function (uri, callback)
if not key then
return
end
- if config.Lua.diagnostics.globals[key] then
+ if config.get 'Lua.diagnostics.globals'[key] then
return
end
- if config.Lua.runtime.special[key] then
+ if config.get 'Lua.runtime.special'[key] then
return
end
local node = src.node
diff --git a/script/core/hint.lua b/script/core/hint.lua
index 857ae510..a2864709 100644
--- a/script/core/hint.lua
+++ b/script/core/hint.lua
@@ -29,11 +29,11 @@ local function typeHint(uri, edits, start, finish)
return
end
if source.parent.type == 'funcargs' then
- if not config.Lua.hint.paramType then
+ if not config.get 'Lua.hint.paramType' then
return
end
else
- if not config.Lua.hint.setType then
+ if not config.get 'Lua.hint.setType' then
return
end
end
@@ -96,7 +96,7 @@ local function hasLiteralArgInCall(call)
end
local function paramName(uri, edits, start, finish)
- if not config.Lua.hint.paramName then
+ if not config.get 'Lua.hint.paramName' then
return
end
local ast = files.getState(uri)
diff --git a/script/core/hover/description.lua b/script/core/hover/description.lua
index 431fa619..5bb86603 100644
--- a/script/core/hover/description.lua
+++ b/script/core/hover/description.lua
@@ -59,11 +59,11 @@ end
local function asStringView(source, literal)
-- 内部包含转义符?
local rawLen = source.finish - source.start - 2 * #source[2] + 1
- if config.Lua.hover.viewString
+ if config.get 'Lua.hover.viewString'
and (source[2] == '"' or source[2] == "'")
and rawLen > #literal then
local view = literal
- local max = config.Lua.hover.viewStringMax
+ local max = config.get 'Lua.hover.viewStringMax'
if #view > max then
view = view:sub(1, max) .. '...'
end
diff --git a/script/core/hover/label.lua b/script/core/hover/label.lua
index cda2af65..15cd2af9 100644
--- a/script/core/hover/label.lua
+++ b/script/core/hover/label.lua
@@ -157,7 +157,7 @@ local function formatNumber(n)
end
local function asNumber(source)
- if not config.Lua.hover.viewNumber then
+ if not config.get 'Lua.hover.viewNumber' then
return nil
end
local num = source[1]
diff --git a/script/core/hover/table.lua b/script/core/hover/table.lua
index f064c99a..00f11659 100644
--- a/script/core/hover/table.lua
+++ b/script/core/hover/table.lua
@@ -91,7 +91,7 @@ local function getKeyMap(fields)
end
return function (source)
- local maxFields = config.Lua.hover.previewFields
+ local maxFields = config.get 'Lua.hover.previewFields'
if maxFields <= 0 then
return 'table'
end
diff --git a/script/core/infer.lua b/script/core/infer.lua
index 06839dd2..ef3076b7 100644
--- a/script/core/infer.lua
+++ b/script/core/infer.lua
@@ -217,7 +217,7 @@ local function bindClassOrType(source)
end
local function cleanInfers(infers)
- local version = config.Lua.runtime.version
+ local version = config.get 'Lua.runtime.version'
local enableInteger = version == 'Lua 5.3' or version == 'Lua 5.4'
infers['unknown'] = nil
if infers['any'] and infers['nil'] then
@@ -305,7 +305,7 @@ function m.viewInfers(infers)
return sa < sb
end
end)
- local limit = config.Lua.hover.enumsLimit
+ local limit = config.get 'Lua.hover.enumsLimit'
if limit < 0 then
limit = 0
end
diff --git a/script/files.lua b/script/files.lua
index 494bdb9f..63499fe2 100644
--- a/script/files.lua
+++ b/script/files.lua
@@ -164,7 +164,7 @@ function m.setText(uri, text, isTrust, instance)
return
end
if not isTrust and unicode then
- if config.Lua.runtime.fileEncoding == 'ansi' then
+ if config.get 'Lua.runtime.fileEncoding' == 'ansi' then
text = unicode.a2u(text)
end
end
@@ -393,7 +393,7 @@ end
function m.compileState(uri, text)
local ws = require 'workspace'
- if not m.isOpen(uri) and #text >= config.Lua.workspace.preloadFileSize * 1000 then
+ if not m.isOpen(uri) and #text >= config.get 'Lua.workspace.preloadFileSize' * 1000 then
if not m.notifyCache['preloadFileSize'] then
m.notifyCache['preloadFileSize'] = {}
m.notifyCache['skipLargeFileCount'] = 0
@@ -406,7 +406,7 @@ function m.compileState(uri, text)
type = 3,
message = lang.script('WORKSPACE_SKIP_LARGE_FILE'
, ws.getRelativePath(m.getOriginUri(uri))
- , config.Lua.workspace.preloadFileSize
+ , config.get 'Lua.workspace.preloadFileSize'
, #text / 1000
),
})
@@ -419,11 +419,11 @@ function m.compileState(uri, text)
local clock = os.clock()
local state, err = parser:compile(text
, 'lua'
- , config.Lua.runtime.version
+ , config.get 'Lua.runtime.version'
, {
- special = config.Lua.runtime.special,
- unicodeName = config.Lua.runtime.unicodeName,
- nonstandardSymbol = config.Lua.runtime.nonstandardSymbol,
+ special = config.get 'Lua.runtime.special',
+ unicodeName = config.get 'Lua.runtime.unicodeName',
+ nonstandardSymbol = config.get 'Lua.runtime.nonstandardSymbol',
delay = await.delay,
}
)
@@ -764,12 +764,12 @@ end
--- 获取文件关联
function m.getAssoc()
- if m.assocVersion == config.version then
+ if m.assocVersion == config.get 'version' then
return m.assocMatcher
end
- m.assocVersion = config.version
+ m.assocVersion = config.get 'version'
local patt = {}
- for k, v in pairs(config.other.associations) do
+ for k, v in pairs(config.get 'other.associations') do
if m.eq(v, 'lua') then
patt[#patt+1] = k
end
diff --git a/script/library.lua b/script/library.lua
index c4308289..985cd1e8 100644
--- a/script/library.lua
+++ b/script/library.lua
@@ -10,7 +10,7 @@ local define = require "proto.define"
local m = {}
local function getDocFormater()
- local version = config.Lua.runtime.version
+ local version = config.get 'Lua.runtime.version'
if client.isVSCode() then
if version == 'Lua 5.1' then
return 'HOVER_NATIVE_DOCUMENT_LUA51'
@@ -94,11 +94,11 @@ local function compileSingleMetaDoc(script, metaLang, status)
middleBuf[#middleBuf+1] = ('PUSH [===[%s]===]'):format(script:sub(last))
local middleScript = table.concat(middleBuf, '\n')
local version, jit
- if config.Lua.runtime.version == 'LuaJIT' then
+ if config.get 'Lua.runtime.version' == 'LuaJIT' then
version = 5.1
jit = true
else
- version = tonumber(config.Lua.runtime.version:sub(-3))
+ version = tonumber(config.get 'Lua.runtime.version':sub(-3))
jit = false
end
@@ -194,8 +194,8 @@ end
local function compileMetaDoc()
local langID = lang.id
- local version = config.Lua.runtime.version
- local metaPath = fs.path(METAPATH) / config.Lua.runtime.meta:gsub('%$%{(.-)%}', {
+ local version = config.get 'Lua.runtime.version'
+ local metaPath = fs.path(METAPATH) / config.get 'Lua.runtime.meta':gsub('%$%{(.-)%}', {
version = version,
language = langID,
})
@@ -212,7 +212,7 @@ local function compileMetaDoc()
local out = fsu.dummyFS()
local templateDir = ROOT / 'meta' / 'template'
for libName, status in pairs(define.BuiltIn) do
- status = config.Lua.runtime.builtin[libName] or status
+ status = config.get 'Lua.runtime.builtin'[libName] or status
if status == 'disable' then
goto CONTINUE
end
diff --git a/script/plugin.lua b/script/plugin.lua
index a3eaf92b..af86cea5 100644
--- a/script/plugin.lua
+++ b/script/plugin.lua
@@ -49,11 +49,11 @@ function m.init()
end
end
- if not config.Lua.runtime.plugin or config.Lua.runtime.plugin == '' then
+ if not config.get 'Lua.runtime.plugin' or config.get 'Lua.runtime.plugin' == '' then
return
end
- local pluginPath = fs.path(config.Lua.runtime.plugin)
+ local pluginPath = fs.path(config.get 'Lua.runtime.plugin')
if pluginPath:is_relative() then
if not ws.path then
return
diff --git a/script/progress.lua b/script/progress.lua
index c16ddd3d..8ae5e9e0 100644
--- a/script/progress.lua
+++ b/script/progress.lua
@@ -83,7 +83,7 @@ function mt:_update()
and self._clock + self._delay <= os.clock() then
self._updated = os.clock()
self._dirty = false
- if not config.Lua.window.progressBar then
+ if not config.get 'Lua.window.progressBar' then
return
end
proto.request('window/workDoneProgress/create', {
@@ -106,7 +106,7 @@ function mt:_update()
if not self._showed then
return
end
- if not config.Lua.window.progressBar then
+ if not config.get 'Lua.window.progressBar' then
self:remove()
return
end
diff --git a/script/provider/diagnostic.lua b/script/provider/diagnostic.lua
index d461ed3c..88fbbc4e 100644
--- a/script/provider/diagnostic.lua
+++ b/script/provider/diagnostic.lua
@@ -26,7 +26,7 @@ local function buildSyntaxError(uri, err)
local message = lang.script('PARSER_'..err.type, err.info)
if err.version then
- local version = err.info and err.info.version or config.Lua.runtime.version
+ local version = err.info and err.info.version or config.get 'Lua.runtime.version'
message = message .. ('(%s)'):format(lang.script('DIAG_NEED_VERSION'
, concat(err.version, '/')
, version
@@ -151,7 +151,7 @@ function m.syntaxErrors(uri, ast)
local results = {}
for _, err in ipairs(ast.errs) do
- if not config.Lua.diagnostics.disable[err.type:lower():gsub('_', '-')] then
+ if not config.get 'Lua.diagnostics.disable'[err.type:lower():gsub('_', '-')] then
results[#results+1] = buildSyntaxError(uri, err)
end
end
@@ -179,7 +179,7 @@ function m.diagnostics(uri, diags)
end
function m.doDiagnostic(uri)
- if not config.Lua.diagnostics.enable then
+ if not config.get 'Lua.diagnostics.enable' then
return
end
uri = files.asKey(uri)
@@ -302,14 +302,14 @@ local function askForDisable()
end
function m.diagnosticsAll()
- if not config.Lua.diagnostics.enable then
+ if not config.get 'Lua.diagnostics.enable' then
m.clearAll()
return
end
if not m._start then
return
end
- local delay = config.Lua.diagnostics.workspaceDelay / 1000
+ local delay = config.get 'Lua.diagnostics.workspaceDelay' / 1000
if delay < 0 then
return
end
@@ -361,7 +361,7 @@ function m.checkWorkspaceDiag()
if not await.hasID 'diagnosticsAll' then
return
end
- local speedRate = config.Lua.diagnostics.workspaceRate
+ local speedRate = config.get 'Lua.diagnostics.workspaceRate'
if speedRate <= 0 or speedRate >= 100 then
return
end
diff --git a/script/provider/provider.lua b/script/provider/provider.lua
index 33404886..54e3d2f4 100644
--- a/script/provider/provider.lua
+++ b/script/provider/provider.lua
@@ -61,11 +61,11 @@ local function updateConfig()
acceptSuggestionOnEnter = configs[5],
}
- local oldConfig = util.deepCopy(config.Lua)
- local oldOther = util.deepCopy(config.other)
- config.setConfig(updated, other)
- local newConfig = config.Lua
- local newOther = config.other
+ local oldConfig = util.deepCopy(config.get 'Lua')
+ local oldOther = util.deepCopy(config.get 'other')
+ config.get 'setConfig'(updated, other)
+ local newConfig = config.get 'Lua'
+ local newOther = config.get 'other'
if not util.equal(oldConfig.runtime, newConfig.runtime) then
library.init()
@@ -474,7 +474,7 @@ proto.on('textDocument/completion', function (params)
return nil
end
local triggerCharacter = params.context and params.context.triggerCharacter
- if config.other.acceptSuggestionOnEnter ~= 'off' then
+ if config.get 'other.acceptSuggestionOnEnter' ~= 'off' then
if triggerCharacter == '\n'
or triggerCharacter == '{'
or triggerCharacter == ',' then
@@ -598,7 +598,7 @@ proto.on('completionItem/resolve', function (item)
end)
proto.on('textDocument/signatureHelp', function (params)
- if not config.Lua.signatureHelp.enable then
+ if not config.get 'Lua.signatureHelp.enable' then
return nil
end
workspace.awaitReady()
@@ -895,7 +895,7 @@ do
local function updateHint(uri)
local awaitID = 'hint:' .. uri
await.close(awaitID)
- if not config.Lua.hint.enable then
+ if not config.get 'Lua.hint.enable' then
return
end
await.setID(awaitID)
diff --git a/script/provider/semantic-tokens.lua b/script/provider/semantic-tokens.lua
index bee31eaa..57c61afd 100644
--- a/script/provider/semantic-tokens.lua
+++ b/script/provider/semantic-tokens.lua
@@ -47,7 +47,7 @@ local function enable()
},
}
})
- if config.other.semantic == 'configuredByTheme' and not dontShowAgain then
+ if config.get 'other.semantic' == 'configuredByTheme' and not dontShowAgain then
proto.request('window/showMessageRequest', {
type = define.MessageType.Info,
message = lang.script.WINDOW_CHECK_SEMANTIC,
diff --git a/script/service/telemetry.lua b/script/service/telemetry.lua
index 19fe86f1..f3a3cf12 100644
--- a/script/service/telemetry.lua
+++ b/script/service/telemetry.lua
@@ -65,7 +65,7 @@ end
timer.wait(5, function ()
timer.loop(300, function ()
- if not config.Lua.telemetry.enable then
+ if not config.get 'Lua.telemetry.enable' then
return
end
local suc, link = pcall(net.connect, 'tcp', 'moe-moe.love', 11577)
@@ -83,7 +83,7 @@ timer.wait(5, function ()
end
end)()
timer.loop(1, function ()
- if not config.Lua.telemetry.enable then
+ if not config.get 'Lua.telemetry.enable' then
return
end
net.update()
@@ -93,7 +93,7 @@ end)
local m = {}
function m.updateConfig()
- if config.Lua.telemetry.enable ~= nil then
+ if config.get 'Lua.telemetry.enable' ~= nil then
return
end
if m.hasShowedMessage then
diff --git a/script/vm/getDocs.lua b/script/vm/getDocs.lua
index dd21c965..e8fefb7a 100644
--- a/script/vm/getDocs.lua
+++ b/script/vm/getDocs.lua
@@ -135,7 +135,7 @@ local function isDeprecated(value)
return true
elseif doc.type == 'doc.version' then
local valids = vm.getValidVersions(doc)
- if not valids[config.Lua.runtime.version] then
+ if not valids[config.get 'Lua.runtime.version'] then
value._deprecated = true
return true
end
diff --git a/script/workspace/workspace.lua b/script/workspace/workspace.lua
index ae3af6d4..8137a507 100644
--- a/script/workspace/workspace.lua
+++ b/script/workspace/workspace.lua
@@ -76,20 +76,20 @@ function m.getNativeMatcher()
end
local pattern = {}
- -- config.workspace.ignoreDir
- for path in pairs(config.Lua.workspace.ignoreDir) do
+ -- config.get 'workspace.ignoreDir'
+ for path in pairs(config.get 'Lua.workspace.ignoreDir') do
log.info('Ignore directory:', path)
pattern[#pattern+1] = path
end
- -- config.files.exclude
- for path, ignore in pairs(config.other.exclude) do
+ -- config.get 'files.exclude'
+ for path, ignore in pairs(config.get 'other.exclude') do
if ignore then
log.info('Ignore by exclude:', path)
pattern[#pattern+1] = path
end
end
- -- config.workspace.ignoreSubmodules
- if config.Lua.workspace.ignoreSubmodules then
+ -- config.get 'workspace.ignoreSubmodules'
+ if config.get 'Lua.workspace.ignoreSubmodules' then
local buf = pub.awaitTask('loadFile', furi.encode(m.path .. '/.gitmodules'))
if buf then
for path in buf:gmatch('path = ([^\r\n]+)') do
@@ -98,8 +98,8 @@ function m.getNativeMatcher()
end
end
end
- -- config.workspace.useGitIgnore
- if config.Lua.workspace.useGitIgnore then
+ -- config.get 'workspace.useGitIgnore'
+ if config.get 'Lua.workspace.useGitIgnore' then
local buf = pub.awaitTask('loadFile', furi.encode(m.path .. '/.gitignore'))
if buf then
for line in buf:gmatch '[^\r\n]+' do
@@ -119,8 +119,8 @@ function m.getNativeMatcher()
end
end
end
- -- config.workspace.library
- for path in pairs(config.Lua.workspace.library) do
+ -- config.get 'workspace.library'
+ for path in pairs(config.get 'Lua.workspace.library') do
path = path:gsub('${(.-)}', {
meta = (ROOT / 'meta' / '3rd'):string(),
})
@@ -131,7 +131,7 @@ function m.getNativeMatcher()
m.nativeMatcher = glob.gitignore(pattern, m.matchOption, globInteferFace)
m.nativeMatcher:setOption('root', m.path)
- m.nativeVersion = config.version
+ m.nativeVersion = config.get 'version'
return m.nativeMatcher
end
@@ -142,7 +142,7 @@ function m.getLibraryMatchers()
end
local librarys = {}
- for path in pairs(config.Lua.workspace.library) do
+ for path in pairs(config.get 'Lua.workspace.library') do
path = path:gsub('${(.-)}', {
meta = (ROOT / 'meta' / '3rd'):string(),
})
@@ -165,7 +165,7 @@ function m.getLibraryMatchers()
end
end
- m.libraryVersion = config.version
+ m.libraryVersion = config.get 'version'
return m.libraryMatchers
end
@@ -183,12 +183,12 @@ local function loadFileFactory(root, progressData, isLibrary)
return function (path)
local uri = furi.encode(path)
if files.isLua(uri) then
- if not isLibrary and progressData.preload >= config.Lua.workspace.maxPreload then
+ if not isLibrary and progressData.preload >= config.get 'Lua.workspace.maxPreload' then
if not m.hasHitMaxPreload then
m.hasHitMaxPreload = true
proto.request('window/showMessageRequest', {
type = define.MessageType.Info,
- message = lang.script('MWS_MAX_PRELOAD', config.Lua.workspace.maxPreload),
+ message = lang.script('MWS_MAX_PRELOAD', config.get 'Lua.workspace.maxPreload'),
actions = {
{
title = lang.script.WINDOW_INCREASE_UPPER_LIMIT,
@@ -207,7 +207,7 @@ local function loadFileFactory(root, progressData, isLibrary)
data = {
key = 'Lua.workspace.maxPreload',
action = 'set',
- value = config.Lua.workspace.maxPreload + math.max(1000, config.Lua.workspace.maxPreload),
+ value = config.get 'Lua.workspace.maxPreload' + math.max(1000, config.get 'Lua.workspace.maxPreload'),
}
})
end
@@ -415,7 +415,7 @@ function m.findUrisByRequirePath(path)
local input = path:gsub('%.', '/')
:gsub('%%', '%%%%')
- for _, luapath in ipairs(config.Lua.runtime.path) do
+ for _, luapath in ipairs(config.get 'Lua.runtime.path') do
local part = m.normalize(luapath:gsub('%?', input))
local uris, posts = m.findUrisByFilePath(part)
for _, uri in ipairs(uris) do