
Security News
Frontier AI Is Now Critical Infrastructure
The Fable shutdown shows how quickly model access can become a business continuity risk for AI-dependent engineering teams.
@mdscript/bundler-utils
Advanced tools
Shared transform utilities for MDS bundler plugins (Vite, Rollup, Webpack).
Note: This package is pre-release and not yet published to npm.
npm install @mdscript/bundler-utils
npm install @mdscript/mds
This package is primarily consumed by the bundler-specific plugin packages
(@mdscript/vite-plugin, @mdscript/rollup-plugin, @mdscript/webpack-loader). You only
need to use it directly if you are writing a plugin for another bundler.
import { createMdsTransformer, formatMdsError, shouldTransform } from '@mdscript/bundler-utils';
// Lazily initialize (call once per build, after loading @mdscript/mds)
const mds = await import('@mdscript/mds');
const transformer = createMdsTransformer(mds, { vars: { env: 'production' } });
// Transform a .mds file to a JavaScript module
if (await transformer.shouldTransform('/path/to/file.mds')) {
const result = await transformer.transform('/path/to/file.mds');
// result.code - JS module source
// result.dependencies - absolute paths of transitively imported files
// result.warnings - non-fatal compiler warnings
}
To tell TypeScript about .mds imports, add the following to your tsconfig.json:
{
"compilerOptions": {
"types": ["@mdscript/bundler-utils/mds"]
}
}
Or add a triple-slash reference in any .d.ts file in your project:
/// <reference types="@mdscript/bundler-utils/mds" />
This makes import content from './prompt.mds' type-safe: content is string
and the module also exports metadata: { warnings: string[]; dependencies: string[] }.
LazyInit<T> is a single-init lazy value holder with concurrent-call deduplication
and retry-on-rejection semantics. It is exported for bundler plugin authors who need
the same guarantee.
import { LazyInit } from '@mdscript/bundler-utils';
// Factory is invoked at most once per successful resolution.
const lazy = new LazyInit(async () => {
const mds = await import('@mdscript/mds');
return createMdsTransformer(mds, options);
});
// Concurrent calls share the in-flight promise; factory runs once.
const transformer = await lazy.get();
// Reset clears state; the next get() re-invokes the factory.
lazy.reset();
Key properties:
reset().get() calls share the in-flight promise.reset().interface MdsPluginOptions {
/** Variables available for interpolation in .mds templates. */
vars?: Record<string, unknown>;
}
MIT
FAQs
Shared utilities for MDS bundler plugins
We found that @mdscript/bundler-utils demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 1 open source maintainer 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
The Fable shutdown shows how quickly model access can become a business continuity risk for AI-dependent engineering teams.

Security News
AI agents are pulling packages into environments no scanner is watching, creating exposure before security teams can see it.

Security News
GitHub Actions checkout now blocks risky pull_request_target checkouts by default to help prevent pwn request supply chain attacks.