$76 GRAYBYTE WORDPRESS FILE MANAGER $87

SERVER : premium201.web-hosting.com #1 SMP Wed Mar 26 12:08:09 UTC 2025
SERVER IP : 104.21.43.35 | ADMIN IP 216.73.216.180
OPTIONS : CRL = ON | WGT = ON | SDO = OFF | PKEX = OFF
DEACTIVATED : mail

/opt/alt/alt-nodejs19/root/usr/lib/node_modules/npm/lib/commands/

HOME
Current File : /opt/alt/alt-nodejs19/root/usr/lib/node_modules/npm/lib/commands//help-search.js
const { readFile } = require('fs/promises')
const path = require('path')
const glob = require('glob')
const BaseCommand = require('../base-command.js')

const globify = pattern => pattern.split('\\').join('/')

class HelpSearch extends BaseCommand {
  static description = 'Search npm help documentation'
  static name = 'help-search'
  static usage = ['<text>']
  static params = ['long']

  async exec (args) {
    if (!args.length) {
      throw this.usageError()
    }

    const docPath = path.resolve(this.npm.npmRoot, 'docs/content')
    let files = await glob(`${globify(docPath)}/*/*.md`)
    // preserve glob@8 behavior
    files = files.sort((a, b) => a.localeCompare(b, 'en'))
    const data = await this.readFiles(files)
    const results = await this.searchFiles(args, data, files)
    const formatted = this.formatResults(args, results)
    if (!formatted.trim()) {
      this.npm.output(`No matches in help for: ${args.join(' ')}\n`)
    } else {
      this.npm.output(formatted)
    }
  }

  async readFiles (files) {
    const res = {}
    await Promise.all(files.map(async file => {
      res[file] = (await readFile(file, 'utf8'))
        .replace(/^---\n(.*\n)*?---\n/, '').trim()
    }))
    return res
  }

  async searchFiles (args, data, files) {
    const results = []
    for (const [file, content] of Object.entries(data)) {
      const lowerCase = content.toLowerCase()
      // skip if no matches at all
      if (!args.some(a => lowerCase.includes(a.toLowerCase()))) {
        continue
      }

      const lines = content.split(/\n+/)

      // if a line has a search term, then skip it and the next line.
      // if the next line has a search term, then skip all 3
      // otherwise, set the line to null.  then remove the nulls.
      for (let i = 0; i < lines.length; i++) {
        const line = lines[i]
        const nextLine = lines[i + 1]
        let match = false
        if (nextLine) {
          match = args.some(a =>
            nextLine.toLowerCase().includes(a.toLowerCase()))
          if (match) {
            // skip over the next line, and the line after it.
            i += 2
            continue
          }
        }

        match = args.some(a => line.toLowerCase().includes(a.toLowerCase()))

        if (match) {
          // skip over the next line
          i++
          continue
        }

        lines[i] = null
      }

      // now squish any string of nulls into a single null
      const pruned = lines.reduce((l, r) => {
        if (!(r === null && l[l.length - 1] === null)) {
          l.push(r)
        }

        return l
      }, [])

      if (pruned[pruned.length - 1] === null) {
        pruned.pop()
      }

      if (pruned[0] === null) {
        pruned.shift()
      }

      // now count how many args were found
      const found = {}
      let totalHits = 0
      for (const line of pruned) {
        for (const arg of args) {
          const hit = (line || '').toLowerCase()
            .split(arg.toLowerCase()).length - 1

          if (hit > 0) {
            found[arg] = (found[arg] || 0) + hit
            totalHits += hit
          }
        }
      }

      const cmd = 'npm help ' +
        path.basename(file, '.md').replace(/^npm-/, '')
      results.push({
        file,
        cmd,
        lines: pruned,
        found: Object.keys(found),
        hits: found,
        totalHits,
      })
    }

    // sort results by number of results found, then by number of hits
    // then by number of matching lines

    // coverage is ignored here because the contents of results are
    // nondeterministic due to either glob or readFiles or Object.entries
    return results.sort(/* istanbul ignore next */ (a, b) =>
      a.found.length > b.found.length ? -1
      : a.found.length < b.found.length ? 1
      : a.totalHits > b.totalHits ? -1
      : a.totalHits < b.totalHits ? 1
      : a.lines.length > b.lines.length ? -1
      : a.lines.length < b.lines.length ? 1
      : 0).slice(0, 10)
  }

