@acarl005/cli-highlight
v1.1.5
Published
Syntax highlighting in your terminal
Downloads
5
Maintainers
Readme
cli-highlight
Syntax highlighting in your terminal
Example
CLI Usage
Output a file
$ highlight package.json
Color output of another program with piping. Example: A database migration script that logs SQL Queries
$ db-migrate --dry-run | highlight
Command line options:
Usage: highlight [options] [file]
Outputs a file or STDIN input with syntax highlighting
Options:
--language, -l Set the langugage explicitely
If omitted will try to auto-detect
--theme, -t Use a theme defined in a JSON file
--version, -v Show version number [boolean]
--help, -h Show help [boolean]
Programmatic Usage
You can use this module programmatically to highlight logs of your Node app. Example:
const highlight = require('cli-highlight').highlight
const Sequelize = require('sequelize')
const db = new Sequelize(process.env.DB, {
logging(log) {
console.log(highlight(log, {language: 'sql', ignoreIllegals: true}))
}
})
Detailed API documenation can be found here.
Themes
You can write your own theme in a JSON file and pass it with --theme
.
The key must be one of the highlight.js CSS class names
and the value must be one or an array of Chalk styles to be applied to that token.
{
"keyword": "blue",
"built_in": ["cyan", "dim"],
"string": "red"
}
The theme is combined with the default theme. The default theme is still not colored a lot or optimized for many languages, PRs welcome!
Supported Languages
In theory, all languages of highlight.js are supported - I just did not adapt the default theme and wrote tests for all languages yet. My primary use case was SQL so that is supported well.
Contributing
The module is written in TypeScript and can be compiled with npm run build
.
npm run watch
starts tsc
in watch mode. Tests are written with mocha.
Improving language support is done by adding more colors to the tokens in the default theme and writing more tests.