# along with this program; if not, write to the Free Software
# Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
-set -e
set -f
-VERSION="1.1+arch"
+VERSION="1.1.1+arch"
function bpgallery_default_head() {
cat <<END
<html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en">
<head>
<title>${TITLE}</title>
- <link rel="stylesheet" href="style.css" type="text/css" />
+ <link rel="stylesheet" href="${BASEURL}style.css" type="text/css" />
</head>
<body>
END
caption_alt=$caption
fi
cat << END
-<div class="thumbnail"><a href="$link"><img src="icons/$filename" alt="$caption_alt" /></a><div class="caption">$caption</div></div>
+<div class="thumbnail"><a href="$link"><img src="${ICONSDIRECTORY}/$filename" alt="$caption_alt" /></a><div class="caption">$caption</div></div>
END
}
<h1>${caption}</h1>
<div class="navigation">
<ul>
- <li><a href='${INDEXDOCUMENT}'>Thumbnails</a></li>
+ <li><a href='${BASEURL}${INDEXDOCUMENT}'>Thumbnails</a></li>
END
if [[ ! -z $previouspage ]]; then
$ECHOCOMMAND "<li><a href='${previouspage}'>Previous</a></li>"
$ECHOCOMMAND $temp
}
+function bpgallery_cleanup_directory_name() {
+ temp=$1
+ temp=${temp//\%/_}
+ temp=${temp//:/_}
+ temp=${temp//;/_}
+ temp=${temp// /_}
+ temp=${temp//$/_}
+ temp=${temp//&/_}
+ temp=${temp//+/_}
+ temp=${temp//,/_}
+ temp=${temp//\//_}
+ temp=${temp//=/_}
+ temp=${temp//\?/_}
+ temp=${temp//@/_}
+ temp=${temp//\"/_}
+ $ECHOCOMMAND $temp
+}
+
declare -rf bpgallery_escape_url
if [[ ! -z ${BPGALLERY_THEME} ]] ; then
fi
if [[ -z $CONVERTTOOL ]]; then
- CONVERTTOOL=convert
+ hash convert
+ if [[ $? != 0 ]]; then
+ echo "Can't find convert, exiting"
+ exit 3
+ fi
+ CONVERTTOOL=$(hash -t convert)
+else
+ if [[ ! -x $CONVERTTOOL ]]; then
+ echo "Can't find convert at location $CONVERTTOOL, exiting"
+ exit 3
+ fi
fi
if [[ -z $FINDCOMMAND ]]; then
- FINDCOMMAND=find
+ hash find
+ if [[ $? != 0 ]]; then
+ echo "Can't find find, exiting"
+ exit 3
+ fi
+ FINDCOMMAND=$(hash -t find)
+else
+ if [[ ! -x $FINDCOMMAND ]]; then
+ echo "Can't find find at $FINDCOMMAND, exiting"
+ exit 3
+ fi
fi
if [[ -z $XARGSCOMMAND ]]; then
- XARGSCOMMAND=xargs
+ hash xargs
+ if [[ $? != 0 ]]; then
+ echo "Can't find xargs, exiting"
+ exit 3
+ fi
+ XARGSCOMMAND=$(hash -t xargs)
+else
+ if [[ ! -x $XARGSCOMMAND ]]; then
+ echo "Can't find xargs at $XARGSCOMMAND, exiting"
+ exit 3
+ fi
fi
if [[ -z $ECHOCOMMAND ]]; then
ECHOCOMMAND=echo
+else
+ if [[ ! -x $ECHOCOMMAND ]]; then
+ echo "Can't find echo at $ECHOCOMMAND, exiting"
+ exit 3
+ fi
fi
if [[ -z $SORTCOMMAND ]]; then
- SORTCOMMAND=sort
+ hash sort
+ if [[ $? != 0 ]]; then
+ echo "Can't find sort, exiting"
+ exit 3
+ fi
+ SORTCOMMAND=$(hash -t sort)
+else
+ if [[ ! -x $SORTCOMMAND ]]; then
+ echo "Can't find sort, exiting"
+ exit 3
+ fi
fi
if [[ -z $IDENTIFYCOMMAND ]]; then
- IDENTIFYCOMMAND=identify
+ hash identify
+ if [[ $? != 0 ]]; then
+ echo "Can't find indentify, exiting"
+ exit 3
+ fi
+ IDENTIFYCOMMAND=$(hash -t identify)
+else
+ if [[ ! -x $IDENTIFYCOMMAND ]]; then
+ echo "Can't find identify at $IDENTIFYCOMMAND, exiting"
+ exit 3
+ fi
fi
if [[ -z $HEADCOMMAND ]]; then
- HEADCOMMAND=head
+ hash head
+ if [[ $? != 0 ]]; then
+ echo "Can't find head, exiting"
+ exit 3
+ fi
+ HEADCOMMAND=$(hash -t head)
+else
+ if [[ ! -x $HEADCOMMAND ]]; then
+ echo "Can't find head at $HEADCOMMAND, exiting"
+ exit 3
+ fi
fi
if [[ -z $GREPCOMMAND ]]; then
- GREPCOMMAND=grep
+ hash grep
+ if [[ $? != 0 ]]; then
+ echo "Can't find grep, exiting"
+ exit 3
+ fi
+ GREPCOMMAND=$(hash -t grep)
+else
+ if [[ ! -x $GREPCOMMAND ]]; then
+ echo "Can't find grep at $GREPCOMMAND, exiting"
+ exit 3
+ fi
fi
if [[ -z $SEDCOMMAND ]]; then
- SEDCOMMAND=sed
+ hash sed
+ if [[ $? != 0 ]]; then
+ echo "Can't find sed, exiting"
+ exit 3
+ fi
+ SEDCOMMAND=$(hash -t sed)
+else
+ if [[ ! -x $SEDCOMMAND ]]; then
+ echo "Can't find sed at $SEDCOMMAND, exiting"
+ exit 3
+ fi
+fi
+
+if [[ -z $WCCOMMAND ]]; then
+ hash wc
+ if [[ $? != 0 ]]; then
+ echo "Can't find wc, exiting"
+ exit 3
+ fi
+ WCCOMMAND=$(hash -t wc)
+ WCCOMMAND="$WCCOMMAND -l"
+else
+ if [[ ! -x $WCCOMMAND ]]; then
+ echo "Can't find wc at $WCCOMMAND, exiting"
+ exit 3
+ fi
+ WCCOMMAND="$WCCOMMAND -l"
fi
if [[ -z $WIDTH ]]; then
IMAGEEXTENSIONS="jpeg jpg gif png";
fi
-if [[ -z $WCCOMMAND ]]; then
- WCCOMMAND="wc -l"
-fi
-
if [[ -z $CAPTIONHEIGHT ]]; then
CAPTIONHEIGHT=75
fi
GENERATEPAGESFORMEDIUMSIZE=1
fi
+if [[ -z $PAGESDIRECTORY ]]; then
+ PAGESDIRECTORY=""
+else
+ removetrailingslashes=${PAGESDIRECTORY%/}
+ temp=$removetrailingslashes
+ while [[ $removetrailingslashes != $temp ]]; do
+ temp=$removetrailingslashes
+ removetrailingslashes=${temp%/}
+ done
+ PAGESDIRECTORY=$(bpgallery_escape_url "${PAGESDIRECTORY}")
+fi
+
if [[ -z $MEDIUMWIDTH ]]; then
MEDIUMWIDTH=400
fi
INDEXDOCUMENT=index.html
fi
-if [[ $GENERATEPAGESFORFULLSIZE != 0 ]]; then
- if declare -F "bpgallery_${BPGALLERY_THEME}_page" > /dev/null ; then
- BPGALLERY_PAGE_FUNCTION="bpgallery_${BPGALLERY_THEME}_page"
- else
- BPGALLERY_PAGE_FUNCTION="bpgallery_default_page"
- fi
+if [[ -z $MEDIUMDIRECTORY ]]; then
+ MEDIUMDIRECTORY=medium
+else
+ # Strip out anything that might be broken
+ MEDIUMDIRECTORY=$(bpgallery_cleanup_directory_name "$MEDIUMDIRECTORY")
+fi
+
+if [[ -z $ICONSDIRECTORY ]]; then
+ ICONSDIRECTORY=icons
+else
+ # Strip out anything that might be broken
+ ICONSDIRECTORY=$(bpgallery_cleanup_directory_name "$ICONSDIRECTORY")
+fi
+
+if declare -F "bpgallery_${BPGALLERY_THEME}_page" > /dev/null ; then
+ BPGALLERY_PAGE_FUNCTION="bpgallery_${BPGALLERY_THEME}_page"
+else
+ BPGALLERY_PAGE_FUNCTION="bpgallery_default_page"
fi
if declare -F "bpgallery_${BPGALLERY_THEME}_head" > /dev/null ; then
}
function generate_thumbs() {
- generate_resized_images $WIDTH icons
+ if [[ ! -z $HEIGHT ]]; then
+ generate_resized_images "${WIDTH}x${HEIGHT}" $ICONSDIRECTORY
+ else
+ generate_resized_images $WIDTH $ICONSDIRECTORY
+ fi
}
function generate_medium() {
- generate_resized_images $MEDIUMWIDTH medium
+ if [[ ! -z $MEDIUMHEIGHT ]]; then
+ generate_resized_images "${WIDTH}x${HEIGHT}" $MEDIUMDIRECTORY
+ else
+ generate_resized_images $MEDIUMWIDTH $MEDIUMDIRECTORY
+ fi
}
function generate_pages() {
addlink=""
if [[ $GENERATEPAGESFORFULLSIZE != 0 ]]; then
- addlink=${currentimage}${extra}.html
+ if [[ $addlinks == 1 ]]; then
+ addlink=${currentimage}.html
+ else
+ addlink=${currentimage}${extra}.html
+ fi
else
addlink=${currentimage}
fi
- if [[ $addlinks == 1 ]]; then
- addlink=${currentimage}.html
- else
- addlink=${currentimage}${extra}.html
- fi
-
previouspage=$currentpage
currentpage=$nextpage
if [[ $addlinks == 1 ]]; then
else
nextpage=${nextimage}.html
fi
- filename=${extradir}${currentimage}
- generate_general_page "$previouspage" "$currentpage" "$nextpage" $addlink
+
+ if [[ "x$PAGESDIRECTORY" != "x" ]]; then
+ filename=../${extradir}${currentimage}
+ else
+ filename=${extradir}${currentimage}
+ fi
+ if [ "x$currentpage" != "x" ]; then
+ generate_general_page "$previouspage" "$currentpage" "$nextpage" $addlink
+ fi
$ECHOCOMMAND $nextimage
done | tail -n 2 | (
read previouspage
addlink=""
if [[ $GENERATEPAGESFORFULLSIZE != 0 ]]; then
- addlink=${currentpage}.html
+ if [[ $addlinks == 1 ]]; then
+ addlink=${currentpage}.html
+ else
+ addlink=${currentpage}${extra}.html
+ fi
else
addlink=${currentpage}
fi
-
- if [[ $addlinks == 1 ]]; then
- addlink=${currentpage}.html
+
+ if [[ "x$PAGESDIRECTORY" != "x" ]]; then
+ filename=../${extradir}${currentpage}
else
- addlink=${currentpage}${extra}.html
+ filename=${extradir}${currentpage}
fi
-
- filename=${extradir}${currentpage}
if [[ $addlinks == 1 ]]; then
currentpage=${currentpage}${extra}.html
previouspage=${previouspage}${extra}.html
}
function generate_medium_pages() {
- generate_pages __medium medium
+ generate_pages __${MEDIUMDIRECTORY} ${MEDIUMDIRECTORY}
}
function generate_general_page() {
fi
if [ -r captions.txt ]; then
- caption=$($GREPCOMMAND -E "^${filename} " captions.txt); caption=${caption#* }
+ imagefilename=${filename##*/}
+ caption=$($GREPCOMMAND -E "^${imagefilename} " captions.txt); caption=${caption#* }
else
caption=""
fi
- $BPGALLERY_PAGE_FUNCTION > "$currentpage"
+ $BPGALLERY_PAGE_FUNCTION > "${UNIXPAGESDIRECTORY}$currentpage"
}
if [[ $OUTPUTHTML != 0 ]]; then
generate_thumbs
+if [[ "x$PAGESDIRECTORY" != "x" ]]; then
+ if [ ! -d $PAGESDIRECTORY ]; then
+ mkdir -p $PAGESDIRECTORY
+ fi
+
+ if [ ! -w $PAGESDIRECTORY ]; then
+ $ECHOCOMMAND "Can't write to $PAGESDIRECTORY directory, exiting"
+ exit 16
+ fi
+ UNIXPAGESDIRECTORY=$PAGESDIRECTORY/
+ PAGESDIRECTORY=$(bpgallery_escape_url $PAGESDIRECTORY)/
+
+ BASEURL="../"
+else
+ BASEURL=""
+ UNIXPAGESDIRECTORY=""
+fi
+
if [ $GENERATEPAGESFORMEDIUMSIZE != 0 ]; then
generate_medium
generate_medium_pages
if [ $GENERATEPAGESFORFULLSIZE != 0 ]; then
if [ $GENERATEPAGESFORMEDIUMSIZE != 0 ]; then
- generate_pages __medium
+ generate_pages __${MEDIUMDIRECTORY}
else
generate_pages
fi
DESCRIPTION=""
fi
+BASEURL=""
$ECHOCOMMAND "Starting to generate page"
extra=""
if [ $GENERATEPAGESFORMEDIUMSIZE != 0 ]; then
- extra=__medium
+ extra=__${MEDIUMDIRECTORY}
fi
-$FINDCOMMAND . $FINDIMAGESOPTIONS | $XARGSCOMMAND -0 -I {} $ECHOCOMMAND {} | $SORTCOMMAND -g | while read filename; do filename=${filename#./}; if [ -r captions.txt ]; then caption=$($GREPCOMMAND -E "^$filename " captions.txt); caption=${caption#* }; else caption=""; fi; if [ $GENERATEPAGESFORMEDIUMSIZE != 0 ]; then link=$(bpgallery_escape_url "${filename}${extra}.html"); elif [ $GENERATEPAGESFORFULLSIZE != 0 ]; then link=$(bpgallery_escape_url "${filename}.html"); else link=$(bpgallery_escape_url "$filename"); fi; filename=$(bpgallery_escape_url "$filename"); $BPGALLERY_THUMBSLINE_FUNCTION; done >> ${INDEXDOCUMENT}
+$FINDCOMMAND . $FINDIMAGESOPTIONS | $XARGSCOMMAND -0 -I {} $ECHOCOMMAND {} | $SORTCOMMAND -g | while read filename; do filename=${filename#./}; if [ -r captions.txt ]; then caption=$($GREPCOMMAND -E "^$filename " captions.txt); caption=${caption#* }; else caption=""; fi; if [ $GENERATEPAGESFORMEDIUMSIZE != 0 ]; then link=${PAGESDIRECTORY}$(bpgallery_escape_url "${filename}${extra}.html"); elif [ $GENERATEPAGESFORFULLSIZE != 0 ]; then link=${PAGESDIRECTORY}$(bpgallery_escape_url "${filename}.html"); else link=$(bpgallery_escape_url "$filename"); fi; filename=$(bpgallery_escape_url "$filename"); $BPGALLERY_THUMBSLINE_FUNCTION; done >> ${INDEXDOCUMENT}
$BPGALLERY_TAIL_FUNCTION >> ${INDEXDOCUMENT}
$ECHOCOMMAND "Finished generating the page"
$ECHOCOMMAND "Generating stylesheet"
-cd icons
+cd $ICONSDIRECTORY
MAXHEIGHT=$($FINDCOMMAND . $FINDIMAGESOPTIONS | $XARGSCOMMAND -0 $IDENTIFYCOMMAND -format "%h\n" | $GREPCOMMAND -v "^$" | $SORTCOMMAND -g -r | $HEADCOMMAND -n 1)
MAXWIDTH=$($FINDCOMMAND . $FINDIMAGESOPTIONS | $XARGSCOMMAND -0 $IDENTIFYCOMMAND -format "%w\n" | $GREPCOMMAND -v "^$" | $SORTCOMMAND -g -r | $HEADCOMMAND -n 1)