  formatResults (args, results) {
    const cols = Math.min(process.stdout.columns || Infinity, 80) + 1

    const output = results.map(res => {
      const out = [res.cmd]
      const r = Object.keys(res.hits)
        .map(k => `${k}:${res.hits[k]}`)
        .sort((a, b) => a > b ? 1 : -1)
        .join(' ')

      out.push(' '.repeat((Math.max(1, cols - out.join(' ').length - r.length - 1))))
      out.push(r)

      if (!this.npm.config.get('long')) {
        return out.join('')
      }

      out.unshift('\n\n')
      out.push('\n')
      out.push('-'.repeat(cols - 1) + '\n')
      res.lines.forEach((line, i) => {
        if (line === null || i > 3) {
          return
        }

        const hilitLine = []
        for (const arg of args) {
          const finder = line.toLowerCase().split(arg.toLowerCase())
          let p = 0
          for (const f of finder) {
            hilitLine.push(line.slice(p, p + f.length))
            const word = line.slice(p + f.length, p + f.length + arg.length)
            const hilit = this.npm.chalk.bgBlack.red(word)
            hilitLine.push(hilit)
            p += f.length + arg.length
          }
        }
        out.push(hilitLine.join('') + '\n')
      })

      return out.join('')
    }).join('\n')

    const finalOut = results.length && !this.npm.config.get('long')
      ? 'Top hits for ' + (args.map(JSON.stringify).join(' ')) + '\n' +
      '—'.repeat(cols - 1) + '\n' +
      output + '\n' +
      '—'.repeat(cols - 1) + '\n' +
      '(run with -l or --long to see more context)'
      : output

    return finalOut.trim()
  }
}
module.exports = HelpSearch


Current_dir [ NOT WRITEABLE ] Document_root [ NOT WRITEABLE ]


