Vulnerabilities | |||||
---|---|---|---|---|---|
Version | Suggest | Low | Medium | High | Critical |
0.45.0 | 0 | 0 | 0 | 0 | 0 |
0.44.0 | 0 | 0 | 0 | 0 | 0 |
0.43.0 | 0 | 0 | 0 | 0 | 0 |
0.42.0 | 0 | 0 | 0 | 0 | 0 |
0.41.0 | 0 | 0 | 0 | 0 | 0 |
0.40.1 | 0 | 0 | 0 | 0 | 0 |
0.40.0 | 0 | 0 | 0 | 0 | 0 |
0.39.0 | 0 | 0 | 0 | 0 | 0 |
0.38.0 | 0 | 0 | 0 | 0 | 0 |
0.37.0 | 0 | 0 | 0 | 0 | 0 |
0.36.0 | 0 | 0 | 0 | 0 | 0 |
0.35.0 | 0 | 0 | 0 | 0 | 0 |
0.34.0 | 0 | 0 | 0 | 0 | 0 |
0.33.0 | 0 | 0 | 0 | 0 | 0 |
0.32.0 | 0 | 0 | 0 | 0 | 0 |
0.31.0 | 0 | 0 | 0 | 0 | 0 |
0.30.5 | 0 | 0 | 0 | 0 | 0 |
0.30.4 | 0 | 0 | 0 | 0 | 0 |
0.30.3 | 0 | 0 | 0 | 0 | 0 |
0.30.2 | 0 | 0 | 0 | 0 | 0 |
0.30.1 | 0 | 0 | 0 | 0 | 0 |
0.30.0 | 0 | 0 | 0 | 0 | 0 |
0.29.0 | 0 | 0 | 0 | 0 | 0 |
0.28.0 | 0 | 0 | 0 | 0 | 0 |
0.27.0 | 0 | 0 | 0 | 0 | 0 |
0.26.0 | 0 | 0 | 0 | 0 | 0 |
0.25.0 | 0 | 0 | 0 | 0 | 0 |
0.24.3 | 0 | 0 | 0 | 0 | 0 |
0.24.2 | 0 | 0 | 0 | 0 | 0 |
0.24.1 | 0 | 0 | 0 | 0 | 0 |
0.24.0 | 0 | 0 | 0 | 0 | 0 |
0.23.1 | 0 | 0 | 0 | 0 | 0 |
0.23.0 | 0 | 0 | 0 | 0 | 0 |
0.22.1 | 0 | 0 | 0 | 0 | 0 |
0.22.0 | 0 | 0 | 0 | 0 | 0 |
0.21.0 | 0 | 0 | 0 | 0 | 0 |
0.20.0 | 0 | 0 | 0 | 0 | 0 |
0.19.0 | 0 | 0 | 0 | 0 | 0 |
0.18.0 | 0 | 0 | 0 | 0 | 0 |
0.17.2 | 0 | 0 | 0 | 0 | 0 |
0.17.1 | 0 | 0 | 0 | 0 | 0 |
0.17.0 | 0 | 0 | 0 | 0 | 0 |
0.16.3 | 0 | 0 | 0 | 0 | 0 |
0.16.2 | 0 | 0 | 0 | 0 | 0 |
0.16.1 | 0 | 0 | 0 | 0 | 0 |
0.16.0 | 0 | 0 | 0 | 0 | 0 |
0.15.0 | 0 | 0 | 0 | 0 | 0 |
0.14.0 | 0 | 0 | 0 | 0 | 0 |
0.13.5 | 0 | 0 | 0 | 0 | 0 |
0.13.4 | 0 | 0 | 0 | 0 | 0 |
0.13.3 | 0 | 0 | 0 | 0 | 0 |
0.13.2 | 0 | 0 | 0 | 0 | 0 |
0.13.1 | 0 | 0 | 0 | 0 | 0 |
0.13.0 | 0 | 0 | 0 | 0 | 0 |
0.12.5 | 0 | 0 | 0 | 0 | 0 |
0.12.4 | 0 | 0 | 0 | 0 | 0 |
0.12.3 | 0 | 0 | 0 | 0 | 0 |
0.12.2 | 0 | 0 | 0 | 0 | 0 |
0.12.1 | 0 | 0 | 0 | 0 | 0 |
0.11.1 | 0 | 0 | 0 | 0 | 0 |
0.11.0 | 0 | 0 | 0 | 0 | 0 |
0.10.0 | 0 | 0 | 0 | 0 | 0 |
0.9.0 | 0 | 0 | 0 | 0 | 0 |
0.8.0 | 0 | 0 | 0 | 0 | 0 |
0.7.0 | 0 | 0 | 0 | 0 | 0 |
0.6.0 | 0 | 0 | 0 | 0 | 0 |
0.5.0 | 0 | 0 | 0 | 0 | 0 |
0.4.0 | 0 | 0 | 0 | 0 | 0 |
0.3.0 | 0 | 0 | 0 | 0 | 0 |
0.2.0 | 0 | 0 | 0 | 0 | 0 |
0.1.3 | 0 | 0 | 0 | 0 | 0 |
0.1.2 | 0 | 0 | 0 | 0 | 0 |
0.1.1 | 0 | 0 | 0 | 0 | 0 |
0.1.0 | 0 | 0 | 0 | 0 | 0 |
0.0.7 | 0 | 0 | 0 | 0 | 0 |
0.45.0 - This version is safe to use because it has no known security vulnerabilities at this time. Find out if your coding project uses this component and get notified of any reported security vulnerabilities with Meterian-X Open Source Security Platform
Maintain your licence declarations and avoid unwanted licences to protect your IP the way you intended.
MIT - MIT LicenseThe Oxidation Compiler is creating a collection of high-performance tools for JavaScript and TypeScript.
Oxc is building a parser, linter, formatter, transformer, minifier, resolver ... all written in Rust.
See more at oxc.rs!
Oxc is a project of VoidZero, see our announcement Announcing VoidZero - Next Generation Toolchain for JavaScript.
If you have requirements for JavaScript tools at scale, please get in touch!
The linter is ready to catch mistakes for you. It comes with 93 rules turned on by default (out of 430+ in total) and no configuration is required.
To get started, run oxlint or via npx
:
npx oxlint@latest
To give you an idea of its capabilities, here is an example from the vscode repository, which finishes linting 4800+ files in 0.7 seconds.
Individual crates are published, you may use them to build your own JavaScript tools.
crates/*/examples
directory.While Rust has gained a reputation for its comparatively slower compilation speed, we have dedicated significant effort to fine-tune the Rust compilation speed. Our aim is to minimize any impact on your development workflow, ensuring that developing your own Oxc based tools remains a smooth and efficient experience.
This is demonstrated by our CI runs, where warm runs complete in 3 minutes.
Oxc maintains its own AST and parser, which is by far the fastest and most conformant JavaScript and TypeScript (including JSX and TSX) parser written in Rust.
As the parser often represents a key performance bottleneck in JavaScript tooling, any minor improvements can have a cascading effect on our downstream tools. By developing our parser, we have the opportunity to explore and implement well-researched performance techniques.
While many existing JavaScript tools rely on estree as their AST specification, a notable drawback is its abundance of ambiguous nodes. This ambiguity often leads to confusion during development with estree.
The Oxc AST differs slightly from the estree AST by removing ambiguous nodes and introducing distinct types.
For example, instead of using a generic estree Identifier
,
the Oxc AST provides specific types such as BindingIdentifier
, IdentifierReference
, and IdentifierName
.
This clear distinction greatly enhances the development experience by aligning more closely with the ECMAScript specification.
Our benchmark reveals that the Oxc parser surpasses the speed of the swc parser by approximately 3 times and the Biome parser by 5 times.
The linter embraces convention over configuration, eliminating the need for extensive configuration and plugin setup. Unlike other linters like ESLint, which often require intricate configurations and plugin installations (e.g. @typescript-eslint), our linter only requires a single command that you can immediately run on your codebase:
npx oxlint@latest
The linter is 50 - 100 times faster than ESLint depending on the number of rules and number of CPU cores used. It completes in less than a second for most codebases with a few hundred files and completes in a few seconds for larger monorepos. See bench-javascript-linter for details.
As an upside, the binary is approximately 5MB, whereas ESLint and its associated plugin dependencies can easily exceed 100.
You may also download the linter binary from the latest release tag as a standalone binary, this lets you run the linter without a Node.js installation in your CI.
Module resolution plays a crucial role in JavaScript tooling, especially for tasks like multi-file analysis or bundling. However, it can often become a performance bottleneck. To address this, we developed oxc_resolver.
The resolver is production-ready and is currently being used in Rolldown. Usage and examples can be found in its own repository.
A transformer is responsible for turning higher versions of ECMAScript to a lower version that can be used in older browsers.
TypeScript and React transforms are complete. See Milestone 2 for current goals.
oxc-transform can be used for experimentation.
TypeScript Isolated Declarations Emit without using the TypeScript compiler.
Our benchmark indications that our implementation is at least 20 times faster than the TypeScript compiler.
The npm package or crate can be used for this task.
JavaScript minification plays a crucial role in optimizing website performance as it reduces the amount of data sent to users, resulting in faster page loads. This holds tremendous economic value, particularly for e-commerce websites, where every second can equate to millions of dollars.
However, existing minifiers typically require a trade-off between compression quality and speed. You have to choose between the slowest for the best compression or the fastest for less compression. But what if we could develop a faster minifier without compromising on compression?
We are actively working on a prototype that aims to achieve this goal, by porting all test cases from well-known minifiers such as google-closure-compiler, terser, esbuild, and tdewolff-minify.
Preliminary results indicate that we are on track to achieve our objectives. With the Oxc minifier, you can expect faster minification times without sacrificing compression quality.
While prettier has established itself as the de facto code formatter for JavaScript, there is a significant demand in the developer community for a less opinionated alternative. Recognizing this need, our ambition is to undertake research and development to create a new JavaScript formatter that offers increased flexibility and customization options.
The prototype is currently work in progress.
In Oxc, correctness and reliability are taken extremely seriously.
We spend half of our time on strengthening the test infrastructure to prevent problems from propagating to downstream tools.
Test Infrastructure documents our test procedures:
See CONTRIBUTING.md for guidance.
Check out some of the good first issues or ask us on Discord.
If you are unable to contribute by code, you can still participate by:
This project was incubated with the assistance of these exceptional mentors and their projects:
Special thanks go to
Oxc is free and open-source software licensed under the MIT License.
Oxc ports or copies code from other open source projects, their licenses are listed in Third-party library licenses.