return result;
}
-
-
void wxHtmlParser::InitParser(const wxString& source)
{
- m_Source = source;
- m_Cache = new wxHtmlTagsCache(m_Source);
+ SetSource(source);
}
-
-
-
+
void wxHtmlParser::DoneParser()
{
delete m_Cache;
m_Cache = NULL;
}
-
-
+void wxHtmlParser::SetSource(const wxString& src)
+{
+ m_Source = src;
+ delete m_Cache;
+ m_Cache = new wxHtmlTagsCache(m_Source);
+}
void wxHtmlParser::DoParsing(int begin_pos, int end_pos)
{
templen = 0;
i = begin_pos;
- while (i < end_pos) {
+ while (i < end_pos)
+ {
c = m_Source[(unsigned int) i];
// continue building word:
- if (c != '<') {
+ if (c != '<')
+ {
temp[templen++] = c;
i++;
}
- else if (c == '<') {
+ else if (c == '<')
+ {
wxHtmlTag tag(m_Source, i, end_pos, m_Cache);
- if (templen) {
+ if (templen)
+ {
temp[templen] = 0;
AddText(temp);
templen = 0;
}
}
- if (templen) { // last word of block :-(
+ if (templen)
+ { // last word of block :-(
temp[templen] = 0;
AddText(temp);
}
delete[] temp;
}
-
-
void wxHtmlParser::AddTag(const wxHtmlTag& tag)
{
wxHtmlTagHandler *h;
h = (wxHtmlTagHandler*) m_HandlersHash.Get(tag.GetName());
if (h)
- inner = h -> HandleTag(tag);
- if (!inner) {
+ inner = h->HandleTag(tag);
+ if (!inner)
+ {
if (tag.HasEnding())
DoParsing(tag.GetBeginPos(), tag.GetEndPos1());
}
}
-
-
void wxHtmlParser::AddTagHandler(wxHtmlTagHandler *handler)
{
- wxString s(handler -> GetSupportedTags());
+ wxString s(handler->GetSupportedTags());
wxStringTokenizer tokenizer(s, ", ");
while (tokenizer.HasMoreTokens())
if (m_HandlersList.IndexOf(handler) == wxNOT_FOUND)
m_HandlersList.Append(handler);
- handler -> SetParser(this);
+ handler->SetParser(this);
}
-
-
void wxHtmlParser::PushTagHandler(wxHtmlTagHandler *handler, wxString tags)
{
wxStringTokenizer tokenizer(tags, ", ");
wxString key;
- if (m_HandlersStack == NULL) {
+ if (m_HandlersStack == NULL)
+ {
m_HandlersStack = new wxList;
- m_HandlersStack -> DeleteContents(TRUE);
+ m_HandlersStack->DeleteContents(TRUE);
}
- m_HandlersStack -> Insert(new wxHashTable(m_HandlersHash));
+ m_HandlersStack->Insert(new wxHashTable(m_HandlersHash));
- while (tokenizer.HasMoreTokens()) {
+ while (tokenizer.HasMoreTokens())
+ {
key = tokenizer.NextToken();
m_HandlersHash.Delete(key);
m_HandlersHash.Put(key, handler);
}
}
-
-
void wxHtmlParser::PopTagHandler()
{
wxNode *first;
if (m_HandlersStack == NULL ||
- (first = m_HandlersStack -> GetFirst()) == NULL)
+ (first = m_HandlersStack->GetFirst()) == NULL)
{
wxLogWarning(_("Warning: attempt to remove HTML tag handler from empty stack."));
return;
}
- m_HandlersHash = *((wxHashTable*) first -> GetData());
- m_HandlersStack -> DeleteNode(first);
+ m_HandlersHash = *((wxHashTable*) first->GetData());
+ m_HandlersStack->DeleteNode(first);
}
-
-
wxHtmlParser::~wxHtmlParser()
{
if (m_HandlersStack) delete m_HandlersStack;
m_HandlersList.Clear();
}
-
-
//-----------------------------------------------------------------------------
// wxHtmlTagHandler
//-----------------------------------------------------------------------------