Important: This documentation covers Yarn 1 (Classic).
For Yarn 2+ docs and migration guide, see yarnpkg.com.

Package detail

yalc

whitecolor649.4kMIT1.0.0-pre.53TypeScript support: included

Work with npm/yarn packages locally like a boss.

readme

Yalc

Better workflow than npm | yarn link for package authors.

Why

When developing and authoring multiple packages (private or public), you often find yourself in need of using the latest/WIP versions in other projects that you are working on in your local environment without publishing those packages to the remote registry. NPM and Yarn address this issue with a similar approach of symlinked packages (npm/yarn link). Though this may work in many cases, it often brings nasty constraints and problems with dependency resolution, symlink interoperability between file systems, etc.

What

  • yalc acts as very simple local repository for your locally developed packages that you want to share across your local environment.
  • When you run yalc publish in the package directory, it grabs only files that should be published to NPM and puts them in a special global store (located, for example, in ~/.yalc).
  • When you run yalc add my-package in your project it pulls package content into .yalc in the current folder and injects a file:/link: dependency into package.json. Alternatively, you may use yalc link my-package which will create a symlink to the package content in node_modules and will not touch package.json (like npm/yarn link does), or you even may use it with Pnmp/Yarn/Npm workspaces.
  • yalc creates a special yalc.lock file in your project (similar to yarn.lock and package-lock.json) that is used to ensure consistency while performing yalc's routines.
  • yalc can be used with projects where yarn or npm package managers are used for managing package.json dependencies.

Installation

npm (scoped) Build Status

Using NPM:

npm i yalc -g

Using Yarn:

yarn global add yalc

Some documented features might not have been published yet, see the change log.

Usage

Publish

  • Run yalc publish in your dependency package my-package.
  • It will copy all the files that should be published in remote NPM registry.
  • If your package has any of these lifecycle scripts: prepublish, prepare, prepublishOnly, prepack, preyalcpublish, they will run before in this order. If your package has any of these: postyalcpublish, postpack, publish, postpublish, they will run after in this order. Use --no-scripts to publish without running scripts.
  • While copying package content, yalc calculates the hash signature of all files and, by default, adds this signature to the package manifest version. You can disable this by using the --no-sig option.
  • You may also use .yalcignore to exclude files from publishing to yalc repo, for example, files like README.md, etc.
  • --files flag will show included files in the published package
  • NB! In terms of which files will be included in the package yalc fully supposed to emulate behavior of npm client (npm pack). If you have nested .yalc folder in your package that you are going to publish with yalc and you use package.json files list, it should be included there explicitly.
  • NB! Windows users should make sure the LF new line symbol is used in published sources; it may be needed for some packages to work correctly (for example, bin scripts). yalc won't convert line endings for you (because npm and yarn won't either).
  • NB! Note that, if you want to include .yalc folder in published package content, you should add !.yalc line to .npmignore.
  • Easily propagate package updates everywhere.
  • Yalc by default resolve workspace: protocol in dependencies, to omit this use -no-workspace-resolve flag

Add

  • Run yalc add my-package in your dependent project, which will copy the current version from the store to your project's .yalc folder and inject a file:.yalc/my-package dependency into package.json.
  • You may specify a particular version with yalc add my-package@version. This version will be fixed in yalc.lock and will not affect newly published versions during updates.
  • Use the --link option to add a link: dependency instead of file:.
  • Use the --dev option to add yalc package to dev dependencies.
  • With --pure flag it will not touch package.json file, nor it will touch modules folder, this is useful for example when working with Yarn workspaces (read below in Advanced usage section)
  • With --workspace (or -W) it will add dependency with "workspace:" protocol.
  • As an alternative to add, you can use the link command which is similar to npm/yarn link, except that the symlink source will be not the global link directory but the local .yalc folder of your project.
  • After yalc copies package content to .yalc folder it will create a symlink: project/.yalc/my-package ==> project/node_modules/my-package. It will not touch package.json in this case.

Update

  • Run yalc update my-package to update the latest version from store.
  • Run yalc update to update all the packages found in yalc.lock.
  • preyalc and postyalc scripts will be executed in target package on add/update operations which are performed while push
  • if need to perform pre/post scripts on update of particular package use (pre|post)yalc.package-name name for script in your package.json.
  • update --update (--upgrade, --up) to run package managers's update command for packages.

Remove

  • Run yalc remove my-package, it will remove package info from package.json and yalc.lock
  • Run yalc remove --all to remove all packages from project.

