Security News
pnpm 10.0.0 Blocks Lifecycle Scripts by Default
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
@rushstack/typings-generator
Advanced tools
This library provides functionality for automatically generator typings for non-TS files.
npm install @rushstack/typings-generator --save-dev
This is a utility for generating typings for non-TS files. It can operate in either a single-run mode or
a watch mode. It is designed to generate .d.ts
files with a specified generation function for all files matching
specified file extensions, with an option to ignore individual files.
import { TypingsGenerator } from '@rushstack/typings-generator';
const typingsGenerator: TypingsGenerator = new TypingsGenerator({
srcFolder: '/repo/package/src',
generatedTsFolder: '/repo/package/temp/generated-typings',
fileExtensions: ['file-extension'],
parseAndGenerateTypings: (fileContents: string, filePath: string) => {
const parsedFile = parseFile(fileContents);
const typings: string = generateTypings(parsedFile);
return typings;
}
});
// To run once before a compilation:
typingsGenerator.generateTypings();
// To start a watcher:
typingsGenerator.runWatcher();
srcFolder = '...'
This property is used as the source root folder for discovery of files for which typings should be generated.
generatedTsFolder = '...'
This property specifies the folder in which .d.ts
files should be dropped. It is recommended
that this be a folder parallel to the source folder, specified in addition to the source folder in the
rootDirs
tsconfig.json
option.
The folder specified by this option is emptied when the utility is invoked.
fileExtensions = [...]
This property enumerates the file extensions that should be handled.
parseAndGenerateTypings = (fileContents: string, filePath: string) => string
This property is used to specify the function that should be called on every file for which typings are being generated. In watch mode, this is called on every file creation and file update. It should return TypeScript declarations for the file it is called with.
terminal
Optionally provide a Terminal object for logging. If one isn't provided, logs will go to the console.
filesToIgnore
Optionally, provide an array of paths to files that should be ignored. These paths can either be absolute
paths, or paths relative to the srcFolder
StringValuesTypingsGenerator
There is an extension of this utility specifically for file types where typings should be a simple
set of exported string values. This is useful for file types like CSS and RESX. This class takes
the same options as the standard TypingsGenerator
, with one additional option (exportAsDefault
) and a different return value for parseAndGenerateTypings
.
parseAndGenerateTypings = (fileContents: string, filePath: string) => { typings: ({ exportName: string, comment?: string })[] }
This function should behave the same as the parseAndGenerateTypings
function for the standard
TypingsGenerator
, except that it should return an object with a typings
property, set to
an array of objects with an exportName
property and an optional comment
property.
See the example below.
{
typings: [
{
exportName: 'myExport'
},
{
exportName: 'myOtherExport',
comment: 'This is the other export'
}
]
}
// This file was generated by a tool. Modifying it will produce unexpected behavior
export declare const myExport: string;
/**
* This is the other export
*/
export declare const myOtherExport: string;
exportAsDefault = true | false
If this option is set to true
, the typings will be exported wrapped in a default
property. This
allows the file to be imported by using the import myFile from './myFile.my-extension';
syntax instead of
the import { myExport } from './myFile.my-extension';
or the import * as myFile from './myFile.my-extension';
syntax. This style of export is not recommended as it can prevent tree-shaking optimization.
FAQs
This library provides functionality for automatically generating typings for non-TS files.
The npm package @rushstack/typings-generator receives a total of 6,541 weekly downloads. As such, @rushstack/typings-generator popularity was classified as popular.
We found that @rushstack/typings-generator demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Security News
pnpm 10 blocks lifecycle scripts by default to improve security, addressing supply chain attack risks but sparking debate over compatibility and workflow changes.
Product
Socket now supports uv.lock files to ensure consistent, secure dependency resolution for Python projects and enhance supply chain security.
Research
Security News
Socket researchers have discovered multiple malicious npm packages targeting Solana private keys, abusing Gmail to exfiltrate the data and drain Solana wallets.