www.alphaworks.ibm.comwww.ibm.com/developerwww.ibm.com

Home

Readme
Download

Build







Migration

Releases

Feedback

Y2K Compliance


CVS Repository
Mail Archive

API Docs for SAX and DOM
 

Main Page   Class Hierarchy   Alphabetical List   Compound List   File List   Compound Members   File Members  

InputSource Class Reference

A single input source for an XML entity. More...

#include <InputSource.hpp>

Inheritance diagram for InputSource

Inheritance graph
class_LocalFileInputSource class_MemBufInputSource class_StdInInputSource class_URLInputSource
[legend]
List of all members.

Public Methods

Destructor
virtual ~InputSource ()
 Destructor.

Virtual input source interface
virtual BinInputStreammakeStream ()const=0
 Makes the byte stream for this input source. More...

Getter methods
const XMLCh* getEncoding ()const
 An input source can be set to force the parser to assume a particular encoding for the data that input source reprsents, via the setEncoding() method. More...

const XMLCh* getPublicId ()const
 Get the public identifier for this input source. More...

const XMLCh* getSystemId ()const
 Get the system identifier for this input source. More...

Setter methods
void setEncoding (const XMLCh *const encodingStr)
 Set the encoding which will be required for use with the XML text read via a stream opened by this input source. More...

void setPublicId (const XMLCh *const publicId)
 Set the public identifier for this input source. More...

void setSystemId (const XMLCh *const systemId)
 Set the system identifier for this input source. More...


Protected Methods

Constructors and Destructor
 InputSource ()
 Default constructor.

 InputSource (const XMLCh *const systemId)
 Constructor with a system identifier as XMLCh type. More...

 InputSource (const XMLCh *const systemId,const XMLCh *const publicId)
 Constructor with a system and public identifiers. More...

 InputSource (const char *const systemId)
 Constructor witha system identifier as string. More...

 InputSource (const char *const systemId,const char *const publicId)
 Constructor witha system and public identifiers. More...


Detailed Description

A single input source for an XML entity.

This class encapsulates information about an input source in a single object, which may include a public identifier or a system identifier

There are two places that the application will deliver this input source to the parser: as the argument to the Parser::parse method, or as the return value of the EntityResolver::resolveEntity method.

InputSource is never used directly, but is the base class for a number of derived classes for particular types of input sources. Derivatives are provided (in the internal/ directory) for URL input sources, memory buffer input sources, and so on.

When it is time to parse the input described by an input source, it will be asked to create a binary stream for that source. That stream will be used to input the data of the source. The derived class provides the implementation of the makeStream() method, and provides a type of stream of the correct type for the input source it represents.

An InputSource object belongs to the application: the parser never modifies them in any way. They are always passed by const reference so the parser will make a copy of any input sources that it must keep around beyond the call.

See also:
Parser::parse , EntityResolver::resolveEntity


Constructor & Destructor Documentation

InputSource::~InputSource ( ) [virtual]
 

Destructor.

InputSource::InputSource ( ) [protected]
 

Default constructor.

InputSource::InputSource ( const XMLCh *const systemId ) [protected]
 

Constructor with a system identifier as XMLCh type.

Parameters:
systemId   The system identifier (URI).

InputSource::InputSource ( const XMLCh *const systemId,
const XMLCh *const publicId ) [protected]
 

Constructor with a system and public identifiers.

Parameters:
systemId   The system identifier (URI).
publicId   The public identifier as in the entity definition.

InputSource::InputSource ( const char *const systemId ) [protected]
 

Constructor witha system identifier as string.

Parameters:
systemId   The system identifier (URI).

InputSource::InputSource ( const char *const systemId,
const char *const publicId ) [protected]
 

Constructor witha system and public identifiers.

Both as string

Parameters:
systemId   The system identifier (URI).
publicId   The public identifier as in the entity definition.


Member Function Documentation

const XMLCh * InputSource::getEncoding ( ) const
 

An input source can be set to force the parser to assume a particular encoding for the data that input source reprsents, via the setEncoding() method.

This method returns name of the encoding that is to be forced. If the encoding has never been forced, it returns a null pointer.

Returns:
The forced encoding, or null if none was supplied.
See also:
setEncoding

const XMLCh * InputSource::getPublicId ( ) const
 

Get the public identifier for this input source.

Returns:
The public identifier, or null if none was supplied.
See also:
setPublicId

const XMLCh * InputSource::getSystemId ( ) const
 

Get the system identifier for this input source.

If the system ID is a URL, it will be fully resolved.

Returns:
The system identifier.
See also:
setSystemId

BinInputStream * InputSource::makeStream ( ) const [pure virtual]
 

Makes the byte stream for this input source.

The derived class must create and return a binary input stream of an appropriate type for its kind of data source. The returned stream must be dynamically allocated and becomes the parser's property.

See also:
BinInputStream

Reimplemented in LocalFileInputSource, MemBufInputSource, StdInInputSource, and URLInputSource.

void InputSource::setEncoding ( const XMLCh *const encodingStr )
 

Set the encoding which will be required for use with the XML text read via a stream opened by this input source.

This is usually not set, allowing the encoding to be sensed in the usual XML way. However, in some cases, the encoding in the file is known to be incorrect because of intermediate transcoding, for instance encapsulation within a MIME document.

Parameters:
encodingStr   The name of the encoding to force.

void InputSource::setPublicId ( const XMLCh *const publicId )
 

Set the public identifier for this input source.

The public identifier is always optional: if the application writer includes one, it will be provided as part of the location information.

Parameters:
publicId   The public identifier as a string.
See also:
Locator::getPublicId , SAXParseException::getPublicId , getPublicId

void InputSource::setSystemId ( const XMLCh *const systemId )
 

Set the system identifier for this input source.

Set the system identifier for this input source.

The system id is always required. The public id may be used to map to another system id, but the system id must always be present as a fall back.

If the system ID is a URL, it must be fully resolved.

Parameters:
systemId   The system identifier as a string.
See also:
getSystemId , Locator::getSystemId , SAXParseException::getSystemId


The documentation for this class was generated from the following file:


Copyright © 2000 The Apache Software Foundation. All Rights Reserved.