Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

[v4.x] New code highlighter #296

Open
yhatt opened this issue May 10, 2022 · 3 comments
Open

[v4.x] New code highlighter #296

yhatt opened this issue May 10, 2022 · 3 comments
Labels
enhancement New feature or request

Comments

@yhatt
Copy link
Member

yhatt commented May 10, 2022

Related: marp-team/marp#103, #194

Let's start to think new architecture for code highlight toward Marp Core v4.

CSS variables based coloring

highlight.js based highlighting has high flexibility that came from stylabillity based on CSS class.

On the other hand, it is hard than expected to overload exist color scheme by the context. If the theme author wanted to use different highlight colors in section.invert, required reverting all styles about highlight.js and adding styles for changed colors.

When using theme inheritance by @import, need to know all of styles using for highlight in the parent theme and revert them surely.

I think it's painful for the custom theme author, so providing much better coloring system in code highlight would be best. https://github.com/orgs/marp-team/discussions/103#discussioncomment-702465

If Marp adopted CSS variables for code highlighting, changing color scheme by class context would be drastically simpler. It also means to deny detailed styling for highlighted keywords through CSS properties, but it's a corner case in the syntax highlight.

highlight.js -> Shiki

#194 (comment) has suggested a modern highlighter Shiki, made on TextMate json and Oniguruma RegExp engine.

Concerns

In future, this concern may become to resolve by adopting JavaScript RegExp instead of Oniguruma.

  • Deasync for loading highlight engine (markdown-it/Marpit does not support Promise in rendering for now)
    • Node.js: synckit (similar to deasync but requires no native bindings or node-gyp)
    • Browser: nothing
      • Inject an inline Web Worker when initializing Marp for deasync
      • Or consider to return thenable proxy object in Marp.render()
    • (We are already planning the next-gen engine of Marpit to support async/await while rendering)
  • Oniguruma WASM
    • Browser requires to fetch WASM from CDN that is supported CORS (jsDelivr, unpkg, etc)

Extended syntax for code fence

CommonMark defines the info string for fenced code block, like ```javascript. It leaves to Markdown processors about how to use this string, so may add more useful features to Marp.

We need work to them carefully because complexity of Marp Core theme CSS will increase at the same time.

@yhatt yhatt added the enhancement New feature or request label May 10, 2022
@yhatt yhatt moved this to Todo in Marp Roadmap May 10, 2022
@yhatt yhatt changed the title [v4] New code highlighter [v4?] New code highlighter Aug 3, 2022
@yhatt
Copy link
Member Author

yhatt commented Aug 30, 2024

The latest Shiki v1.15.0 has been introduced experimental JavaScript RegExp Engine. This may become a huge step for this task.

An concern of using Shiki highilghter is depending on Oniguruma RegExp engine to recognize TextMate JSON. That is provided by WASM, and not supporting non-asynchronous function that is only supported by markdown-it API. The JavaScript RegExp engine could become to remove that dependency, support sync function, and make simplify the architecture.

@yhatt yhatt changed the title [v4?] New code highlighter [v4.x] New code highlighter Sep 8, 2024
@isBatak
Copy link

isBatak commented Nov 18, 2024

Hi @yhatt,
I managed to use Shiki highlighter like this:

// engine.js

import Shiki from "@shikijs/markdown-it";

const shiki = await Shiki({
  themes: {
    light: "one-light",
    dark: "one-dark-pro",
  },
});

export default ({ marp }) => marp.use(shiki);

Would it be possible to also incorporate magic-move ?
Do you have any ideas how?

@yhatt
Copy link
Member Author

yhatt commented Nov 18, 2024

@isBatak Yes, this is the correct way to use Shiki with the current version of Marp Core. In an environment where there are no issues with using WASM and where a Promise can be resolved before initializing Marp, this would be the best approach.

(We are currently waiting for the stabilization of synchronous API and JavaScript RegExp engine to maintain maximum compatibility with other environments)

The application of magic-move is challenging for some reasons:

  • Lack of built-in syntax for step-based code animations
  • Server-side JS orientation on Marp Core and its plugins (magic-move should render in the client-side)

However, it should not be impossible if implemented custom syntax extension and a tailored slide display HTML for Marp Core slides.

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
enhancement New feature or request
Projects
Status: Todo
Development

No branches or pull requests

2 participants