Get the file associated with a dependency/partial's path
npm install filing-cabinetconst cabinet = require('filing-cabinet');
const result = cabinet({
partial: 'somePartialPath',
directory: 'path/to/all/files',
filename: 'path/to/parent/file',
ast: {}, // an optional AST representation of `filename`
// Only for JavaScript files
config: 'path/to/requirejs/config',
webpackConfig: 'path/to/webpack/config',
// Node modules entry resolution:
// - As an object: choose which package.json field to use as entry instead of "main"
nodeModulesConfig: {
entry: 'module'
},
// - Or as a function: fully custom package.json transformer (resolve's packageFilter)
// nodeModulesConfig: (pkg) => {
// // Example: prefer "module" and fallback to "main"
// pkg.main = pkg.module ?? pkg.main;
// return pkg;
// },
tsConfig: 'path/to/tsconfig.json', // or an object
tsConfigPath: 'path/to/tsconfig.json'
});
console.log(result); // /absolute/path/to/somePartialPathpartial: the dependency path- This could be in any of the registered languages
directory: the path to all filesfilename: the path to the file containing thepartialast: (optional) the parsed AST forfilename.- Useful optimization for avoiding a parse of filename
config: (optional) requirejs config for resolving aliased JavaScript moduleswebpackConfig: (optional) Webpack config for resolving aliased JavaScript modules. If exporting multiple configurations, the first configuration is used.nodeModulesConfig: (optional) configuration to choose the entry file when resolving packages fromnode_modules.- You can pass an object like
{ entry: 'module' }— in this case theentryfield replacesmainin the target package'spackage.json(for example, to select the ESM entry via themodulefield). - Or you can pass a function — a custom
packageFilterfrom theresolvepackage. The function receives thepackage.jsonobject (pkg), may mutate it (e.g., setpkg.main), and must return the object. This gives you full control over how the entry file is selected.
- You can pass an object like
tsConfig: (optional) path to a TypeScript configuration. Could also be an object representing a pre-parsed TypeScript config.tsConfigPath: (optional) A (virtual) path to TypeScript config file whentsConfigoption is given as an object, not a string. Needed to calculate Path Mapping. If not given whentsConfigis an object, Path Mapping is ignored. This is not need whentsConfigis given as string (path to the tsconfig file).noTypeDefinitions: (optional) For TypeScript files, whether to prefer*.jsover*.d.ts.
By default, filing-cabinet provides support for the following languages:
- JavaScript: CommonJS, AMD, ES6
- TypeScript
- CSS Preprocessors: Sass (
.scssand.sass), Stylus (.styl), and Less (.less) - Svelte
- Vue
You can register resolvers for new languages via cabinet.register(extension, resolver).
extension: the extension of the file that should use the custom resolver (ex: '.py', '.php')resolver: a function that accepts the following (ordered) arguments that were given to cabinet:partialfilenamedirectoryconfig
For examples of resolver implementations, take a look at the default language resolvers:
If a given extension does not have a registered resolver, cabinet will use
a generic file resolver which is basically require('path').join with a bit of extension defaulting logic.
Requires a global install with npm install -g filing-cabinet
filing-cabinet [options] <dependencyPath>See filing-cabinet --help for details on the options.