-
Notifications
You must be signed in to change notification settings - Fork 86
/
Copy pathbuild-stylesheet.sh
executable file
·57 lines (53 loc) · 2.9 KB
/
build-stylesheet.sh
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
#!/bin/sh
STYLESHEET_NAME=asciidoctor
if [ ! -z $1 ]; then
STYLESHEET_NAME=$1
fi
bundle exec compass compile -s compact
LINES=`wc -l stylesheets/$STYLESHEET_NAME.css | cut -d" " -f1`
echo '/* Asciidoctor default stylesheet | MIT License | https://asciidoctor.org */' > $STYLESHEET_NAME.css
cat stylesheets/$STYLESHEET_NAME.css | \
sed 's/ *\/\*\+!\? [^*]\+\($\| \*\/\)//g' | \
sed 's/^\/\*\* .* \*\/$//' | \
sed '/^\(*\/\|\) *$/d' | \
sed 's/^@media only/@media/' | \
sed '/\.antialiased {/d' | \
sed '/^body { margin: 0;/d' | \
sed "s/^body { background:[^}]*/&$(grep -oP '(?<=^body {) *tab-size.*-moz[^}]*' stylesheets/$STYLESHEET_NAME.css)/" | \
sed '/^body { *tab-size/d' | \
sed 's/direction: ltr;//' | \
sed 's/, \(summary\|canvas\)//' | \
sed '/^script /d' | \
sed '/object, svg { display: inline-block;/d' | \
sed '/blockquote cite[ :]/d' | \
sed 's/img { display: inline-block;/img, object, svg { display: inline-block;/' | \
sed 's/table thead, table tfoot {\(.*\) font-weight: bold;\(.*\)}/table thead, table tfoot {\1\2}/' | \
sed 's/ tr td { display: table-cell; / tr td { /' | \
sed 's/ tr th { display: table-cell; line-height: [^;]\+; / tr th { /' | \
sed 's/, table tr:nth-of-type(even)//' | \
sed 's/table { \(background:.*\) }/table { \1 word-wrap: normal; }/' | \
sed '/table { word-wrap:/d' | \
sed '/^p\.lead {/d' | \
sed '/^ul\.no-bullet, ol\.no-bullet { margin-left: 1.5em; }$/d' | \
sed '/^ul\.no-bullet { list-style: none; }$/d' | \
sed '/\(meta\.\|\.vcard\|\.vevent\|#map_canvas\|"search"\|\[hidden\]\)/d' | \
grep -v 'font-awesome' >> $STYLESHEET_NAME.css
# see https://www.npmjs.org/package/cssshrink (using 0.0.5)
# must run first: npm install cssshrink
./node_modules/.bin/cssshrink $STYLESHEET_NAME.css | \
sed '1i\
/* Uncomment @import statement to use as custom stylesheet */\
/*@import "https://fonts.googleapis.com/css?family=Open+Sans:300,300italic,400,400italic,600,600italic%7CNoto+Serif:400,400italic,700,700italic%7CDroid+Sans+Mono:400,700";*/' | \
sed '1i\
/* Asciidoctor default stylesheet | MIT License | https://asciidoctor.org */' | \
sed 's/\(Open Sans\|DejaVu Sans\|Noto Serif\|DejaVu Serif\|Droid Sans Mono\|DejaVu Sans Mono\|Ubuntu Mono\|Liberation Mono\|Varela Round\)/"\1"/g' | \
sed 's/background:transparent/background:none/g' | \
sed 's/background-color:\([^};]\+\)/background:\1/g' | \
sed 's/border:none/border:0/g' | \
# changing to font-weight:bold allows us to map the font weight 600 as bold
sed 's/font-weight:700/font-weight:bold/g' | \
# use double colon for before/after pseudo-elements (see https://www.w3.org/TR/selectors/#pseudo-element-syntax)
sed 's/\([^:]\):\(before\|after\)/\1::\2/g' | \
# drop the fourth value if it matches the second
sed 's/\([a-z-]\+\):\([0-9.empx-]\+\) \([0-9.empx-]\+\) \([0-9.empx-]\+\) \3/\1:\2 \3 \4/g' | \
ruby -e 'puts STDIN.read.gsub(/}(?!})/, %(}\n)).chomp' - > $STYLESHEET_NAME.min.css