X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/4eecf1150d4954e389f49c402756f2381915dd10..9a33ef7c3cc827658ba12b553c40af432f10bc3b:/src/html/winpars.cpp?ds=sidebyside diff --git a/src/html/winpars.cpp b/src/html/winpars.cpp index 4a5de2de4d..e8cbb16fff 100644 --- a/src/html/winpars.cpp +++ b/src/html/winpars.cpp @@ -8,7 +8,7 @@ ///////////////////////////////////////////////////////////////////////////// -#ifdef __GNUG__ +#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA) #pragma implementation "winpars.h" #endif @@ -54,6 +54,7 @@ wxHtmlWinParser::wxHtmlWinParser(wxHtmlWindow *wnd) : wxHtmlParser() m_InputEnc = wxFONTENCODING_ISO8859_1; m_OutputEnc = wxFONTENCODING_DEFAULT; #endif + m_lastWordCell = NULL; { int i, j, k, l, m; @@ -74,7 +75,7 @@ wxHtmlWinParser::wxHtmlWinParser(wxHtmlWindow *wnd) : wxHtmlParser() } // fill in wxHtmlParser's tables: - wxNode *node = m_Modules.GetFirst(); + wxList::compatibility_iterator node = m_Modules.GetFirst(); while (node) { wxHtmlTagsModule *mod = (wxHtmlTagsModule*) node->GetData(); @@ -170,6 +171,7 @@ void wxHtmlWinParser::InitParser(const wxString& source) m_ActualColor.Set(0, 0, 0); m_Align = wxHTML_ALIGN_LEFT; m_tmpLastWasSpace = FALSE; + m_lastWordCell = NULL; OpenContainer(); OpenContainer(); @@ -206,6 +208,8 @@ wxObject* wxHtmlWinParser::GetProduct() top = m_Container; while (top->GetParent()) top = top->GetParent(); + top->RemoveExtraSpacing(true, true); + return top; } @@ -278,9 +282,6 @@ void wxHtmlWinParser::AddText(const wxChar* txt) { temp[templen-1] = wxT(' '); temp[templen] = 0; -#if 0 // VS - WHY was this here?! - if (templen == 1) continue; -#endif templen = 0; #if !wxUSE_UNICODE if (m_EncConv) @@ -294,6 +295,8 @@ void wxHtmlWinParser::AddText(const wxChar* txt) if (m_UseLink) c->SetLink(m_Link); m_Container->InsertCell(c); + ((wxHtmlWordCell*)c)->SetPreviousWord(m_lastWordCell); + m_lastWordCell = (wxHtmlWordCell*)c; m_tmpLastWasSpace = TRUE; } } @@ -313,6 +316,8 @@ void wxHtmlWinParser::AddText(const wxChar* txt) if (m_UseLink) c->SetLink(m_Link); m_Container->InsertCell(c); + ((wxHtmlWordCell*)c)->SetPreviousWord(m_lastWordCell); + m_lastWordCell = (wxHtmlWordCell*)c; m_tmpLastWasSpace = FALSE; } }