blob: d1d7b1f24e478de35045d10c6c97bc1212ac65d9 [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.cocoon.components.source.impl;
import java.io.ByteArrayInputStream;
import java.io.IOException;
import java.io.InputStream;
import org.apache.cocoon.xml.XMLUtils;
import org.apache.excalibur.xml.sax.XMLizable;
import org.apache.excalibur.source.Source;
import org.apache.excalibur.source.SourceNotFoundException;
import org.apache.excalibur.source.SourceValidity;
import org.apache.excalibur.source.impl.validity.NOPValidity;
import org.xml.sax.ContentHandler;
import org.xml.sax.SAXException;
/**
* A <code>Source</code> that generates completely empty XML document or an
* XML document that contains just a root node.
*
* <p>
* The URI syntax is <code>empty:</code> for completely empty XML document
* or <code>create-document:root-element</code> for document with root element,
* where <code>root-element</code> is the name of the root element to create.
*
* @version $Id$
* @since 2.1.8
*/
public class EmptySource implements XMLizable, Source {
protected String rootElementName;
protected String scheme;
protected String uri;
protected String xmlDocument;
public EmptySource(String location) {
this.uri = location;
final int pos = location.indexOf(':');
this.scheme = location.substring(0, pos);
final String rootName = location.substring(pos + 1).trim();
if (rootName.length() > 0) {
this.rootElementName = rootName;
this.xmlDocument = '<' + this.rootElementName + "/>";
} else {
this.xmlDocument = "";
}
}
/**
* @see org.apache.excalibur.xml.sax.XMLizable#toSAX(org.xml.sax.ContentHandler)
*/
public void toSAX(ContentHandler handler) throws SAXException {
handler.startDocument();
if (rootElementName != null) {
XMLUtils.createElement(handler, this.rootElementName);
}
handler.endDocument();
}
/**
* @see org.apache.excalibur.source.Source#exists()
*/
public boolean exists() {
return true;
}
/**
* @see org.apache.excalibur.source.Source#getContentLength()
*/
public long getContentLength() {
return this.xmlDocument.length();
}
/**
* @see org.apache.excalibur.source.Source#getInputStream()
*/
public InputStream getInputStream() throws IOException, SourceNotFoundException {
return new ByteArrayInputStream(this.xmlDocument.getBytes("utf-8"));
}
/**
* @see org.apache.excalibur.source.Source#getLastModified()
*/
public long getLastModified() {
// this document *never* changes
return 1;
}
/**
* @see org.apache.excalibur.source.Source#getMimeType()
*/
public String getMimeType() {
return "text/xml";
}
/**
* @see org.apache.excalibur.source.Source#getScheme()
*/
public String getScheme() {
return this.scheme;
}
/**
* @see org.apache.excalibur.source.Source#getURI()
*/
public String getURI() {
return this.uri;
}
/**
* @see org.apache.excalibur.source.Source#getValidity()
*/
public SourceValidity getValidity() {
return NOPValidity.SHARED_INSTANCE;
}
/**
* @see org.apache.excalibur.source.Source#refresh()
*/
public void refresh() {
// nothing to do here
}
}