#!/usr/bin/sh
NAME="$0"
CSS_LINK="https://raw.githubusercontent.com/sindresorhus/github-markdown-css/gh-pages/github-markdown.css"
INPUT="/dev/stdin"
CUSTOM_INPUT=0
OUTPUT="/dev/stdout"
CUSTOM_OUTPUT=0
COMPILER="marked --gfm"
print_help() {
echo "Usage: $NAME [OPTION]... [INPUT]"
echo "Compile INPUT markdown file to github-styled html"
echo ""
echo " --compiler [COMPILER] set the markdown compiler to use. Default is marked --gfm"
echo " -h, --help print this help message"
echo " -i, --input [INPUT] specify INPUT file"
echo " -o, --output [OUTPUT] output to specified OUTPUT file"
echo " -y, --yes automatic yes to prompts"
}
# Parse arguments
while [ $# -gt 0 ]; do
case $1 in
--compiler)
COMPILER="$2"
shift 2
;;
-h | --help)
print_help
exit 1
;;
-i | --input)
INPUT="$2"
CUSTOM_INPUT=1
shift 2
;;
-o | --output)
OUTPUT="$2"
CUSTOM_OUTPUT=1
shift 2
;;
*)
INPUT="$1"
CUSTOM_INPUT=1
shift
;;
esac
done
# Check if overwrite
if [ $CUSTOM_OUTPUT -eq 1 ] && [ -e "$OUTPUT" ]; then
echo -n "File $OUTPUT already exists. Overwrite it? [y/N] "
read -r PROMPT
if [ "$PROMPT" = "y" ]; then
echo -n "" > "$OUTPUT"
else
exit 1
fi
fi
# Add meta, link, and style lines to OUTPUT
echo "" >> "$OUTPUT"
echo "" >> "$OUTPUT"
echo "" >> "$OUTPUT"
echo "" >> "$OUTPUT"
# Add body (from markdown) using compiler (default is marked --gfm)
# TODO work on getting syntax highlighting support
$COMPILER "$INPUT" >> "$OUTPUT"
# Close output
echo "" >> "$OUTPUT"