2012-10-07 08:23:31 -04:00
|
|
|
#!/bin/bash
|
|
|
|
#
|
|
|
|
# Formats a Git commit message
|
|
|
|
#
|
|
|
|
# Copyright (C) 2012 Mike Gerwitz
|
|
|
|
#
|
2012-10-07 11:22:49 -04:00
|
|
|
# This file is part of repo2html.
|
2012-10-07 08:23:31 -04:00
|
|
|
#
|
|
|
|
# This program is free software: you can redistribute it and/or modify
|
|
|
|
# it under the terms of the GNU General Public License as published by
|
|
|
|
# the Free Software Foundation, either version 3 of the License, or
|
|
|
|
# (at your option) any later version.
|
|
|
|
#
|
|
|
|
# This program is distributed in the hope that it will be useful,
|
|
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
# GNU General Public License for more details.
|
|
|
|
#
|
|
|
|
# You should have received a copy of the GNU General Public License
|
|
|
|
# along with this program. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
# #
|
|
|
|
|
2013-03-10 21:51:08 -04:00
|
|
|
# optional id (for cref errors)
|
|
|
|
id="$1"
|
|
|
|
|
2012-10-13 00:42:29 -04:00
|
|
|
# HTML replacements (default)
|
|
|
|
lquo='\“'
|
|
|
|
rquo='\”'
|
|
|
|
mdash='\—'
|
2013-05-27 16:50:34 -04:00
|
|
|
opar='<p>'
|
|
|
|
epar='</p>'
|
2012-10-13 00:42:29 -04:00
|
|
|
|
|
|
|
# redefines replacements to yield plain text (instead of HTML entities)
|
|
|
|
nohtml()
|
|
|
|
{
|
|
|
|
lquo=\"
|
|
|
|
rquo=\"
|
|
|
|
mdash=---
|
|
|
|
}
|
|
|
|
|
2013-05-27 16:50:34 -04:00
|
|
|
# no paragraph tags should be output
|
|
|
|
nopar()
|
|
|
|
{
|
|
|
|
opar=
|
|
|
|
epar=
|
|
|
|
}
|
2012-10-13 00:42:29 -04:00
|
|
|
|
2013-05-27 16:50:34 -04:00
|
|
|
|
|
|
|
while getopts nP opt; do
|
2012-10-13 00:42:29 -04:00
|
|
|
case "$opt" in
|
|
|
|
n) nohtml;;
|
2013-05-27 16:50:34 -04:00
|
|
|
P) nopar;;
|
2012-10-13 00:42:29 -04:00
|
|
|
esac
|
|
|
|
done
|
|
|
|
|
2013-05-27 16:50:34 -04:00
|
|
|
# calculate this after options have been parsed
|
|
|
|
refopar="${opar:+${opar%>} id="ref-\\1" class="ref">}"
|
|
|
|
|
2012-10-07 08:23:31 -04:00
|
|
|
# format the commit message, stopping at the diff (if any)
|
2013-06-04 22:42:47 -04:00
|
|
|
awk -vid="$id" -vurl_root="${url_root%/}" -vcref_errlog="$cref_errlog" '
|
2013-03-09 09:50:32 -05:00
|
|
|
# replace commit refs with generated URL (allows linking to prior commits
|
|
|
|
# without hard-coding the configurable links that could change or be
|
|
|
|
# relative to where the content is hosted); this will then be processed as a
|
|
|
|
# normal URL by the remainder of the script
|
|
|
|
match($0, /\[cref:(.*?)\]/, g) {
|
|
|
|
# retrieve the URL from the hashcache and perform the line replacement
|
|
|
|
# (which will be reflected once we print the line)
|
|
|
|
c = "./hashcache " g[1]
|
|
|
|
c | getline result
|
2013-03-10 21:51:08 -04:00
|
|
|
|
|
|
|
# if a cref error logfile path was provided, log unknown refs so that they
|
|
|
|
# can be re-processed (if commits are processed in reverse order and the
|
|
|
|
# hashcache is cleared before the run, then this is likely to occur for
|
|
|
|
# every cref)
|
|
|
|
if ( result == "" && cref_errlog && id ) {
|
2013-03-12 22:47:01 -04:00
|
|
|
printf id"\n" >>cref_errlog
|
2013-03-10 21:51:08 -04:00
|
|
|
}
|
|
|
|
|
2013-06-04 22:42:47 -04:00
|
|
|
gsub(/\[cref:.*?\]/, (url_root "/" result))
|
2013-03-09 09:50:32 -05:00
|
|
|
}
|
|
|
|
|
|
|
|
# stop printing at diff
|
|
|
|
/^diff --git/ { exit }
|
|
|
|
|
|
|
|
# otherwise, print everything
|
|
|
|
{ print }
|
|
|
|
' \
|
2012-10-07 08:23:31 -04:00
|
|
|
| sed ':a;N;$!ba;
|
2012-10-28 00:03:31 -04:00
|
|
|
# handle <>-delimited links (strip delimiters)
|
|
|
|
s#<\([fh]ttps\?://[^ ]\+\)>#\1#g;
|
|
|
|
|
2012-10-07 08:23:31 -04:00
|
|
|
# escaping
|
2012-10-27 23:09:03 -04:00
|
|
|
s/\&/\&/g;
|
2012-10-07 08:23:31 -04:00
|
|
|
s/</\</g;
|
|
|
|
s/>/\>/g;
|
|
|
|
|
2012-10-16 22:49:46 -04:00
|
|
|
# quoting (initiated by an indented paragraph and terminated by a new
|
2012-10-27 23:18:45 -04:00
|
|
|
# paragraph, unless that paragraph is also indented)
|
|
|
|
s#\n\n \+\(\([^\n]\+\n\(\n \+\)\?\)\+\)#<blockquote>\1</blockquote>#g
|
2014-11-30 16:31:57 -05:00
|
|
|
|
|
|
|
# pre-formatted block. markdown-style
|
|
|
|
s#\n\n \+\(\([^\n]\+\n\(\n \+\)\?\)\+\)#<blockquote>\1</blockquote>#g
|
2012-10-16 22:49:46 -04:00
|
|
|
|
2012-10-07 08:23:31 -04:00
|
|
|
# unfortunately, non-greedy matches make it difficult to exclude punctuation
|
2012-10-28 00:03:31 -04:00
|
|
|
# at the end of a link, so we will handle it in a separate expression
|
2012-10-07 08:23:31 -04:00
|
|
|
s#[fh]ttps\?://[^]\n )]\+#<a href="&">&</a>#g;
|
2012-10-28 00:03:31 -04:00
|
|
|
s#<a href="\([^"]\+\)\([.;,!]\)">\([^<]\+\).</a>#<a href="\1">\3</a>\2#g;
|
2012-10-07 08:23:31 -04:00
|
|
|
|
2012-10-09 23:31:40 -04:00
|
|
|
# reference definitions (footnotes)
|
2013-05-27 16:50:34 -04:00
|
|
|
s#\n\[\([0-9]\+\)\]#'"$epar$refopar"'&#g;
|
2012-10-09 23:31:40 -04:00
|
|
|
|
2013-03-15 16:26:05 -04:00
|
|
|
# references in text (note that references that enclose text as a hyperlink
|
|
|
|
# must not start with a number, otherwise they will be considered to be a
|
|
|
|
# reference number)
|
|
|
|
s|\[\([^0-9][^]]\+\)\]\[\([0-9]\+\)\]|<a href="#ref-\2">\1</a>\[\2\]|g
|
2012-10-09 23:31:40 -04:00
|
|
|
s|\[\([0-9]\+\)\]|<sup><a href="#ref-\1">&</a></sup>|g
|
|
|
|
|
2012-10-07 08:23:31 -04:00
|
|
|
# paragraphs
|
2013-05-27 16:50:34 -04:00
|
|
|
s#\n\n#'"$epar"'&'"$opar"'#g;
|
|
|
|
/^/i'"$opar"'
|
|
|
|
/$/a'"$epar"'
|
2012-10-07 08:23:31 -04:00
|
|
|
|
|
|
|
# basic formatting
|
2012-10-13 00:42:29 -04:00
|
|
|
s/---/'"$mdash"'/g;
|
|
|
|
s#``#'"$lquo"'#g;
|
|
|
|
s#'\'\''#'"$rquo"'#g;
|
2014-11-30 16:32:22 -05:00
|
|
|
s#\(\W\|^\)\*\*\([^\*]\+\)\*\*\(\W\)#\1<strong>\2</strong>\3#g;
|
2013-05-28 23:38:11 -04:00
|
|
|
s#\(\W\)\*\([^\*]\+\)\*\(\W\)#\1<em>\2</em>\3#g;
|
2012-10-07 08:23:31 -04:00
|
|
|
'
|