Installations

  • Run yalc installations clean my-package to unpublish a package published with yalc publish
  • Run yalc installations show my-package to show all packages to which my-package has been installed.

Advanced usage

Pushing updates automatically to all installations

  • When you run yalc add|link|update, the project's package locations are tracked and saved, so yalc knows where each package in the store is being used in your local environment.
  • yalc publish --push will publish your package to the store and propagate all changes to existing yalc package installations (this will actually do update operation on the location).
  • yalc push - is a use shortcut command for push operation (which will likely become your primarily used command for publication):
  • scripts options is false by default, so it won't run pre/post scripts (may change this with passing --scripts flag).
  • With --changed flag yalc will first check if package content has changed before publishing and pushing, it is a quick operation and may be useful for file watching scenarios with pushing on changes.
  • Use --replace option to force replacement of package content.
  • Use preyalc and postyalc (read in update docs) to execute needed script on every push.
  • Use --update to run yarn/npm/pnpm update command for pushed packages.

Keep it out of git

  • If you are using yalc'ed modules temporarily during development, first add .yalc and yalc.lock to .gitignore.
  • Use yalc link, that won't touch package.json
  • If you use yalc add it will change package.json, and ads file:/link: dependencies, if you may want to use yalc check in the precommit hook which will check package.json for yalc'ed dependencies and exits with an error if you forgot to remove them.

Keep it in git

  • You may want to keep shared yalc'ed stuff within the projects you are working on and treat it as a part of the project's codebase. This may really simplify management and usage of shared work in progress packages within your projects and help to make things consistent. So, then just do it, keep .yalc folder and yalc.lock in git.
  • Replace it with published versions from remote repository when ready.
  • NB! - standard non-code files like README, LICENCE etc. will be included also, so you may want to exclude them in .gitignore with a line like **/.yalc/**/*.md or you may use .yalcignore not to include those files in package content.

Publish/push sub-projects

  • Useful for monorepos (projects with multiple sub-projects/packages): yalc publish some-project will perform publish operation in the ./some-project directory relative to process.cwd()

Retreat and Restore

  • Instead of completely removing package you may temporary set it back with yalc retreat [--all] for example before package publication to remote registry.
  • After or later restore it with yalc restore.

Use with Yarn/Pnpm workspaces

Use if you will try to add repo in workspaces enabled package, --pure option will be used by default, so package.json and modules folder will not be touched.

Then you add yalc'ed package folder to workspaces in package.json (you may just add .yalc/* and .yalc/@*/* patterns). While update (or push) operation, packages content will be updated automatically and yarn will care about everything else.

If you want to override default pure behavior use --no-pure flag.

Clean up installations file

  • While working with yalc for some time on the dev machine you may face the situation when you have locations where you added yalc'ed packages being removed from file system, and this will cause some warning messages when yalc will try to push package to removed location. To get rid of such messages, there is an explicit command for this: yalc installations clean [package].

Override default package store folder

  • You may use --store-folder flag option to override default location for storing published packages.

Control output

  • Use --quiet to fully disable output (except of errors). Use --no-colors to disable colors.

Set default options via .yalcrc

  • For example add workspace-resolve=false line to the .yalcrc file to turn off workspace: protocol resolution or sig=false to disable package version hash signature.

Licence

WTF.

changelog

Yalc changelog

