From 39de6077b1a1a6224d1acb52d17ab8ba7c885305 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?=E6=9C=80=E8=90=8C=E5=B0=8F=E6=B1=90?= Date: Sun, 10 Nov 2019 20:58:05 +0800 Subject: =?UTF-8?q?=E6=9B=B4=E6=96=B0=E8=A1=8C=E5=B0=BE=E7=A9=BA=E7=99=BD?= =?UTF-8?q?=E8=AF=8A=E6=96=AD=E5=AE=9E=E7=8E=B0?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- .../src/core/diagnostics/trailing-space.lua | 48 +++++++++++----------- 1 file changed, 23 insertions(+), 25 deletions(-) (limited to 'server-beta/src/core') diff --git a/server-beta/src/core/diagnostics/trailing-space.lua b/server-beta/src/core/diagnostics/trailing-space.lua index ef7fbef1..e54a6e60 100644 --- a/server-beta/src/core/diagnostics/trailing-space.lua +++ b/server-beta/src/core/diagnostics/trailing-space.lua @@ -17,41 +17,39 @@ return function (uri, callback) if not ast then return end - local lines = files.getLines(uri) local text = files.getText(uri) - + local lines = files.getLines(uri) for i = 1, #lines do - local start = lines[i].start + 1 - local finish = lines[i].finish - 1 - local line = text:sub(start, finish) - if line:find '^[ \t]+[\r\n]*$' then - local offset = guide.offsetOf(lines, i-1, start-1) - if isInString(ast.ast, offset) then - goto NEXT_LINE + local start = lines[i].start + local range = lines[i].range + local lastChar = text:sub(range, range) + if lastChar ~= ' ' and lastChar ~= '\t' then + goto NEXT_LINE + end + if isInString(ast.ast, range) then + goto NEXT_LINE + end + local first = start + for n = range - 1, start, -1 do + local char = text:sub(n, n) + if char ~= ' ' and char ~= '\t' then + first = n + 1 + break end + end + if first == start then callback { - start = start, - finish = finish, + start = first, + finish = range, message = lang.script.DIAG_LINE_ONLY_SPACE, } - goto NEXT_LINE - end - - local pos = line:find '[ \t]+[\r\n]*$' - if pos then - start = start + pos - 1 - local offset = guide.offsetOf(lines, i-1, start-1) - if isInString(ast.ast, offset) then - goto NEXT_LINE - end + else callback { - start = start, - finish = finish, + start = first, + finish = range, message = lang.script.DIAG_LINE_POST_SPACE, } - goto NEXT_LINE end - ::NEXT_LINE:: end end -- cgit v1.2.3