highlighting-kate ================= **This library has been deprecated. Please use skylighting instead ([Hackage](https://hackage.haskell.org/package/skylighting) | [GitHub](https://github.com/jgm/skylighting)).** A Haskell source code highlighting library, based on Kate's syntax description files (http://kate-editor.org/), now [part of the KDE Framework's "KTextEditor" component](http://kate-editor.org/2013/11/11/kate-on-5-the-future-of-ktexteditor-and-kate-part/). It can produce both HTML and LaTeX output. Building -------- To install, use the [stack] tool: stack install [stack]: http://docs.haskellstack.org/en/stable/README/ Note: If you have checked out the source from the git repository, you will first need to do: make prep which generates some of the needed source files from xml syntax definitions. To generate the documentation: stack haddock To run the test suite: stack test For an example of the use of the library, see highlighting-kate.hs. By default, this installation method will install an executable, `highlighting-kate`, along with the library. Normally this is put into `$HOME/.local/bin`. To avoid creation of the executable, use `--flag highlighting-kate:-executable` with the `stack` commands above. Using ----- If you want to use highlighting-kate as a library in a Haskell program, see the API documentation at . To run the `highlighting-kate` program, specify the language name using `-s`: highlighting-kate -s haskell highlighting-kate.hs > example.html If you don't specify a language name, `highlighting-kate` will try to guess it from the file extension.`highlighting-kate` can also be used as a pipe, reading input from STDIN. For other options, highlighting-kate --help Styling is done using span tags. The Highlight program will include default styles in the generated HTML, unless a link to a CSS file is provided using the '--css' option. Some sample CSS files can be found in the css directory. These use generic class names (Normal, Keyword, DataType, DecVal, BaseN, Float, Char, String, Comment, Function, Others, Alert, Error). For more fine-grained highlighting, users may wish to create their own CSS files that use language-specific classes. Adding syntax definitions ------------------------- The parsers in Text/Highlighting/Kate/Syntax were automatically generated from the Kate syntax definitions in the xml directory. You may modify the xml files in this directory, or add new ones, and then regenerate the parsers by doing: make prep Note that ParseSyntaxFiles.hs requires the HXT package (>= 9.0.0). `make prep` should install this automatically. To get the current Kate syntax highlighting files, clone the ktexteditor repository: git clone git://anongit.kde.org/ktexteditor The syntax definitions can then be found in src/syntax/data There is information on the syntax highlighting definitions at . See also . Thanks are due to all the authors of these syntax definitions. Changes have been made to the following xml files (diffs have been left in the directory, with .patch extensions): - haskell.xml: Small changes to mapping of styles to token types. - lua.xml: Variables and constants highlighted as "normal", not keywords. - perl.xml: Small regex change due to differences in regex engines. - php.xml: Added fallthrough so `