1.0.0.pre.53 (2021-04-28)

  • support ^/~/* workspace package resolution while publish

1.0.0.pre.52 (2021-04-28)

  • fix/workaround @scoped root dir names bug (in npm-packlist)

1.0.0.pre.51 (2021-04-23)

  • BREAKING (shock!): version signature (adding build meta to pkg version) is turned off by default (use explicit --sig)
  • link .bin scripts only when yalc link or yalc add --link
  • read package manifest after running pre-script while publish
  • add -W flag to add with workspace: protocol
  • fix --scripts flag
  • upgrade npm-packlist to v2

1.0.0.pre.50 (2021-01-19)

  • add restore package operation after retreat
  • add resolution of workspace: protocol by default (--no-workspace-resolve to avoid)
  • add support for .yalcrc file (ini format)

1.0.0.pre.49 (2020-12-17)

  • fix --quiet option name typing
  • fix removing multiple packages

1.0.0.pre.48 (2020-12-10)

  • add update (upgrade, up) flag to run PM's package update command on add/update/publish/push
  • remove yarn, npm flags

1.0.0.pre.47 (2020-11-20)

  • update yargs package version

1.0.0.pre.46 (2020-11-18)

  • dev-mod flag (use --no-dev-mod not to remove devDependencies)
  • use detect-indent whn modifying package.json

1.0.0.pre.45 (2020-09-30)

  • remove --force flag
  • surface STDOUT/STDERR of execSync

1.0.0.pre.44 (2020-09-18)

  • fix removing scoped package folder

1.0.0.pre.43 (2020-09-17)

  • try/catch for ensuring symlink when modifying bin permissions
  • add signature (yalcSig key) to published package.json
  • add --no-scripts to publish/push without running scripts
  • add -W (workspaces) as alias for --no-pure
  • prevent removing .yalc folder if something else exists there

1.0.0.pre.42 (2020-08-17)

  • replace pre/postyalc scripts with pre/postyalcpublish
  • execute pre/postyalc scripts in target package/project on add/update
  • added --quite f to disabled output (except of errors)
  • added colored output can be disabled --no-color
  • fixed removing installations
  • fixed running pm scripts

1.0.0.pre.41 (2020-08-06)

  • add quotes around workingDir
  • try/catch when modifying bin permissions

1.0.0.pre.40 (2020-07-24)

  • remove empty directories why sync dir copy

1.0.0.pre.39 (2020-07-24)

  • yalc publish now runs all of the lifecycle scripts it finds

1.0.0.pre.38 (2020-07-23)

  • use --pure flag with workspaces by default
  • add check for PNPM workspace for --pure flag

1.0.0.pre.37 (2020-07-05)

  • allow using --pure flag without workspaces
  • --replace flag to force replacement of content while adding/pushing package

1.0.0.pre.36 (2020-06-14)

1.0.0.pre.35 (2020-01-16)

  • fix --pure flag usage

1.0.0.pre.34 (2019-08-27)

  • added --store-folder to override default global package store folder

1.0.0.pre.33 (2019-08-15)

  • added lifecycle scripts, like prepack

1.0.0.pre.30 (2019-06-05)

  • fix copy method

1.0.0.pre.29 (2019-06-03)

  • new safe copy method

1.0.0.pre.28 (2019-05-26)

  • updates .bin scripts with permissions

1.0.0.pre.26 (2018-12-24)

  • prepare script
  • --private flag to publish private package
  • --version flag
  • fix of npm-packlist that may not include nested package.json

1.0.0.pre.25 (2018-12-14)

  • --pure flag, yarn workspaces support
  • --changed option, publish/push only if package content changed
  • remove devDependencies from published content
  • --files option

1.0.0.pre.24 (2018-11-23)

  • postupdate script on update (and push)
  • new file inclusion algorithm with npm-packlist
  • .yalcignore added
  • installations show/clean commmand

1.0.0.pre.16 (2018-01-02)

  • fix package deps
  • fix --link removal

1.0.0.pre.15 (2017-12-30)

  • run prepblushOnly script on publish
  • fixed darwin os support
  • fixed linking EPERM
  • added --link option to add command for adding link: deps

1.0.0.pre.14 (2017-12-15)

  • fix: remove package dir from node_modules only if needed

1.0.0.pre.13 (2017-11-22)

  • fix: remove .yalc folder from ignored

1.0.0.pre.12 (2017-10-24)

  • update fs-extra
  • fix #7

1.0.0.pre.11 (2017-06-09)

  • fixed include rules for folder/file

1.0.0.pre.10 (2017-05-27)

  • fixed --all option for retreat command
  • fixed #3 yarn absence error output

1.0.0.pre.9 (2017-05-21)

  • added hash signature
  • no default command
  • fixed not-exiting package removal
  • added --all option for remove
  • handle unknown command

1.0.0.pre.8 (2017-05-25)

  • fix copy if no files in manifest defined

1.0.0.pre.7 (2017-05-11)

  • fixes files inclusion (#2)

1.0.0.pre.6 (2017-05-09)

  • fixed yarn.lock bug

1.0.0.pre.5 (2017-05-07)

  • copy to dest package dir not removing inner node_modules

1.0.0.pre.4 (2017-05-02)

  • do not publish standard non-code files (README, LICENCE, etc.)
  • remove lockfile and .yalc dir if empty

1.0.0.pre.3 (2017-04-28)

  • use .gitignore if no files entry in manifest

1.0.0.pre.2 (2017-04-26)

  • remove removes from .yalc and node_modules
  • fixed installtion file write bug when publish
  • handle files field in manifest

1.0.0.pre.1 (2017-04-25)

  • fixed installation file first read
  • check command
  • remove and retreat commands

1.0.0.pre.0 (2017-04-23)

  • publish, push, add, update