NAME
Apache::VimColor - Apache mod_perl Handler for syntax highlighting in HTML.
DESCRIPTION
This apache handler converts text files in syntax highlighted HTML output using Text::VimColor. If allowed by the configuration the visitor can also download the text-file without syntax highlighting.
Since Text::VimColor isn't the fastest module this version can use Cache::Cache to cache the parsed files. Also the ETag and LastModified HTTP headers are set to help browsers and proxy servers to cache the URL.
SYNOPSIS
This module requires mod_perl2 (see http://perl.apache.org/) and Text::VimColor.
The apache configuration neccessary might look a bit like this:
# in httpd.conf (or any other apache configuration file)
<Location /source>
SetHandler perl-script
PerlHandler Apache::VimColor
# Below here is optional
PerlSetVar AllowDownload "True"
PerlSetVar CacheType "File"
PerlSetVar CacheSize 1048576 # 1 MByte
PerlSetVar CacheExpire 7200 # 2 hours
PerlSetVar StyleSheet "http://domain.com/stylesheet.css"
PerlSetVar TabSize 8
PerlSetVar LineNumbers "True"
</Location>
For a complete list of all options and descriptions see below.
CONFIGURATION DIRECTIVES
All features of the this PerlHandler can be set in the apache configuration using the PerlSetVar directive. For example:
PerlSetVar AllowDownload true # inside <Files>, <Location>, ...
# apache directives
- AllowDownload
-
Setting this option to true will allow plaintext downloads of the files. A link will be included in the output. The default is not to allow downloads.
- CacheType
-
Selects the caching method to use. Depending on your choices a Cache::Cache module will be loaded and used. The default is not to use any caching. CacheType can be one of:
Memory SharedMemory File
Although the default is not to use caching, if CacheSize is given and CacheType is not, then Memory is being used. Obviously these values correspond to the Cache::*Cache modules.
The modules are loaded at runtime. If errors occur they are logged to Apache's errorlog.
- CacheSize
-
Sets the maximum size of the cache in bytes. If CacheSize is non-zero the Cache::SizeAware*Cache variants will be used.
- CacheExpire
-
CacheExpire sets the expiration time. The value must be given in seconds. Defaults to 3600 seconds (one hour). See Cache::Cache for details.
- TabStop
-
Sets the width of one tab symbol. The default is eight spaces.
- StyleSheet
-
If you want to include a custom stylesheet you can set this option. The string will be included in the html-output as-is, you will have to take care of relative filenames yourself.
All highlighted text is withing a
span
-tag with one of the following classes:Comment Constant Error Identifier PreProc Special Statement Todo Type Underlined
- LineNumbers
-
Sets wether or not line numbers will be displayed. The Default is not to display line numbers.
SEE ALSO
perl(1), mod_perl(3), Apache(3), Text::VimColor, Cache::Cache
AUTHOR
Florian octo Forster
octo(at)verplant.org
http://verplant.org/
COPYRIGHT
Copyright (c) 2005 Florian Forster.
All rights reserved. This package is free software; you can redistribute it and/or modify it under the same terms as Perl itself.