Skip to content

You take some Shiki, add a hint of TypeScript compiler, and πŸŽ‰ incredible static code samples

License

Notifications You must be signed in to change notification settings

shikijs/twoslash

Folders and files

NameName
Last commit message
Last commit date

Latest commit

42015c1 Β· Feb 19, 2024
Apr 28, 2023
Jun 27, 2023
Feb 3, 2022
Feb 3, 2022
May 26, 2021
Jun 27, 2023
Jun 27, 2023
Jun 26, 2023
Jun 27, 2023
May 26, 2021
May 26, 2021
Jun 26, 2023
May 26, 2021
Feb 19, 2024
Mar 28, 2023
Jun 8, 2021
Jul 3, 2021
Jun 27, 2023
Jun 27, 2023
May 29, 2021
May 26, 2021

Repository files navigation

Note

Twoslash has been moved to the new repository twoslashes/twoslash with some refactoring and improvements. The Shiki v1.0 integration is now in Shiki's monorepo as a transformer, which means Twoslash will now work everywhere Shiki is supported. We will make Shiki supports more high-level tools so Twoslash could later inherit that.

This repository is for Shiki v0.x integration with Twoslash. As we port more integrations to the new format, this repo will fade out gradually.

You take some Shiki, add a hint of TypeScript compiler, and πŸŽ‰ incredible statically generated code samples.

See the user-facing docs at: https://shikijs.github.io/twoslash/

This Repo

The majority of this repo uses pnpm, the rest yarn. There are four main areas of interest:

  • packages, the shiki meets twoslash plugins for markdown renderers and static site generators
  • site, the docs micro-site
  • examples, example static site generator projects which use the plugins
  • extensions, right now, just the vscode extension for twoslash code samples

Packages

The site extensions and examples are excluded from the workspace. To work on those, cd to their folders and read instructions.

Otherwise:

git clone https://github.com/shikijs/twoslash
cd twoslash

pnpm i
pnpm bootstrap
pnpm test

Then see the contributing for advice and the vision file for the long-term perspective.

Plugins

Markdown Renderers

Root Abstractions

Deploys

Run: pnpm deploy.