2012-04-29 20:52:25 +02:00
|
|
|
//
|
|
|
|
// CharacterData.h
|
|
|
|
//
|
|
|
|
// $Id: //poco/1.4/XML/include/Poco/DOM/CharacterData.h#1 $
|
|
|
|
//
|
|
|
|
// Library: XML
|
|
|
|
// Package: DOM
|
|
|
|
// Module: DOM
|
|
|
|
//
|
|
|
|
// Definition of the DOM CharacterData class.
|
|
|
|
//
|
|
|
|
// Copyright (c) 2004-2006, Applied Informatics Software Engineering GmbH.
|
|
|
|
// and Contributors.
|
|
|
|
//
|
|
|
|
// Permission is hereby granted, free of charge, to any person or organization
|
|
|
|
// obtaining a copy of the software and accompanying documentation covered by
|
|
|
|
// this license (the "Software") to use, reproduce, display, distribute,
|
|
|
|
// execute, and transmit the Software, and to prepare derivative works of the
|
|
|
|
// Software, and to permit third-parties to whom the Software is furnished to
|
|
|
|
// do so, all subject to the following:
|
|
|
|
//
|
|
|
|
// The copyright notices in the Software and this entire statement, including
|
|
|
|
// the above license grant, this restriction and the following disclaimer,
|
|
|
|
// must be included in all copies of the Software, in whole or in part, and
|
|
|
|
// all derivative works of the Software, unless such copies or derivative
|
|
|
|
// works are solely in the form of machine-executable object code generated by
|
|
|
|
// a source language processor.
|
|
|
|
//
|
|
|
|
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
// FITNESS FOR A PARTICULAR PURPOSE, TITLE AND NON-INFRINGEMENT. IN NO EVENT
|
|
|
|
// SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE
|
|
|
|
// FOR ANY DAMAGES OR OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE,
|
|
|
|
// ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
|
|
|
|
// DEALINGS IN THE SOFTWARE.
|
|
|
|
//
|
|
|
|
|
|
|
|
|
|
|
|
#ifndef DOM_CharacterData_INCLUDED
|
|
|
|
#define DOM_CharacterData_INCLUDED
|
|
|
|
|
|
|
|
|
|
|
|
#include "Poco/XML/XML.h"
|
|
|
|
#include "Poco/DOM/AbstractNode.h"
|
|
|
|
#include "Poco/XML/XMLString.h"
|
|
|
|
|
|
|
|
|
|
|
|
namespace Poco {
|
|
|
|
namespace XML {
|
|
|
|
|
|
|
|
|
|
|
|
class XML_API CharacterData: public AbstractNode
|
|
|
|
/// The CharacterData interface extends Node with a set of attributes and methods
|
|
|
|
/// for accessing character data in the DOM. For clarity this set is defined
|
|
|
|
/// here rather than on each object that uses these attributes and methods.
|
|
|
|
/// No DOM objects correspond directly to CharacterData, though Text and others
|
|
|
|
/// do inherit the interface from it. All offsets in this interface start from 0.
|
|
|
|
///
|
|
|
|
/// Text strings in the DOM are represented in either UTF-8 (if XML_UNICODE_WCHAR_T is
|
|
|
|
/// not defined) or in UTF-16 (if XML_UNICODE_WCHAR_T is defined).
|
|
|
|
/// Indexing on character data is done in XMLChar units.
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
const XMLString& data() const;
|
|
|
|
/// Returns the character data of the node that
|
|
|
|
/// implements the interface.
|
|
|
|
|
|
|
|
const XMLString& getData() const;
|
|
|
|
/// Returns the character data of the node that
|
|
|
|
/// implements the interface.
|
|
|
|
|
|
|
|
void setData(const XMLString& data);
|
|
|
|
/// Sets the character data of the node that
|
|
|
|
/// implements the interface.
|
|
|
|
|
|
|
|
unsigned long length() const;
|
|
|
|
/// Returns the number of XMLChars that are available
|
|
|
|
/// through getData and substringData. This may have the
|
|
|
|
/// value zero.
|
|
|
|
|
|
|
|
XMLString substringData(unsigned long offset, unsigned long count) const;
|
|
|
|
/// Extracts a range of data from the node.
|
|
|
|
/// If offset and count exceeds the length, then all
|
|
|
|
/// the characters to the end of the data are returned.
|
|
|
|
|
|
|
|
void appendData(const XMLString& arg);
|
|
|
|
/// Append the string to the end of the character data
|
|
|
|
/// of the node.
|
|
|
|
|
|
|
|
void insertData(unsigned long offset, const XMLString& arg);
|
|
|
|
/// Insert a string at the specified character offset.
|
|
|
|
|
|
|
|
void deleteData(unsigned long offset, unsigned long count);
|
|
|
|
/// Remove a range of characters from the node.
|
|
|
|
|
|
|
|
void replaceData(unsigned long offset, unsigned long count, const XMLString& arg);
|
|
|
|
/// Replace the characters starting at the specified character
|
|
|
|
/// offset with the specified string.
|
|
|
|
|
|
|
|
// Non-standard extensions
|
|
|
|
XMLString trimmedData() const;
|
|
|
|
/// Returns the character data of that node with
|
|
|
|
/// all surrounding whitespace removed.
|
|
|
|
///
|
|
|
|
/// This method is an extension to the W3C Document Object Model.
|
|
|
|
|
|
|
|
// Node
|
|
|
|
const XMLString& getNodeValue() const;
|
|
|
|
void setNodeValue(const XMLString& value);
|
|
|
|
|
|
|
|
protected:
|
|
|
|
CharacterData(Document* pOwnerDocument, const XMLString& data);
|
|
|
|
CharacterData(Document* pOwnerDocument, const CharacterData& data);
|
|
|
|
~CharacterData();
|
|
|
|
|
|
|
|
private:
|
|
|
|
XMLString _data;
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
|
|
//
|
|
|
|
// inlines
|
|
|
|
//
|
|
|
|
inline const XMLString& CharacterData::data() const
|
|
|
|
{
|
|
|
|
return _data;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
inline const XMLString& CharacterData::getData() const
|
|
|
|
{
|
|
|
|
return _data;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
inline unsigned long CharacterData::length() const
|
|
|
|
{
|
|
|
|
return (unsigned long) _data.length();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
} } // namespace Poco::XML
|
|
|
|
|
|
|
|
|
|
|
|
#endif // DOM_CharacterData_INCLUDED
|