blob: f37c7ec0e419995eb8c33c6985007211ca908f9d (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
|
#!/bin/sh
set -eu
. src/development/lib.sh
usage() {
cat <<-'EOF'
Usage:
md2html.sh -T TITLE [-D TOC_DEPTH] < FILE.md
md2html.sh -h
EOF
}
help() {
cat <<-'EOF'
Options:
-T TITLE the required title of the generated HTML
document
-D TOC_DEPTH the depth of the generated table of
contents (default: 2)
-h, --help show this message
Read markdown text from STDIN and emit HTML to STDOUT.
Examples:
Generate the HTML from markdown using the default:
$ md2html.sh -T 'Homepage' < index.md > index.html
Pick a different TOC depth:
$ md2html.sh -D3 -T 'TODOs' < TODOs.md > TODOs.html
EOF
}
for flag in "$@"; do
case "$flag" in
--)
break
;;
--help)
usage
help
exit
;;
*)
;;
esac
done
TOC_DEPTH=2
while getopts 'T:D:h' flag; do
case "$flag" in
T)
TITLE="$OPTARG"
;;
D)
TOC_DEPTH="$OPTARG"
;;
h)
usage
help
exit
;;
*)
usage >&2
exit 2
;;
esac
done
shift $((OPTIND - 1))
eval "$(assert_arg "${TITLE:-}" '-T TITLE')"
HEAD="$(mkstemp)"
trap 'rm -f "$HEAD"' EXIT
cat <<-'EOF' > "$HEAD"
<link rel="icon" href="favicon.svg" type="image/svg+xml" />
<link rel="stylesheet" href="style.css" type="text/css" />
EOF
pandoc \
-s \
--toc \
--toc-depth="$TOC_DEPTH" \
--metadata lang=pt \
--metadata title="$TITLE" \
-H "$HEAD"
|