View Javadoc

1   /*
2    =================== DO NOT EDIT THIS FILE ====================
3    Generated by Modello 1.4.1 on 2012-04-13 21:33:05,
4    any modifications will be overwritten.
5    ==============================================================
6    */
7   
8   package org.apache.maven.doxia.document.io.xpp3;
9   
10    //---------------------------------/
11   //- Imported classes and packages -/
12  //---------------------------------/
13  
14  import java.io.IOException;
15  import java.io.InputStream;
16  import java.io.Reader;
17  import java.text.DateFormat;
18  import java.util.Locale;
19  import org.apache.maven.doxia.document.DocumentAuthor;
20  import org.apache.maven.doxia.document.DocumentCover;
21  import org.apache.maven.doxia.document.DocumentHyperlinkBehaviour;
22  import org.apache.maven.doxia.document.DocumentMeta;
23  import org.apache.maven.doxia.document.DocumentModel;
24  import org.apache.maven.doxia.document.DocumentStatistic;
25  import org.apache.maven.doxia.document.DocumentTOC;
26  import org.apache.maven.doxia.document.DocumentTOCItem;
27  import org.apache.maven.doxia.document.DocumentTemplate;
28  import org.codehaus.plexus.util.ReaderFactory;
29  import org.codehaus.plexus.util.xml.pull.MXParser;
30  import org.codehaus.plexus.util.xml.pull.XmlPullParser;
31  import org.codehaus.plexus.util.xml.pull.XmlPullParserException;
32  
33  /**
34   * Class DocumentXpp3Reader.
35   * 
36   * @version $Revision$ $Date$
37   */
38  @SuppressWarnings( "all" )
39  public class DocumentXpp3Reader
40  {
41  
42        //--------------------------/
43       //- Class/Member Variables -/
44      //--------------------------/
45  
46      /**
47       * If set the parser will be loaded with all single characters
48       * from the XHTML specification.
49       * The entities used:
50       * <ul>
51       * <li>http://www.w3.org/TR/xhtml1/DTD/xhtml-lat1.ent</li>
52       * <li>http://www.w3.org/TR/xhtml1/DTD/xhtml-special.ent</li>
53       * <li>http://www.w3.org/TR/xhtml1/DTD/xhtml-symbol.ent</li>
54       * </ul>
55       */
56      private boolean addDefaultEntities = true;
57  
58  
59        //-----------/
60       //- Methods -/
61      //-----------/
62  
63      /**
64       * Method checkFieldWithDuplicate.
65       * 
66       * @param parser
67       * @param parsed
68       * @param alias
69       * @param tagName
70       * @throws XmlPullParserException
71       * @return boolean
72       */
73      private boolean checkFieldWithDuplicate( XmlPullParser parser, String tagName, String alias, java.util.Set parsed )
74          throws XmlPullParserException
75      {
76          if ( !( parser.getName().equals( tagName ) || parser.getName().equals( alias ) ) )
77          {
78              return false;
79          }
80          if ( !parsed.add( tagName ) )
81          {
82              throw new XmlPullParserException( "Duplicated tag: '" + tagName + "'", parser, null );
83          }
84          return true;
85      } //-- boolean checkFieldWithDuplicate( XmlPullParser, String, String, java.util.Set )
86  
87      /**
88       * Method checkUnknownAttribute.
89       * 
90       * @param parser
91       * @param strict
92       * @param tagName
93       * @param attribute
94       * @throws XmlPullParserException
95       * @throws IOException
96       */
97      private void checkUnknownAttribute( XmlPullParser parser, String attribute, String tagName, boolean strict )
98          throws XmlPullParserException, IOException
99      {
100         // strictXmlAttributes = true for model: if strict == true, not only elements are checked but attributes too
101         if ( strict )
102         {
103             throw new XmlPullParserException( "Unknown attribute '" + attribute + "' for tag '" + tagName + "'", parser, null );
104         }
105     } //-- void checkUnknownAttribute( XmlPullParser, String, String, boolean )
106 
107     /**
108      * Method checkUnknownElement.
109      * 
110      * @param parser
111      * @param strict
112      * @throws XmlPullParserException
113      * @throws IOException
114      */
115     private void checkUnknownElement( XmlPullParser parser, boolean strict )
116         throws XmlPullParserException, IOException
117     {
118         if ( strict )
119         {
120             throw new XmlPullParserException( "Unrecognised tag: '" + parser.getName() + "'", parser, null );
121         }
122 
123         for ( int unrecognizedTagCount = 1; unrecognizedTagCount > 0; )
124         {
125             int eventType = parser.next();
126             if ( eventType == XmlPullParser.START_TAG )
127             {
128                 unrecognizedTagCount++;
129             }
130             else if ( eventType == XmlPullParser.END_TAG )
131             {
132                 unrecognizedTagCount--;
133             }
134         }
135     } //-- void checkUnknownElement( XmlPullParser, boolean )
136 
137     /**
138      * Returns the state of the "add default entities" flag.
139      * 
140      * @return boolean
141      */
142     public boolean getAddDefaultEntities()
143     {
144         return addDefaultEntities;
145     } //-- boolean getAddDefaultEntities()
146 
147     /**
148      * Method getBooleanValue.
149      * 
150      * @param s
151      * @param parser
152      * @param attribute
153      * @throws XmlPullParserException
154      * @return boolean
155      */
156     private boolean getBooleanValue( String s, String attribute, XmlPullParser parser )
157         throws XmlPullParserException
158     {
159         return getBooleanValue( s, attribute, parser, null );
160     } //-- boolean getBooleanValue( String, String, XmlPullParser )
161 
162     /**
163      * Method getBooleanValue.
164      * 
165      * @param s
166      * @param defaultValue
167      * @param parser
168      * @param attribute
169      * @throws XmlPullParserException
170      * @return boolean
171      */
172     private boolean getBooleanValue( String s, String attribute, XmlPullParser parser, String defaultValue )
173         throws XmlPullParserException
174     {
175         if ( s != null && s.length() != 0 )
176         {
177             return Boolean.valueOf( s ).booleanValue();
178         }
179         if ( defaultValue != null )
180         {
181             return Boolean.valueOf( defaultValue ).booleanValue();
182         }
183         return false;
184     } //-- boolean getBooleanValue( String, String, XmlPullParser, String )
185 
186     /**
187      * Method getByteValue.
188      * 
189      * @param s
190      * @param strict
191      * @param parser
192      * @param attribute
193      * @throws XmlPullParserException
194      * @return byte
195      */
196     private byte getByteValue( String s, String attribute, XmlPullParser parser, boolean strict )
197         throws XmlPullParserException
198     {
199         if ( s != null )
200         {
201             try
202             {
203                 return Byte.valueOf( s ).byteValue();
204             }
205             catch ( NumberFormatException nfe )
206             {
207                 if ( strict )
208                 {
209                     throw new XmlPullParserException( "Unable to parse element '" + attribute + "', must be a byte", parser, nfe );
210                 }
211             }
212         }
213         return 0;
214     } //-- byte getByteValue( String, String, XmlPullParser, boolean )
215 
216     /**
217      * Method getCharacterValue.
218      * 
219      * @param s
220      * @param parser
221      * @param attribute
222      * @throws XmlPullParserException
223      * @return char
224      */
225     private char getCharacterValue( String s, String attribute, XmlPullParser parser )
226         throws XmlPullParserException
227     {
228         if ( s != null )
229         {
230             return s.charAt( 0 );
231         }
232         return 0;
233     } //-- char getCharacterValue( String, String, XmlPullParser )
234 
235     /**
236      * Method getDateValue.
237      * 
238      * @param s
239      * @param parser
240      * @param attribute
241      * @throws XmlPullParserException
242      * @return Date
243      */
244     private java.util.Date getDateValue( String s, String attribute, XmlPullParser parser )
245         throws XmlPullParserException
246     {
247         return getDateValue( s, attribute, null, parser );
248     } //-- java.util.Date getDateValue( String, String, XmlPullParser )
249 
250     /**
251      * Method getDateValue.
252      * 
253      * @param s
254      * @param parser
255      * @param dateFormat
256      * @param attribute
257      * @throws XmlPullParserException
258      * @return Date
259      */
260     private java.util.Date getDateValue( String s, String attribute, String dateFormat, XmlPullParser parser )
261         throws XmlPullParserException
262     {
263         if ( s != null )
264         {
265             String effectiveDateFormat = dateFormat;
266             if ( dateFormat == null )
267             {
268                 effectiveDateFormat = "yyyy-MM-dd'T'HH:mm:ss.SSS";
269             }
270             if ( "long".equals( effectiveDateFormat ) )
271             {
272                 try
273                 {
274                     return new java.util.Date( Long.parseLong( s ) );
275                 }
276                 catch ( NumberFormatException e )
277                 {
278                     throw new XmlPullParserException( e.getMessage(), parser, e );
279                 }
280             }
281             else
282             {
283                 try
284                 {
285                     DateFormat dateParser = new java.text.SimpleDateFormat( effectiveDateFormat, Locale.US );
286                     return dateParser.parse( s );
287                 }
288                 catch ( java.text.ParseException e )
289                 {
290                     throw new XmlPullParserException( e.getMessage(), parser, e );
291                 }
292             }
293         }
294         return null;
295     } //-- java.util.Date getDateValue( String, String, String, XmlPullParser )
296 
297     /**
298      * Method getDoubleValue.
299      * 
300      * @param s
301      * @param strict
302      * @param parser
303      * @param attribute
304      * @throws XmlPullParserException
305      * @return double
306      */
307     private double getDoubleValue( String s, String attribute, XmlPullParser parser, boolean strict )
308         throws XmlPullParserException
309     {
310         if ( s != null )
311         {
312             try
313             {
314                 return Double.valueOf( s ).doubleValue();
315             }
316             catch ( NumberFormatException nfe )
317             {
318                 if ( strict )
319                 {
320                     throw new XmlPullParserException( "Unable to parse element '" + attribute + "', must be a floating point number", parser, nfe );
321                 }
322             }
323         }
324         return 0;
325     } //-- double getDoubleValue( String, String, XmlPullParser, boolean )
326 
327     /**
328      * Method getFloatValue.
329      * 
330      * @param s
331      * @param strict
332      * @param parser
333      * @param attribute
334      * @throws XmlPullParserException
335      * @return float
336      */
337     private float getFloatValue( String s, String attribute, XmlPullParser parser, boolean strict )
338         throws XmlPullParserException
339     {
340         if ( s != null )
341         {
342             try
343             {
344                 return Float.valueOf( s ).floatValue();
345             }
346             catch ( NumberFormatException nfe )
347             {
348                 if ( strict )
349                 {
350                     throw new XmlPullParserException( "Unable to parse element '" + attribute + "', must be a floating point number", parser, nfe );
351                 }
352             }
353         }
354         return 0;
355     } //-- float getFloatValue( String, String, XmlPullParser, boolean )
356 
357     /**
358      * Method getIntegerValue.
359      * 
360      * @param s
361      * @param strict
362      * @param parser
363      * @param attribute
364      * @throws XmlPullParserException
365      * @return int
366      */
367     private int getIntegerValue( String s, String attribute, XmlPullParser parser, boolean strict )
368         throws XmlPullParserException
369     {
370         if ( s != null )
371         {
372             try
373             {
374                 return Integer.valueOf( s ).intValue();
375             }
376             catch ( NumberFormatException nfe )
377             {
378                 if ( strict )
379                 {
380                     throw new XmlPullParserException( "Unable to parse element '" + attribute + "', must be an integer", parser, nfe );
381                 }
382             }
383         }
384         return 0;
385     } //-- int getIntegerValue( String, String, XmlPullParser, boolean )
386 
387     /**
388      * Method getLongValue.
389      * 
390      * @param s
391      * @param strict
392      * @param parser
393      * @param attribute
394      * @throws XmlPullParserException
395      * @return long
396      */
397     private long getLongValue( String s, String attribute, XmlPullParser parser, boolean strict )
398         throws XmlPullParserException
399     {
400         if ( s != null )
401         {
402             try
403             {
404                 return Long.valueOf( s ).longValue();
405             }
406             catch ( NumberFormatException nfe )
407             {
408                 if ( strict )
409                 {
410                     throw new XmlPullParserException( "Unable to parse element '" + attribute + "', must be a long integer", parser, nfe );
411                 }
412             }
413         }
414         return 0;
415     } //-- long getLongValue( String, String, XmlPullParser, boolean )
416 
417     /**
418      * Method getRequiredAttributeValue.
419      * 
420      * @param s
421      * @param strict
422      * @param parser
423      * @param attribute
424      * @throws XmlPullParserException
425      * @return String
426      */
427     private String getRequiredAttributeValue( String s, String attribute, XmlPullParser parser, boolean strict )
428         throws XmlPullParserException
429     {
430         if ( s == null )
431         {
432             if ( strict )
433             {
434                 throw new XmlPullParserException( "Missing required value for attribute '" + attribute + "'", parser, null );
435             }
436         }
437         return s;
438     } //-- String getRequiredAttributeValue( String, String, XmlPullParser, boolean )
439 
440     /**
441      * Method getShortValue.
442      * 
443      * @param s
444      * @param strict
445      * @param parser
446      * @param attribute
447      * @throws XmlPullParserException
448      * @return short
449      */
450     private short getShortValue( String s, String attribute, XmlPullParser parser, boolean strict )
451         throws XmlPullParserException
452     {
453         if ( s != null )
454         {
455             try
456             {
457                 return Short.valueOf( s ).shortValue();
458             }
459             catch ( NumberFormatException nfe )
460             {
461                 if ( strict )
462                 {
463                     throw new XmlPullParserException( "Unable to parse element '" + attribute + "', must be a short integer", parser, nfe );
464                 }
465             }
466         }
467         return 0;
468     } //-- short getShortValue( String, String, XmlPullParser, boolean )
469 
470     /**
471      * Method getTrimmedValue.
472      * 
473      * @param s
474      * @return String
475      */
476     private String getTrimmedValue( String s )
477     {
478         if ( s != null )
479         {
480             s = s.trim();
481         }
482         return s;
483     } //-- String getTrimmedValue( String )
484 
485     /**
486      * Method initParser.
487      * 
488      * @param parser
489      * @throws XmlPullParserException
490      */
491     private void initParser( XmlPullParser parser )
492         throws XmlPullParserException
493     {
494         if ( addDefaultEntities )
495         {
496             // ----------------------------------------------------------------------
497             // Latin 1 entities
498             // ----------------------------------------------------------------------
499 
500             parser.defineEntityReplacementText( "nbsp", "\u00a0" );
501             parser.defineEntityReplacementText( "iexcl", "\u00a1" );
502             parser.defineEntityReplacementText( "cent", "\u00a2" );
503             parser.defineEntityReplacementText( "pound", "\u00a3" );
504             parser.defineEntityReplacementText( "curren", "\u00a4" );
505             parser.defineEntityReplacementText( "yen", "\u00a5" );
506             parser.defineEntityReplacementText( "brvbar", "\u00a6" );
507             parser.defineEntityReplacementText( "sect", "\u00a7" );
508             parser.defineEntityReplacementText( "uml", "\u00a8" );
509             parser.defineEntityReplacementText( "copy", "\u00a9" );
510             parser.defineEntityReplacementText( "ordf", "\u00aa" );
511             parser.defineEntityReplacementText( "laquo", "\u00ab" );
512             parser.defineEntityReplacementText( "not", "\u00ac" );
513             parser.defineEntityReplacementText( "shy", "\u00ad" );
514             parser.defineEntityReplacementText( "reg", "\u00ae" );
515             parser.defineEntityReplacementText( "macr", "\u00af" );
516             parser.defineEntityReplacementText( "deg", "\u00b0" );
517             parser.defineEntityReplacementText( "plusmn", "\u00b1" );
518             parser.defineEntityReplacementText( "sup2", "\u00b2" );
519             parser.defineEntityReplacementText( "sup3", "\u00b3" );
520             parser.defineEntityReplacementText( "acute", "\u00b4" );
521             parser.defineEntityReplacementText( "micro", "\u00b5" );
522             parser.defineEntityReplacementText( "para", "\u00b6" );
523             parser.defineEntityReplacementText( "middot", "\u00b7" );
524             parser.defineEntityReplacementText( "cedil", "\u00b8" );
525             parser.defineEntityReplacementText( "sup1", "\u00b9" );
526             parser.defineEntityReplacementText( "ordm", "\u00ba" );
527             parser.defineEntityReplacementText( "raquo", "\u00bb" );
528             parser.defineEntityReplacementText( "frac14", "\u00bc" );
529             parser.defineEntityReplacementText( "frac12", "\u00bd" );
530             parser.defineEntityReplacementText( "frac34", "\u00be" );
531             parser.defineEntityReplacementText( "iquest", "\u00bf" );
532             parser.defineEntityReplacementText( "Agrave", "\u00c0" );
533             parser.defineEntityReplacementText( "Aacute", "\u00c1" );
534             parser.defineEntityReplacementText( "Acirc", "\u00c2" );
535             parser.defineEntityReplacementText( "Atilde", "\u00c3" );
536             parser.defineEntityReplacementText( "Auml", "\u00c4" );
537             parser.defineEntityReplacementText( "Aring", "\u00c5" );
538             parser.defineEntityReplacementText( "AElig", "\u00c6" );
539             parser.defineEntityReplacementText( "Ccedil", "\u00c7" );
540             parser.defineEntityReplacementText( "Egrave", "\u00c8" );
541             parser.defineEntityReplacementText( "Eacute", "\u00c9" );
542             parser.defineEntityReplacementText( "Ecirc", "\u00ca" );
543             parser.defineEntityReplacementText( "Euml", "\u00cb" );
544             parser.defineEntityReplacementText( "Igrave", "\u00cc" );
545             parser.defineEntityReplacementText( "Iacute", "\u00cd" );
546             parser.defineEntityReplacementText( "Icirc", "\u00ce" );
547             parser.defineEntityReplacementText( "Iuml", "\u00cf" );
548             parser.defineEntityReplacementText( "ETH", "\u00d0" );
549             parser.defineEntityReplacementText( "Ntilde", "\u00d1" );
550             parser.defineEntityReplacementText( "Ograve", "\u00d2" );
551             parser.defineEntityReplacementText( "Oacute", "\u00d3" );
552             parser.defineEntityReplacementText( "Ocirc", "\u00d4" );
553             parser.defineEntityReplacementText( "Otilde", "\u00d5" );
554             parser.defineEntityReplacementText( "Ouml", "\u00d6" );
555             parser.defineEntityReplacementText( "times", "\u00d7" );
556             parser.defineEntityReplacementText( "Oslash", "\u00d8" );
557             parser.defineEntityReplacementText( "Ugrave", "\u00d9" );
558             parser.defineEntityReplacementText( "Uacute", "\u00da" );
559             parser.defineEntityReplacementText( "Ucirc", "\u00db" );
560             parser.defineEntityReplacementText( "Uuml", "\u00dc" );
561             parser.defineEntityReplacementText( "Yacute", "\u00dd" );
562             parser.defineEntityReplacementText( "THORN", "\u00de" );
563             parser.defineEntityReplacementText( "szlig", "\u00df" );
564             parser.defineEntityReplacementText( "agrave", "\u00e0" );
565             parser.defineEntityReplacementText( "aacute", "\u00e1" );
566             parser.defineEntityReplacementText( "acirc", "\u00e2" );
567             parser.defineEntityReplacementText( "atilde", "\u00e3" );
568             parser.defineEntityReplacementText( "auml", "\u00e4" );
569             parser.defineEntityReplacementText( "aring", "\u00e5" );
570             parser.defineEntityReplacementText( "aelig", "\u00e6" );
571             parser.defineEntityReplacementText( "ccedil", "\u00e7" );
572             parser.defineEntityReplacementText( "egrave", "\u00e8" );
573             parser.defineEntityReplacementText( "eacute", "\u00e9" );
574             parser.defineEntityReplacementText( "ecirc", "\u00ea" );
575             parser.defineEntityReplacementText( "euml", "\u00eb" );
576             parser.defineEntityReplacementText( "igrave", "\u00ec" );
577             parser.defineEntityReplacementText( "iacute", "\u00ed" );
578             parser.defineEntityReplacementText( "icirc", "\u00ee" );
579             parser.defineEntityReplacementText( "iuml", "\u00ef" );
580             parser.defineEntityReplacementText( "eth", "\u00f0" );
581             parser.defineEntityReplacementText( "ntilde", "\u00f1" );
582             parser.defineEntityReplacementText( "ograve", "\u00f2" );
583             parser.defineEntityReplacementText( "oacute", "\u00f3" );
584             parser.defineEntityReplacementText( "ocirc", "\u00f4" );
585             parser.defineEntityReplacementText( "otilde", "\u00f5" );
586             parser.defineEntityReplacementText( "ouml", "\u00f6" );
587             parser.defineEntityReplacementText( "divide", "\u00f7" );
588             parser.defineEntityReplacementText( "oslash", "\u00f8" );
589             parser.defineEntityReplacementText( "ugrave", "\u00f9" );
590             parser.defineEntityReplacementText( "uacute", "\u00fa" );
591             parser.defineEntityReplacementText( "ucirc", "\u00fb" );
592             parser.defineEntityReplacementText( "uuml", "\u00fc" );
593             parser.defineEntityReplacementText( "yacute", "\u00fd" );
594             parser.defineEntityReplacementText( "thorn", "\u00fe" );
595             parser.defineEntityReplacementText( "yuml", "\u00ff" );
596 
597             // ----------------------------------------------------------------------
598             // Special entities
599             // ----------------------------------------------------------------------
600 
601             parser.defineEntityReplacementText( "OElig", "\u0152" );
602             parser.defineEntityReplacementText( "oelig", "\u0153" );
603             parser.defineEntityReplacementText( "Scaron", "\u0160" );
604             parser.defineEntityReplacementText( "scaron", "\u0161" );
605             parser.defineEntityReplacementText( "Yuml", "\u0178" );
606             parser.defineEntityReplacementText( "circ", "\u02c6" );
607             parser.defineEntityReplacementText( "tilde", "\u02dc" );
608             parser.defineEntityReplacementText( "ensp", "\u2002" );
609             parser.defineEntityReplacementText( "emsp", "\u2003" );
610             parser.defineEntityReplacementText( "thinsp", "\u2009" );
611             parser.defineEntityReplacementText( "zwnj", "\u200c" );
612             parser.defineEntityReplacementText( "zwj", "\u200d" );
613             parser.defineEntityReplacementText( "lrm", "\u200e" );
614             parser.defineEntityReplacementText( "rlm", "\u200f" );
615             parser.defineEntityReplacementText( "ndash", "\u2013" );
616             parser.defineEntityReplacementText( "mdash", "\u2014" );
617             parser.defineEntityReplacementText( "lsquo", "\u2018" );
618             parser.defineEntityReplacementText( "rsquo", "\u2019" );
619             parser.defineEntityReplacementText( "sbquo", "\u201a" );
620             parser.defineEntityReplacementText( "ldquo", "\u201c" );
621             parser.defineEntityReplacementText( "rdquo", "\u201d" );
622             parser.defineEntityReplacementText( "bdquo", "\u201e" );
623             parser.defineEntityReplacementText( "dagger", "\u2020" );
624             parser.defineEntityReplacementText( "Dagger", "\u2021" );
625             parser.defineEntityReplacementText( "permil", "\u2030" );
626             parser.defineEntityReplacementText( "lsaquo", "\u2039" );
627             parser.defineEntityReplacementText( "rsaquo", "\u203a" );
628             parser.defineEntityReplacementText( "euro", "\u20ac" );
629 
630             // ----------------------------------------------------------------------
631             // Symbol entities
632             // ----------------------------------------------------------------------
633 
634             parser.defineEntityReplacementText( "fnof", "\u0192" );
635             parser.defineEntityReplacementText( "Alpha", "\u0391" );
636             parser.defineEntityReplacementText( "Beta", "\u0392" );
637             parser.defineEntityReplacementText( "Gamma", "\u0393" );
638             parser.defineEntityReplacementText( "Delta", "\u0394" );
639             parser.defineEntityReplacementText( "Epsilon", "\u0395" );
640             parser.defineEntityReplacementText( "Zeta", "\u0396" );
641             parser.defineEntityReplacementText( "Eta", "\u0397" );
642             parser.defineEntityReplacementText( "Theta", "\u0398" );
643             parser.defineEntityReplacementText( "Iota", "\u0399" );
644             parser.defineEntityReplacementText( "Kappa", "\u039a" );
645             parser.defineEntityReplacementText( "Lambda", "\u039b" );
646             parser.defineEntityReplacementText( "Mu", "\u039c" );
647             parser.defineEntityReplacementText( "Nu", "\u039d" );
648             parser.defineEntityReplacementText( "Xi", "\u039e" );
649             parser.defineEntityReplacementText( "Omicron", "\u039f" );
650             parser.defineEntityReplacementText( "Pi", "\u03a0" );
651             parser.defineEntityReplacementText( "Rho", "\u03a1" );
652             parser.defineEntityReplacementText( "Sigma", "\u03a3" );
653             parser.defineEntityReplacementText( "Tau", "\u03a4" );
654             parser.defineEntityReplacementText( "Upsilon", "\u03a5" );
655             parser.defineEntityReplacementText( "Phi", "\u03a6" );
656             parser.defineEntityReplacementText( "Chi", "\u03a7" );
657             parser.defineEntityReplacementText( "Psi", "\u03a8" );
658             parser.defineEntityReplacementText( "Omega", "\u03a9" );
659             parser.defineEntityReplacementText( "alpha", "\u03b1" );
660             parser.defineEntityReplacementText( "beta", "\u03b2" );
661             parser.defineEntityReplacementText( "gamma", "\u03b3" );
662             parser.defineEntityReplacementText( "delta", "\u03b4" );
663             parser.defineEntityReplacementText( "epsilon", "\u03b5" );
664             parser.defineEntityReplacementText( "zeta", "\u03b6" );
665             parser.defineEntityReplacementText( "eta", "\u03b7" );
666             parser.defineEntityReplacementText( "theta", "\u03b8" );
667             parser.defineEntityReplacementText( "iota", "\u03b9" );
668             parser.defineEntityReplacementText( "kappa", "\u03ba" );
669             parser.defineEntityReplacementText( "lambda", "\u03bb" );
670             parser.defineEntityReplacementText( "mu", "\u03bc" );
671             parser.defineEntityReplacementText( "nu", "\u03bd" );
672             parser.defineEntityReplacementText( "xi", "\u03be" );
673             parser.defineEntityReplacementText( "omicron", "\u03bf" );
674             parser.defineEntityReplacementText( "pi", "\u03c0" );
675             parser.defineEntityReplacementText( "rho", "\u03c1" );
676             parser.defineEntityReplacementText( "sigmaf", "\u03c2" );
677             parser.defineEntityReplacementText( "sigma", "\u03c3" );
678             parser.defineEntityReplacementText( "tau", "\u03c4" );
679             parser.defineEntityReplacementText( "upsilon", "\u03c5" );
680             parser.defineEntityReplacementText( "phi", "\u03c6" );
681             parser.defineEntityReplacementText( "chi", "\u03c7" );
682             parser.defineEntityReplacementText( "psi", "\u03c8" );
683             parser.defineEntityReplacementText( "omega", "\u03c9" );
684             parser.defineEntityReplacementText( "thetasym", "\u03d1" );
685             parser.defineEntityReplacementText( "upsih", "\u03d2" );
686             parser.defineEntityReplacementText( "piv", "\u03d6" );
687             parser.defineEntityReplacementText( "bull", "\u2022" );
688             parser.defineEntityReplacementText( "hellip", "\u2026" );
689             parser.defineEntityReplacementText( "prime", "\u2032" );
690             parser.defineEntityReplacementText( "Prime", "\u2033" );
691             parser.defineEntityReplacementText( "oline", "\u203e" );
692             parser.defineEntityReplacementText( "frasl", "\u2044" );
693             parser.defineEntityReplacementText( "weierp", "\u2118" );
694             parser.defineEntityReplacementText( "image", "\u2111" );
695             parser.defineEntityReplacementText( "real", "\u211c" );
696             parser.defineEntityReplacementText( "trade", "\u2122" );
697             parser.defineEntityReplacementText( "alefsym", "\u2135" );
698             parser.defineEntityReplacementText( "larr", "\u2190" );
699             parser.defineEntityReplacementText( "uarr", "\u2191" );
700             parser.defineEntityReplacementText( "rarr", "\u2192" );
701             parser.defineEntityReplacementText( "darr", "\u2193" );
702             parser.defineEntityReplacementText( "harr", "\u2194" );
703             parser.defineEntityReplacementText( "crarr", "\u21b5" );
704             parser.defineEntityReplacementText( "lArr", "\u21d0" );
705             parser.defineEntityReplacementText( "uArr", "\u21d1" );
706             parser.defineEntityReplacementText( "rArr", "\u21d2" );
707             parser.defineEntityReplacementText( "dArr", "\u21d3" );
708             parser.defineEntityReplacementText( "hArr", "\u21d4" );
709             parser.defineEntityReplacementText( "forall", "\u2200" );
710             parser.defineEntityReplacementText( "part", "\u2202" );
711             parser.defineEntityReplacementText( "exist", "\u2203" );
712             parser.defineEntityReplacementText( "empty", "\u2205" );
713             parser.defineEntityReplacementText( "nabla", "\u2207" );
714             parser.defineEntityReplacementText( "isin", "\u2208" );
715             parser.defineEntityReplacementText( "notin", "\u2209" );
716             parser.defineEntityReplacementText( "ni", "\u220b" );
717             parser.defineEntityReplacementText( "prod", "\u220f" );
718             parser.defineEntityReplacementText( "sum", "\u2211" );
719             parser.defineEntityReplacementText( "minus", "\u2212" );
720             parser.defineEntityReplacementText( "lowast", "\u2217" );
721             parser.defineEntityReplacementText( "radic", "\u221a" );
722             parser.defineEntityReplacementText( "prop", "\u221d" );
723             parser.defineEntityReplacementText( "infin", "\u221e" );
724             parser.defineEntityReplacementText( "ang", "\u2220" );
725             parser.defineEntityReplacementText( "and", "\u2227" );
726             parser.defineEntityReplacementText( "or", "\u2228" );
727             parser.defineEntityReplacementText( "cap", "\u2229" );
728             parser.defineEntityReplacementText( "cup", "\u222a" );
729             parser.defineEntityReplacementText( "int", "\u222b" );
730             parser.defineEntityReplacementText( "there4", "\u2234" );
731             parser.defineEntityReplacementText( "sim", "\u223c" );
732             parser.defineEntityReplacementText( "cong", "\u2245" );
733             parser.defineEntityReplacementText( "asymp", "\u2248" );
734             parser.defineEntityReplacementText( "ne", "\u2260" );
735             parser.defineEntityReplacementText( "equiv", "\u2261" );
736             parser.defineEntityReplacementText( "le", "\u2264" );
737             parser.defineEntityReplacementText( "ge", "\u2265" );
738             parser.defineEntityReplacementText( "sub", "\u2282" );
739             parser.defineEntityReplacementText( "sup", "\u2283" );
740             parser.defineEntityReplacementText( "nsub", "\u2284" );
741             parser.defineEntityReplacementText( "sube", "\u2286" );
742             parser.defineEntityReplacementText( "supe", "\u2287" );
743             parser.defineEntityReplacementText( "oplus", "\u2295" );
744             parser.defineEntityReplacementText( "otimes", "\u2297" );
745             parser.defineEntityReplacementText( "perp", "\u22a5" );
746             parser.defineEntityReplacementText( "sdot", "\u22c5" );
747             parser.defineEntityReplacementText( "lceil", "\u2308" );
748             parser.defineEntityReplacementText( "rceil", "\u2309" );
749             parser.defineEntityReplacementText( "lfloor", "\u230a" );
750             parser.defineEntityReplacementText( "rfloor", "\u230b" );
751             parser.defineEntityReplacementText( "lang", "\u2329" );
752             parser.defineEntityReplacementText( "rang", "\u232a" );
753             parser.defineEntityReplacementText( "loz", "\u25ca" );
754             parser.defineEntityReplacementText( "spades", "\u2660" );
755             parser.defineEntityReplacementText( "clubs", "\u2663" );
756             parser.defineEntityReplacementText( "hearts", "\u2665" );
757             parser.defineEntityReplacementText( "diams", "\u2666" );
758 
759         }
760     } //-- void initParser( XmlPullParser )
761 
762     /**
763      * Method nextTag.
764      * 
765      * @param parser
766      * @throws IOException
767      * @throws XmlPullParserException
768      * @return int
769      */
770     private int nextTag( XmlPullParser parser )
771         throws IOException, XmlPullParserException
772     {
773         int eventType = parser.next();
774         if ( eventType == XmlPullParser.TEXT )
775         {
776             eventType = parser.next();
777         }
778         if ( eventType != XmlPullParser.START_TAG && eventType != XmlPullParser.END_TAG )
779         {
780             throw new XmlPullParserException( "expected START_TAG or END_TAG not " + XmlPullParser.TYPES[eventType], parser, null );
781         }
782         return eventType;
783     } //-- int nextTag( XmlPullParser )
784 
785     /**
786      * Method parseDocumentAuthor.
787      * 
788      * @param parser
789      * @param strict
790      * @throws IOException
791      * @throws XmlPullParserException
792      * @return DocumentAuthor
793      */
794     private DocumentAuthor parseDocumentAuthor( XmlPullParser parser, boolean strict )
795         throws IOException, XmlPullParserException
796     {
797         String tagName = parser.getName();
798         DocumentAuthor documentAuthor = new DocumentAuthor();
799         for ( int i = parser.getAttributeCount() - 1; i >= 0; i-- )
800         {
801             String name = parser.getAttributeName( i );
802             String value = parser.getAttributeValue( i );
803 
804             if ( name.indexOf( ':' ) >= 0 )
805             {
806                 // just ignore attributes with non-default namespace (for example: xmlns:xsi)
807             }
808             else
809             {
810                 checkUnknownAttribute( parser, name, tagName, strict );
811             }
812         }
813         java.util.Set parsed = new java.util.HashSet();
814         while ( ( strict ? parser.nextTag() : nextTag( parser ) ) == XmlPullParser.START_TAG )
815         {
816             if ( checkFieldWithDuplicate( parser, "firstName", null, parsed ) )
817             {
818                 documentAuthor.setFirstName( getTrimmedValue( parser.nextText() ) );
819             }
820             else if ( checkFieldWithDuplicate( parser, "lastName", null, parsed ) )
821             {
822                 documentAuthor.setLastName( getTrimmedValue( parser.nextText() ) );
823             }
824             else if ( checkFieldWithDuplicate( parser, "name", null, parsed ) )
825             {
826                 documentAuthor.setName( getTrimmedValue( parser.nextText() ) );
827             }
828             else if ( checkFieldWithDuplicate( parser, "initials", null, parsed ) )
829             {
830                 documentAuthor.setInitials( getTrimmedValue( parser.nextText() ) );
831             }
832             else if ( checkFieldWithDuplicate( parser, "title", null, parsed ) )
833             {
834                 documentAuthor.setTitle( getTrimmedValue( parser.nextText() ) );
835             }
836             else if ( checkFieldWithDuplicate( parser, "position", null, parsed ) )
837             {
838                 documentAuthor.setPosition( getTrimmedValue( parser.nextText() ) );
839             }
840             else if ( checkFieldWithDuplicate( parser, "email", null, parsed ) )
841             {
842                 documentAuthor.setEmail( getTrimmedValue( parser.nextText() ) );
843             }
844             else if ( checkFieldWithDuplicate( parser, "phoneNumber", null, parsed ) )
845             {
846                 documentAuthor.setPhoneNumber( getTrimmedValue( parser.nextText() ) );
847             }
848             else if ( checkFieldWithDuplicate( parser, "faxNumber", null, parsed ) )
849             {
850                 documentAuthor.setFaxNumber( getTrimmedValue( parser.nextText() ) );
851             }
852             else if ( checkFieldWithDuplicate( parser, "companyName", null, parsed ) )
853             {
854                 documentAuthor.setCompanyName( getTrimmedValue( parser.nextText() ) );
855             }
856             else if ( checkFieldWithDuplicate( parser, "street", null, parsed ) )
857             {
858                 documentAuthor.setStreet( getTrimmedValue( parser.nextText() ) );
859             }
860             else if ( checkFieldWithDuplicate( parser, "city", null, parsed ) )
861             {
862                 documentAuthor.setCity( getTrimmedValue( parser.nextText() ) );
863             }
864             else if ( checkFieldWithDuplicate( parser, "postalCode", null, parsed ) )
865             {
866                 documentAuthor.setPostalCode( getTrimmedValue( parser.nextText() ) );
867             }
868             else if ( checkFieldWithDuplicate( parser, "country", null, parsed ) )
869             {
870                 documentAuthor.setCountry( getTrimmedValue( parser.nextText() ) );
871             }
872             else if ( checkFieldWithDuplicate( parser, "state", null, parsed ) )
873             {
874                 documentAuthor.setState( getTrimmedValue( parser.nextText() ) );
875             }
876             else
877             {
878                 checkUnknownElement( parser, strict );
879             }
880         }
881         return documentAuthor;
882     } //-- DocumentAuthor parseDocumentAuthor( XmlPullParser, boolean )
883 
884     /**
885      * Method parseDocumentCover.
886      * 
887      * @param parser
888      * @param strict
889      * @throws IOException
890      * @throws XmlPullParserException
891      * @return DocumentCover
892      */
893     private DocumentCover parseDocumentCover( XmlPullParser parser, boolean strict )
894         throws IOException, XmlPullParserException
895     {
896         String tagName = parser.getName();
897         DocumentCover documentCover = new DocumentCover();
898         for ( int i = parser.getAttributeCount() - 1; i >= 0; i-- )
899         {
900             String name = parser.getAttributeName( i );
901             String value = parser.getAttributeValue( i );
902 
903             if ( name.indexOf( ':' ) >= 0 )
904             {
905                 // just ignore attributes with non-default namespace (for example: xmlns:xsi)
906             }
907             else
908             {
909                 checkUnknownAttribute( parser, name, tagName, strict );
910             }
911         }
912         java.util.Set parsed = new java.util.HashSet();
913         while ( ( strict ? parser.nextTag() : nextTag( parser ) ) == XmlPullParser.START_TAG )
914         {
915             if ( checkFieldWithDuplicate( parser, "coverTitle", null, parsed ) )
916             {
917                 documentCover.setCoverTitle( getTrimmedValue( parser.nextText() ) );
918             }
919             else if ( checkFieldWithDuplicate( parser, "coverSubTitle", null, parsed ) )
920             {
921                 documentCover.setCoverSubTitle( getTrimmedValue( parser.nextText() ) );
922             }
923             else if ( checkFieldWithDuplicate( parser, "coverVersion", null, parsed ) )
924             {
925                 documentCover.setCoverVersion( getTrimmedValue( parser.nextText() ) );
926             }
927             else if ( checkFieldWithDuplicate( parser, "coverType", null, parsed ) )
928             {
929                 documentCover.setCoverType( getTrimmedValue( parser.nextText() ) );
930             }
931             else if ( checkFieldWithDuplicate( parser, "coverDate", null, parsed ) )
932             {
933                 String dateFormat = null;
934                 documentCover.setCoverDate( getDateValue( getTrimmedValue( parser.nextText() ), "coverDate", dateFormat, parser ) );
935             }
936             else if ( checkFieldWithDuplicate( parser, "coverdate", null, parsed ) )
937             {
938                 documentCover.setCoverdate( getTrimmedValue( parser.nextText() ) );
939             }
940             else if ( checkFieldWithDuplicate( parser, "authors", null, parsed ) )
941             {
942                 java.util.List authors = new java.util.ArrayList/*<DocumentAuthor>*/();
943                 documentCover.setAuthors( authors );
944                 while ( parser.nextTag() == XmlPullParser.START_TAG )
945                 {
946                     if ( "author".equals( parser.getName() ) )
947                     {
948                         authors.add( parseDocumentAuthor( parser, strict ) );
949                     }
950                     else
951                     {
952                         checkUnknownElement( parser, strict );
953                     }
954                 }
955             }
956             else if ( checkFieldWithDuplicate( parser, "author", null, parsed ) )
957             {
958                 documentCover.setAuthor( getTrimmedValue( parser.nextText() ) );
959             }
960             else if ( checkFieldWithDuplicate( parser, "projectName", null, parsed ) )
961             {
962                 documentCover.setProjectName( getTrimmedValue( parser.nextText() ) );
963             }
964             else if ( checkFieldWithDuplicate( parser, "projectLogo", null, parsed ) )
965             {
966                 documentCover.setProjectLogo( getTrimmedValue( parser.nextText() ) );
967             }
968             else if ( checkFieldWithDuplicate( parser, "companyName", null, parsed ) )
969             {
970                 documentCover.setCompanyName( getTrimmedValue( parser.nextText() ) );
971             }
972             else if ( checkFieldWithDuplicate( parser, "companyLogo", null, parsed ) )
973             {
974                 documentCover.setCompanyLogo( getTrimmedValue( parser.nextText() ) );
975             }
976             else
977             {
978                 checkUnknownElement( parser, strict );
979             }
980         }
981         return documentCover;
982     } //-- DocumentCover parseDocumentCover( XmlPullParser, boolean )
983 
984     /**
985      * Method parseDocumentHyperlinkBehaviour.
986      * 
987      * @param parser
988      * @param strict
989      * @throws IOException
990      * @throws XmlPullParserException
991      * @return DocumentHyperlinkBehaviour
992      */
993     private DocumentHyperlinkBehaviour parseDocumentHyperlinkBehaviour( XmlPullParser parser, boolean strict )
994         throws IOException, XmlPullParserException
995     {
996         String tagName = parser.getName();
997         DocumentHyperlinkBehaviour documentHyperlinkBehaviour = new DocumentHyperlinkBehaviour();
998         for ( int i = parser.getAttributeCount() - 1; i >= 0; i-- )
999         {
1000             String name = parser.getAttributeName( i );
1001             String value = parser.getAttributeValue( i );
1002 
1003             if ( name.indexOf( ':' ) >= 0 )
1004             {
1005                 // just ignore attributes with non-default namespace (for example: xmlns:xsi)
1006             }
1007             else if ( "targetFrame".equals( name ) )
1008             {
1009                 documentHyperlinkBehaviour.setTargetFrame( getTrimmedValue( value ) );
1010             }
1011             else
1012             {
1013                 checkUnknownAttribute( parser, name, tagName, strict );
1014             }
1015         }
1016         java.util.Set parsed = new java.util.HashSet();
1017         while ( ( strict ? parser.nextTag() : nextTag( parser ) ) == XmlPullParser.START_TAG )
1018         {
1019             checkUnknownElement( parser, strict );
1020         }
1021         return documentHyperlinkBehaviour;
1022     } //-- DocumentHyperlinkBehaviour parseDocumentHyperlinkBehaviour( XmlPullParser, boolean )
1023 
1024     /**
1025      * Method parseDocumentMeta.
1026      * 
1027      * @param parser
1028      * @param strict
1029      * @throws IOException
1030      * @throws XmlPullParserException
1031      * @return DocumentMeta
1032      */
1033     private DocumentMeta parseDocumentMeta( XmlPullParser parser, boolean strict )
1034         throws IOException, XmlPullParserException
1035     {
1036         String tagName = parser.getName();
1037         DocumentMeta documentMeta = new DocumentMeta();
1038         for ( int i = parser.getAttributeCount() - 1; i >= 0; i-- )
1039         {
1040             String name = parser.getAttributeName( i );
1041             String value = parser.getAttributeValue( i );
1042 
1043             if ( name.indexOf( ':' ) >= 0 )
1044             {
1045                 // just ignore attributes with non-default namespace (for example: xmlns:xsi)
1046             }
1047             else
1048             {
1049                 checkUnknownAttribute( parser, name, tagName, strict );
1050             }
1051         }
1052         java.util.Set parsed = new java.util.HashSet();
1053         while ( ( strict ? parser.nextTag() : nextTag( parser ) ) == XmlPullParser.START_TAG )
1054         {
1055             if ( checkFieldWithDuplicate( parser, "title", null, parsed ) )
1056             {
1057                 documentMeta.setTitle( getTrimmedValue( parser.nextText() ) );
1058             }
1059             else if ( checkFieldWithDuplicate( parser, "author", null, parsed ) )
1060             {
1061                 documentMeta.setAuthor( getTrimmedValue( parser.nextText() ) );
1062             }
1063             else if ( checkFieldWithDuplicate( parser, "authors", null, parsed ) )
1064             {
1065                 java.util.List authors = new java.util.ArrayList/*<DocumentAuthor>*/();
1066                 documentMeta.setAuthors( authors );
1067                 while ( parser.nextTag() == XmlPullParser.START_TAG )
1068                 {
1069                     if ( "author".equals( parser.getName() ) )
1070                     {
1071                         authors.add( parseDocumentAuthor( parser, strict ) );
1072                     }
1073                     else
1074                     {
1075                         checkUnknownElement( parser, strict );
1076                     }
1077                 }
1078             }
1079             else if ( checkFieldWithDuplicate( parser, "subject", null, parsed ) )
1080             {
1081                 documentMeta.setSubject( getTrimmedValue( parser.nextText() ) );
1082             }
1083             else if ( checkFieldWithDuplicate( parser, "keywords", null, parsed ) )
1084             {
1085                 documentMeta.setKeywords( getTrimmedValue( parser.nextText() ) );
1086             }
1087             else if ( checkFieldWithDuplicate( parser, "keyWords", null, parsed ) )
1088             {
1089                 java.util.List keyWords = new java.util.ArrayList/*<String>*/();
1090                 documentMeta.setKeyWords( keyWords );
1091                 while ( parser.nextTag() == XmlPullParser.START_TAG )
1092                 {
1093                     if ( "keyWord".equals( parser.getName() ) )
1094                     {
1095                         keyWords.add( getTrimmedValue( parser.nextText() ) );
1096                     }
1097                     else
1098                     {
1099                         checkUnknownElement( parser, strict );
1100                     }
1101                 }
1102             }
1103             else if ( checkFieldWithDuplicate( parser, "pageSize", null, parsed ) )
1104             {
1105                 documentMeta.setPageSize( getTrimmedValue( parser.nextText() ) );
1106             }
1107             else if ( checkFieldWithDuplicate( parser, "generator", null, parsed ) )
1108             {
1109                 documentMeta.setGenerator( getTrimmedValue( parser.nextText() ) );
1110             }
1111             else if ( checkFieldWithDuplicate( parser, "description", null, parsed ) )
1112             {
1113                 documentMeta.setDescription( getTrimmedValue( parser.nextText() ) );
1114             }
1115             else if ( checkFieldWithDuplicate( parser, "initialCreator", null, parsed ) )
1116             {
1117                 documentMeta.setInitialCreator( getTrimmedValue( parser.nextText() ) );
1118             }
1119             else if ( checkFieldWithDuplicate( parser, "creator", null, parsed ) )
1120             {
1121                 documentMeta.setCreator( getTrimmedValue( parser.nextText() ) );
1122             }
1123             else if ( checkFieldWithDuplicate( parser, "printedBy", null, parsed ) )
1124             {
1125                 documentMeta.setPrintedBy( getTrimmedValue( parser.nextText() ) );
1126             }
1127             else if ( checkFieldWithDuplicate( parser, "creationDate", null, parsed ) )
1128             {
1129                 String dateFormat = null;
1130                 documentMeta.setCreationDate( getDateValue( getTrimmedValue( parser.nextText() ), "creationDate", dateFormat, parser ) );
1131             }
1132             else if ( checkFieldWithDuplicate( parser, "creationdate", null, parsed ) )
1133             {
1134                 documentMeta.setCreationdate( getTrimmedValue( parser.nextText() ) );
1135             }
1136             else if ( checkFieldWithDuplicate( parser, "date", null, parsed ) )
1137             {
1138                 String dateFormat = null;
1139                 documentMeta.setDate( getDateValue( getTrimmedValue( parser.nextText() ), "date", dateFormat, parser ) );
1140             }
1141             else if ( checkFieldWithDuplicate( parser, "modifydate", null, parsed ) )
1142             {
1143                 documentMeta.setModifydate( getTrimmedValue( parser.nextText() ) );
1144             }
1145             else if ( checkFieldWithDuplicate( parser, "printDate", null, parsed ) )
1146             {
1147                 String dateFormat = null;
1148                 documentMeta.setPrintDate( getDateValue( getTrimmedValue( parser.nextText() ), "printDate", dateFormat, parser ) );
1149             }
1150             else if ( checkFieldWithDuplicate( parser, "printdate", null, parsed ) )
1151             {
1152                 documentMeta.setPrintdate( getTrimmedValue( parser.nextText() ) );
1153             }
1154             else if ( checkFieldWithDuplicate( parser, "template", null, parsed ) )
1155             {
1156                 documentMeta.setTemplate( parseDocumentTemplate( parser, strict ) );
1157             }
1158             else if ( checkFieldWithDuplicate( parser, "hyperlinkBehaviour", null, parsed ) )
1159             {
1160                 documentMeta.setHyperlinkBehaviour( parseDocumentHyperlinkBehaviour( parser, strict ) );
1161             }
1162             else if ( checkFieldWithDuplicate( parser, "language", null, parsed ) )
1163             {
1164                 documentMeta.setLanguage( getTrimmedValue( parser.nextText() ) );
1165             }
1166             else if ( checkFieldWithDuplicate( parser, "editingCycles", null, parsed ) )
1167             {
1168                 documentMeta.setEditingCycles( getLongValue( getTrimmedValue( parser.nextText() ), "editingCycles", parser, strict ) );
1169             }
1170             else if ( checkFieldWithDuplicate( parser, "editingDuration", null, parsed ) )
1171             {
1172                 documentMeta.setEditingDuration( getLongValue( getTrimmedValue( parser.nextText() ), "editingDuration", parser, strict ) );
1173             }
1174             else if ( checkFieldWithDuplicate( parser, "documentStatistic", null, parsed ) )
1175             {
1176                 documentMeta.setDocumentStatistic( parseDocumentStatistic( parser, strict ) );
1177             }
1178             else if ( checkFieldWithDuplicate( parser, "confidential", null, parsed ) )
1179             {
1180                 documentMeta.setConfidential( getBooleanValue( getTrimmedValue( parser.nextText() ), "confidential", parser, "false" ) );
1181             }
1182             else if ( checkFieldWithDuplicate( parser, "draft", null, parsed ) )
1183             {
1184                 documentMeta.setDraft( getBooleanValue( getTrimmedValue( parser.nextText() ), "draft", parser, "false" ) );
1185             }
1186             else
1187             {
1188                 checkUnknownElement( parser, strict );
1189             }
1190         }
1191         return documentMeta;
1192     } //-- DocumentMeta parseDocumentMeta( XmlPullParser, boolean )
1193 
1194     /**
1195      * Method parseDocumentModel.
1196      * 
1197      * @param parser
1198      * @param strict
1199      * @throws IOException
1200      * @throws XmlPullParserException
1201      * @return DocumentModel
1202      */
1203     private DocumentModel parseDocumentModel( XmlPullParser parser, boolean strict )
1204         throws IOException, XmlPullParserException
1205     {
1206         String tagName = parser.getName();
1207         DocumentModel documentModel = new DocumentModel();
1208         for ( int i = parser.getAttributeCount() - 1; i >= 0; i-- )
1209         {
1210             String name = parser.getAttributeName( i );
1211             String value = parser.getAttributeValue( i );
1212 
1213             if ( name.indexOf( ':' ) >= 0 )
1214             {
1215                 // just ignore attributes with non-default namespace (for example: xmlns:xsi)
1216             }
1217             else if ( "xmlns".equals( name ) )
1218             {
1219                 // ignore xmlns attribute in root class, which is a reserved attribute name
1220             }
1221             else if ( "outputName".equals( name ) )
1222             {
1223                 documentModel.setOutputName( getTrimmedValue( value ) );
1224             }
1225             else
1226             {
1227                 checkUnknownAttribute( parser, name, tagName, strict );
1228             }
1229         }
1230         java.util.Set parsed = new java.util.HashSet();
1231         while ( ( strict ? parser.nextTag() : nextTag( parser ) ) == XmlPullParser.START_TAG )
1232         {
1233             if ( checkFieldWithDuplicate( parser, "meta", null, parsed ) )
1234             {
1235                 documentModel.setMeta( parseDocumentMeta( parser, strict ) );
1236             }
1237             else if ( checkFieldWithDuplicate( parser, "toc", null, parsed ) )
1238             {
1239                 documentModel.setToc( parseDocumentTOC( parser, strict ) );
1240             }
1241             else if ( checkFieldWithDuplicate( parser, "cover", null, parsed ) )
1242             {
1243                 documentModel.setCover( parseDocumentCover( parser, strict ) );
1244             }
1245             else
1246             {
1247                 checkUnknownElement( parser, strict );
1248             }
1249         }
1250         return documentModel;
1251     } //-- DocumentModel parseDocumentModel( XmlPullParser, boolean )
1252 
1253     /**
1254      * Method parseDocumentStatistic.
1255      * 
1256      * @param parser
1257      * @param strict
1258      * @throws IOException
1259      * @throws XmlPullParserException
1260      * @return DocumentStatistic
1261      */
1262     private DocumentStatistic parseDocumentStatistic( XmlPullParser parser, boolean strict )
1263         throws IOException, XmlPullParserException
1264     {
1265         String tagName = parser.getName();
1266         DocumentStatistic documentStatistic = new DocumentStatistic();
1267         for ( int i = parser.getAttributeCount() - 1; i >= 0; i-- )
1268         {
1269             String name = parser.getAttributeName( i );
1270             String value = parser.getAttributeValue( i );
1271 
1272             if ( name.indexOf( ':' ) >= 0 )
1273             {
1274                 // just ignore attributes with non-default namespace (for example: xmlns:xsi)
1275             }
1276             else if ( "pageCount".equals( name ) )
1277             {
1278                 documentStatistic.setPageCount( getLongValue( getTrimmedValue( value ), "pageCount", parser, strict ) );
1279             }
1280             else if ( "tableCount".equals( name ) )
1281             {
1282                 documentStatistic.setTableCount( getLongValue( getTrimmedValue( value ), "tableCount", parser, strict ) );
1283             }
1284             else if ( "drawCount".equals( name ) )
1285             {
1286                 documentStatistic.setDrawCount( getLongValue( getTrimmedValue( value ), "drawCount", parser, strict ) );
1287             }
1288             else if ( "imageCount".equals( name ) )
1289             {
1290                 documentStatistic.setImageCount( getLongValue( getTrimmedValue( value ), "imageCount", parser, strict ) );
1291             }
1292             else if ( "objectCount".equals( name ) )
1293             {
1294                 documentStatistic.setObjectCount( getLongValue( getTrimmedValue( value ), "objectCount", parser, strict ) );
1295             }
1296             else if ( "oleObjectCount".equals( name ) )
1297             {
1298                 documentStatistic.setOleObjectCount( getLongValue( getTrimmedValue( value ), "oleObjectCount", parser, strict ) );
1299             }
1300             else if ( "paragraphCount".equals( name ) )
1301             {
1302                 documentStatistic.setParagraphCount( getLongValue( getTrimmedValue( value ), "paragraphCount", parser, strict ) );
1303             }
1304             else if ( "wordCount".equals( name ) )
1305             {
1306                 documentStatistic.setWordCount( getLongValue( getTrimmedValue( value ), "wordCount", parser, strict ) );
1307             }
1308             else if ( "characterCount".equals( name ) )
1309             {
1310                 documentStatistic.setCharacterCount( getLongValue( getTrimmedValue( value ), "characterCount", parser, strict ) );
1311             }
1312             else if ( "rowCount".equals( name ) )
1313             {
1314                 documentStatistic.setRowCount( getLongValue( getTrimmedValue( value ), "rowCount", parser, strict ) );
1315             }
1316             else if ( "frameCount".equals( name ) )
1317             {
1318                 documentStatistic.setFrameCount( getLongValue( getTrimmedValue( value ), "frameCount", parser, strict ) );
1319             }
1320             else if ( "sentenceCount".equals( name ) )
1321             {
1322                 documentStatistic.setSentenceCount( getLongValue( getTrimmedValue( value ), "sentenceCount", parser, strict ) );
1323             }
1324             else if ( "syllableCount".equals( name ) )
1325             {
1326                 documentStatistic.setSyllableCount( getLongValue( getTrimmedValue( value ), "syllableCount", parser, strict ) );
1327             }
1328             else if ( "nonWhitespaceCharacterCount".equals( name ) )
1329             {
1330                 documentStatistic.setNonWhitespaceCharacterCount( getLongValue( getTrimmedValue( value ), "nonWhitespaceCharacterCount", parser, strict ) );
1331             }
1332             else
1333             {
1334                 checkUnknownAttribute( parser, name, tagName, strict );
1335             }
1336         }
1337         java.util.Set parsed = new java.util.HashSet();
1338         while ( ( strict ? parser.nextTag() : nextTag( parser ) ) == XmlPullParser.START_TAG )
1339         {
1340             checkUnknownElement( parser, strict );
1341         }
1342         return documentStatistic;
1343     } //-- DocumentStatistic parseDocumentStatistic( XmlPullParser, boolean )
1344 
1345     /**
1346      * Method parseDocumentTOC.
1347      * 
1348      * @param parser
1349      * @param strict
1350      * @throws IOException
1351      * @throws XmlPullParserException
1352      * @return DocumentTOC
1353      */
1354     private DocumentTOC parseDocumentTOC( XmlPullParser parser, boolean strict )
1355         throws IOException, XmlPullParserException
1356     {
1357         String tagName = parser.getName();
1358         DocumentTOC documentTOC = new DocumentTOC();
1359         for ( int i = parser.getAttributeCount() - 1; i >= 0; i-- )
1360         {
1361             String name = parser.getAttributeName( i );
1362             String value = parser.getAttributeValue( i );
1363 
1364             if ( name.indexOf( ':' ) >= 0 )
1365             {
1366                 // just ignore attributes with non-default namespace (for example: xmlns:xsi)
1367             }
1368             else if ( "name".equals( name ) )
1369             {
1370                 documentTOC.setName( getTrimmedValue( value ) );
1371             }
1372             else if ( "depth".equals( name ) )
1373             {
1374                 documentTOC.setDepth( getIntegerValue( getTrimmedValue( value ), "depth", parser, strict ) );
1375             }
1376             else
1377             {
1378                 checkUnknownAttribute( parser, name, tagName, strict );
1379             }
1380         }
1381         java.util.Set parsed = new java.util.HashSet();
1382         while ( ( strict ? parser.nextTag() : nextTag( parser ) ) == XmlPullParser.START_TAG )
1383         {
1384             if ( "item".equals( parser.getName() ) )
1385             {
1386                 java.util.List items = documentTOC.getItems();
1387                 if ( items == null )
1388                 {
1389                     items = new java.util.ArrayList/*<DocumentTOCItem>*/();
1390                     documentTOC.setItems( items );
1391                 }
1392                 items.add( parseDocumentTOCItem( parser, strict ) );
1393             }
1394             else
1395             {
1396                 checkUnknownElement( parser, strict );
1397             }
1398         }
1399         return documentTOC;
1400     } //-- DocumentTOC parseDocumentTOC( XmlPullParser, boolean )
1401 
1402     /**
1403      * Method parseDocumentTOCItem.
1404      * 
1405      * @param parser
1406      * @param strict
1407      * @throws IOException
1408      * @throws XmlPullParserException
1409      * @return DocumentTOCItem
1410      */
1411     private DocumentTOCItem parseDocumentTOCItem( XmlPullParser parser, boolean strict )
1412         throws IOException, XmlPullParserException
1413     {
1414         String tagName = parser.getName();
1415         DocumentTOCItem documentTOCItem = new DocumentTOCItem();
1416         for ( int i = parser.getAttributeCount() - 1; i >= 0; i-- )
1417         {
1418             String name = parser.getAttributeName( i );
1419             String value = parser.getAttributeValue( i );
1420 
1421             if ( name.indexOf( ':' ) >= 0 )
1422             {
1423                 // just ignore attributes with non-default namespace (for example: xmlns:xsi)
1424             }
1425             else if ( "name".equals( name ) )
1426             {
1427                 documentTOCItem.setName( getTrimmedValue( value ) );
1428             }
1429             else if ( "ref".equals( name ) )
1430             {
1431                 documentTOCItem.setRef( getTrimmedValue( value ) );
1432             }
1433             else if ( "collapse".equals( name ) )
1434             {
1435                 documentTOCItem.setCollapse( getBooleanValue( getTrimmedValue( value ), "collapse", parser, "false" ) );
1436             }
1437             else
1438             {
1439                 checkUnknownAttribute( parser, name, tagName, strict );
1440             }
1441         }
1442         java.util.Set parsed = new java.util.HashSet();
1443         while ( ( strict ? parser.nextTag() : nextTag( parser ) ) == XmlPullParser.START_TAG )
1444         {
1445             if ( "item".equals( parser.getName() ) )
1446             {
1447                 java.util.List items = documentTOCItem.getItems();
1448                 if ( items == null )
1449                 {
1450                     items = new java.util.ArrayList/*<DocumentTOCItem>*/();
1451                     documentTOCItem.setItems( items );
1452                 }
1453                 items.add( parseDocumentTOCItem( parser, strict ) );
1454             }
1455             else
1456             {
1457                 checkUnknownElement( parser, strict );
1458             }
1459         }
1460         return documentTOCItem;
1461     } //-- DocumentTOCItem parseDocumentTOCItem( XmlPullParser, boolean )
1462 
1463     /**
1464      * Method parseDocumentTemplate.
1465      * 
1466      * @param parser
1467      * @param strict
1468      * @throws IOException
1469      * @throws XmlPullParserException
1470      * @return DocumentTemplate
1471      */
1472     private DocumentTemplate parseDocumentTemplate( XmlPullParser parser, boolean strict )
1473         throws IOException, XmlPullParserException
1474     {
1475         String tagName = parser.getName();
1476         DocumentTemplate documentTemplate = new DocumentTemplate();
1477         for ( int i = parser.getAttributeCount() - 1; i >= 0; i-- )
1478         {
1479             String name = parser.getAttributeName( i );
1480             String value = parser.getAttributeValue( i );
1481 
1482             if ( name.indexOf( ':' ) >= 0 )
1483             {
1484                 // just ignore attributes with non-default namespace (for example: xmlns:xsi)
1485             }
1486             else if ( "href".equals( name ) )
1487             {
1488                 documentTemplate.setHref( getTrimmedValue( value ) );
1489             }
1490             else if ( "title".equals( name ) )
1491             {
1492                 documentTemplate.setTitle( getTrimmedValue( value ) );
1493             }
1494             else if ( "date".equals( name ) )
1495             {
1496                 String dateFormat = null;
1497                 documentTemplate.setDate( getDateValue( getTrimmedValue( value ), "date", dateFormat, parser ) );
1498             }
1499             else if ( "modifydate".equals( name ) )
1500             {
1501                 documentTemplate.setModifydate( getTrimmedValue( value ) );
1502             }
1503             else
1504             {
1505                 checkUnknownAttribute( parser, name, tagName, strict );
1506             }
1507         }
1508         java.util.Set parsed = new java.util.HashSet();
1509         while ( ( strict ? parser.nextTag() : nextTag( parser ) ) == XmlPullParser.START_TAG )
1510         {
1511             checkUnknownElement( parser, strict );
1512         }
1513         return documentTemplate;
1514     } //-- DocumentTemplate parseDocumentTemplate( XmlPullParser, boolean )
1515 
1516     /**
1517      * @see ReaderFactory#newXmlReader
1518      * 
1519      * @param reader
1520      * @param strict
1521      * @throws IOException
1522      * @throws XmlPullParserException
1523      * @return DocumentModel
1524      */
1525     public DocumentModel read( Reader reader, boolean strict )
1526         throws IOException, XmlPullParserException
1527     {
1528         XmlPullParser parser = new MXParser();
1529 
1530         parser.setInput( reader );
1531 
1532         initParser( parser );
1533 
1534         return read( parser, strict );
1535     } //-- DocumentModel read( Reader, boolean )
1536 
1537     /**
1538      * @see ReaderFactory#newXmlReader
1539      * 
1540      * @param reader
1541      * @throws IOException
1542      * @throws XmlPullParserException
1543      * @return DocumentModel
1544      */
1545     public DocumentModel read( Reader reader )
1546         throws IOException, XmlPullParserException
1547     {
1548         return read( reader, true );
1549     } //-- DocumentModel read( Reader )
1550 
1551     /**
1552      * Method read.
1553      * 
1554      * @param in
1555      * @param strict
1556      * @throws IOException
1557      * @throws XmlPullParserException
1558      * @return DocumentModel
1559      */
1560     public DocumentModel read( InputStream in, boolean strict )
1561         throws IOException, XmlPullParserException
1562     {
1563         return read( ReaderFactory.newXmlReader( in ), strict );
1564     } //-- DocumentModel read( InputStream, boolean )
1565 
1566     /**
1567      * Method read.
1568      * 
1569      * @param in
1570      * @throws IOException
1571      * @throws XmlPullParserException
1572      * @return DocumentModel
1573      */
1574     public DocumentModel read( InputStream in )
1575         throws IOException, XmlPullParserException
1576     {
1577         return read( ReaderFactory.newXmlReader( in ) );
1578     } //-- DocumentModel read( InputStream )
1579 
1580     /**
1581      * Method read.
1582      * 
1583      * @param parser
1584      * @param strict
1585      * @throws IOException
1586      * @throws XmlPullParserException
1587      * @return DocumentModel
1588      */
1589     private DocumentModel read( XmlPullParser parser, boolean strict )
1590         throws IOException, XmlPullParserException
1591     {
1592         int eventType = parser.getEventType();
1593         while ( eventType != XmlPullParser.END_DOCUMENT )
1594         {
1595             if ( eventType == XmlPullParser.START_TAG )
1596             {
1597                 if ( strict && ! "document".equals( parser.getName() ) )
1598                 {
1599                     throw new XmlPullParserException( "Expected root element 'document' but found '" + parser.getName() + "'", parser, null );
1600                 }
1601                 DocumentModel documentModel = parseDocumentModel( parser, strict );
1602                 documentModel.setModelEncoding( parser.getInputEncoding() );
1603                 return documentModel;
1604             }
1605             eventType = parser.next();
1606         }
1607         throw new XmlPullParserException( "Expected root element 'document' but found no element at all: invalid XML document", parser, null );
1608     } //-- DocumentModel read( XmlPullParser, boolean )
1609 
1610     /**
1611      * Sets the state of the "add default entities" flag.
1612      * 
1613      * @param addDefaultEntities
1614      */
1615     public void setAddDefaultEntities( boolean addDefaultEntities )
1616     {
1617         this.addDefaultEntities = addDefaultEntities;
1618     } //-- void setAddDefaultEntities( boolean )
1619 
1620 }