Read the package.json
file from any sub-directory in your project.
npm i @mnrendra/read-package
Using CommonJS
:
const { readPackage, readPackageSync } = require('@mnrendra/read-package')
// Asynchronously
readPackage()
.then(({ name, version }) => {
console.log('asynchronously:', name, version)
})
// Synchronously
const { name, version } = readPackageSync()
console.log('synchronously:', name, version)
Using ES Module
:
import { readPackage, readPackageSync } from '@mnrendra/read-package'
// Asynchronously
readPackage()
.then(({ name, version }) => {
console.log('asynchronously:', name, version)
})
// Synchronously
const { name, version } = readPackageSync()
console.log('synchronously:', name, version)
Assuming your project's ~/project-name/package.json
file is as follows:
{
"name": "project-name",
"version": "1.0.0"
}
Then, you can access and read the ~/project-name/package.json
file from any directory within your project.
Here are some examples:
const { readPackageSync } = require('@mnrendra/read-package')
// Synchronously
const { name, version } = readPackageSync()
console.log('synchronously:', name, version) // Output: synchronously: project-name 1.0.0
import { readPackage } from '@mnrendra/read-package'
// Asynchronously
readPackage()
.then(({ name, version }) => {
console.log('asynchronously:', name, version) // Output: asynchronously: project-name 1.0.0
})
Assuming your module is installed in the /consumer/node_modules/module-name/
directory and the package.json
file for your module located at /consumer/node_modules/module-name/package.json
is as follows:
{
"name": "module-name",
"version": "1.0.0"
}
Then, you can access and read your package.json
file from any directory within your module.
Here are some examples:
"use strict";
const { readPackageSync } = require('@mnrendra/read-package');
// Synchronously
const { name, version } = readPackageSync();
console.log('synchronously:', name, version); // Output: synchronously: module-name 1.0.0
"use strict";
const { readPackage } = require('@mnrendra/read-package');
// Asynchronously
readPackage()
.then(({ name, version }) => {
console.log('asynchronously:', name, version); // Output: asynchronously: module-name 1.0.0
});
type: string|string[]
default: []
A name or a list of names of stack traces that need to be skipped.
type: number
default: 10
The Error.stackTraceLimit
property specifies the number of stack frames to be collected by a stack trace.
import {
validateSkippedStacks // To validate a name or a list of names of stack traces that need to be skipped. More info: @see https://github.com/mnrendra/validate-skipped-stacks
} from '@mnrendra/read-package'
import type {
Package, // Exported from @mnrendra/types-package
Options, // @mnrendra/read-package options
SkippedStacks, // @mnrendra/validate-skipped-stacks input
ValidSkippedStacks // @mnrendra/validate-skipped-stacks output
} from '@mnrendra/read-package'