#DtdAnalyzer
DtdAnalyzer provides a set of tools:
- dtdanalyzer - creates an XML representation (using elements and attributes) of an XML DTD
- dtddocumentor - generates pretty HTML documentation, including annotations (if present) from specially-formatted comments of the DTD
- dtdflatten - flattens a multi-file DTD into one big file. See also the Perl script script/dtdflatten.pl.
- dtdcompare - compares two DTDs and generate a report of differences
- dtd2xml2json - generates XSLT to convert instance documents into JSON format.
- dtdschematron - generates a schematron file from the DTD, including extra schematron rules (if present) from specially-formatted comments of the DTD
- scaffold.xsl - generates XSLT scaffolding that can be used as a starting point for writing a transform from one schema to another
The home page for this project is at http://dtd.nlm.nih.gov/ncbi/dtdanalyzer.
Detailed documentation is available on the GitHub wiki.
##Quick start
-
Download the latest release, either as a zip file: DtdAnalyzer-0.5.zip; or as a gzipped tar: DtdAnalyzer-0.5.tar.gz.
Note: Do not use the "Zip" download button on the main GitHub page! That button downloads the source files, not the pre-built packages. They are different!
-
Unzip that file on your machine.
-
Open up a Windows command or a bash shell window. Add the path to the package root to your PATH environment variable.
On Windows:
set PATH=%PATH%;-path-to-dtdanalyzer-package-
On Mac OS X or Unix:
export PATH=$PATH:-path-to-dtdanalyzer-package-
-
Note for Mac OS X: This software depends on a utility called
greadlink
, which might not be installed on your system. To see whether or not it is, enterwhich greadlink
at a terminal prompt. If it is not installed, then the easiest way to get it is with Homebrew. Install Homebrew, if necessary, and then enterbrew install coreutils
. -
Try the following command (which analyzes the Journal Archiving and Interchange flavor of the NLM/NISO Journal Article Tag Suite, and writes the output to a file):
dtdanalyzer http://jats.nlm.nih.gov/archiving/1.0/JATS-archivearticle1.dtd out.daz.xml
-
Check that you have sensible results in the output file,
out.daz.xml
. -
As another example, the next command produces HTML documentation for that DTD. It should run for a little while and then announce that it's done, and that the documentation is in the
doc
subdirectory. (Enter all on one line).dtddocumentor http://jats.nlm.nih.gov/archiving/1.0/JATS-archivearticle1.dtd --exclude mml: --exclude-except mml:math
-
Open the
doc/index.html
file in a browser, and check that it looks good. -
Run
--help
with any of the tools for more complete usage information, or continue by visiting the documentation pages on the GitHub wiki.
##Discussion forum / mailing list
This software is in beta stage.
Join the DtdAnalyzer Google group for discussions.
File bug reports at the GitHub issues page.
##Public domain
This work is in the public domain and may be reproduced, published or otherwise used without permission of the National Library of Medicine (NLM).
Although all reasonable efforts have been taken to ensure the accuracy and reliability of the software and data, the NLM and the U.S. Government do not and cannot warrant the performance or results that may be obtained by using this software or data. The NLM and the U.S. Government disclaim all warranties, express or implied, including warranties of performance, merchantability or fitness for any particular purpose.