HEX
Server: Apache
System: Linux zacp120.webway.host 4.18.0-553.50.1.lve.el8.x86_64 #1 SMP Thu Apr 17 19:10:24 UTC 2025 x86_64
User: govancoz (1003)
PHP: 8.3.26
Disabled: exec,system,passthru,shell_exec,proc_close,proc_open,dl,popen,show_source,posix_kill,posix_mkfifo,posix_getpwuid,posix_setpgid,posix_setsid,posix_setuid,posix_setgid,posix_seteuid,posix_setegid,posix_uname
Upload Files
File: //opt/alt/alt-nodejs18/root/lib/node_modules/npm/node_modules/@npmcli/arborist/bin/lib/timers.js
const { bin: options } = require('./options.js')
const log = require('./logging.js')

const timers = new Map()
const finished = new Map()

process.on('time', (level, name) => {
  if (level === 'start') {
    if (timers.has(name)) {
      throw new Error('conflicting timer! ' + name)
    }
    timers.set(name, process.hrtime.bigint())
  } else if (level === 'end') {
    if (!timers.has(name)) {
      throw new Error('timer not started! ' + name)
    }
    const elapsed = Number(process.hrtime.bigint() - timers.get(name))
    timers.delete(name)
    finished.set(name, elapsed)
    if (options.timing) {
      log.info('timeEnd', `${name} ${elapsed / 1e9}s`, log.meta({ force: options.timing === 'always' }))
    }
  }
})

process.on('exit', () => {
  for (const name of timers.keys()) {
    log.error('timeError', 'Dangling timer:', name)
    process.exitCode = 1
  }
})

module.exports = finished