KickJava   Java API By Example, From Geeks To Geeks.

Java > Open Source Codes > sax > DTDReader


1 /*
2  * The Apache Software License, Version 1.1
3  *
4  *
5  * Copyright (c) 1999 The Apache Software Foundation. All rights
6  * reserved.
7  *
8  * Redistribution and use in source and binary forms, with or without
9  * modification, are permitted provided that the following conditions
10  * are met:
11  *
12  * 1. Redistributions of source code must retain the above copyright
13  * notice, this list of conditions and the following disclaimer.
14  *
15  * 2. Redistributions in binary form must reproduce the above copyright
16  * notice, this list of conditions and the following disclaimer in
17  * the documentation and/or other materials provided with the
18  * distribution.
19  *
20  * 3. The end-user documentation included with the redistribution,
21  * if any, must include the following acknowledgment:
22  * "This product includes software developed by the
23  * Apache Software Foundation (http://www.apache.org/)."
24  * Alternately, this acknowledgment may appear in the software itself,
25  * if and wherever such third-party acknowledgments normally appear.
26  *
27  * 4. The names "Xerces" and "Apache Software Foundation" must
28  * not be used to endorse or promote products derived from this
29  * software without prior written permission. For written
30  * permission, please contact apache@apache.org.
31  *
32  * 5. Products derived from this software may not be called "Apache",
33  * nor may "Apache" appear in their name, without prior written
34  * permission of the Apache Software Foundation.
35  *
36  * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
37  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
38  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
39  * DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
40  * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
41  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
42  * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
43  * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
44  * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
45  * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
46  * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
47  * SUCH DAMAGE.
48  * ====================================================================
49  *
50  * This software consists of voluntary contributions made by many
51  * individuals on behalf of the Apache Software Foundation and was
52  * originally based on software copyright (c) 1999, International
53  * Business Machines, Inc., http://www.apache.org. For more
54  * information on the Apache Software Foundation, please see
55  * <http://www.apache.org/>.
56  */

57
58
59 package sax;
60
61 import org.enhydra.apache.xerces.parsers.SAXParser;
62 import org.xml.sax.SAXException JavaDoc;
63 import org.xml.sax.ext.DeclHandler JavaDoc;
64
65
66
67
68 /**
69  * Provides DTD Grammar information
70  * This is a very simple program that shows DTD access
71  * through the usage of the DeclHandler interface.
72  *
73  * @author Jeffrey Rodriguez
74  * @version $Id: DTDReader.java,v 1.2 2005/01/26 08:28:44 jkjome Exp $
75  * @see org.xml.sax.ext.DeclHandler
76  */

77 public class DTDReader implements DeclHandler JavaDoc {
78
79     /**
80      * AttributeDecl
81      *
82      * @param eName
83      * @param aName
84      * @param type
85      * @param valueDefault
86      * @param value
87      * @exception SAXException
88      */

89     public void attributeDecl( String JavaDoc eName, String JavaDoc aName,String JavaDoc
90                                type, String JavaDoc valueDefault, String JavaDoc value ) throws SAXException JavaDoc {
91         System.out.println( "\nAttributeDecl:" );
92         System.out.println( " eName = " + eName );
93         System.out.println( " aName = " + aName );
94         System.out.println( " type = " + type );
95         System.out.println( " valueDefault = " + valueDefault );
96         System.out.println( " value = " + value );
97
98     }
99
100     /**
101      * ElementDecl
102      *
103      * @param name
104      * @param model
105      * @exception SAXException
106      */

107     public void elementDecl( String JavaDoc name, String JavaDoc model ) throws SAXException JavaDoc {
108         System.out.println( "\nElementDecl = " + name );
109         System.out.println( " ContentModel =" + model +"\n" );
110     }
111
112     /**
113      * Internal Entity Decl
114      *
115      * @param name
116      * @param value
117      * @exception SAXException
118      */

119     public void internalEntityDecl (String JavaDoc name, String JavaDoc value)
120     throws SAXException JavaDoc {
121         System.out.println( "\nInternalEntityDecl" );
122         System.out.println( " Name = " + name+ ",value = " + value );
123
124     }
125
126     /**
127      * External Entity Decl
128      *
129      * @param name
130      * @param publicId
131      * @param systemId
132      * @exception SAXException
133      */

134     public void externalEntityDecl (String JavaDoc name, String JavaDoc publicId,
135                                      String JavaDoc systemId)
136     throws SAXException JavaDoc {
137         System.out.println( "\nExternalEntityDecl" );
138         System.out.println( " Name = " + name + "publicId = " + publicId + "systemId = " + systemId );
139     }
140
141
142
143
144     /**
145      * driver
146      *
147      * @param argv
148      */

149     public static void main( String JavaDoc[] argv ) {
150
151         if ( argv.length != 1 ) {
152
153             System.out.println( "Error: Usage: java -cp ... DTDReader myxmlfile" );
154             System.exit(0);
155         }
156
157         DTDReader handler = new DTDReader();
158
159         try {
160             SAXParser parser = new SAXParser( );
161             parser.setProperty( "http://xml.org/sax/properties/declaration-handler", handler );
162             System.out.println( "argv = " + argv[0] );
163             parser.parse( argv[0] );
164
165         } catch ( Exception JavaDoc ex ){
166             ex.printStackTrace();
167         }
168
169     }
170
171 }
172
Popular Tags