treeSitter()
Membuat plugin Tree-sitter yang mengaktifkan syntax highlighting untuk fenced code block menggunakan library parsing Tree-sitter.
import { treeSitter } from "@unifast/node";Signature
function treeSitter(options?: TreeSitterPluginOptions): UnifastPluginParameter
options?
Konfigurasi engine highlighting
| Properti | Tipe | Default | Deskripsi |
|---|---|---|---|
engine | "none" | "treeSitter" | "treeSitter" | “treeSitter” menggunakan highlighter Tree-sitter; “none” menonaktifkan highlighting |
Penggunaan
import { compile, treeSitter } from "@unifast/node";
const md = `
# Code Example
\`\`\`rust
fn main() {
println!("Hello, world!");
}
\`\`\`
`;
const result = compile(md, {
plugins: [
treeSitter({
engine: "treeSitter",
}),
],
});
console.log(result.output);
// Code blocks are syntax highlighted with <span> elements and CSS classesContoh
Mengaktifkan syntax highlighting
import { compile, treeSitter } from "@unifast/node";
const md = `
\`\`\`typescript
const greeting: string = "Hello";
console.log(greeting);
\`\`\`
`;
const result = compile(md, { plugins: [treeSitter()] });
console.log(result.output);
// <pre><code class="language-typescript">
// <span class="...">const</span> ...
// </code></pre>Menonaktifkan highlighting
import { compile, treeSitter } from "@unifast/node";
const result = compile(md, {
plugins: [treeSitter({ engine: "none" })],
});
console.log(result.output);
// Code blocks are rendered without syntax highlighting