]> git.saurik.com Git - wxWidgets.git/blame - interface/wx/html/htmltag.h
avoid GTK+ prefixes for our tree entry code, it is not part of GTK+
[wxWidgets.git] / interface / wx / html / htmltag.h
CommitLineData
23324ae1
FM
1/////////////////////////////////////////////////////////////////////////////
2// Name: html/htmltag.h
e54c96f1 3// Purpose: interface of wxHtmlTag
23324ae1
FM
4// Author: wxWidgets team
5// RCS-ID: $Id$
526954c5 6// Licence: wxWindows licence
23324ae1
FM
7/////////////////////////////////////////////////////////////////////////////
8
9/**
10 @class wxHtmlTag
7c913512
FM
11
12 This class represents a single HTML tag.
5bddd46d 13 It is used by @ref overview_html_handlers "tag handlers".
7c913512 14
23324ae1 15 @library{wxhtml}
551266a9 16 @category{html}
23324ae1 17*/
7c913512 18class wxHtmlTag
23324ae1 19{
551266a9 20protected:
23324ae1
FM
21 /**
22 Constructor. You will probably never have to construct a wxHtmlTag object
23 yourself. Feel free to ignore the constructor parameters.
5bddd46d 24 Have a look at @c src/html/htmlpars.cpp if you're interested in creating it.
23324ae1 25 */
8067ee11
FM
26 wxHtmlTag(wxHtmlTag* parent, const wxString* source,
27 const const_iterator& pos, const const_iterator& end_pos,
28 wxHtmlTagsCache* cache, wxHtmlEntitiesParser* entParser);
23324ae1 29
551266a9 30public:
23324ae1
FM
31 /**
32 Returns a string containing all parameters.
5bddd46d
FM
33 Example: tag contains \<FONT SIZE=+2 COLOR="#000000"\>.
34 Call to tag.GetAllParams() would return @c 'SIZE=+2 COLOR="#000000"'.
23324ae1 35 */
5267aefd 36 wxString GetAllParams() const;
23324ae1
FM
37
38 /**
39 Returns beginning position of the text @e between this tag and paired
5bddd46d
FM
40 ending tag. See explanation (returned position is marked with '|'):
41 @code
42 bla bla bla <MYTAG> bla bla internal text</MYTAG> bla bla
43 |
44 @endcode
45
adaaa686 46 @deprecated @todo provide deprecation description
23324ae1 47 */
328f5751 48 int GetBeginPos() const;
23324ae1
FM
49
50 /**
51 Returns ending position of the text @e between this tag and paired
5bddd46d
FM
52 ending tag. See explanation (returned position is marked with '|'):
53 @code
54 bla bla bla <MYTAG> bla bla internal text</MYTAG> bla bla
55 |
56 @endcode
57
18e8e19b 58 @deprecated @todo provide deprecation description
23324ae1 59 */
328f5751 60 int GetEndPos1() const;
23324ae1
FM
61
62 /**
63 Returns ending position 2 of the text @e between this tag and paired
5bddd46d
FM
64 ending tag. See explanation (returned position is marked with '|'):
65 @code
66 bla bla bla <MYTAG> bla bla internal text</MYTAG> bla bla
67 |
68 @endcode
69
18e8e19b 70 @deprecated @todo provide deprecation description
23324ae1 71 */
328f5751 72 int GetEndPos2() const;
23324ae1
FM
73
74 /**
75 Returns tag's name. The name is always in uppercase and it doesn't contain
163bd4f7 76 &quot; or '/' characters. (So the name of \<FONT SIZE=+2\> tag is "FONT"
5bddd46d 77 and name of \</table\> is "TABLE").
23324ae1 78 */
328f5751 79 wxString GetName() const;
23324ae1
FM
80
81 /**
82 Returns the value of the parameter. You should check whether the
83 parameter exists or not (use wxHtmlTag::HasParam) first.
18e8e19b 84
7c913512 85 @param par
4cc4bfaf 86 The parameter's name.
7c913512 87 @param with_quotes
4cc4bfaf 88 @true if you want to get quotes as well. See example.
5bddd46d
FM
89
90 Example:
91 @code
92 ...
93 // you have wxHtmlTag variable tag which is equal to the
94 // HTML tag <FONT SIZE=+2 COLOR="#0000FF">
95 dummy = tag.GetParam("SIZE");
96 // dummy == "+2"
97 dummy = tag.GetParam("COLOR");
98 // dummy == "#0000FF"
99 dummy = tag.GetParam("COLOR", true);
100 // dummy == "\"#0000FF\"" -- see the difference!!
101 @endcode
23324ae1 102 */
328f5751 103 wxString GetParam(const wxString& par, bool with_quotes = false) const;
23324ae1
FM
104
105 /**
4cc4bfaf 106 Interprets tag parameter @a par as colour specification and saves its value
5bddd46d
FM
107 into wxColour variable pointed by @a clr.
108
4cc4bfaf 109 Returns @true on success and @false if @a par is not colour specification or
23324ae1 110 if the tag has no such parameter.
f68e16c5
VZ
111
112 @see ParseAsColour()
23324ae1 113 */
328f5751 114 bool GetParamAsColour(const wxString& par, wxColour* clr) const;
23324ae1
FM
115
116 /**
4cc4bfaf 117 Interprets tag parameter @a par as an integer and saves its value
5bddd46d
FM
118 into int variable pointed by @a value.
119
4cc4bfaf 120 Returns @true on success and @false if @a par is not an integer or
23324ae1
FM
121 if the tag has no such parameter.
122 */
328f5751 123 bool GetParamAsInt(const wxString& par, int* value) const;
23324ae1
FM
124
125 /**
126 Returns @true if this tag is paired with ending tag, @false otherwise.
23324ae1 127 See the example of HTML document:
5bddd46d
FM
128 @code
129 <html><body>
130 Hello<p>
131 How are you?
132 <p align=center>This is centered...</p>
133 Oops<br>Oooops!
134 </body></html>
135 @endcode
18e8e19b 136
7c913512 137 In this example tags HTML and BODY have ending tags, first P and BR
5bddd46d
FM
138 doesn't have ending tag while the second P has.
139 The third P tag (which is ending itself) of course doesn't have ending tag.
23324ae1 140 */
328f5751 141 bool HasEnding() const;
23324ae1
FM
142
143 /**
7c913512 144 Returns @true if the tag has a parameter of the given name.
5bddd46d 145 Example: \<FONT SIZE=+2 COLOR="\#FF00FF"\> has two parameters named
23324ae1 146 "SIZE" and "COLOR".
18e8e19b 147
7c913512 148 @param par
4cc4bfaf 149 the parameter you're looking for.
23324ae1 150 */
328f5751 151 bool HasParam(const wxString& par) const;
23324ae1 152
f68e16c5
VZ
153 /**
154 Parses the given string as an HTML colour.
155
156 This function recognizes the standard named HTML 4 colours as well as
157 the usual RGB syntax.
158
159 @since 2.9.1
160
161 @see wxColour::Set()
162
163 @return @true if the string was successfully parsed and @a clr was
164 filled with the result or @false otherwise.
165 */
166 static bool ParseAsColour(const wxString& str, wxColour *clr);
167
a44f3b5a 168 //@{
23324ae1 169 /**
7c913512 170 This method scans the given parameter. Usage is exactly the same as sscanf's
23324ae1 171 usage except that you don't pass a string but a parameter name as the first
5bddd46d
FM
172 argument and you can only retrieve one value (i.e. you can use only one "%"
173 element in @a format).
18e8e19b 174
7c913512 175 @param par
4cc4bfaf 176 The name of the tag you want to query
7c913512 177 @param format
4cc4bfaf 178 scanf()-like format string.
7c913512 179 @param value
4cc4bfaf 180 pointer to a variable to store the value in
23324ae1 181 */
a44f3b5a
FM
182 int ScanParam(const wxString& par, const wchar_t* format, void* value) const;
183 int ScanParam(const wxString& par, const char* format, void* value) const;
184 //@}
23324ae1 185};
e54c96f1 186