blob: 90a159c949b746929bcc630c929697edb38097a6 [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.
*/
#if !defined(XALAN_XSLTINPUTSOURCE_HEADER_GUARD)
#define XALAN_XSLTINPUTSOURCE_HEADER_GUARD
// Base include file. Must be first.
#include "XSLTDefinitions.hpp"
#include <iosfwd>
#include "xercesc/sax/InputSource.hpp"
#include "xalanc/Include/XalanMemoryManagement.hpp"
namespace XERCES_CPP_NAMESPACE
{
class Locator;
}
namespace XALAN_CPP_NAMESPACE {
typedef xercesc::BinInputStream BinInputStreamType;
typedef xercesc::InputSource InputSourceType;
using xercesc::MemoryManager;
class XalanDOMString;
class XalanNode;
class XALAN_XSLT_EXPORT XSLTInputSource : public InputSourceType
{
public:
typedef std::istream StreamType;
explicit
XSLTInputSource(MemoryManager& theMemoryManager = XalanMemMgrs::getDefault());
/**
* Copy constructor.
*/
XSLTInputSource(
const XSLTInputSource& theSource,
MemoryManager& theMemoryManager = XalanMemMgrs::getDefault());
/**
* Assignment operator.
*/
XSLTInputSource&
operator=(const XSLTInputSource& theRHS);
/**
* Create a new input source with a system identifier.
*
* <p>Applications may use setPublicId to include a public identifier as
* well, or setEncoding to specify the character encoding, if known.</p>
*
* <p>If the system identifier is a URL, it must be full resolved.</p>
*
* @param systemId system identifier (URI)
* @param theMemoryManager The MemoryManager instance to use.
*/
XSLTInputSource(
const XMLCh* systemId,
MemoryManager& theMemoryManager = XalanMemMgrs::getDefault());
/**
* Create a new input source with a system identifier.
*
* <p>Applications may use setPublicId to include a public identifier as
* well, or setEncoding to specify the character encoding, if known.</p>
*
* <p>If the system identifier is a URL, it must be full resolved.</p>
*
* @param systemId system identifier (URI)
* @param theMemoryManager The MemoryManager instance to use.
*/
XSLTInputSource(
const XalanDOMString& systemId,
MemoryManager& theMemoryManager = XalanMemMgrs::getDefault());
/**
* Create a new input source with a system identifier.
*
* <p>Applications may use setPublicId to include a public identifier as
* well, or setEncoding to specify the character encoding, if known.</p>
*
* <p>If the system identifier is a URL, it must be full resolved.</p>
*
* @param systemId system identifier (URI)
* @param theMemoryManager The MemoryManager instance to use.
*/
XSLTInputSource(
const char* systemId,
MemoryManager& theMemoryManager = XalanMemMgrs::getDefault());
/**
* Create a new input source with a system identifier and a public
* identifier.
*
* <p>If the system identifier is a URL, it must be full resolved.</p>
*
* @param systemId system identifier (URI)
* @param publicId public identifier
* @param theMemoryManager The MemoryManager instance to use.
*/
XSLTInputSource(
const char* systemId,
const char* publicId,
MemoryManager& theMemoryManager = XalanMemMgrs::getDefault());
/**
* Create a new input source with a system identifier and a public
* identifier.
*
* <p>If the system identifier is a URL, it must be full resolved.</p>
*
* @param systemId system identifier (URI)
* @param publicId public identifier
* @param theMemoryManager The MemoryManager instance to use.
*/
XSLTInputSource(
const XMLCh* systemId,
const XMLCh* publicId,
MemoryManager& theMemoryManager = XalanMemMgrs::getDefault());
/**
* Create a new input source with a system identifier and a public
* identifier.
*
* <p>If the system identifier is a URL, it must be full resolved.</p>
*
* @param systemId system identifier (URI)
* @param publicId public identifier
* @param theMemoryManager The MemoryManager instance to use.
*/
XSLTInputSource(
const XalanDOMString& systemId,
const XalanDOMString& publicId,
MemoryManager& theMemoryManager = XalanMemMgrs::getDefault());
/**
* Create a new input source with a DOM node.
*
* <p>Application writers may use setSystemId() to provide a base for
* resolving relative URIs, and setPublicId to include a public
* identifier.</p>
*
* @param node DOM node that is root of the document
* @param theMemoryManager The MemoryManager instance to use.
*/
XSLTInputSource(
XalanNode* node,
MemoryManager& theMemoryManager = XalanMemMgrs::getDefault());
/**
* Create a new input source with std stream.
*
* <p>Application writers may use setSystemId() to provide a base for
* resolving relative URIs, and setPublicId to include a public
* identifier.</p>
*
* @param stream the input stream...
* @param theMemoryManager The MemoryManager instance to use.
*/
XSLTInputSource(
StreamType* stream,
MemoryManager& theMemoryManager = XalanMemMgrs::getDefault());
/**
* Create a new input source with std stream.
*
* <p>Application writers may use setSystemId() to provide a base for
* resolving relative URIs, and setPublicId to include a public
* identifier.</p>
*
* @param stream the input stream...
* @param theMemoryManager The MemoryManager instance to use.
*/
XSLTInputSource(
StreamType& stream,
MemoryManager& theMemoryManager = XalanMemMgrs::getDefault());
/**
* Makes the byte stream for this input source.
*
* <p>The SAX parser will ignore this if there is also a character
* stream specified, but it will use a byte stream in preference
* to opening a URI connection itself.</p>
*
*
* @return pointer to byte stream created
*/
virtual BinInputStreamType*
makeStream() const;
/**
* Set the DOM node for this input source.
*
* @param node DOM node that is root of the document
*/
void
setNode(XalanNode* node)
{
m_node = node;
}
/**
* Retrieve the DOM node for this input source.
*
* @return DOM node that is root of the document
*/
XalanNode*
getNode() const
{
return m_node;
}
StreamType*
getStream() const
{
return m_stream;
}
void
setStream(StreamType* stream)
{
m_stream = stream;
}
private:
StreamType* m_stream;
XalanNode* m_node;
};
}
#endif // XALAN_XSLTINPUTSOURCE_HEADER_GUARD