jdk/src/share/classes/com/sun/beans/decoder/DocumentHandler.java
author ohair
Tue, 25 May 2010 15:58:33 -0700
changeset 5506 202f599c92aa
parent 1844 ac2cf8242428
child 14221 441a3cd5e5e3
permissions -rw-r--r--
6943119: Rebrand source copyright notices Reviewed-by: darcy, weijun
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
1844
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
     1
/*
5506
202f599c92aa 6943119: Rebrand source copyright notices
ohair
parents: 1844
diff changeset
     2
 * Copyright (c) 2008, Oracle and/or its affiliates. All rights reserved.
1844
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
     3
 * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER.
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
     4
 *
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
     5
 * This code is free software; you can redistribute it and/or modify it
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
     6
 * under the terms of the GNU General Public License version 2 only, as
5506
202f599c92aa 6943119: Rebrand source copyright notices
ohair
parents: 1844
diff changeset
     7
 * published by the Free Software Foundation.  Oracle designates this
1844
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
     8
 * particular file as subject to the "Classpath" exception as provided
5506
202f599c92aa 6943119: Rebrand source copyright notices
ohair
parents: 1844
diff changeset
     9
 * by Oracle in the LICENSE file that accompanied this code.
1844
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    10
 *
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    11
 * This code is distributed in the hope that it will be useful, but WITHOUT
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    12
 * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    13
 * FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public License
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    14
 * version 2 for more details (a copy is included in the LICENSE file that
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    15
 * accompanied this code).
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    16
 *
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    17
 * You should have received a copy of the GNU General Public License version
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    18
 * 2 along with this work; if not, write to the Free Software Foundation,
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    19
 * Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301 USA.
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    20
 *
5506
202f599c92aa 6943119: Rebrand source copyright notices
ohair
parents: 1844
diff changeset
    21
 * Please contact Oracle, 500 Oracle Parkway, Redwood Shores, CA 94065 USA
202f599c92aa 6943119: Rebrand source copyright notices
ohair
parents: 1844
diff changeset
    22
 * or visit www.oracle.com if you need additional information or have any
202f599c92aa 6943119: Rebrand source copyright notices
ohair
parents: 1844
diff changeset
    23
 * questions.
1844
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    24
 */
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    25
package com.sun.beans.decoder;
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    26
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    27
import com.sun.beans.finder.ClassFinder;
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    28
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    29
import java.beans.ExceptionListener;
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    30
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    31
import java.io.IOException;
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    32
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    33
import java.lang.ref.Reference;
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    34
import java.lang.ref.WeakReference;
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    35
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    36
import java.util.ArrayList;
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    37
import java.util.HashMap;
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    38
import java.util.List;
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    39
import java.util.Map;
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    40
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    41
import javax.xml.parsers.ParserConfigurationException;
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    42
import javax.xml.parsers.SAXParserFactory;
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    43
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    44
import org.xml.sax.Attributes;
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    45
import org.xml.sax.InputSource;
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    46
import org.xml.sax.SAXException;
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    47
import org.xml.sax.helpers.DefaultHandler;
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    48
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    49
/**
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    50
 * The main class to parse JavaBeans XML archive.
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    51
 *
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    52
 * @since 1.7
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    53
 *
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    54
 * @author Sergey A. Malenkov
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    55
 *
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    56
 * @see ElementHandler
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    57
 */
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    58
public final class DocumentHandler extends DefaultHandler {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    59
    private final Map<String, Class<? extends ElementHandler>> handlers = new HashMap<String, Class<? extends ElementHandler>>();
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    60
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    61
    private final Map<String, Object> environment = new HashMap<String, Object>();
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    62
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    63
    private final List<Object> objects = new ArrayList<Object>();
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    64
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    65
    private Reference<ClassLoader> loader;
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    66
    private ExceptionListener listener;
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    67
    private Object owner;
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    68
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    69
    private ElementHandler handler;
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    70
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    71
    /**
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    72
     * Creates new instance of document handler.
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    73
     */
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    74
    public DocumentHandler() {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    75
        setElementHandler("java", JavaElementHandler.class); // NON-NLS: the element name
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    76
        setElementHandler("null", NullElementHandler.class); // NON-NLS: the element name
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    77
        setElementHandler("array", ArrayElementHandler.class); // NON-NLS: the element name
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    78
        setElementHandler("class", ClassElementHandler.class); // NON-NLS: the element name
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    79
        setElementHandler("string", StringElementHandler.class); // NON-NLS: the element name
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    80
        setElementHandler("object", ObjectElementHandler.class); // NON-NLS: the element name
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    81
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    82
        setElementHandler("void", VoidElementHandler.class); // NON-NLS: the element name
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    83
        setElementHandler("char", CharElementHandler.class); // NON-NLS: the element name
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    84
        setElementHandler("byte", ByteElementHandler.class); // NON-NLS: the element name
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    85
        setElementHandler("short", ShortElementHandler.class); // NON-NLS: the element name
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    86
        setElementHandler("int", IntElementHandler.class); // NON-NLS: the element name
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    87
        setElementHandler("long", LongElementHandler.class); // NON-NLS: the element name
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    88
        setElementHandler("float", FloatElementHandler.class); // NON-NLS: the element name
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    89
        setElementHandler("double", DoubleElementHandler.class); // NON-NLS: the element name
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    90
        setElementHandler("boolean", BooleanElementHandler.class); // NON-NLS: the element name
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    91
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    92
        // some handlers for new elements
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    93
        setElementHandler("new", NewElementHandler.class); // NON-NLS: the element name
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    94
        setElementHandler("var", VarElementHandler.class); // NON-NLS: the element name
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    95
        setElementHandler("true", TrueElementHandler.class); // NON-NLS: the element name
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    96
        setElementHandler("false", FalseElementHandler.class); // NON-NLS: the element name
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    97
        setElementHandler("field", FieldElementHandler.class); // NON-NLS: the element name
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    98
        setElementHandler("method", MethodElementHandler.class); // NON-NLS: the element name
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
    99
        setElementHandler("property", PropertyElementHandler.class); // NON-NLS: the element name
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   100
    }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   101
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   102
    /**
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   103
     * Returns the class loader used to instantiate objects.
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   104
     * If the class loader has not been explicitly set
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   105
     * then {@code null} is returned.
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   106
     *
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   107
     * @return the class loader used to instantiate objects
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   108
     */
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   109
    public ClassLoader getClassLoader() {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   110
        return (this.loader != null)
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   111
                ? this.loader.get()
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   112
                : null;
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   113
    }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   114
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   115
    /**
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   116
     * Sets the class loader used to instantiate objects.
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   117
     * If the class loader is not set
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   118
     * then default class loader will be used.
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   119
     *
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   120
     * @param loader  a classloader to use
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   121
     */
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   122
    public void setClassLoader(ClassLoader loader) {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   123
        this.loader = new WeakReference<ClassLoader>(loader);
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   124
    }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   125
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   126
    /**
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   127
     * Returns the exception listener for parsing.
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   128
     * The exception listener is notified
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   129
     * when handler catches recoverable exceptions.
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   130
     * If the exception listener has not been explicitly set
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   131
     * then default exception listener is returned.
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   132
     *
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   133
     * @return the exception listener for parsing
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   134
     */
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   135
    public ExceptionListener getExceptionListener() {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   136
        return this.listener;
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   137
    }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   138
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   139
    /**
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   140
     * Sets the exception listener for parsing.
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   141
     * The exception listener is notified
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   142
     * when handler catches recoverable exceptions.
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   143
     *
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   144
     * @param listener  the exception listener for parsing
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   145
     */
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   146
    public void setExceptionListener(ExceptionListener listener) {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   147
        this.listener = listener;
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   148
    }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   149
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   150
    /**
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   151
     * Returns the owner of this document handler.
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   152
     *
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   153
     * @return the owner of this document handler
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   154
     */
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   155
    public Object getOwner() {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   156
        return this.owner;
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   157
    }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   158
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   159
    /**
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   160
     * Sets the owner of this document handler.
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   161
     *
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   162
     * @param owner  the owner of this document handler
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   163
     */
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   164
    public void setOwner(Object owner) {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   165
        this.owner = owner;
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   166
    }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   167
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   168
    /**
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   169
     * Returns the handler for the element with specified name.
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   170
     *
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   171
     * @param name  the name of the element
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   172
     * @return the corresponding element handler
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   173
     */
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   174
    public Class<? extends ElementHandler> getElementHandler(String name) {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   175
        Class<? extends ElementHandler> type = this.handlers.get(name);
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   176
        if (type == null) {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   177
            throw new IllegalArgumentException("Unsupported element: " + name);
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   178
        }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   179
        return type;
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   180
    }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   181
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   182
    /**
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   183
     * Sets the handler for the element with specified name.
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   184
     *
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   185
     * @param name     the name of the element
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   186
     * @param handler  the corresponding element handler
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   187
     */
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   188
    public void setElementHandler(String name, Class<? extends ElementHandler> handler) {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   189
        this.handlers.put(name, handler);
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   190
    }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   191
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   192
    /**
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   193
     * Indicates whether the variable with specified identifier is defined.
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   194
     *
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   195
     * @param id  the identifier
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   196
     * @return @{code true} if the variable is defined;
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   197
     *         @{code false} otherwise
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   198
     */
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   199
    public boolean hasVariable(String id) {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   200
        return this.environment.containsKey(id);
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   201
    }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   202
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   203
    /**
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   204
     * Returns the value of the variable with specified identifier.
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   205
     *
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   206
     * @param id  the identifier
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   207
     * @return the value of the variable
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   208
     */
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   209
    public Object getVariable(String id) {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   210
        if (!this.environment.containsKey(id)) {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   211
            throw new IllegalArgumentException("Unbound variable: " + id);
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   212
        }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   213
        return this.environment.get(id);
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   214
    }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   215
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   216
    /**
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   217
     * Sets new value of the variable with specified identifier.
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   218
     *
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   219
     * @param id     the identifier
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   220
     * @param value  new value of the variable
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   221
     */
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   222
    public void setVariable(String id, Object value) {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   223
        this.environment.put(id, value);
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   224
    }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   225
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   226
    /**
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   227
     * Returns the array of readed objects.
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   228
     *
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   229
     * @return the array of readed objects
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   230
     */
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   231
    public Object[] getObjects() {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   232
        return this.objects.toArray();
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   233
    }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   234
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   235
    /**
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   236
     * Adds the object to the list of readed objects.
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   237
     *
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   238
     * @param object  the object that is readed from XML document
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   239
     */
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   240
    void addObject(Object object) {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   241
        this.objects.add(object);
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   242
    }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   243
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   244
    /**
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   245
     * Prepares this handler to read objects from XML document.
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   246
     */
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   247
    @Override
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   248
    public void startDocument() {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   249
        this.objects.clear();
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   250
        this.handler = null;
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   251
    }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   252
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   253
    /**
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   254
     * Parses opening tag of XML element
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   255
     * using corresponding element handler.
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   256
     *
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   257
     * @param uri         the namespace URI, or the empty string
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   258
     *                    if the element has no namespace URI or
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   259
     *                    if namespace processing is not being performed
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   260
     * @param localName   the local name (without prefix), or the empty string
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   261
     *                    if namespace processing is not being performed
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   262
     * @param qName       the qualified name (with prefix), or the empty string
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   263
     *                    if qualified names are not available
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   264
     * @param attributes  the attributes attached to the element
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   265
     */
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   266
    @Override
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   267
    public void startElement(String uri, String localName, String qName, Attributes attributes) throws SAXException {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   268
        ElementHandler parent = this.handler;
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   269
        try {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   270
            this.handler = getElementHandler(qName).newInstance();
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   271
            this.handler.setOwner(this);
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   272
            this.handler.setParent(parent);
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   273
        }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   274
        catch (Exception exception) {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   275
            throw new SAXException(exception);
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   276
        }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   277
        for (int i = 0; i < attributes.getLength(); i++)
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   278
            try {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   279
                String name = attributes.getQName(i);
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   280
                String value = attributes.getValue(i);
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   281
                this.handler.addAttribute(name, value);
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   282
            }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   283
            catch (RuntimeException exception) {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   284
                handleException(exception);
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   285
            }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   286
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   287
        this.handler.startElement();
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   288
    }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   289
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   290
    /**
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   291
     * Parses closing tag of XML element
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   292
     * using corresponding element handler.
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   293
     *
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   294
     * @param uri        the namespace URI, or the empty string
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   295
     *                   if the element has no namespace URI or
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   296
     *                   if namespace processing is not being performed
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   297
     * @param localName  the local name (without prefix), or the empty string
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   298
     *                   if namespace processing is not being performed
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   299
     * @param qName      the qualified name (with prefix), or the empty string
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   300
     *                   if qualified names are not available
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   301
     */
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   302
    @Override
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   303
    public void endElement(String uri, String localName, String qName) {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   304
        try {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   305
            this.handler.endElement();
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   306
        }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   307
        catch (RuntimeException exception) {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   308
            handleException(exception);
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   309
        }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   310
        finally {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   311
            this.handler = this.handler.getParent();
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   312
        }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   313
    }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   314
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   315
    /**
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   316
     * Parses character data inside XML element.
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   317
     *
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   318
     * @param chars   the array of characters
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   319
     * @param start   the start position in the character array
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   320
     * @param length  the number of characters to use
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   321
     */
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   322
    @Override
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   323
    public void characters(char[] chars, int start, int length) {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   324
        if (this.handler != null) {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   325
            try {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   326
                while (0 < length--) {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   327
                    this.handler.addCharacter(chars[start++]);
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   328
                }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   329
            }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   330
            catch (RuntimeException exception) {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   331
                handleException(exception);
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   332
            }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   333
        }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   334
    }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   335
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   336
    /**
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   337
     * Handles an exception using current exception listener.
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   338
     *
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   339
     * @param exception  an exception to handle
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   340
     * @see #setExceptionListener
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   341
     */
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   342
    public void handleException(Exception exception) {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   343
        if (this.listener == null) {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   344
            throw new IllegalStateException(exception);
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   345
        }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   346
        this.listener.exceptionThrown(exception);
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   347
    }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   348
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   349
    /**
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   350
     * Starts parsing of the specified input source.
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   351
     *
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   352
     * @param input  the input source to parse
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   353
     */
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   354
    public void parse(InputSource input) {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   355
        try {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   356
            SAXParserFactory.newInstance().newSAXParser().parse(input, this);
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   357
        }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   358
        catch (ParserConfigurationException exception) {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   359
            handleException(exception);
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   360
        }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   361
        catch (SAXException wrapper) {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   362
            Exception exception = wrapper.getException();
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   363
            if (exception == null) {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   364
                exception = wrapper;
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   365
            }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   366
            handleException(exception);
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   367
        }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   368
        catch (IOException exception) {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   369
            handleException(exception);
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   370
        }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   371
    }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   372
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   373
    /**
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   374
     * Resolves class by name using current class loader.
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   375
     * This method handles exception using current exception listener.
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   376
     *
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   377
     * @param name  the name of the class
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   378
     * @return the object that represents the class
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   379
     */
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   380
    public Class<?> findClass(String name) {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   381
        try {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   382
            return ClassFinder.resolveClass(name, getClassLoader());
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   383
        }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   384
        catch (ClassNotFoundException exception) {
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   385
            handleException(exception);
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   386
            return null;
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   387
        }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   388
    }
ac2cf8242428 4864117: RFE: Make XMLDecoder API more reusable
malenkov
parents:
diff changeset
   389
}