VERSION

version 0.0004

NAME

Dancer2::Plugin::SyntaxHighlight::Perl - Generate pretty HTML from Perl code in a Dancer2 app

DESCRIPTION

This module provides on-the-fly conversion of Perl to syntax-highlighted HTML. For convenience it adds the keywords highlight_perl and highlight_output to the Dancer2 DSL.

SYNOPSIS

Configuration

plugins:
  'SyntaxHighlight::Perl':
      line_numbers: 1

Application code

get '/perl_tutorial' => sub {
    return template 'perl_tutorial', {
        example_code   => highlight_perl('/path/to/file.pl'),
        example_output => highlight_output('/path/to/file.txt'),
    };
};

HTML template

<div style="white-space: pre-wrap">
  [% example_code %]
</div>

Or:

<div>
  <pre>[%example_code %]</pre>
</div>

EXAMPLE OUTPUT

FUNCTIONS

highlight_perl

Takes as input the full pathname of a file, or a filehandle, or a reference to a scalar. Expects what it is given to contain Perl code.

Outputs Perl code as HTML with syntax highlighting, in the form of <span></span> tags, with the appropriate class names, around the elements of the Perl code after it has been parsed by PPI.

If line_numbers is set to true in the Dancer2 config, the output will have line numbers.

For more details on the format of the ouput, see PPI::HTML, or examine the files in the examples/ directory in this distribution.

You will need to provide the CSS for the styling, see examples/ for examples.

Important: This module removes the <BR> tags from the end of the generated HTML lines, so you must enclose the HTML in either <pre></pre> tags or an element with style="white-space: pre-wrap">.

You can override this transformation by setting skip_postprocessing to true in the Dancer2 config.

highlight_output

Often when showing Perl code you will want to show also the output of the code, This function adds very simple highlighting to the saved output of Perl code.

Takes as input the full pathname of a file, or a filehandle, or a reference to a scalar.

Outputs the content with the first line wrapped in a <span></span> tag with the special class prompt, and all other with the class word.

This generated HTML also must be enclosed in either <pre></pre> tags or an element with style="white-space: pre-wrap" (or set skip_postprocessing to true in the Dancer2 config).

SEE ALSO

PPI, PPI::HTML

AUTHOR

Nick Tonkin <tonkin@cpan.org>

COPYRIGHT AND LICENSE

This software is copyright (c) 2017 by Nick Tonkin.

This is free software; you can redistribute it and/or modify it under the same terms as the Perl 5 programming language system itself.