org.pentaho.reporting.libraries.xmlns.parser.ResourceDataInputSource.java Source code

Java tutorial

Introduction

Here is the source code for org.pentaho.reporting.libraries.xmlns.parser.ResourceDataInputSource.java

Source

/*
* This program is free software; you can redistribute it and/or modify it under the
* terms of the GNU Lesser General Public License, version 2.1 as published by the Free Software
* Foundation.
*
* You should have received a copy of the GNU Lesser General Public License along with this
* program; if not, you can obtain a copy at http://www.gnu.org/licenses/old-licenses/lgpl-2.1.html
* or from the Free Software Foundation, Inc.,
* 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
*
* This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY;
* without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
* See the GNU Lesser General Public License for more details.
*
* Copyright (c) 2001 - 2013 Object Refinery Ltd, Hitachi Vantara and Contributors..  All rights reserved.
*/

package org.pentaho.reporting.libraries.xmlns.parser;

import org.apache.commons.logging.Log;
import org.apache.commons.logging.LogFactory;
import org.pentaho.reporting.libraries.resourceloader.ResourceData;
import org.pentaho.reporting.libraries.resourceloader.ResourceLoadingException;
import org.pentaho.reporting.libraries.resourceloader.ResourceManager;
import org.xml.sax.InputSource;

import java.io.InputStream;
import java.net.URL;

/**
 * A SAX InputSource implementation that reads its data from a LibLoader ResourceData object.
 *
 * @author Thomas Morgner
 */
public class ResourceDataInputSource extends InputSource {
    private static final Log logger = LogFactory.getLog(ResourceDataInputSource.class);
    private ResourceData data;
    private long version;
    private ResourceManager caller;

    /**
     * Creates a new InputSource using the given resource-data and resource-manager as source.
     *
     * @param data   the resource-data object holding the raw-data.
     * @param caller the resource manager that is loading the current resource.
     * @throws ResourceLoadingException if an error occurs.
     * @see #setPublicId
     * @see #setSystemId
     * @see #setByteStream
     * @see #setCharacterStream
     * @see #setEncoding
     */
    public ResourceDataInputSource(final ResourceData data, final ResourceManager caller)
            throws ResourceLoadingException {
        if (data == null) {
            throw new NullPointerException("Data must not be null");
        }
        if (caller == null) {
            throw new NullPointerException("ResourceManager must not be null");
        }
        this.data = data;
        this.version = data.getVersion(caller);
        this.caller = caller;
        final URL url = caller.toURL(data.getKey());
        if (url != null) {
            setSystemId(url.toExternalForm());
        }
    }

    /**
     * Set the byte stream for this input source.
     *
     * @param byteStream A byte stream containing an XML document or other entity.
     */
    public void setByteStream(final InputStream byteStream) {
        throw new UnsupportedOperationException();
    }

    /**
     * Get the byte stream for this input source.
     * <p/>
     * <p>The getEncoding method will return the character encoding for this byte stream, or null if unknown.</p>
     *
     * @return The byte stream, or null if none was supplied.
     * @see #getEncoding
     * @see #setByteStream
     */
    public InputStream getByteStream() {
        try {
            return data.getResourceAsStream(caller);
        } catch (ResourceLoadingException e) {
            logger.error("Unable to create byte-stream: " + data.getKey());
            return null;
        }
    }

    /**
     * Returns the resource-data object that provides the raw-data.
     *
     * @return the resource-data object.
     */
    public ResourceData getData() {
        return data;
    }

    /**
     * Returns the version (changetracker) of this input source.
     *
     * @return the version (changetracker) of the input source.
     */
    public long getVersion() {
        return version;
    }
}