[ Back ]
NAME
SIZE
LAST TOUCH
USER
CAN-I?
FUNCTIONS
..
--
3 Mar 2024 10.54 PM
root / root
0755
access.js
6.079 KB
6 Dec 2023 6.07 PM
root / root
0644
adduser.js
1.318 KB
6 Dec 2023 6.07 PM
root / root
0644
audit.js
13.863 KB
6 Dec 2023 6.07 PM
root / root
0644
bugs.js
0.796 KB
6 Dec 2023 6.07 PM
root / root
0644
cache.js
7.072 KB
6 Dec 2023 6.07 PM
root / root
0644
ci.js
3.509 KB
6 Dec 2023 6.07 PM
root / root
0644
completion.js
8.734 KB
6 Dec 2023 6.07 PM
root / root
0644
config.js
10.037 KB
6 Dec 2023 6.07 PM
root / root
0644
dedupe.js
1.396 KB
6 Dec 2023 6.07 PM
root / root
0644
deprecate.js
2.029 KB
6 Dec 2023 6.07 PM
root / root
0644
diff.js
8.123 KB
6 Dec 2023 6.07 PM
root / root
0644
dist-tag.js
5.451 KB
6 Dec 2023 6.07 PM
root / root
0644
docs.js
0.437 KB
6 Dec 2023 6.07 PM
root / root
0644
doctor.js
11.512 KB
6 Dec 2023 6.07 PM
root / root
0644
edit.js
1.997 KB
6 Dec 2023 6.07 PM
root / root
0644
exec.js
2.542 KB
6 Dec 2023 6.07 PM
root / root
0644
explain.js
3.554 KB
6 Dec 2023 6.07 PM
root / root
0644
explore.js
2.305 KB
6 Dec 2023 6.07 PM
root / root
0644
find-dupes.js
0.607 KB
6 Dec 2023 6.07 PM
root / root
0644
fund.js
6.513 KB
6 Dec 2023 6.07 PM
root / root
0644
get.js
0.512 KB
6 Dec 2023 6.07 PM
root / root
0644
help-search.js
5.494 KB
6 Dec 2023 6.07 PM
root / root
0644
help.js
3.535 KB
6 Dec 2023 6.07 PM
root / root
0644
hook.js
3.77 KB
6 Dec 2023 6.07 PM
root / root
0644
init.js
6.902 KB
6 Dec 2023 6.07 PM
root / root
0644
install-ci-test.js
0.364 KB
6 Dec 2023 6.07 PM
root / root
0644
install-test.js
0.361 KB
6 Dec 2023 6.07 PM
root / root
0644
install.js
5.108 KB
6 Dec 2023 6.07 PM
root / root
0644
link.js
5.154 KB
6 Dec 2023 6.07 PM
root / root
0644
ll.js
0.229 KB
6 Dec 2023 6.07 PM
root / root
0644
login.js
1.315 KB
6 Dec 2023 6.07 PM
root / root
0644
logout.js
1.305 KB
6 Dec 2023 6.07 PM
root / root
0644
ls.js
16.729 KB
6 Dec 2023 6.07 PM
root / root
0644
org.js
4.144 KB
6 Dec 2023 6.07 PM
root / root
0644
outdated.js
8.762 KB
6 Dec 2023 6.07 PM
root / root
0644
owner.js
5.906 KB
6 Dec 2023 6.07 PM
root / root
0644
pack.js
2.373 KB
6 Dec 2023 6.07 PM
root / root
0644
ping.js
0.896 KB
6 Dec 2023 6.07 PM
root / root
0644
pkg.js
3.499 KB
6 Dec 2023 6.07 PM
root / root
0644
prefix.js
0.296 KB
6 Dec 2023 6.07 PM
root / root
0644
profile.js
11.188 KB
6 Dec 2023 6.07 PM
root / root
0644
prune.js
0.761 KB
6 Dec 2023 6.07 PM
root / root
0644
publish.js
6.503 KB
6 Dec 2023 6.07 PM
root / root
0644
query.js
2.9 KB
6 Dec 2023 6.07 PM
root / root
0644
rebuild.js
2.141 KB
6 Dec 2023 6.07 PM
root / root
0644
repo.js
1.242 KB
6 Dec 2023 6.07 PM
root / root
0644
restart.js
0.303 KB
6 Dec 2023 6.07 PM
root / root
0644
root.js
0.252 KB
6 Dec 2023 6.07 PM
root / root
0644
run-script.js
6.814 KB
6 Dec 2023 6.07 PM
root / root
0644
search.js
2.677 KB
6 Dec 2023 6.07 PM
root / root
0644
set.js
0.559 KB
6 Dec 2023 6.07 PM
root / root
0644
shrinkwrap.js
2.642 KB
6 Dec 2023 6.07 PM
root / root
0644
star.js
1.866 KB
6 Dec 2023 6.07 PM
root / root
0644
stars.js
1.027 KB
6 Dec 2023 6.07 PM
root / root
0644
start.js
0.293 KB
6 Dec 2023 6.07 PM
root / root
0644
stop.js
0.288 KB
6 Dec 2023 6.07 PM
root / root
0644
team.js
4.438 KB
6 Dec 2023 6.07 PM
root / root
0644
test.js
0.288 KB
6 Dec 2023 6.07 PM
root / root
0644
token.js
6.642 KB
6 Dec 2023 6.07 PM
root / root
0644
uninstall.js
1.506 KB
6 Dec 2023 6.07 PM
root / root
0644
unpublish.js
4.544 KB
6 Dec 2023 6.07 PM
root / root
0644
unstar.js
0.178 KB
6 Dec 2023 6.07 PM
root / root
0644
update.js
1.709 KB
6 Dec 2023 6.07 PM
root / root
0644
version.js
3.576 KB
6 Dec 2023 6.07 PM
root / root
0644
view.js
14.375 KB
6 Dec 2023 6.07 PM
root / root
0644
whoami.js
0.463 KB
6 Dec 2023 6.07 PM
root / root
0644

GRAYBYTE WORDPRESS FILE MANAGER @ 2025 CONTACT ME
Static GIF