npm-mono-repo v1.2.0
Sodaru Mono Repo
Sodaru Mono repo Utility
Overview
Mono repos helps to build the related packages in single git repos
lerna is the opensource tool used to maintain npm mono-repos. lerna is not maintained actively and has not suppport for peer dependencies
This tool contains the subset of features from lerna and some extra features
Installation
npm i npm-mono-repoUsage
mono-repo -hCommon Options
mono-repo <command> [-p|--packages package1 package2 package3 ...] [-v|--verbose]packages (package-filters)
The command applies to selected packages only.
If no packages is provided, all packages are considered
verbose
Prints verbose log to std out
Commands
1. install
mono-repo install [--save | --save-dev | --save-peer] [<package-filters>] [-v] [-d|--dependencies [pkg1 pkg2 ...]]install npm packages to packages in the mono-repo
Options
- [-d|--dependencies [pkg1 pkg2 ...]]( Optional ) Name of the packages tobe installed- if no packages provided this is similar to npm i
- if package name is one if the package in mono-repo , then it is symlinked
- if package.jsoncontains the a package from mono-repo, it is alwayssymlinked
 
- if no packages provided this is similar to 
- [--save | --save-dev | --save-peer]( Optional ) Save the packages as dependencies or devDependencies or peerDependencies- no support for optionalorbundleddependencies
 
- no support for 
2. clean
mono-repo clean [<package-filters>] [-v]delete node_modules and package-lock.json from every (or selected) package
3. create
mono-repo create [-v] <packageDirName>creates a new package at packagesDir/packageDirName
Options
- packageDirName( Required ) Name of the directory to be created for the package
4. run
mono-repo run [<package-filters>] [-v] <npm-script> [<npm-script-args>]Runs the npm script in every (or selected) package (In the 'dependency first' order)
IMP NOTE: Skips if package does not have
scriptto run
Options
- npm-script( Required ) Name of the script to be run
- [<npm-script-args>]( Optional ) list of args to be passed to- npm runcommand
5. version
mono-repo version [<package-filters>] [-v]Applies root package version to all (or selected) child packages, and updates the symlinked dependency's version
To be used in version script of the root package to pipeline the version change from root to child packages.
IMP NOTE:
- Lifecycle scipts
preversion,version,postversionare not run- The updated files are added to git stage, if git is enabled for the root package
6. publish
mono-repo publish [-v]Runs npm publish on all child packages (In the 'dependency first' order) whose version matches with the root package.
- skips privatepackages
7. init
mono-repo init [-v]initializes mono repo , by adding required scripts to root package
Support
This project is a part of the Open Source Initiative from Sodaru Technologies
Write an email to opensource@sodaru.com for queries on this project