aboutsummaryrefslogtreecommitdiff
path: root/v2/src/bin/feed
blob: 96c40a6e38a2547f589994283d5087a604145abf (about) (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
#!/bin/sh
set -eu

usage() {
	cat <<-'EOF'
		Usage:
		  feed FILENAME
		  feed -h
	EOF
}

help() {
	cat <<-'EOF'


		Options:
		  -h, --help    show this message

		  FILENAME      the target feed to be generated


		Generate FILENAME as an Atom feed.  The collection type and
		language are inferred by the name of FILENAME.


		Examples:

		  Generate a feed for TILs:

		    $ feed src/en/feeds/til.xml
	EOF
}


for flag in "$@"; do
	case "$flag" in
		--)
			break
			;;
		--help)
			usage
			help
			exit
			;;
		*)
			;;
	esac
done

while getopts 'h' flag; do
	case "$flag" in
		h)
			usage
			help
			exit
			;;
		*)
			usage >&2
			exit 2
			;;
	esac
done
shift $((OPTIND - 1))

. src/lib.sh

FILENAME="${1:-}"
eval "$(assert_arg "$FILENAME" 'FILENAME')"


COLLECTION="$(basename "$FILENAME" '.xml')"
LANGUAGE="$(lang-for "$FILENAME")"
DIR="$(dirname "$(dirname "$FILENAME")")/$COLLECTION"


. src/lib/base.conf
# shellcheck source=/dev/null
. src/lib/base."$LANGUAGE".conf

now="$(date -uIs)"
url="$(url-for "${FILENAME#"$CONTENT_PREFIX"}" | absolute)"
site_name_html="$(htmlesc "${site_name:?}")"
export now url site_name_html


mkdir -p "$(dirname "$FILENAME")"
{
	envsubst < src/lib/feed.xml
	find "$DIR"/*.sortdata | sort -nr | xargs cat | xargs cat
	printf '</feed>\n'
} > "$FILENAME"