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
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
|
local files = require 'files'
local fsu = require 'fs-utility'
local furi = require 'file-uri'
local diag = require 'provider.diagnostic'
local config = require 'config'
local ws = require 'workspace'
local guide = require 'parser.guide'
local vm = require 'vm'
local util = require 'utility'
local path = ROOT / 'script'
local uris = {}
files.reset()
fsu.scanDirectory(path, function (path)
if path:extension():string() ~= '.lua' then
return
end
local uri = furi.encode(path:string())
local text = fsu.loadFile(path)
files.setText(uri, text)
files.open(uri)
uris[#uris+1] = uri
end)
local _ <close> = function ()
for _, uri in ipairs(uris) do
files.remove(uri)
end
end
print('基准诊断目录:', path)
ws.awaitReady(furi.encode(path:string()))
diag.diagnosticsScope(furi.encode(path:string()))
local clock = os.clock()
---@diagnostic disable: await-in-sync
for uri in files.eachFile() do
local state = files.getState(uri)
if not state then
goto CONTINUE
end
guide.eachSource(state.ast, function (src)
assert(src.parent ~= nil or src.type == 'main')
end)
local fileClock = os.clock()
diag.doDiagnostic(uri, true)
print('诊断文件耗时:', os.clock() - fileClock, uri)
::CONTINUE::
end
local passed = os.clock() - clock
print('基准全量诊断用时:', passed)
vm.clearNodeCache()
local clock = os.clock()
local compileDatas = {}
for uri in files.eachFile() do
local state = files.getState(uri)
if not state then
goto CONTINUE
end
local clock = os.clock()
guide.eachSource(state.ast, function (src)
vm.compileNode(src)
end)
compileDatas[uri] = {
passed = os.clock() - clock,
uri = uri,
}
::CONTINUE::
end
local printTexts = {}
for uri, data in util.sortPairs(compileDatas, function (a, b)
return compileDatas[a].passed > compileDatas[b].passed
end) do
printTexts[#printTexts+1] = ('全量编译耗时:%05.3f [%s]'):format(data.passed, uri)
if #printTexts >= 10 then
break
end
end
util.revertArray(printTexts)
for _, text in ipairs(printTexts) do
print(text)
end
local passed = os.clock() - clock
print('基准全量编译用时:', passed)
|