PATH:
usr
/
lib
/
node_modules
/
npm
/
lib
/
utils
const EE = require('node:events') const fs = require('node:fs') const { log, time } = require('proc-log') const INITIAL_TIMER = 'npm' class Timers extends EE { #file #timing #unfinished = new Map() #finished = {} constructor () { super() this.on() time.start(INITIAL_TIMER) this.started = this.#unfinished.get(INITIAL_TIMER) } on () { process.on('time', this.#timeHandler) } off () { process.off('time', this.#timeHandler) } load ({ path, timing } = {}) { this.#timing = timing this.#file = `${path}timing.json` } finish (metadata) { time.end(INITIAL_TIMER) for (const [name, timer] of this.#unfinished) { log.silly('unfinished npm timer', name, timer) } if (!this.#timing) { // Not in timing mode, nothing else to do here return } try { this.#writeFile(metadata) log.info('timing', `Timing info written to: ${this.#file}`) } catch (e) { log.warn('timing', `could not write timing file: ${e}`) } } #writeFile (metadata) { const globalStart = this.started const globalEnd = this.#finished[INITIAL_TIMER] const content = { metadata, timers: this.#finished, // add any unfinished timers with their relative start/end unfinishedTimers: [...this.#unfinished.entries()].reduce((acc, [name, start]) => { acc[name] = [start - globalStart, globalEnd - globalStart] return acc }, {}), } fs.writeFileSync(this.#file, JSON.stringify(content) + '\n') } #timeHandler = (level, name) => { const now = Date.now() switch (level) { case time.KEYS.start: this.#unfinished.set(name, now) break case time.KEYS.end: { if (this.#unfinished.has(name)) { const ms = now - this.#unfinished.get(name) this.#finished[name] = ms this.#unfinished.delete(name) log.timing(name, `Completed in ${ms}ms`) } else { log.silly('timing', `Tried to end timer that doesn't exist: ${name}`) } } } } } module.exports = Timers
[-] verify-signatures.js
[edit]
[-] format.js
[edit]
[-] completion.fish
[edit]
[-] validate-lockfile.js
[edit]
[-] display.js
[edit]
[-] installed-shallow.js
[edit]
[-] format-search-stream.js
[edit]
[-] tar.js
[edit]
[-] sbom-spdx.js
[edit]
[-] update-workspaces.js
[edit]
[-] explain-dep.js
[edit]
[-] npm-usage.js
[edit]
[-] log-file.js
[edit]
[-] sbom-cyclonedx.js
[edit]
[-] open-url.js
[edit]
[-] get-workspaces.js
[edit]
[-] format-bytes.js
[edit]
[-] did-you-mean.js
[edit]
[-] audit-error.js
[edit]
[-] get-identity.js
[edit]
[-] output-error.js
[edit]
[-] error-message.js
[edit]
[-] reify-finish.js
[edit]
[-] queryable.js
[edit]
[+]
..
[-] timers.js
[edit]
[-] auth.js
[edit]
[-] cmd-list.js
[edit]
[-] explain-eresolve.js
[edit]
[-] reify-output.js
[edit]
[-] installed-deep.js
[edit]
[-] ping.js
[edit]
[-] completion.sh
[edit]
[-] read-user-info.js
[edit]
[-] is-windows.js
[edit]