The typical use for dependency-cruiser is on the command line. However, you might want to use it programmatically. For this, dependency-cruiser has an API.
The API follows the same (semantic) versioning rules and rhythm as the CLI does.
The most basic use for dependency cruiser is to retrieve the dependencies of
and between modules in folder. Here's an example that cruises all files in
the src
folder and prints the dependencies to stdout:
import { cruise, type IReporterOutput } from "dependency-cruiser";
const ARRAY_OF_FILES_AND_DIRS_TO_CRUISE: string[] = ["src"];
try {
const cruiseResult: IReporterOutput = await cruise(
ARRAY_OF_FILES_AND_DIRS_TO_CRUISE,
);
console.dir(cruiseResult.output, { depth: 10 });
} catch (pError) {
console.error(pError);
}
You might notice a few things when you do this
- the function ruthlessly cruises everything in
src
and whatever it uses, recursively - even in yournode_modules
. This takes a long time and might not give the information you actually seek. Dependency-cruiser has a bunch of options to steer what it actually cruises; [passing cruise options](#Passing cruise options) will get you sorted. - If you're using Babel, Webpack or TypeScript the results you get without passing their respective configs might not be what you expect. You can tell dependency-cruiser to [adapt to your environment](#Adapt to your environment), though.
import { cruise, IReporterOutput, ICruiseOptions } from "dependency-cruiser";
const ARRAY_OF_FILES_AND_DIRS_TO_CRUISE: string[] = ["src"];
const cruiseOptions: ICruiseOptions = {
includeOnly: "src",
};
try {
const cruiseResult: IReporterOutput = await cruise(
ARRAY_OF_FILES_AND_DIRS_TO_CRUISE,
cruiseOptions,
);
console.dir(cruiseResult.output, { depth: 10 });
} catch (pError) {
console.error(pError);
}
Apart from all the ones mentioned in the options reference, you can use these options:
option | meaning |
---|---|
validate | if true, will attempt to validate with the rules in ruleSet - defaults to false. |
ruleSet | An object containing the rules to validate against. The rules should adhere to the configuration schema |
outputType | One of the output types mentioned in the --output-format command line options |
import { cruise, IReporterOutput, ICruiseOptions } from "dependency-cruiser";
const ARRAY_OF_FILES_AND_DIRS_TO_CRUISE: string[] = ["src"];
const cruiseOptions: ICruiseOptions = {
includeOnly: "src",
};
const webpackResolveOptions = {
exportsFields: ["exports"],
conditionNames: ["require"],
};
try {
const cruiseResult: IReporterOutput = await cruise(
ARRAY_OF_FILES_AND_DIRS_TO_CRUISE,
cruiseOptions,
webpackResolveOptions,
);
console.dir(cruiseResult.output, { depth: 10 });
} catch (pError) {
console.error(pError);
}
import {
IResolveOptions,
cruise,
type ICruiseOptions,
type IReporterOutput,
} from "dependency-cruiser";
import extractDepcruiseOptions from "dependency-cruiser/config-utl/extract-depcruise-options";
import extractTSConfig from "dependency-cruiser/config-utl/extract-ts-config";
import extractWebpackResolveConfig from "dependency-cruiser/config-utl/extract-webpack-resolve-config";
// import extractBabelConfig from "dependency-cruiser/config-utl/extract-babel-config";
try {
const lArrayOfFilesAndDirectoriesToCruise = ["src"];
const depcruiseOptions: ICruiseOptions = await extractDepcruiseOptions(
"./.dependency-cruiser.json",
);
const lWebpackResolveConfig = (await extractWebpackResolveConfig(
"./webpack.config.js",
)) as IResolveOptions;
const tsConfig = extractTSConfig("./tsconfig.json");
// const babelConfig = await extractBabelConfig("./babel.conf.json");
const cruiseResult: IReporterOutput = await cruise(
lArrayOfFilesAndDirectoriesToCruise,
depcruiseOptions,
lWebpackResolveConfig,
// change since v13: in stead of passing the tsConfig directly, like so:
// tsconfig
// you now pass it into an object that also supports other types of
// compiler options, like those for babel:
{
tsConfig,
// babelConfig: babelConfig,
},
);
console.dir(cruiseResult.output, { depth: 10 });
} catch (pError) {
console.error(pError);
}