diff options
-rw-r--r-- | script/core/diagnostics/codestyle-check.lua | 34 | ||||
-rw-r--r-- | script/core/formatting.lua | 4 | ||||
-rw-r--r-- | script/core/rangeformatting.lua | 4 | ||||
-rw-r--r-- | script/core/type-formatting.lua | 3 | ||||
-rw-r--r-- | script/proto/define.lua | 1 | ||||
-rw-r--r-- | script/provider/capability.lua | 3 | ||||
-rw-r--r-- | script/provider/provider.lua | 12 | ||||
-rw-r--r-- | test/crossfile/diagnostic.lua | 2 |
8 files changed, 49 insertions, 14 deletions
diff --git a/script/core/diagnostics/codestyle-check.lua b/script/core/diagnostics/codestyle-check.lua new file mode 100644 index 00000000..16623eca --- /dev/null +++ b/script/core/diagnostics/codestyle-check.lua @@ -0,0 +1,34 @@ +local files = require("files") +local codeFormat = require "code_format" +local converter = require("proto.converter") +local log = require("log") +local config = require("config") + + +---@async +return function(uri, callback) + local text = files.getText(uri) + if not text then + return + end + + local status, diagnosticInfos = codeFormat.diagnose_file(uri, text) + + if not status then + if diagnosticInfos ~= nil then + log.error(diagnosticInfos) + end + + return + end + + if diagnosticInfos then + for _, diagnosticInfo in pairs(diagnosticInfos) do + callback { + start = converter.unpackPosition(uri, diagnosticInfo.range.start), + finish = converter.unpackPosition(uri, diagnosticInfo.range["end"]), + message = diagnosticInfo.message + } + end + end +end diff --git a/script/core/formatting.lua b/script/core/formatting.lua index 8f72028b..6c57b8c2 100644 --- a/script/core/formatting.lua +++ b/script/core/formatting.lua @@ -1,11 +1,11 @@ -local code_format = require "code_format" +local codeFormat = require("code_format") local files = require("files") local log = require("log") return function(uri) local text = files.getText(uri) local ast = files.getState(uri) - local status, formattedText = code_format.format(uri, text) + local status, formattedText = codeFormat.format(uri, text) if not status then if formattedText ~= nil then diff --git a/script/core/rangeformatting.lua b/script/core/rangeformatting.lua index b66f0fbd..de9516c1 100644 --- a/script/core/rangeformatting.lua +++ b/script/core/rangeformatting.lua @@ -1,11 +1,11 @@ -local code_format = require "code_format" +local codeFormat = require("code_format") local files = require("files") local log = require("log") local converter = require("proto.converter") return function(uri, range) local text = files.getText(uri) - local status, formattedText, startLine, endLine = code_format.range_format( + local status, formattedText, startLine, endLine = codeFormat.range_format( uri, text, range.start.line, range["end"].line) if not status then diff --git a/script/core/type-formatting.lua b/script/core/type-formatting.lua index b946184b..cc305982 100644 --- a/script/core/type-formatting.lua +++ b/script/core/type-formatting.lua @@ -46,6 +46,7 @@ local function checkSplitOneLine(results, uri, position, ch) if ch ~= '\n' then return end + local fPosition, fSymbol = findForward(uri, position, 'end', '}') if not fPosition then return @@ -77,7 +78,7 @@ local function checkSplitOneLine(results, uri, position, ch) end return function (uri, position, ch) - local ast = files.getState(uri) + local ast = files.getState(uri) if not ast then return nil end diff --git a/script/proto/define.lua b/script/proto/define.lua index dbb6ba85..b4a0da0c 100644 --- a/script/proto/define.lua +++ b/script/proto/define.lua @@ -58,6 +58,7 @@ m.DiagnosticDefaultSeverity = { ['doc-field-no-class'] = 'Warning', ['duplicate-doc-field'] = 'Warning', ['unknown-diag-code'] = 'Waiting', + ['codestyle-check'] = "Warning", } ---@alias DiagnosticDefaultNeededFileStatus diff --git a/script/provider/capability.lua b/script/provider/capability.lua index 31baf690..e13e11e0 100644 --- a/script/provider/capability.lua +++ b/script/provider/capability.lua @@ -114,9 +114,6 @@ function m.getIniter() }, documentFormattingProvider = true, documentRangeFormattingProvider = true - --documentOnTypeFormattingProvider = { - -- firstTriggerCharacter = '}', - --}, } --testFileEvents() diff --git a/script/provider/provider.lua b/script/provider/provider.lua index a5e0a1ca..329bc66b 100644 --- a/script/provider/provider.lua +++ b/script/provider/provider.lua @@ -103,9 +103,9 @@ m.register 'initialize' { if params.initializationOptions then if params.initializationOptions.editorConfigFiles then - local code_format = require "code_format" + local codeFormat = require "code_format" for _, config in pairs(params.initializationOptions.editorConfigFiles) do - local status, err = code_format.update_config(1, config.workspace, config.path) + local status, err = codeFormat.update_config(1, config.workspace, config.path) if not status and err ~= nil then log.error(err) @@ -930,7 +930,7 @@ m.register 'textDocument/formatting' { function(params) local uri = files.getRealUri(params.textDocument.uri) workspace.awaitReady(uri) - local _<close> = progress.create(workspace.getScope(uri), lang.script.WINDOW_PROCESSING_TYPE_FORMATTING, 0.5) + local _ <close> = progress.create(workspace.getScope(uri), lang.script.WINDOW_PROCESSING_TYPE_FORMATTING, 0.5) if not files.exists(uri) then return nil @@ -960,7 +960,7 @@ m.register 'textDocument/rangeFormatting' { function(params) local uri = files.getRealUri(params.textDocument.uri) workspace.awaitReady(uri) - local _<close> = progress.create(workspace.getScope(uri), lang.script.WINDOW_PROCESSING_TYPE_FORMATTING, 0.5) + local _ <close> = progress.create(workspace.getScope(uri), lang.script.WINDOW_PROCESSING_TYPE_FORMATTING, 0.5) if not files.exists(uri) then return nil @@ -988,8 +988,8 @@ m.register 'config/editorconfig/update' { abortByFileUpdate = true, ---@async function(params) - local code_format = require "code_format" - local status, err = code_format.update_config(params.type, params.source.workspace, params.source.path) + local codeFormat = require "code_format" + local status, err = codeFormat.update_config(params.type, params.source.workspace, params.source.path) if not status and err ~= nil then log.error(err) diff --git a/test/crossfile/diagnostic.lua b/test/crossfile/diagnostic.lua index 43028744..dd06351f 100644 --- a/test/crossfile/diagnostic.lua +++ b/test/crossfile/diagnostic.lua @@ -5,8 +5,10 @@ local config = require 'config' local platform = require 'bee.platform' local catch = require 'catch' + config.get(nil, 'Lua.diagnostics.neededFileStatus')['deprecated'] = 'Any' config.get(nil, 'Lua.diagnostics.neededFileStatus')['type-check'] = 'Any' +config.get(nil, 'Lua.diagnostics.neededFileStatus')['codestyle-check'] = 'None' rawset(_G, 'TEST', true) |