2009-08-09 14:56:23 +02:00
|
|
|
#!/bin/sh
|
|
|
|
# This script can be used to implement syntax highlighting in the cgit
|
|
|
|
# tree-view by refering to this file with the source-filter or repo.source-
|
|
|
|
# filter options in cgitrc.
|
|
|
|
#
|
2009-11-19 12:14:45 +01:00
|
|
|
# This script requires a shell supporting the ${var##pattern} syntax.
|
|
|
|
# It is supported by at least dash and bash, however busybox environments
|
|
|
|
# might have to use an external call to sed instead.
|
|
|
|
#
|
2009-08-09 14:56:23 +02:00
|
|
|
# Note: the highlight command (http://www.andre-simon.de/) uses css for syntax
|
|
|
|
# highlighting, so you'll probably want something like the following included
|
|
|
|
# in your css file (generated by highlight 2.4.8 and adapted for cgit):
|
|
|
|
#
|
|
|
|
# table.blob .num { color:#2928ff; }
|
|
|
|
# table.blob .esc { color:#ff00ff; }
|
|
|
|
# table.blob .str { color:#ff0000; }
|
|
|
|
# table.blob .dstr { color:#818100; }
|
|
|
|
# table.blob .slc { color:#838183; font-style:italic; }
|
|
|
|
# table.blob .com { color:#838183; font-style:italic; }
|
|
|
|
# table.blob .dir { color:#008200; }
|
|
|
|
# table.blob .sym { color:#000000; }
|
|
|
|
# table.blob .kwa { color:#000000; font-weight:bold; }
|
|
|
|
# table.blob .kwb { color:#830000; }
|
|
|
|
# table.blob .kwc { color:#000000; font-weight:bold; }
|
|
|
|
# table.blob .kwd { color:#010181; }
|
2011-03-23 11:57:44 +01:00
|
|
|
#
|
|
|
|
# The following environment variables can be used to retrieve the configuration
|
|
|
|
# of the repository for which this script is called:
|
|
|
|
# CGIT_REPO_URL ( = repo.url setting )
|
|
|
|
# CGIT_REPO_NAME ( = repo.name setting )
|
|
|
|
# CGIT_REPO_PATH ( = repo.path setting )
|
|
|
|
# CGIT_REPO_OWNER ( = repo.owner setting )
|
|
|
|
# CGIT_REPO_DEFBRANCH ( = repo.defbranch setting )
|
|
|
|
# CGIT_REPO_SECTION ( = section setting )
|
|
|
|
# CGIT_REPO_CLONE_URL ( = repo.clone-url setting )
|
|
|
|
#
|
2009-08-09 14:56:23 +02:00
|
|
|
|
2009-11-19 12:14:45 +01:00
|
|
|
# store filename and extension in local vars
|
|
|
|
BASENAME="$1"
|
|
|
|
EXTENSION="${BASENAME##*.}"
|
|
|
|
|
|
|
|
# map Makefile and Makefile.* to .mk
|
|
|
|
[ "${BASENAME%%.*}" == "Makefile" ] && EXTENSION=mk
|
|
|
|
|
2012-03-18 11:38:26 +00:00
|
|
|
# highlight versions 2 and 3 have different commandline options. Specifically,
|
|
|
|
# the -X option that is used for version 2 is replaced by the -O xhtml option
|
|
|
|
# for version 3.
|
|
|
|
#
|
|
|
|
# Version 2 can be found (for example) on EPEL 5, while version 3 can be
|
|
|
|
# found (for example) on EPEL 6.
|
|
|
|
#
|
|
|
|
# This is for version 2
|
2009-11-19 12:14:45 +01:00
|
|
|
exec highlight --force -f -I -X -S $EXTENSION 2>/dev/null
|
2012-03-18 11:38:26 +00:00
|
|
|
|
|
|
|
# This is for version 3
|
2012-03-18 11:48:01 +00:00
|
|
|
#
|
|
|
|
# On CentOS 6.2 (using highlight from EPEL), when highlight doesn't know about
|
|
|
|
# an EXTENSION, it outputs a lua error and _no_ text, even when the --force
|
|
|
|
# option is used.
|
|
|
|
#
|
|
|
|
# Also see the bug reports at:
|
|
|
|
# http://sourceforge.net/tracker/?func=detail&aid=3490017&group_id=215618&atid=1034391
|
|
|
|
# https://bugzilla.redhat.com/show_bug.cgi?id=795567
|
|
|
|
#
|
|
|
|
# This workaround can be removed when the bug is fixed upstream and the new
|
|
|
|
# version is packaged in most distributions.
|
|
|
|
#
|
|
|
|
# The workaround is to set the extension to 'txt' (plain text) when highlight
|
|
|
|
# exits with an error (doesn't know the format).
|
|
|
|
#
|
|
|
|
#echo "test" | highlight -f -I -O xhtml -S $EXTENSION &>/dev/null
|
|
|
|
#[ ${?} -ne 0 ] && EXTENSION="txt"
|
2012-03-18 11:38:26 +00:00
|
|
|
#exec highlight --force -f -I -O xhtml -S $EXTENSION 2>/dev/null
|