summaryrefslogtreecommitdiff
path: root/script/core/diagnostics/newfield-call.lua
blob: 61d52dd21349514dedc8637c9361dcf39bb42b8b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
local files = require 'files'
local guide = require 'parser.guide'
local lang  = require 'language'

return function (uri, callback)
    local ast = files.getState(uri)
    if not ast then
        return
    end

    local lines = files.getLines(uri)
    local text  = files.getText(uri)

    guide.eachSourceType(ast.ast, 'table', function (source)
        for i = 1, #source do
            local field = source[i]
            if field.type ~= 'tableexp' then
                goto CONTINUE
            end
            local call = field.value
            if not call then
                goto CONTINUE
            end
            if call.type ~= 'call' then
                return
            end
            local func = call.node
            local args = call.args
            if args then
                local funcLine = guide.positionOf(func.finish)
                local argsLine = guide.positionOf(args.start)
                if argsLine > funcLine then
                    callback {
                        start   = call.start,
                        finish  = call.finish,
                        message = lang.script('DIAG_PREFIELD_CALL'
                            , text:sub(func.start, func.finish)
                            , text:sub(args.start, args.finish)
                        )
                    }
                end
            end
            ::CONTINUE::
        end
    end)
end