Include shell scripts themselves in repo, rather than generating from wrappers.
+ Removed wrappers directory + Removed wrappers Makefile target + Added hsmarkdown, html2markdown, and markdown2pdf git-svn-id: https://pandoc.googlecode.com/svn/trunk@1387 788f1e2b-df1e-0410-8736-df70ead52e1b
This commit is contained in:
parent
db729a08c8
commit
2ba5ff9483
7 changed files with 122 additions and 89 deletions
3
.gitignore
vendored
3
.gitignore
vendored
|
@ -5,9 +5,6 @@ INSTALL.*
|
|||
.configure-stamp
|
||||
man/man?/*.1
|
||||
man/man?/*.html
|
||||
markdown2pdf
|
||||
html2markdown
|
||||
hsmarkdown
|
||||
*.diff
|
||||
pandoc.cabal.orig
|
||||
|
||||
|
|
21
Makefile
21
Makefile
|
@ -93,33 +93,12 @@ all: build-program
|
|||
%.1: %.1.md $(MAIN)
|
||||
./$(MAIN) -s -S -w man $< >$@ || rm -f $@
|
||||
|
||||
define generate-shell-script
|
||||
echo >&2 "Generating $@..."; \
|
||||
awk ' \
|
||||
/^[ \t]*###+ / { \
|
||||
lead = $$0; sub(/[^ \t].*$$/, "", lead); \
|
||||
t = "$(dir $<)/"$$2; \
|
||||
while (getline line < t > 0) \
|
||||
print lead line; \
|
||||
next; \
|
||||
} \
|
||||
{ print } \
|
||||
' <$< >$@
|
||||
chmod +x $@
|
||||
endef
|
||||
|
||||
cleanup_files+=$(ODTREF)
|
||||
$(ODTREF): $(addprefix $(ODTSTYLES)/, layout-cache meta.xml styles.xml content.xml mimetype \
|
||||
settings.xml Configurations2 Thumbnails META-INF)
|
||||
cd $(ODTSTYLES) ; \
|
||||
zip -9 -q -r $(notdir $@) * -x $(notdir $@)
|
||||
|
||||
.PHONY: wrappers
|
||||
wrappers: $(WRAPPERS)
|
||||
cleanup_files+=$(WRAPPERS)
|
||||
$(WRAPPERS): %: $(SRCDIR)/wrappers/%.in $(SRCDIR)/wrappers/*.sh
|
||||
@$(generate-shell-script)
|
||||
|
||||
.PHONY: configure
|
||||
cleanup_files+=Setup.hi Setup.o $(BUILDCMD) $(BUILDVARS)
|
||||
ifdef GHC_PKG
|
||||
|
|
0
wrappers/hsmarkdown.in → hsmarkdown
Normal file → Executable file
0
wrappers/hsmarkdown.in → hsmarkdown
Normal file → Executable file
63
wrappers/html2markdown.in → html2markdown
Normal file → Executable file
63
wrappers/html2markdown.in → html2markdown
Normal file → Executable file
|
@ -5,7 +5,49 @@
|
|||
REQUIRED="tidy"
|
||||
SYNOPSIS="converts HTML from a URL, file, or STDIN to markdown-formatted text."
|
||||
|
||||
### common.sh
|
||||
THIS=${0##*/}
|
||||
|
||||
NEWLINE='
|
||||
'
|
||||
|
||||
err () { echo "$*" | fold -s -w ${COLUMNS:-110} >&2; }
|
||||
errn () { printf "$*" | fold -s -w ${COLUMNS:-110} >&2; }
|
||||
|
||||
usage () {
|
||||
err "$1 - $2" # short description
|
||||
err "See the $1(1) man page for usage."
|
||||
}
|
||||
|
||||
# Portable which(1).
|
||||
pathfind () {
|
||||
oldifs="$IFS"; IFS=':'
|
||||
for _p in $PATH; do
|
||||
if [ -x "$_p/$*" ] && [ -f "$_p/$*" ]; then
|
||||
IFS="$oldifs"
|
||||
return 0
|
||||
fi
|
||||
done
|
||||
IFS="$oldifs"
|
||||
return 1
|
||||
}
|
||||
|
||||
for p in pandoc $REQUIRED; do
|
||||
pathfind $p || {
|
||||
err "You need '$p' to use this program!"
|
||||
exit 1
|
||||
}
|
||||
done
|
||||
|
||||
CONF=$(pandoc --dump-args "$@" 2>&1) || {
|
||||
errcode=$?
|
||||
echo "$CONF" | sed -e '/^pandoc \[OPTIONS\] \[FILES\]/,$d' >&2
|
||||
[ $errcode -eq 2 ] && usage "$THIS" "$SYNOPSIS"
|
||||
exit $errcode
|
||||
}
|
||||
|
||||
OUTPUT=$(echo "$CONF" | sed -ne '1p')
|
||||
ARGS=$(echo "$CONF" | sed -e '1d')
|
||||
|
||||
|
||||
grab_url_with () {
|
||||
url="${1:?internal error: grab_url_with: url required}"
|
||||
|
@ -104,7 +146,24 @@ if [ -n "$argument" ] && ! [ -f "$argument" ]; then
|
|||
inurl="$argument"
|
||||
fi
|
||||
|
||||
### tempdir.sh
|
||||
# As a security measure refuse to proceed if mktemp is not available.
|
||||
pathfind mktemp || { err "Couldn't find 'mktemp'; aborting."; exit 1; }
|
||||
|
||||
# Avoid issues with /tmp directory on Windows/Cygwin
|
||||
cygwin=
|
||||
cygwin=$(uname | sed -ne '/^CYGWIN/p')
|
||||
if [ -n "$cygwin" ]; then
|
||||
TMPDIR=.
|
||||
export TMPDIR
|
||||
fi
|
||||
|
||||
THIS_TEMPDIR=
|
||||
THIS_TEMPDIR="$(mktemp -d -t $THIS.XXXXXXXX)" || exit 1
|
||||
readonly THIS_TEMPDIR
|
||||
|
||||
trap 'exitcode=$?
|
||||
[ -z "$THIS_TEMPDIR" ] || rm -rf "$THIS_TEMPDIR"
|
||||
exit $exitcode' 0 1 2 3 13 15
|
||||
|
||||
if [ -n "$inurl" ]; then
|
||||
err "Attempting to fetch file from '$inurl'..."
|
63
wrappers/markdown2pdf.in → markdown2pdf
Normal file → Executable file
63
wrappers/markdown2pdf.in → markdown2pdf
Normal file → Executable file
|
@ -3,9 +3,68 @@
|
|||
REQUIRED="pdflatex"
|
||||
SYNOPSIS="converts markdown-formatted text to PDF, using pdflatex."
|
||||
|
||||
### common.sh
|
||||
THIS=${0##*/}
|
||||
|
||||
### tempdir.sh
|
||||
NEWLINE='
|
||||
'
|
||||
|
||||
err () { echo "$*" | fold -s -w ${COLUMNS:-110} >&2; }
|
||||
errn () { printf "$*" | fold -s -w ${COLUMNS:-110} >&2; }
|
||||
|
||||
usage () {
|
||||
err "$1 - $2" # short description
|
||||
err "See the $1(1) man page for usage."
|
||||
}
|
||||
|
||||
# Portable which(1).
|
||||
pathfind () {
|
||||
oldifs="$IFS"; IFS=':'
|
||||
for _p in $PATH; do
|
||||
if [ -x "$_p/$*" ] && [ -f "$_p/$*" ]; then
|
||||
IFS="$oldifs"
|
||||
return 0
|
||||
fi
|
||||
done
|
||||
IFS="$oldifs"
|
||||
return 1
|
||||
}
|
||||
|
||||
for p in pandoc $REQUIRED; do
|
||||
pathfind $p || {
|
||||
err "You need '$p' to use this program!"
|
||||
exit 1
|
||||
}
|
||||
done
|
||||
|
||||
CONF=$(pandoc --dump-args "$@" 2>&1) || {
|
||||
errcode=$?
|
||||
echo "$CONF" | sed -e '/^pandoc \[OPTIONS\] \[FILES\]/,$d' >&2
|
||||
[ $errcode -eq 2 ] && usage "$THIS" "$SYNOPSIS"
|
||||
exit $errcode
|
||||
}
|
||||
|
||||
OUTPUT=$(echo "$CONF" | sed -ne '1p')
|
||||
ARGS=$(echo "$CONF" | sed -e '1d')
|
||||
|
||||
|
||||
# As a security measure refuse to proceed if mktemp is not available.
|
||||
pathfind mktemp || { err "Couldn't find 'mktemp'; aborting."; exit 1; }
|
||||
|
||||
# Avoid issues with /tmp directory on Windows/Cygwin
|
||||
cygwin=
|
||||
cygwin=$(uname | sed -ne '/^CYGWIN/p')
|
||||
if [ -n "$cygwin" ]; then
|
||||
TMPDIR=.
|
||||
export TMPDIR
|
||||
fi
|
||||
|
||||
THIS_TEMPDIR=
|
||||
THIS_TEMPDIR="$(mktemp -d -t $THIS.XXXXXXXX)" || exit 1
|
||||
readonly THIS_TEMPDIR
|
||||
|
||||
trap 'exitcode=$?
|
||||
[ -z "$THIS_TEMPDIR" ] || rm -rf "$THIS_TEMPDIR"
|
||||
exit $exitcode' 0 1 2 3 13 15
|
||||
|
||||
texname=output
|
||||
logfile=$THIS_TEMPDIR/log
|
|
@ -1,43 +0,0 @@
|
|||
THIS=${0##*/}
|
||||
|
||||
NEWLINE='
|
||||
'
|
||||
|
||||
err () { echo "$*" | fold -s -w ${COLUMNS:-110} >&2; }
|
||||
errn () { printf "$*" | fold -s -w ${COLUMNS:-110} >&2; }
|
||||
|
||||
usage () {
|
||||
err "$1 - $2" # short description
|
||||
err "See the $1(1) man page for usage."
|
||||
}
|
||||
|
||||
# Portable which(1).
|
||||
pathfind () {
|
||||
oldifs="$IFS"; IFS=':'
|
||||
for _p in $PATH; do
|
||||
if [ -x "$_p/$*" ] && [ -f "$_p/$*" ]; then
|
||||
IFS="$oldifs"
|
||||
return 0
|
||||
fi
|
||||
done
|
||||
IFS="$oldifs"
|
||||
return 1
|
||||
}
|
||||
|
||||
for p in pandoc $REQUIRED; do
|
||||
pathfind $p || {
|
||||
err "You need '$p' to use this program!"
|
||||
exit 1
|
||||
}
|
||||
done
|
||||
|
||||
CONF=$(pandoc --dump-args "$@" 2>&1) || {
|
||||
errcode=$?
|
||||
echo "$CONF" | sed -e '/^pandoc \[OPTIONS\] \[FILES\]/,$d' >&2
|
||||
[ $errcode -eq 2 ] && usage "$THIS" "$SYNOPSIS"
|
||||
exit $errcode
|
||||
}
|
||||
|
||||
OUTPUT=$(echo "$CONF" | sed -ne '1p')
|
||||
ARGS=$(echo "$CONF" | sed -e '1d')
|
||||
|
|
@ -1,18 +0,0 @@
|
|||
# As a security measure refuse to proceed if mktemp is not available.
|
||||
pathfind mktemp || { err "Couldn't find 'mktemp'; aborting."; exit 1; }
|
||||
|
||||
# Avoid issues with /tmp directory on Windows/Cygwin
|
||||
cygwin=
|
||||
cygwin=$(uname | sed -ne '/^CYGWIN/p')
|
||||
if [ -n "$cygwin" ]; then
|
||||
TMPDIR=.
|
||||
export TMPDIR
|
||||
fi
|
||||
|
||||
THIS_TEMPDIR=
|
||||
THIS_TEMPDIR="$(mktemp -d -t $THIS.XXXXXXXX)" || exit 1
|
||||
readonly THIS_TEMPDIR
|
||||
|
||||
trap 'exitcode=$?
|
||||
[ -z "$THIS_TEMPDIR" ] || rm -rf "$THIS_TEMPDIR"
|
||||
exit $exitcode' 0 1 2 3 13 15
|
Loading…
Add table
Reference in a new issue