Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/innocenzi/shiki-processor

Add processing capabilities to Shiki's highlighter
https://github.com/innocenzi/shiki-processor

code code-highlight highlight processor shiki

Last synced: 3 months ago
JSON representation

Add processing capabilities to Shiki's highlighter

Awesome Lists containing this project

README

        

shiki-processor



Status

 

npm






Add processing capabilities to Shiki's highlighter


npm i shiki shiki-processor

 

## Package is no longer maintained

I suggest migrating to [`shikiji`](https://github.com/antfu/shikiji) and its dedicated [`shikiji-transformers`](https://github.com/antfu/shikiji/tree/main/packages/shikiji-transformers) package, that's a port of this one.
- https://twitter.com/antfu7/status/1727781829082595341
- https://github.com/vuejs/vitepress/pull/3237

 

## Usage

`shiki-processor` exports a custom `getHighlighter` that provides the same API as the one exported from `shiki`, except it adds a new `processors` option.

```ts
import { getHighlighter, createFocusProcessor } from 'shiki-processor'

const snippet = /** ... */
const highlighter = await getHighlighter({
processors: [
createFocusProcessor(),
],
})

highlighter.codeToHtml(snippet, { lang: 'javascript' })
```

Alternatively, for more flexibility, it is possible to use the `process` and `postProcess` functions directly.

```ts
import { getHighlighter } from 'shiki'
import { process, postProcess } from 'shiki-processor'

const theme = 'material-theme-palenight'
const lang = 'javascript'
const snippet = /** ... */
const processors = [
createFocusProcessor(),
]

const highlighter = await getHighlighter({ theme })

const { code, lineOptions } = process(processors, snippet, lang)
const highlighted = highlighter.codeToHtml(code, {
lang,
theme,
lineOptions,
})

return postProcess(processors, highlighted, lang)
```

 

## Built-in processors

There is currently three processors: `focus`, `diff` and `highlight`. Each one of them adds the possibility of adding a `// [!code ]` annotation to a line in a code snipppet.

When this annotation is found, it is removed and a class corresponding to the processor is added to the line. The complete code block is also added a class.

```ts
// Input
function() {
console.log('hewwo') // [!code --]
console.log('hello') // [!code ++]
}
```
```html

 



function(){

console.log('hewwo')


console.log('hello')

}



```

Optionally, a range can be defined by adding a colon and a number of lines: `// [!code focus:3]`.






·




Built with ❤︎ by Enzo Innocenzi