if (wd[wd.length()-1] == wxT('%'))
{
- wxSscanf(wd.c_str(), wxT("%i%%"), &m_ColsInfo[c].width);
- m_ColsInfo[c].units = wxHTML_UNITS_PERCENT;
+ if ( wxSscanf(wd.c_str(), wxT("%i%%"), &m_ColsInfo[c].width) == 1 )
+ {
+ m_ColsInfo[c].units = wxHTML_UNITS_PERCENT;
+ }
}
else
{
- wxSscanf(wd.c_str(), wxT("%i"), &m_ColsInfo[c].width);
- m_ColsInfo[c].width = (int)(m_PixelScale * (double)m_ColsInfo[c].width);
- m_ColsInfo[c].units = wxHTML_UNITS_PIXELS;
+ long width;
+ if ( wd.ToLong(&width) )
+ {
+ m_ColsInfo[c].width = (int)(m_PixelScale * (double)width);
+ m_ColsInfo[c].units = wxHTML_UNITS_PIXELS;
+ }
}
}
}
TAG_HANDLER_VARS
wxHtmlTableCell* m_Table;
wxString m_tAlign, m_rAlign;
+ wxHtmlContainerCell *m_enclosingContainer;
TAG_HANDLER_CONSTR(TABLE)
{
m_Table = NULL;
+ m_enclosingContainer = NULL;
m_tAlign = m_rAlign = wxEmptyString;
}
if (tag.GetName() == wxT("TABLE"))
{
wxHtmlTableCell *oldt = m_Table;
- wxHtmlContainerCell *oldcont;
- oldcont = c = m_WParser->OpenContainer();
+ m_enclosingContainer = c = m_WParser->OpenContainer();
- m_Table = new wxHtmlTableCell(c, tag);
+ m_Table = new wxHtmlTableCell(c, tag, m_WParser->GetPixelScale());
// width:
{
ParseInner(tag);
m_WParser->SetAlign(oldAlign);
- m_WParser->SetContainer(oldcont);
+ m_WParser->SetContainer(m_enclosingContainer);
m_WParser->CloseContainer();
m_Table = oldt;
- return true;
+
+ return true; // ParseInner() called
}
m_WParser->SetAlign(wxHTML_ALIGN_CENTER);
m_WParser->OpenContainer();
+
+ ParseInner(tag);
+
+ // set the current container back to the enclosing one so that
+ // text outside of <th> and <td> isn't included in any cell
+ // (this happens often enough in practice because it's common
+ // to use whitespace between </td> and the next <td>):
+ m_WParser->SetContainer(m_enclosingContainer);
+
+ return true; // ParseInner() called
}
}
+
return false;
}