Skip to content

sveltejs/acorn-typescript

Folders and files

NameName
Last commit message
Last commit date

Latest commit

ac652a3 · Apr 1, 2025
Apr 1, 2025
Feb 26, 2025
Feb 28, 2025
Apr 1, 2025
Apr 1, 2025
Feb 28, 2025
Oct 26, 2022
Feb 27, 2025
Feb 25, 2025
Mar 4, 2025
Feb 25, 2025
Apr 1, 2025
Feb 26, 2025
Mar 4, 2025
Feb 27, 2025
Feb 27, 2025

Repository files navigation

@sveltejs/acorn-typescript

License Chat

This is a plugin for Acorn - a tiny, fast JavaScript parser, written completely in JavaScript.

It was created as an experimental alternative, faster TypeScript parser. It will help you to parse TypeScript using Acorn.

Usage

To get started, import the plugin and use Acorn's extension mechanism to register it. You have to enable options.locations while using @sveltejs/acorn-typescript.

import * as acorn from 'acorn';
import tsPlugin from '@sveltejs/acorn-typescript';

const node = acorn.Parser.extend(tsPlugin()).parse(
	`
const a = 1
type A = number
export {
  a,
  type A as B
}
`,
	{
		sourceType: 'module',
		ecmaVersion: 'latest',
		locations: true
	}
);

If you want to enable parsing within a TypeScript ambient context, where certain syntax have different rules (like .d.ts files and inside declare module blocks):

import * as acorn from 'acorn';
import tsPlugin from '@sveltejs/acorn-typescript';

const node = acorn.Parser.extend(tsPlugin({ dts: true })).parse(
	`
const a = 1
type A = number
export {
  a,
  type A as B
}
`,
	{
		sourceType: 'module',
		ecmaVersion: 'latest',
		locations: true
	}
);

SUPPORTED

  • Typescript normal syntax
  • Support to parse TypeScript Decorators
  • Support to parse JSX & TSX

CHANGELOG

click

Acknowledgments

We want to thank TyrealHu for his original work on this project. He maintained acorn-typescript until early 2024.