@zkochan/supi
v0.7.12
Published
Fast, disk space efficient installation engine
Downloads
1
Maintainers
Readme
supi
Fast, disk space efficient installation engine. Used by pnpm
Install
Install it via npm.
npm install supi
It also depends on @pnpm/logger
version 1
, so install it as well via:
npm install @pnpm/logger@1
API
supi.installPkgs(pkgsToInstall, [options])
Install packages.
Arguments:
pkgsToInstall
- Object | String[] - either an object that maps package names to version ranges or inputs usually passed tonpm install
(e.g.,[email protected]
,foo
).options.saveProd
- Boolean - package will appear independencies
.options.saveDev
- Boolean - package will appear indevDependencies
.options.saveOptional
- Boolean - package will appear inoptionalDependencies
.options.saveExact
- Boolean - saved dependencies will be configured with an exact version rather than using npm's default semver range operator.options.global
- Boolean - the packages will be installed globally rather than locally.options.prefix
- String - the directory in which the installation will be performed. By default theprocess.cwd()
value is used.options.metaCache
- Map - a cache for package meta info.options.networkConcurrency
- Number -16
by default. Max amount of network requests to perform concurrently.options.offline
- Boolean -false
by default. Install packages using only the local registry mirror, w/o doing any network requests.options.reporter
- Function - A function that listens for logs.options.packageManager
- Object - Thepackage.json
of the package manager.options.hooks
- Object - A property that contains installation hooks. Hooks are documented separately.options.ignoreFile
- Function & (filename: string) => boolean - A function that decides which files in a package are ignored. For instance, there's no need in.travis.yml
files in production, so you can set{ignoreFile: fn => fn === '.travis.yml'}
.
Returns: a Promise
Example:
const pnpm = require('pnpm')
pnpm.installPkgs({
'is-positive': '1.0.0',
'hello-world': '^2.3.1'
}, { saveDev: true })
supi.install([options])
Install all modules listed as dependencies in package.json
.
Arguments: (same as in named install and additionally)
options.production
- Boolean -true
by default. Iftrue
, packages listed independencies
will be installed.options.development
- Boolean -true
by default. Iftrue
, packages listed indevDependencies
will be installed.options.optional
- Boolean - Has the value ofoptions.production
by default. Iftrue
, packages listed inoptionalDependencies
will be installed. Can betrue
only whenoptions.production
istrue
as well.
supi.uninstall(pkgsToUninstall, [options])
Uninstalls a package, completely removing everything pnpm installed on its behalf.
Arguments:
pkgsToUninstall
- String[] - the package names to be uninstalled.options.saveProd
- Boolean - the package will be removed fromdependencies
.options.saveDev
- Boolean - the package will be removed fromdevDependencies
.options.saveOptional
- Boolean - the package will be removed fromoptionalDependencies
.options.global
- Boolean - the packages will be uninstalled globally.options.reporter
- Function - A function that listens for logs.
supi.link(linkFrom, lintTo, [options])
Create a symbolic link from the linked package to the target package's node_modules
(and its node_modules/.bin
).
Arguments:
linkFrom
- String - path to the package that should be linked.lintTo
- String - path to the dependent package.options.reporter
- Function - A function that listens for logs.
supi.linkToGlobal(linkFrom, options)
Create a symbolic link from the specified package to the global node_modules
.
Arguments:
linkFrom
- String - path to the package that should be linked.globalPrefix
- String - path to the global directory.options.reporter
- Function - A function that listens for logs.
supi.linkFromGlobal(pkgName, linkTo, options)
Create a symbolic link from the global pkgName
to the linkTo/node_modules
folder.
Arguments:
pkgName
- String - package to link.linkTo
- String - package to link to.globalPrefix
- String - path to the global directory.options.reporter
- Function - A function that listens for logs.
supi.unlink([options])
Unlinks all packages that were linked during development in a project. If the linked package is in package.json
of the project,
it is installed after unlinking.
Arguments:
options.prefix
- String - by defaultprocess.cwd()
. Path to the project.options.reporter
- Function - A function that listens for logs.
supi.unlinkPkgs(pkgsToUnlink, [options])
Unlinks the listed packages that were linked during development in a project. If the linked package is in package.json
of the project,
it is installed after unlinking.
Arguments:
pkgsToUnlink
- String[] - the list of packages that have to be unlinked. If the passed in package is not an external link, then a warning is reported.options.prefix
- String - by defaultprocess.cwd()
. Path to the project.options.reporter
- Function - A function that listens for logs.
supi.prune([options])
Remove extraneous packages. Extraneous packages are packages that are not listed on the parent package's dependencies list.
Arguments:
options.production
- Boolean - by defaultfalse
. If this property istrue
, prune will remove the packages specified indevDependencies
.options.prefix
- String - by defaultprocess.cwd()
.options.reporter
- Function - A function that listens for logs.
supi.storeStatus([options])
Return the list of modified dependencies.
Arguments:
options.reporter
- Function - A function that listens for logs.
Returns: Promise<string[]>
- the paths to the modified packages of the current project. The paths contain the location of packages in the store,
not in the projects node_modules
folder.
supi.storePrune([options])
Remove unreferenced packages from the store.
Hooks
Hooks are functions that can step into the installation process.
readPackage(pkg)
This hook is called with every dependency's manifest information. The modified manifest returned by this hook is then used by supi during installation.
Example:
const supi = require('supi')
supi.installPkgs({
hooks: {readPackage}
})
function readPackage (pkg) {
if (pkg.name === 'foo') {
pkg.dependencies = {
bar: '^2.0.0',
}
}
return pkg
}
Acknowledgements
Thanks to Valentina Kozlova for the supi logo