1. npm-package-arg
Parse the things that can be arguments to `npm install`
npm-package-arg
Package: npm-package-arg
Created by: npm
Last modified: Fri, 12 Apr 2024 22:05:08 GMT
Version: 11.0.2
License: ISC
Downloads: 56,380,449
Repository: https://github.com/npm/npm-package-arg

Install

npm install npm-package-arg
yarn add npm-package-arg

npm-package-arg

Build Status

Parses package name and specifier passed to commands like npm install or
npm cache add, or as found in package.json dependency sections.

EXAMPLES

 var assert = require("assert")
var npa = require("npm-package-arg")

// Pass in the descriptor, and it'll return an object
try {
  var parsed = npa("@bar/[email protected]")
} catch (ex) {
  …
}

USING

var npa = require('npm-package-arg')

var result = npa(arg[, where])

  • arg - a string that you might pass to npm install, like:
    [email protected], @bar/[email protected], foo@user/foo, http://x.com/foo.tgz,
    git+https://github.com/user/foo, bitbucket:user/foo, foo.tar.gz,
    ../foo/bar/ or bar. If the arg you provide doesn't have a specifier
    part, eg foo then the specifier will default to latest.
  • where - Optionally the path to resolve file paths relative to. Defaults to process.cwd()

Throws if the package name is invalid, a dist-tag is invalid or a URL's protocol is not supported.

var result = npa.resolve(name, spec[, where])

  • name - The name of the module you want to install. For example: foo or @bar/foo.
  • spec - The specifier indicating where and how you can get this module. Something like:
    1.2, ^1.7.17, http://x.com/foo.tgz, git+https://github.com/user/foo,
    bitbucket:user/foo, file:foo.tar.gz or file:../foo/bar/. If not
    included then the default is latest.
  • where - Optionally the path to resolve file paths relative to. Defaults to process.cwd()

Throws if the package name is invalid, a dist-tag is invalid or a URL's protocol is not supported.

var purl = npa.toPurl(arg, reg)

Returns the purl (package URL) form of the given package name/spec.

  • arg - A package/version string. For example: [email protected] or @bar/[email protected].
  • reg - Optionally the URL to the package registry. If not specified, assumes the default
    https://registry.npmjs.org.

Throws if the package name is invalid, or the supplied arg can't be resolved to a purl.

RESULT OBJECT

The objects that are returned by npm-package-arg contain the following
keys:

  • type - One of the following strings:
    • git - A git repo
    • tag - A tagged version, like "foo@latest"
    • version - A specific version number, like "[email protected]"
    • range - A version range, like "[email protected]"
    • file - A local .tar.gz, .tar or .tgz file.
    • directory - A local directory.
    • remote - An http url (presumably to a tgz)
    • alias - A specifier with an alias, like myalias@npm:[email protected]
  • registry - If true this specifier refers to a resource hosted on a
    registry. This is true for tag, version and range types.
  • name - If known, the name field expected in the resulting pkg.
  • scope - If a name is something like @org/module then the scope
    field will be set to @org. If it doesn't have a scoped name, then
    scope is null.
  • escapedName - A version of name escaped to match the npm scoped packages
    specification. Mostly used when making requests against a registry. When
    name is null, escapedName will also be null.
  • rawSpec - The specifier part that was parsed out in calls to npa(arg),
    or the value of spec in calls to `npa.resolve(name, spec).
  • saveSpec - The normalized specifier, for saving to package.json files.
    null for registry dependencies.
  • fetchSpec - The version of the specifier to be used to fetch this
    resource. null for shortcuts to hosted git dependencies as there isn't
    just one URL to try with them.
  • gitRange - If set, this is a semver specifier to match against git tags with
  • gitCommittish - If set, this is the specific committish to use with a git dependency.
  • hosted - If from === 'hosted' then this will be a hosted-git-info
    object. This property is not included when serializing the object as
    JSON.
  • raw - The original un-modified string that was provided. If called as
    npa.resolve(name, spec) then this will be name + '@' + spec.
  • subSpec - If type === 'alias', this is a Result Object for parsing the
    target specifier for the alias.

RELATED POST

10 Must-Know Windows Shortcuts That Will Save You Time

10 Must-Know Windows Shortcuts That Will Save You Time

Arrays vs Linked Lists: Which is Better for Memory Management in Data Structures?

Arrays vs Linked Lists: Which is Better for Memory Management in Data Structures?

Navigating AWS Networking: Essential Hacks for Smooth Operation

Navigating AWS Networking: Essential Hacks for Smooth Operation

Achieving Stunning Visuals with Unity's Global Illumination

Achieving Stunning Visuals with Unity's Global Illumination

Nim's Hidden Gems: Lesser-known Features for Writing Efficient Code

Nim's Hidden Gems: Lesser-known Features for Writing Efficient Code