@vltpkg/workspaces
Classes
Monorepo
Defined in: index.ts:149
Class representing a Monorepo containing multiple workspaces.
Does not automatically look up the root, but that can be provided by
running Config.load()
, since it stops seeking the route when a
vlt-workspaces.json
file is encountered.
Constructors
new Monorepo()
Defined in: index.ts:168
Parameters
projectRoot
string
options
MonorepoOptions
= {}
Returns
Properties
packageJson
Defined in: index.ts:159
projectRoot
Defined in: index.ts:151
The project root where vlt-workspaces.json is found
scurry
Defined in: index.ts:153
Scurry object to cache all filesystem calls (mostly globs)
Accessors
config
Get Signature
Defined in: index.ts:185
Load the workspace definitions from vlt-workspaces.json,
canonicalizing the result into the effective {[group:string]:string[]}
form.
Eg:
"src/*"
=>{packages:["src/*"]}
{"apps": "src/*"}
=>{apps: ["src/*"]}
Returns
size
Get Signature
Defined in: index.ts:164
Number of Workspace objects loaded in this Monorepo
Returns
number
Methods
[asyncIterator]()
Defined in: index.ts:228
Iterating the Monorepo object yields the workspace objects, in as close to topological dependency order as possible.
Returns
AsyncGenerator
<Workspace
, void
, void
>
[iterator]()
Defined in: index.ts:214
Iterating the Monorepo object yields the workspace objects, in as close to topological dependency order as possible.
Returns
Generator
<Workspace
, void
, void
>
filter()
Defined in: index.ts:492
Filter the monorepo object yielding the workspace objects that matches either of the WorkspacesLoadedConfig options provided, in as close to topological dependency order as possible.
Parameters
__namedParameters
Returns
Generator
<Workspace
, void
>
get()
Defined in: index.ts:439
Get a loaded workspace by path or name.
Note that this can only return workspaces that were ingested via a previous call to Monorepo#load.
Parameters
nameOrPath
string
Returns
undefined
| Workspace
getDeps()
Defined in: index.ts:379
Return the array of workspace dependencies that are found in the loaded set, for use in calculating dependency graph order for build operations.
This does not get the full set of dependencies, or expand any
workspace:
dependencies that are not loaded.
Call with the forceLoad
param set to true
to attempt a full
load if any deps are not currently loaded.
Parameters
ws
forceLoad
boolean
= false
Returns
group()
Defined in: index.ts:429
Return the set of workspaces in the named group. If the group is not one we know about, then undefined is returned.
Parameters
group
string
Returns
undefined
| Set
<Workspace
>
keys()
Defined in: index.ts:480
Get all the keys (package names and paths) for loaded workspaces. Union of Monorepo#names and Monorepo#paths
Returns
Generator
<string
, void
>
load()
Defined in: index.ts:255
By default, loads all workspaces reachable in the Monorepo.
If provided with one (string
)or more (string[]
) group names in
the LoadQuery#groups field, then only Workspaces in the named
group(s) will be considered. Note that group names are unique string
matches, not globs.
If provided with a set of arbitrary path arguments, then only paths patching the provided pattern(s) will be included.
These two options intersect, so
load({groups:'foo', paths:'./foo/[xy]*'})
will only load the workspaces
in the group foo
that match the paths glob.
Parameters
query
LoadQuery
= {}
Returns
this
names()
Defined in: index.ts:446
get the list of all loaded workspace names used as keys
Returns
Generator
<string
, void
>
onCycle()
Defined in: index.ts:411
Parameters
_ws
_cycle
_depPath
Returns
void
paths()
Defined in: index.ts:455
get the list of all loaded workspace paths used as keys
Returns
Generator
<string
, void
>
run()
Defined in: index.ts:535
Run an operation asynchronously over all loaded workspaces
If the forceLoad
param is true, then it will attempt to do a full load
when encountering a workspace:
dependency that isn’t loaded.
Note that because the return type appears in the parameters of the
operation function, it must be set explicitly either in the operation
function signature or by calling run<MyType>
or it’ll fall back to
unknown
, similar to Array.reduce()
, and for the same reason.
Type Parameters
• R
Parameters
operation
(s
, signal
, depResults
) => R
| Promise
<R
>
forceLoad
boolean
= false
Returns
Promise
<Map
<Workspace
, R
>>
runSync()
Defined in: index.ts:568
Run an operation synchronously over all loaded workspaces
If the forceLoad
param is true, then it will attempt to do a full load
when encountering a workspace:
dependency that isn’t loaded.
Note that because the return type appears in the parameters of the
operation function, it must be set explicitly either in the operation
function signature or by calling runSync<MyType>
or it’ll fall back to
unknown
, similar to Array.reduce()
, and for the same reason.
Type Parameters
• R
Parameters
operation
(s
, signal
, depResults
) => R
forceLoad
boolean
= false
Returns
Map
<Workspace
, R
>
values()
Defined in: index.ts:467
get the workspace objects in no particular order. this is ever so slightly faster than iterating, because it doesn’t explore the graph to yield results in topological dependency order, and should be used instead when order doesn’t matter.
Returns
Generator
<Workspace
, void
>
load()
Defined in: index.ts:618
Convenience method to instantiate and load in one call. Throws if called on a directory that is not a workspaces root.
Parameters
projectRoot
string
options
MonorepoOptions
= ...
Returns
maybeLoad()
Defined in: index.ts:595
Convenience method to instantiate and load in one call. Returns undefined if the project is not a monorepo workspaces root, otherwise returns the loaded Monorepo.
Parameters
projectRoot
string
options
MonorepoOptions
= ...
Returns
undefined
| Monorepo
Workspace
Defined in: index.ts:632
Class representing a single Workspace in a Monorepo
Constructors
new Workspace()
Defined in: index.ts:641
Parameters
path
string
manifest
fullpath
string
Returns
Properties
fullpath
Defined in: index.ts:635
groups
Defined in: index.ts:637
id
Defined in: index.ts:633
manifest
Defined in: index.ts:636
name
Defined in: index.ts:638
path
Defined in: index.ts:634
Accessors
keys
Get Signature
Defined in: index.ts:650
Returns
string
[]
Type Aliases
LoadQuery
Defined in: index.ts:22
The object passed to the constructor or Monorepo#load to limit which Workspaces get loaded.
Type declaration
groups?
A string, or an array of strings. If set, only workspaces in the specified groups named will be included, if set.
paths?
A glob pattern string, or an array of them. Only workspaces found in paths matched will be loaded.
MonorepoOptions
Defined in: index.ts:124
Type declaration
config?
Parsed normalized contents of a vlt-workspaces.json
file
load?
If set, then Monorepo#load will be called immediately with this argument.
packageJson?
A PackageJson object, for sharing manifest caches
scurry?
A PathScurry object, for use in globs
WorkspaceConfig
Defined in: index.ts:44
Allowed datatype in the vlt-workspaces.json
file.
WorkspaceConfigObject
Defined in: index.ts:39
Canonical form of the WorkspaceConfig, used internally for consistency.
WorkspacesLoadedConfig
Defined in: index.ts:13
Type declaration
workspace?
workspace-group?
Variables
workspaceCache
Defined in: index.ts:627
Functions
assertWSConfig()
Defined in: index.ts:68
Throw if the provided value is not a valid WorkspaceConfig
Parameters
conf
unknown
path?
string
Returns
asserts conf is WorkspaceConfig
asWSConfig()
Defined in: index.ts:53
Turn a WorkspaceConfig into a WorkspaceConfigObject, or throw if it’s not valid.
Parameters
conf
unknown
path?
string