summaryrefslogtreecommitdiff
path: root/node_modules/xmlbuilder/perf/index.coffee
diff options
context:
space:
mode:
authorLinuxWizard42 <computerwizard@linuxmail.org>2022-10-12 23:08:57 +0300
committerLinuxWizard42 <computerwizard@linuxmail.org>2022-10-12 23:08:57 +0300
commit726b81b19251674e149ccfbb1abacbd837fc6db0 (patch)
treefbdbb227dc01357eb76e8222d76185bc124c5ca6 /node_modules/xmlbuilder/perf/index.coffee
parent34f0890e175698940d49238097579f44e4d78c89 (diff)
downloadFlashRunner-726b81b19251674e149ccfbb1abacbd837fc6db0.tar.gz
FlashRunner-726b81b19251674e149ccfbb1abacbd837fc6db0.tar.zst
Removed files that should not have been included in git
Diffstat (limited to 'node_modules/xmlbuilder/perf/index.coffee')
-rw-r--r--node_modules/xmlbuilder/perf/index.coffee161
1 files changed, 0 insertions, 161 deletions
diff --git a/node_modules/xmlbuilder/perf/index.coffee b/node_modules/xmlbuilder/perf/index.coffee
deleted file mode 100644
index 3bd0f93..0000000
--- a/node_modules/xmlbuilder/perf/index.coffee
+++ /dev/null
@@ -1,161 +0,0 @@
-builder = require('../src/index')
-git = require('git-state')
-fs = require('fs')
-path = require('path')
-{ performance, PerformanceObserver } = require('perf_hooks')
-
-global.xml = builder.create
-global.doc = builder.begin
-
-global.perf = (description, count, func) ->
-
- totalTime = 0
-
- callback = (userFunction) ->
- startTime = performance.now()
- for i in [1..count]
- userFunction()
- endTime = performance.now()
- totalTime += endTime - startTime
- func(callback)
-
- averageTime = totalTime / count
-
- version = require('../package.json').version
- working = gitWorking(gitDir)
- if working then version = version + "*"
- if not perfObj[version] then perfObj[version] = { }
-
- perfObj[version][description] = averageTime.toFixed(4)
-
-readPerf = (filename) ->
- if not fs.existsSync(filename) then fs.closeSync(fs.openSync(filename, 'w'))
- str = fs.readFileSync(filename, 'utf8')
- if str then JSON.parse(str) else { }
-
-runPerf = (dirPath) ->
- for file from walkDir(dirPath)
- filename = path.basename(file)
- if filename is "index.coffee" or filename is "perf.list" then continue
- require(file)
-
-walkDir = (dirPath) ->
- for file in fs.readdirSync(dirPath)
- filePath = path.join(dirPath, file)
- stat = fs.statSync(filePath)
- if stat.isFile() then yield filePath else if stat.isDirectory() then yield from walkDir(filePath)
- return undefined
-
-gitWorking = (dirPath) ->
- return git.isGitSync(dirPath) and git.dirtySync(dirPath)
-
-printPerf = (perfObj) ->
- sorted = sortByVersion(perfObj)
-
- for sortedItems in sorted
- version = sortedItems.version
- items = sortedItems.item
- sortedItem = sortByDesc(items)
-
- if parseVersion(version)[3]
- console.log "\x1b[4mv%s (Working Tree):\x1b[0m", version
- else
- console.log "\x1b[4mv%s:\x1b[0m", version
-
- longestDescription = 0
- for item in sortedItem
- descriptionLength = item.description.length
- if descriptionLength > longestDescription
- longestDescription = descriptionLength
-
- for item in sortedItem
- description = item.description
- averageTime = item.averageTime
- prevItem = findPrevPerf(sorted, version, description)
- if prevItem
- if averageTime < prevItem.item[description]
- console.log " - \x1b[36m%s\x1b[0m \x1b[1m\x1b[32m%s\x1b[0m ms (v%s was \x1b[1m%s\x1b[0m ms, -\x1b[1m%s\x1b[0m%)", padRight(description, longestDescription), averageTime, prevItem.version, prevItem.item[description], (-100*(averageTime - prevItem.item[description]) / prevItem.item[description]).toFixed(0)
- else if averageTime > prevItem.item[description]
- console.log " - \x1b[36m%s\x1b[0m \x1b[1m\x1b[31m%s\x1b[0m ms (v%s was \x1b[1m%s\x1b[0m ms, +\x1b[1m%s\x1b[0m%)", padRight(description, longestDescription), averageTime, prevItem.version, prevItem.item[description], (100*(averageTime - prevItem.item[description]) / prevItem.item[description]).toFixed(0)
- else
- console.log " - \x1b[36m%s\x1b[0m \x1b[1m%s\x1b[0m ms (v%s was \x1b[1m%s\x1b[0m ms, \x1b[1m%s\x1b[0m%)", padRight(description, longestDescription), averageTime, prevItem.version, prevItem.item[description], (100*(averageTime - prevItem.item[description]) / prevItem.item[description]).toFixed(0)
- else
- console.log " - \x1b[36m%s\x1b[0m \x1b[1m%s\x1b[0m ms (no previous result)", padRight(description, longestDescription), averageTime
-
-padRight = (str, len) ->
- str + " ".repeat(len - str.length)
-
-writePerf = (filename, perfObj) ->
- writePerfObj = { }
- for version, items of perfObj
- if not parseVersion(version)[3]
- writePerfObj[version] = items
- fs.writeFileSync(filename, JSON.stringify(writePerfObj, null, 2) , 'utf-8')
-
-findPrevPerf = (sorted, version, description) ->
- prev = undefined
- for item in sorted
- if compareVersion(item.version, version) is -1
- if item.item[description]
- prev = item
- return prev
-
-sortByVersion = (perfObj) ->
- sorted = []
- for version, items of perfObj
- sorted.push
- version: version
- item: items
- sorted.sort (item1, item2) ->
- compareVersion(item1.version, item2.version)
-
-sortByDesc = (item) ->
- sorted = []
- for description, averageTime of item
- sorted.push
- description: description
- averageTime: averageTime
- sorted.sort (item1, item2) ->
- if item1.description < item2.description then -1 else 1
-
-parseVersion = (version) ->
- isDirty = version[version.length - 1] is "*"
- if isDirty then version = version.substr(0, version.length - 1)
- v = version.split('.')
- v.push(isDirty)
- return v
-
-compareVersion = (v1, v2) ->
- v1 = parseVersion(v1)
- v2 = parseVersion(v2)
-
- if v1[0] < v2[0]
- -1
- else if v1[0] > v2[0]
- 1
- else # v1[0] = v2[0]
- if v1[1] < v2[1]
- -1
- else if v1[1] > v2[1]
- 1
- else # v1[1] = v2[1]
- if v1[2] < v2[2]
- -1
- else if v1[2] > v2[2]
- 1
- else # v1[2] = v2[2]
- if v1[3] and not v2[3]
- 1
- else if v2[3] and not v1[3]
- -1
- else
- 0
-
-
-perfDir = __dirname
-gitDir = path.resolve(__dirname, '..')
-perfFile = path.join(perfDir, './perf.list')
-perfObj = readPerf(perfFile)
-runPerf(perfDir)
-printPerf(perfObj)
-writePerf(perfFile, perfObj)