diff --git a/usr.bin/sgmlfmt/sgmlfmt.pl b/usr.bin/sgmlfmt/sgmlfmt.pl index a38d118529b1..29500ce06bf2 100755 --- a/usr.bin/sgmlfmt/sgmlfmt.pl +++ b/usr.bin/sgmlfmt/sgmlfmt.pl @@ -41,15 +41,6 @@ require 'newgetopt.pl'; $sgmls = "sgmls"; $instant = "instant"; -# -# Locate the DTD, an SGML declaration, and the replacement files -# - -$doctype = ""; -$dtdbase = "/usr/share/sgml/FreeBSD"; -$dtd = "$dtdbase/linuxdoc.dtd"; -$decl = "$dtdbase/linuxdoc.dcl"; - # # Things to clean up if we exit abnormally # @@ -121,7 +112,7 @@ sub sgmlparse { $defines = "-i $defines"; } open($ifhandle, "$sgmls $defines $decl $file | " . - "$instant -Dfilename=$fileroot -t linuxdoc-${replacement}.ts |"); + "$instant -Dfilename=$fileroot -t ${dtd}-${replacement}.ts |"); } # @@ -209,6 +200,9 @@ $m_depth = 2; # depth of menus $sc = 0; # section counter $filecount = 0; # file counter +$doctype = ""; +$BODY = ""; + # Other variables: # # st_xxxx - Section Table. Arrays containing information about a @@ -636,6 +630,21 @@ sub navbar { } +# +# Generate html output from docbook input +# + +sub docbook_html { + $decl = "/usr/share/sgml/docbook/docbook.dcl"; + @cleanfiles = (@cleanfiles, "${fileroot}.html"); + open (outfile, ">$fileroot.html"); + &sgmlparse(infile, "html"); + while () { + print outfile; + } + close(infile); + close(outfile); +} # extlink # @@ -667,7 +676,7 @@ sub extlink { sub main { # Check arguments - if (!&NGetOpt('f=s', 'links', 'ssi', 'i:s@', 'hdr=s', 'ftr=s', 'white')) { + if (!&NGetOpt('d=s', 'f=s', 'links', 'ssi', 'i:s@', 'hdr=s', 'ftr=s')) { &usage; exit 1; } @@ -683,42 +692,61 @@ sub main { } # Generate output - if ($opt_f eq 'html') { - if ($opt_hdr) {$html_header = &gethf($opt_hdr);} - if ($opt_ftr) {$html_footer = &gethf($opt_ftr);} - if ($opt_white) {$BODY = "";} - else {$BODY = ""} - &gen_html(); - } - elsif ($opt_f eq 'latex' || $opt_f eq 'latex') { - &gen_latex(); - } - elsif ($opt_f eq 'roff') { - &gen_roff(); - } - elsif ($opt_f eq 'ascii') { - &do_groff("ascii", "| col"); - } - elsif ($opt_f eq 'latin1') { - &do_groff("latin1", "| col"); - } - elsif ($opt_f eq 'koi8-r') { - &do_groff("koi8-r", "| col"); - } - elsif ($opt_f eq 'ps') { - &do_groff("ps", ""); + if ($opt_d eq 'docbook') { + $dtd = "docbook"; + $decl = "/usr/share/sgml/docbook/docbook.dcl"; + if ($opt_f eq 'html') { + &docbook_html(); + } + else { + if ($opt_f eq "") { + print "An output format must be specified with the -f + option.\n"; + } + else { + print "\"$opt_f\" is an unknown output format.\n"; + } + &usage; + exit 1; + } } else { - if ($opt_f eq "") { - print "An output format must be specified with the -f option.\n"; + $dtd = "linuxdoc"; + $decl = "/usr/share/sgml/FreeBSD/linuxdoc.dcl"; + if ($opt_f eq 'html') { + if ($opt_hdr) {$html_header = &gethf($opt_hdr);} + if ($opt_ftr) {$html_footer = &gethf($opt_ftr);} + &gen_html(); + } + elsif ($opt_f eq 'latex' || $opt_f eq 'latex') { + &gen_latex(); + } + elsif ($opt_f eq 'roff') { + &gen_roff(); + } + elsif ($opt_f eq 'ascii') { + &do_groff("ascii", "| col"); + } + elsif ($opt_f eq 'latin1') { + &do_groff("latin1", "| col"); + } + elsif ($opt_f eq 'koi8-r') { + &do_groff("koi8-r", "| col"); + } + elsif ($opt_f eq 'ps') { + &do_groff("ps", ""); } else { - print "\"$opt_f\" is an unknown output format.\n"; + if ($opt_f eq "") { + print "An output format must be specified with the -f option.\n"; + } + else { + print "\"$opt_f\" is an unknown output format.\n"; + } + &usage; + exit 1; } - &usage; - exit 1; } - } &main;