]>
git.saurik.com Git - wxWidgets.git/blob - interface/wx/html/htmlpars.h
1 /////////////////////////////////////////////////////////////////////////////
2 // Name: html/htmlpars.h
3 // Purpose: interface of wxHtmlTagHandler
4 // Author: wxWidgets team
6 // Licence: wxWindows licence
7 /////////////////////////////////////////////////////////////////////////////
19 @class wxHtmlTagHandler
26 @see @ref overview_html_handlers, wxHtmlTag
28 class wxHtmlTagHandler
: public wxObject
37 Returns list of supported tags.
38 The list is in uppercase and tags are delimited by ','.
39 Example: @c "I,B,FONT,P"
41 virtual wxString
GetSupportedTags() = 0;
44 This is the core method of each handler. It is called each time
45 one of supported tags is detected. @a tag contains all necessary
46 info (see wxHtmlTag for details).
51 bool MyHandler::HandleTag(const wxHtmlTag& tag)
54 // change state of parser (e.g. set bold face)
57 // restore original state of parser
61 You shouldn't call ParseInner() if the tag is not paired with an ending one.
63 @return @true if ParseInner() was called, @false otherwise.
65 virtual bool HandleTag(const wxHtmlTag
& tag
) = 0;
68 Assigns @a parser to this handler. Each @b instance of handler
69 is guaranteed to be called only from the one parser.
71 virtual void SetParser(wxHtmlParser
* parser
);
74 Returns the parser associated with this tag handler.
78 wxHtmlParser
* GetParser() const;
84 This method calls parser's wxHtmlParser::DoParsing method
85 for the string between this tag and the paired ending tag:
87 ...<A HREF="x.htm">Hello, world!</A>...
90 In this example, a call to ParseInner() (with @a tag pointing to A tag)
91 will parse 'Hello, world!'.
93 void ParseInner(const wxHtmlTag
& tag
);
96 Parses given source as if it was tag's inner code (see
97 wxHtmlParser::GetInnerSource). Unlike ParseInner(), this method lets
98 you specify the source code to parse. This is useful when you need to
99 modify the inner text before parsing.
101 void ParseInnerSource(const wxString
& source
);
104 This attribute is used to access parent parser. It is protected so that
105 it can't be accessed by user but can be accessed from derived classes.
107 wxHtmlParser
* m_Parser
;
115 Classes derived from this handle the @b generic parsing of HTML documents: it
116 scans the document and divide it into blocks of tags (where one block consists
117 of beginning and ending tag and of text between these two tags).
119 It is independent from wxHtmlWindow and can be used as stand-alone parser.
121 It uses system of tag handlers to parse the HTML document. Tag handlers
122 are not statically shared by all instances but are created for each
123 wxHtmlParser instance. The reason is that the handler may contain
124 document-specific temporary data used during parsing (e.g. complicated
125 structures like tables).
127 Typically the user calls only the wxHtmlParser::Parse method.
132 @see @ref overview_html_cells, @ref overview_html_handlers, wxHtmlTag
143 Adds handler to the internal list ( hash table) of handlers.
144 This method should not be called directly by user but rather by derived class'
147 This adds the handler to this @b instance of wxHtmlParser, not to
148 all objects of this class!
149 (Static front-end to AddTagHandler is provided by wxHtmlWinParser).
151 All handlers are deleted on object deletion.
153 virtual void AddTagHandler(wxHtmlTagHandler
* handler
);
156 Must be overwritten in derived class.
158 This method is called by DoParsing() each time a part of text is parsed.
159 @a txt is NOT only one word, it is substring of input.
160 It is not formatted or preprocessed (so white spaces are unmodified).
162 virtual void AddWord(const wxString
& txt
);
165 Parses the m_Source from @a begin_pos to @a end_pos - 1.
167 void DoParsing(const const_iterator
& begin_pos
, const const_iterator
& end_pos
);
170 Parses the whole m_Source.
175 This must be called after DoParsing().
177 virtual void DoneParser();
180 Returns pointer to the file system. Because each tag handler has
181 reference to it is parent parser it can easily request the file by
184 wxFSFile *f = m_Parser -> GetFS() -> OpenFile("image.jpg");
187 wxFileSystem
* GetFS() const;
190 Returns product of parsing.
191 Returned value is result of parsing of the document.
193 The type of this result depends on internal representation in derived
194 parser (but it must be derived from wxObject!).
195 See wxHtmlWinParser for details.
197 virtual wxObject
* GetProduct() = 0;
200 Returns pointer to the source being parsed.
202 const wxString
* GetSource();
205 Setups the parser for parsing the @a source string.
206 (Should be overridden in derived class)
208 virtual void InitParser(const wxString
& source
);
211 Opens given URL and returns @c wxFSFile object that can be used to read data
212 from it. This method may return @NULL in one of two cases: either the URL doesn't
213 point to any valid resource or the URL is blocked by overridden implementation
214 of @e OpenURL in derived class.
217 Indicates type of the resource. Is one of:
218 - wxHTML_URL_PAGE: Opening a HTML page.
219 - wxHTML_URL_IMAGE: Opening an image.
220 - wxHTML_URL_OTHER: Opening a resource that doesn't fall into
226 Always use this method in tag handlers instead of GetFS()->OpenFile()
227 because it can block the URL and is thus more secure.
228 Default behaviour is to call wxHtmlWindow::OnOpeningURL of the associated
229 wxHtmlWindow object (which may decide to block the URL or redirect it to
230 another one),if there's any, and always open the URL if the parser is not
231 used with wxHtmlWindow.
232 Returned wxFSFile object is not guaranteed to point to url, it might have
235 virtual wxFSFile
* OpenURL(wxHtmlURLType type
, const wxString
& url
) const;
238 Proceeds parsing of the document. This is end-user method. You can simply
239 call it when you need to obtain parsed output (which is parser-specific).
241 The method does these things:
242 -# calls InitParser(source)
244 -# calls GetProduct()
245 -# calls DoneParser()
246 -# returns value returned by GetProduct()
248 You shouldn't use InitParser(), DoParsing(), GetProduct() or DoneParser() directly.
250 wxObject
* Parse(const wxString
& source
);
253 Restores parser's state before last call to PushTagHandler().
255 void PopTagHandler();
258 Forces the handler to handle additional tags
259 (not returned by wxHtmlTagHandler::GetSupportedTags).
260 The handler should already be added to this parser.
265 List of tags (in same format as GetSupportedTags()'s return value).
266 The parser will redirect these tags to handler (until call to PopTagHandler()).
270 Imagine you want to parse following pseudo-html structure:
273 <param name="one" value="1">
274 <param name="two" value="2">
278 <param program="text.exe">
282 It is obvious that you cannot use only one tag handler for \<param\> tag.
283 Instead you must use context-sensitive handlers for \<param\> inside \<myitems\>
284 and \<param\> inside \<execute\>.
285 This is the preferred solution:
288 TAG_HANDLER_BEGIN(MYITEM, "MYITEMS")
289 TAG_HANDLER_PROC(tag)
293 m_Parser -> PushTagHandler(this, "PARAM");
295 m_Parser -> PopTagHandler();
299 TAG_HANDLER_END(MYITEM)
302 void PushTagHandler(wxHtmlTagHandler
* handler
,
303 const wxString
& tags
);
306 Sets the virtual file system that will be used to request additional files.
307 (For example @c IMG tag handler requests wxFSFile with the image data.)
309 void SetFS(wxFileSystem
* fs
);
312 Call this function to interrupt parsing from a tag handler.
313 No more tags will be parsed afterward. This function may only be called
314 from Parse() or any function called by it (i.e. from tag handlers).
316 virtual void StopParsing();
321 This may (and may not) be overwritten in derived class.
323 This method is called each time new tag is about to be added.
324 @a tag contains information about the tag. (See wxHtmlTag for details.)
326 Default (wxHtmlParser) behaviour is this: first it finds a handler capable
327 of handling this tag and then it calls handler's HandleTag() method.
329 virtual void AddTag(const wxHtmlTag
& tag
);