mirror of
				https://gitlab.gnome.org/GNOME/libxml2.git
				synced 2025-10-24 13:33:01 +03:00 
			
		
		
		
	Sun Nov 30 21:06:29 MST 2003 John Fleck <jfleck@inkstain.net> * doc/docdescr.doc Updating William's explanation of how to build docs, reflecting Daniel's new docs build system
		
			
				
	
	
		
			101 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
			
		
		
	
	
			101 lines
		
	
	
		
			4.5 KiB
		
	
	
	
		
			Plaintext
		
	
	
	
	
	
|                    Notes on the libxml2 Documentation
 | |
|             Prepared by: William Brack <wbrack@mmm.com.hk>
 | |
| 	    
 | |
|   After spending a  lot of time tracing through  Makefile.am, some Python
 | |
| scripts  and some xsl  scripts and xml files, I  thought it might be good
 | |
| to save others some time  by setting down the basic information about how
 | |
| the library documentation  is created.  I intend to enhance this process,
 | |
| but will keep this document up-to-date for  everyone's information.  Note
 | |
| that this document does not  apply to the subdirectory  "tutorial", which
 | |
| is separately maintained by John Fleck.
 | |
| 
 | |
|   There are a relatively  small number of files  which form the "core" of
 | |
| the document directory.  All  the other files in the directory can be re-
 | |
| generated using  the information  present in these  core files,  plus the
 | |
| actual library  source files (*.[ch]) in the parent  directory  "../" and
 | |
| it's descendants include  and include/libxml.  These core files, together
 | |
| with a brief description of each, are as follows:-
 | |
| 
 | |
| xml.html           The "main page", manually produced by Daniel Veillard
 | |
| news.html          The latest news, extracted from xml.html by site.xsl
 | |
| 
 | |
| benchmark.gif      Illustrations used for the "main page" and subsidiaries
 | |
| gnome2.png                              -------
 | |
| Libxml2-Logo-180x168.gif                   |
 | |
| libxml.gif                                 |
 | |
| linus.gif                                  |
 | |
| redhat.gif                                 |
 | |
| structure.gif                             \ /
 | |
| w3c.png                                    -
 | |
| 
 | |
| apibuild.py        Python script which generates the file libxml2-api.xml
 | |
| parsedecl.py       Python secipt which generates the file libxml2-refs.xml
 | |
| 
 | |
| api.xsl            xslt script to generate API cross-references APIchunk*.html
 | |
|                      using information from libxml2-api.xml and libxml2-refs.xml
 | |
| news.xsl           xslt script to generate ../NEWS from news.html
 | |
| site.xsl           xslt script imported by api.xsl, generates most top-level
 | |
|                      pages from news.html
 | |
| xsa.xsl            xslt script to generate libxml.xsa from news.html
 | |
| 
 | |
| xmlcatalog.1       Man page for xml catalogs, built from xmlcatalog_man.xml DocBook
 | |
| 		   source with "make xmlcatalog.1" or "make all"
 | |
| xmllint.1          Man page for xmllint program, built from xmllint.xml DocBook
 | |
| 		   source with "make xmllint.1" or "make all"
 | |
| 
 | |
| libxml-doc.el      Control script for displaying docs under emacs
 | |
| 
 | |
| 
 | |
|   Given the above files, the generation of the complete documentation (as
 | |
| provided on the web by xmlsoft.org) can be created with the following steps:
 | |
| 
 | |
| NOTE:  Steps 1 through 7 are performed with the command "make rebuild";
 | |
|        Steps 3 and 5 through 7 are performed with the command "make all"
 | |
| 
 | |
| 
 | |
| 1) Generate libxml2-api.xml:
 | |
|        ./apibuild.py
 | |
| 
 | |
|     This script is a more recent addition to the documentation generation.
 | |
|     Instead of using the information from the gtk-doc routines, it actually
 | |
|     re-processes all the the library source files, extracting information
 | |
|     about the api (exported procedures and symbols, together with information
 | |
|     from the source comments within these).  It produces an xml file which
 | |
|     contains all of this information, "libxml2-api.xml".
 | |
| 
 | |
| 2) Generate libxml2-refs.xml:
 | |
|        ./parsedecl.py
 | |
| 
 | |
|     This script produces the summary
 | |
|     xml file "libxml2-refs.xml".  Historically, it also used to produce
 | |
|     information on the api's in the file "libxml2-api.xml", but that step is
 | |
|     now being done by a separate script.
 | |
| 
 | |
| 3) Generate the site's main pages:
 | |
|        xsltproc --nonet --html --output index.html site.xsl xml.html
 | |
| 
 | |
|     All of the "top-level" pages (except xmlreader.html and guidelines.html)
 | |
|     which have navigation framing, are generated from this step
 | |
| 
 | |
| 4) Generate the contents and cross-referencing pages:
 | |
|        xsltproc --nonet --html api.xsl xml.html
 | |
| 
 | |
| 5) Generate the NEWS file in the top directory:
 | |
|        xsltproc --nonet --output ../NEWS news.xsl news.html
 | |
| 
 | |
| 6) Generate the XML Software Autoupdate file libxml2.xsa:
 | |
|        make libxml2.xsa, or,
 | |
|        xsltproc --nonet --output libxml2.xsa xsa.xsl news.html
 | |
| 
 | |
| 7) Manually generate xmlcatalog.1 and xmllint.1 using manpages/docbook.xsl
 | |
|    stylesheet in docbook stylesheets. "make all" also takes care of this.
 | |
| 
 | |
|   After these steps have been done, the documentation is complete.
 | |
| The search engine is then set up using the script index.py, using
 | |
| libxml2-api.xml, the HTML web pages generated above, and the HTML
 | |
| mailing list archives at gnome.org.
 | |
| 
 | |
| 
 | |
| Last update:  30 November 2003
 | |
| 
 |