Uname: Linux premium294.web-hosting.com 4.18.0-553.45.1.lve.el8.x86_64 #1 SMP Wed Mar 26 12:08:09 UTC 2025 x86_64
Software: LiteSpeed
PHP version: 8.1.32 [ PHP INFO ] PHP os: Linux
Server Ip: 104.21.80.1
Your Ip: 216.73.216.223
User: mjbynoyq (1574) | Group: mjbynoyq (1570)
Safe Mode: OFF
Disable Function:
NONE

name : timers.js
const { bin: options } = require('./options.js')
const log = require('./logging.js')

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

process.on('time', name => {
  if (timers.has(name)) {
    throw new Error('conflicting timer! ' + name)
  }
  timers.set(name, process.hrtime.bigint())
})

process.on('timeEnd', name => {
  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
© 2025 XylotrechusZ