Skip to content

ncbi/DtdAnalyzer

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

#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

Home page and documentation

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, enter which 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 enter brew 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.

About

No description, website, or topics provided.

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • XSLT 50.9%
  • Java 35.7%
  • HTML 3.8%
  • Shell 3.3%
  • CSS 2.2%
  • Perl 2.0%
  • Other 2.1%