1
2
3
4
5
6
7
8 package org.apache.maven.doxia.document.io.xpp3;
9
10
11
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
35
36
37
38 @SuppressWarnings( "all" )
39 public class DocumentXpp3Reader
40 {
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56 private boolean addDefaultEntities = true;
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
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 }
86
87
88
89
90
91
92
93
94
95
96
97 private void checkUnknownAttribute( XmlPullParser parser, String attribute, String tagName, boolean strict )
98 throws XmlPullParserException, IOException
99 {
100
101 if ( strict )
102 {
103 throw new XmlPullParserException( "Unknown attribute '" + attribute + "' for tag '" + tagName + "'", parser, null );
104 }
105 }
106
107
108
109
110
111
112
113
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 }
136
137
138
139
140
141
142 public boolean getAddDefaultEntities()
143 {
144 return addDefaultEntities;
145 }
146
147
148
149
150
151
152
153
154
155
156 private boolean getBooleanValue( String s, String attribute, XmlPullParser parser )
157 throws XmlPullParserException
158 {
159 return getBooleanValue( s, attribute, parser, null );
160 }
161
162
163
164
165
166
167
168
169
170
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 }
185
186
187
188
189
190
191
192
193
194
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 }
215
216
217
218
219
220
221
222
223
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 }
234
235
236
237
238
239
240
241
242
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 }
249
250
251
252
253
254
255
256
257
258
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 }
296
297
298
299
300
301
302
303
304
305
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 }
326
327
328
329
330
331
332
333
334
335
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 }
356
357
358
359
360
361
362
363
364
365
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 }
386
387
388
389
390
391
392
393
394
395
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 }
416
417
418
419
420
421
422
423
424
425
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 }
439
440
441
442
443
444
445
446
447
448
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 }
469
470
471
472
473
474
475
476 private String getTrimmedValue( String s )
477 {
478 if ( s != null )
479 {
480 s = s.trim();
481 }
482 return s;
483 }
484
485
486
487
488
489
490
491 private void initParser( XmlPullParser parser )
492 throws XmlPullParserException
493 {
494 if ( addDefaultEntities )
495 {
496
497
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
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
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 }
761
762
763
764
765
766
767
768
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 }
784
785
786
787
788
789
790
791
792
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
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 }
883
884
885
886
887
888
889
890
891
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
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
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 }
983
984
985
986
987
988
989
990
991
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
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 }
1023
1024
1025
1026
1027
1028
1029
1030
1031
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
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
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
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 }
1193
1194
1195
1196
1197
1198
1199
1200
1201
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
1216 }
1217 else if ( "xmlns".equals( name ) )
1218 {
1219
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 }
1252
1253
1254
1255
1256
1257
1258
1259
1260
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
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 }
1344
1345
1346
1347
1348
1349
1350
1351
1352
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
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
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 }
1401
1402
1403
1404
1405
1406
1407
1408
1409
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
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
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 }
1462
1463
1464
1465
1466
1467
1468
1469
1470
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
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 }
1515
1516
1517
1518
1519
1520
1521
1522
1523
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 }
1536
1537
1538
1539
1540
1541
1542
1543
1544
1545 public DocumentModel read( Reader reader )
1546 throws IOException, XmlPullParserException
1547 {
1548 return read( reader, true );
1549 }
1550
1551
1552
1553
1554
1555
1556
1557
1558
1559
1560 public DocumentModel read( InputStream in, boolean strict )
1561 throws IOException, XmlPullParserException
1562 {
1563 return read( ReaderFactory.newXmlReader( in ), strict );
1564 }
1565
1566
1567
1568
1569
1570
1571
1572
1573
1574 public DocumentModel read( InputStream in )
1575 throws IOException, XmlPullParserException
1576 {
1577 return read( ReaderFactory.newXmlReader( in ) );
1578 }
1579
1580
1581
1582
1583
1584
1585
1586
1587
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 }
1609
1610
1611
1612
1613
1614
1615 public void setAddDefaultEntities( boolean addDefaultEntities )
1616 {
1617 this.addDefaultEntities = addDefaultEntities;
1618 }
1619
1620 }