2024-08-05 00:44:23 +00:00
|
|
|
# TARTRAZINE
|
2024-08-02 20:03:39 +00:00
|
|
|
|
2024-08-05 00:44:23 +00:00
|
|
|
Tartrazine is a library to syntax-highlight code. It is
|
2024-08-04 23:36:35 +00:00
|
|
|
a port of [Pygments](https://pygments.org/) to
|
|
|
|
[Crystal](https://crystal-lang.org/). Kind of.
|
|
|
|
|
|
|
|
It's not currently usable unless what you need is a way
|
|
|
|
to turn your files into a pile of json describing its
|
|
|
|
constituent tokens, because I have not implemented any
|
|
|
|
formatters, yet, only the part that parses the code (the lexers).
|
|
|
|
|
|
|
|
# A port of what? Why "kind of"?
|
|
|
|
|
|
|
|
Because I did not read the Pygments code. And this is actually
|
2024-08-05 00:44:23 +00:00
|
|
|
based on [Chroma](https://github.com/alecthomas/chroma) ...
|
2024-08-04 23:36:35 +00:00
|
|
|
although I did not read that code either.
|
|
|
|
|
|
|
|
Chroma has taken most of the Pygments lexers and turned them into
|
|
|
|
XML descriptions. What I did was take those XML files from Chroma
|
|
|
|
and a pile of test cases from Pygments, and I slapped them together
|
|
|
|
until the tests passed and my code produced the same output as
|
|
|
|
Chroma. Think of it as *extreme TDD*.
|
|
|
|
|
2024-08-05 00:44:23 +00:00
|
|
|
Currently the pass rate for tests in the supported languages
|
2024-08-05 00:38:00 +00:00
|
|
|
is `96.8%`, which is *not bad for a couple days hacking*.
|
2024-08-04 23:36:35 +00:00
|
|
|
|
|
|
|
This only covers the RegexLexers, which are the most common ones,
|
2024-08-05 00:44:23 +00:00
|
|
|
but it means the supported languages are a subset of Chroma's, which
|
2024-08-04 23:36:35 +00:00
|
|
|
is a subset of Pygments'.
|
|
|
|
|
|
|
|
Currently Tartrazine supports ... 241 languages.
|
2024-08-02 20:03:39 +00:00
|
|
|
|
|
|
|
## Installation
|
|
|
|
|
2024-08-04 23:36:35 +00:00
|
|
|
If you need to ask how to install this, it's not ready for you yet.
|
2024-08-02 20:03:39 +00:00
|
|
|
|
|
|
|
## Usage
|
|
|
|
|
2024-08-04 23:36:35 +00:00
|
|
|
If you need to ask how to use this, it's not ready for you yet.
|
2024-08-02 20:03:39 +00:00
|
|
|
|
|
|
|
## Development
|
|
|
|
|
|
|
|
TODO: Write development instructions here
|
|
|
|
|
|
|
|
## Contributing
|
|
|
|
|
2024-08-04 23:36:35 +00:00
|
|
|
1. Fork it (<https://github.com/ralsina/tartrazine/fork>)
|
2024-08-02 20:03:39 +00:00
|
|
|
2. Create your feature branch (`git checkout -b my-new-feature`)
|
|
|
|
3. Commit your changes (`git commit -am 'Add some feature'`)
|
|
|
|
4. Push to the branch (`git push origin my-new-feature`)
|
|
|
|
5. Create a new Pull Request
|
|
|
|
|
|
|
|
## Contributors
|
|
|
|
|
2024-08-04 23:36:35 +00:00
|
|
|
- [Roberto Alsina](https://github.com/ralsina) - creator and maintainer
|