#!/bin/sh # Jade Wrapper # Script to convert a SGML file into some other format # Send any comments to Eric Bischoff # This program is under GPL license. See LICENSE file for details. # Set help message SGML_HELP_MESSAGE="Usage: `basename $0` [] where are: -f|--frontend : Specify the frontend (source format) (default is docbook) -b|--backend : Specify the backend (destination format) (default is html) -c|--cat : Specify an extra SGML open catalog -n|--nostd: Do not use the standard SGML open catalogs -d|--dsl |default|none: Specify an alternate style sheet (default is to use the default stylesheet) -l|--dcl : Specify an alternate SGML declaration (usual ones like xml.dcl get detected automatically) -s|--sgmlbase : Change base directory for SGML distribution (usually /usr/share/sgml) -p|--parser : Specify the parser if several are installed (jade or openjade) -o|--output : Set output directory -u|--nochunks: Output only one big file (overrides the stylesheet settings) -i|--include
: Specify a SGML marked section to include (should be marked as \"ignore\" in the SGML text) -w|--warning |list: Control warnings or display the allowed warning types -e|--errors |list: Control errors or display the allowed error types -h|--help: Print this help message and exit -V : Set a variable -v|--version: Print the version and exit" # Set list of warning types SGML_WARNINGS_LIST=" xml Warn about constructs that are not allowed by XML mixed Warn about mixed content models that do not allow #pcdata anywhere sgmldecl Warn about various dubious constructions in the SGML declaration should Warn about various recommendations made in ISO 8879 that the document does not comply with default Warn about defaulted references duplicate Warn about duplicate entity declarations undefined Warn about undefined elements: elements used in the DTD but not defined unclosed Warn about unclosed start and end-tags empty Warn about empty start and end-tags net Warn about net-enabling start-tags and null end-tags min-tag Warn about minimized start and end-tags. Equivalent to: unclosed, empty and net unused-map Warn about unused short reference maps unused-param Warn about parameter entities that are defined but not used in a DTD notation-sysid Warn about notations for which no system identifier could be generated all Equivalent to: mixed, should, default, undefined, sgmldecl, unused-map, unused-param, empty and unclosedn\ A warning can be disabled by using its name prefixed with no-. Example: -w all -w no-duplicate" # Set list of error types SGML_ERRORS_LIST=" no-idref No error for an ID reference value which no element has as its ID no-significant No errors for characters not significant in the reference concrete syntax no-valid Do not require the document to be type-valid" # Get name of main SGML configuration file which sgmlwhich >/dev/null 2>/dev/null if [ $? -eq 0 ] then SGML_CONF=`sgmlwhich` else SGML_CONF="/etc/sgml/sgml.conf" fi # Set version message SGML_VERSION_MESSAGE="DocBook-utils version 0.6.14 (jw version 1.1)" # Set option: use standard catalogs SGML_STANDARD_CATALOGS="yes" # Set path to user SGML catalogs SGML_EXTRA_CATALOGS=":/etc/sgml/catalog:/usr/share/sgml/CATALOG.docbook-dsssl-stylesheets" # Set SGML base directory and centralized catalogs directory SGML_BASE_DIR="/usr/share/sgml" SGML_CATALOGS_DIR="/etc/sgml" if [ -f "$SGML_CONF" ] then RE='^[:space:]*SGML_BASE_DIR[:space:]*=[:space:]*' SGML_BASE_DIR=`grep $RE $SGML_CONF | sed "s/$RE//"` RE='^[:space:]*SGML_CATALOGS_DIR[:space:]*=[:space:]*' SGML_CATALOGS_DIR=`grep $RE $SGML_CONF | sed "s/$RE//"` fi # Set frontend to use SGML_FRONTEND="$SGML_BASE_DIR/docbook/utils-0.6.14/frontends/docbook" # Set backend to use SGML_BACKEND="$SGML_BASE_DIR/docbook/utils-0.6.14/backends/html" # Set main stylesheet SGML_STYLESHEET="default" # Set flavour of jade parser to use SGML_JADE="" # Set SGML declaration and file to process SGML_DECL="" SGML_FILE="" # Set output and current directories SGML_OUTPUT_DIRECTORY="." SGML_CURRENT_DIRECTORY=`pwd` # Set of options to set SGML_OPTIONS="" # Set list of "include" marked sections SGML_INCLUDE="" # Set list of warning types and errors types SGML_WARNINGS="" # Process options while [ $# -gt 0 ] do case $1 in -f|--frontend) case "$2" in /*) SGML_FRONTEND="$2" ;; *) d=$SGML_BASE_DIR/docbook/utils-0.6.14/frontends SGML_FRONTEND="$d/$2" ;; esac shift 2 ;; -b|--backend) case "$2" in /*) SGML_BACKEND="$2" ;; *) d=$SGML_BASE_DIR/docbook/utils-0.6.14/backends SGML_BACKEND="$d/$2" ;; esac shift 2 ;; -c|--cat) case "$2" in /*) SGML_EXTRA_CATALOGS="$SGML_EXTRA_CATALOGS:$2" ;; *) SGML_EXTRA_CATALOGS="$SGML_EXTRA_CATALOGS:$SGML_CURRENT_DIRECTORY/$2" ;; esac shift 2 ;; -d|--dsl) case "$2" in /*|none|default) SGML_STYLESHEET="$2" ;; *) SGML_STYLESHEET="$SGML_CURRENT_DIRECTORY/$2" ;; esac shift 2 ;; -l|--dcl) case "$2" in /*) SGML_DECL="$2" ;; *) SGML_DECL="$SGML_CURRENT_DIRECTORY/$2" ;; esac shift 2 ;; -n|--nostd) SGML_STANDARD_CATALOGS="no" shift 1 ;; -s|--sgmlbase) case "$2" in /*) SGML_BASE_DIR="$2" ;; *) SGML_BASE_DIR="$SGML_CURRENT_DIRECTORY/$2" ;; esac shift 2 ;; -p|--parser) case "$2" in /*) SGML_JADE="$2" ;; *) SGML_JADE="$SGML_CURRENT_DIRECTORY/$2" ;; esac shift 2 ;; -o|--output) case "$2" in /*) SGML_OUTPUT_DIRECTORY="$2" ;; *) SGML_OUTPUT_DIRECTORY="$SGML_CURRENT_DIRECTORY/$2" ;; esac shift 2 ;; -u|--nochunks) SGML_OPTIONS="$SGML_OPTIONS -V nochunks" shift 1 ;; -V) SGML_OPTIONS="$SGML_OPTIONS -V $2" shift 2 ;; -i|--include) case $2 in print|html) echo "The marked section named \"$2\" is reserved for internal use by `basename $0`." >&2 exit 1 ;; esac SGML_INCLUDE="$SGML_INCLUDE -i $2" shift 2 ;; -w|--warning) case $2 in list) echo "List of allowed warning types (multiple -w options are allowed):" echo $SGML_WARNINGS_LIST exit 0 ;; xml|mixed|sgmldecl|should|default|duplicate|undefined|unclosed|empty|net|min-tag|unused-map|unused-param|notation-sysid|all|no-xml|no-mixed|no-sgmldecl|no-should|no-default|no-duplicate|no-undefined|no-unclosed|no-empty|no-net|no-min-tag|no-unused-map|no-unused-param|no-notation-sysid) \ SGML_WARNINGS="$SGML_WARNINGS -w $2" shift 2 ;; *) echo "Unknown warning type \"$2\". Allowed warning types are:" >&2 echo $SGML_WARNINGS_LIST >&2 exit 1 ;; esac ;; -e|--error) case $2 in list) echo "List of allowed error types (multiple -e options are allowed):" echo $SGML_ERRORS_LIST exit 0 ;; no-idref|no-significant|no-valid) \ SGML_WARNINGS="$SGML_WARNINGS -w $2" shift 2 ;; *) echo "Unknown error type \"$2\". Allowed error types are:" >&2 echo $SGML_ERRORS_LIST >&2 exit 1 ;; esac ;; -h|--help) echo "`basename $0` - Jade Wrapper" echo echo "$SGML_HELP_MESSAGE" exit 0 ;; -v|--version) echo "$SGML_VERSION_MESSAGE" exit 0 ;; -*) echo "$SGML_HELP_MESSAGE" >&2 exit 1 ;; *) if [ -z "$SGML_FILE" ] then case "$1" in /*) SGML_FILE="$1" ;; *) SGML_FILE="$SGML_CURRENT_DIRECTORY/$1" ;; esac shift 1 else echo "$SGML_HELP_MESSAGE" >&2 exit 1 fi ;; esac done # Check that we have a frontend if [ -z "$SGML_FRONTEND" ] then echo $SGML_HELP_MESSAGE >&2 exit 1 fi if [ ! -s $SGML_FRONTEND ] then echo "`basename $0`: There is no frontend called \"$SGML_FRONTEND\"." >&2 exit 2 fi # Check that we have a backend if [ -z "$SGML_BACKEND" ] then echo $SGML_HELP_MESSAGE >&2 exit 1 fi if [ ! -s $SGML_BACKEND ] then echo "`basename $0`: There is no backend called \"$SGML_BACKEND\"." >&2 exit 2 fi # Check that we have a file to process if [ -z "$SGML_FILE" ] then echo $SGML_HELP_MESSAGE >&2 exit 1 fi if [ ! -s $SGML_FILE ] then echo "`basename $0`: Cannot open \"$SGML_FILE\"." >&2 exit 3 fi # Separate the file name and the extension (if any) SGML_FILE_NAME=`basename $SGML_FILE` SGML_FILE_NAME=${SGML_FILE_NAME%.*} # Determine if we are in an XML file SGML_XML=`head "$SGML_FILE" | grep "" | wc -l` if [ $SGML_XML -eq 1 ]; then SGML_XML="xml" else SGML_XML="sgml" fi # Use SGML declaration for XML if needed if [ "$SGML_DECL" = "" -a "$SGML_XML" = "xml" ] then SGML_DECL=${SGML_BASE_DIR}/xml.dcl [ -f $SGML_DECL ] || SGML_DECL=${SGML_BASE_DIR}/opensp/xml.dcl fi # Try to find the SGML normalizer if [ -z "$SGML_NORM" ] then SGML_NORM=`which sgmlnorm 2>/dev/null` if [ -z "SGML_NORM" ] then SGML_NORM=`which osgmlnorm 2>/dev/null` fi fi # Set path to SGML catalogs (first try centralized catalog) case $SGML_STANDARD_CATALOGS in yes) export SGML_CATALOGS_DIR SGML_FILE SGML_XML SGML_NORM SGML_CENTRALIZED_CATALOG=`sh $SGML_FRONTEND centralized-catalog` if [ -s $SGML_CENTRALIZED_CATALOG ] then SGML_CATALOG_FILES=$SGML_CENTRALIZED_CATALOG else SGML_CATALOG_FILES=`find $SGML_BASE_DIR -name catalog` SGML_CATALOG_FILES=`echo "$SGML_CATALOG_FILES" | tr [:space:] :` fi ;; no) SGML_CATALOG_FILES="" ;; esac SGML_CATALOG_FILES=${SGML_CATALOG_FILES}${SGML_EXTRA_CATALOGS} SGML_CATALOG_FILES=`echo "$SGML_CATALOG_FILES" | sed 's/^://;s/:$//'` if [ -z "$SGML_CATALOG_FILES" ] then echo "`basename $0`: Please specify at least one catalog" >&2 exit 4 fi # Determine the backend type case $SGML_BACKEND in *html|*txt) \ SGML_TYPE=html ;; *) SGML_TYPE=print ;; esac # Determine which stylesheet to use # (run the frontend to know it if the default stylesheet or no custom stylesheet is desired) if [ "$SGML_STYLESHEET" = "default" -o "$SGML_STYLESHEET" = "none" ] then export SGML_BASE_DIR SGML_TYPE SGML_STYLESHEET SGML_STYLESHEET=`sh $SGML_FRONTEND style-sheet` SGML_RETURN=$? if [ $SGML_RETURN -gt 0 ] then exit `expr 7 + $SGML_RETURN` fi fi if [ -z "$SGML_STYLESHEET" ] then echo "`basename $0`: Please specify at least one stylesheet" >&2 exit 5 fi case "$SGML_OPTIONS" in *paper-type*) ;; *) # Set the paper size to A4 if the locale suggests so papersize= if [ -x /usr/bin/locale ] then h=$(/usr/bin/locale LC_PAPER 2>/dev/null | head -n 1) if [ "$h" = 297 ] then papersize=A4 fi fi if [ -n "$papersize" ] then SGML_OPTIONS="-V paper-type=$papersize $SGML_OPTIONS" fi ;; esac # Choose a parser if [ -z "$SGML_JADE" ] then which jade >/dev/null 2>/dev/null if [ $? -eq 0 ] then SGML_JADE="jade" else which openjade >/dev/null 2>/dev/null if [ $? -eq 0 ] then SGML_JADE="openjade" else echo "`basename $0`: No parser available" >&2 exit 6 fi fi else which $SGML_JADE >/dev/null 2>/dev/null if [ $? -ne 0 ] then echo "`basename $0`: parser $SGML_JADE is not available" >&2 exit 6 fi fi # Create output directory if not available if [ -z "$SGML_OUTPUT_DIRECTORY" ] then echo $SGML_HELP_MESSAGE >&2 exit 1 fi if [ ! -d $SGML_OUTPUT_DIRECTORY ] then mkdir $SGML_OUTPUT_DIRECTORY 2>/dev/null if [ $? -ne 0 ] then echo "`basename $0`: Could not create \"$SGML_OUTPUT_DIRECTORY\" output directory" >&2 exit 7 fi fi # Prepare the parser's arguments SGML_ARGUMENTS="$SGML_INCLUDE -i $SGML_TYPE -d $SGML_STYLESHEET $SGML_OPTIONS $SGML_WARNINGS $SGML_DECL $SGML_FILE" # Call the backend echo "Using catalogs: `echo $SGML_CATALOG_FILES | sed 's/:/, /g'`" echo "Using stylesheet: $SGML_STYLESHEET" echo "Working on: $SGML_FILE" cd $SGML_OUTPUT_DIRECTORY export SGML_JADE SGML_FILE_NAME SGML_ARGUMENTS export SGML_CATALOG_FILES SGML_BASE_DIR SGML_FILE SGML_STYLESHEET NOCHUNKS=`echo $SGML_OPTIONS | grep nochunks` if [ -z "$NOCHUNKS" ] then sh $SGML_BACKEND else sh $SGML_BACKEND >$SGML_FILE_NAME.html fi SGML_RETURN=$? cd $SGML_CURRENT_DIRECTORY if [ $SGML_RETURN -gt 0 ] then exit `expr 7 + $SGML_RETURN` fi echo "Done." exit 0