2008-03-08 13:52:38 +00:00
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
// Name: richtext/richtextxml.h
|
2008-03-09 17:09:29 +00:00
|
|
|
// Purpose: interface of wxRichTextXMLHandler
|
2008-03-08 13:52:38 +00:00
|
|
|
// Author: wxWidgets team
|
|
|
|
// RCS-ID: $Id$
|
|
|
|
// Licence: wxWindows license
|
|
|
|
/////////////////////////////////////////////////////////////////////////////
|
|
|
|
|
|
|
|
/**
|
|
|
|
@class wxRichTextXMLHandler
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
A handler for loading and saving content in an XML format specific
|
|
|
|
to wxRichTextBuffer. You can either add the handler to the buffer
|
|
|
|
and load and save through the buffer or control API, or you can
|
|
|
|
create an instance of the handler on the stack and call its
|
|
|
|
functions directly.
|
2008-03-08 14:43:31 +00:00
|
|
|
|
2008-03-08 13:52:38 +00:00
|
|
|
@library{wxrichtext}
|
2008-03-09 17:09:29 +00:00
|
|
|
@category{richtext}
|
2008-03-08 13:52:38 +00:00
|
|
|
*/
|
|
|
|
class wxRichTextXMLHandler : public wxRichTextFileHandler
|
|
|
|
{
|
|
|
|
public:
|
|
|
|
/**
|
2008-03-09 16:24:26 +00:00
|
|
|
, wxString&@e ext = wxT("xml"), @b int@e type = wxRICHTEXT_TYPE_XML)
|
2008-03-08 13:52:38 +00:00
|
|
|
Constructor.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
wxRichTextXMLHandler() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns @true.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
bool CanLoad() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Returns @true.
|
|
|
|
*/
|
2008-03-09 16:24:26 +00:00
|
|
|
bool CanSave() const;
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Creates XML code for a given character or paragraph style.
|
|
|
|
*/
|
2008-03-09 12:33:59 +00:00
|
|
|
wxString CreateStyle(const wxTextAttr& attr, bool isPara = false);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Loads buffer context from the given stream.
|
|
|
|
*/
|
|
|
|
bool DoLoadFile(wxRichTextBuffer* buffer, wxInputStream& stream);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Saves buffer context to the given stream.
|
|
|
|
*/
|
|
|
|
bool DoSaveFile(wxRichTextBuffer* buffer, wxOutputStream& stream);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Recursively exports an object to the stream.
|
|
|
|
*/
|
|
|
|
bool ExportXML(wxOutputStream& stream, wxMBConv* convMem,
|
|
|
|
wxMBConv* convFile,
|
|
|
|
wxRichTextObject& obj,
|
|
|
|
int level);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Helper function: gets node context.
|
|
|
|
*/
|
|
|
|
wxString GetNodeContent(wxXmlNode* node);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Helper function: gets a named parameter from the XML node.
|
|
|
|
*/
|
|
|
|
wxXmlNode* GetParamNode(wxXmlNode* node, const wxString& param);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Helper function: gets a named parameter from the XML node.
|
|
|
|
*/
|
|
|
|
wxString GetParamValue(wxXmlNode* node, const wxString& param);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Helper function: gets style parameters from the given XML node.
|
|
|
|
*/
|
|
|
|
bool GetStyle(wxTextAttr& attr, wxXmlNode* node,
|
2008-03-09 12:33:59 +00:00
|
|
|
bool isPara = false);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Helper function: gets text from the node.
|
|
|
|
*/
|
|
|
|
wxString GetText(wxXmlNode* node,
|
|
|
|
const wxString& param = wxEmptyString,
|
2008-03-09 12:33:59 +00:00
|
|
|
bool translate = false);
|
2008-03-08 13:52:38 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
Helper function: returns @true if the node has the given parameter.
|
|
|
|
*/
|
|
|
|
bool HasParam(wxXmlNode* node, const wxString& param);
|
|
|
|
|
|
|
|
/**
|
|
|
|
Recursively imports an object.
|
|
|
|
*/
|
|
|
|
bool ImportXML(wxRichTextBuffer* buffer, wxXmlNode* node);
|
|
|
|
};
|
2008-03-10 15:24:38 +00:00
|
|
|
|