X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/1309ba6c7ec76b4507cf1f2e8656749e3de1befa..f2616db56739e4962f683f59ac9e207756efe23c:/src/html/m_pre.cpp?ds=inline
diff --git a/src/html/m_pre.cpp b/src/html/m_pre.cpp
index a474a1ec38..43b3b597b5 100644
--- a/src/html/m_pre.cpp
+++ b/src/html/m_pre.cpp
@@ -20,10 +20,8 @@
#endif
#ifndef WXPRECOMP
-#include "wx/wx.h"
#endif
-
#include "wx/html/forcelnk.h"
#include "wx/html/m_templ.h"
@@ -33,6 +31,38 @@
FORCE_LINK_ME(m_pre)
+// replaces '\t', ' ' and '\n' with HTML markup:
+static wxString LINKAGEMODE HtmlizeWhitespaces(const wxString& str)
+{
+ wxString out;
+ size_t i = 0, j = 0, len = str.Len();
+ for (i = 0; i < len; i++)
+ {
+ switch (str[i])
+ {
+ case wxT('<'):
+ while (i < len && str[i] != wxT('>'))
+ out << str[i++];
+ out << wxT('>');
+ break;
+ case wxT(' '):
+ out << wxT(" ");
+ break;
+ case wxT('\n'):
+ out << wxT("
");
+ break;
+ case wxT('\t'):
+ for (j = 8 - i%8; j > 0; j--) out << wxT(" ");
+ break;
+ default:
+ out << str[i];
+ break;
+ }
+ }
+ return out;
+}
+
+
//-----------------------------------------------------------------------------
// The list handler:
//-----------------------------------------------------------------------------
@@ -62,21 +92,15 @@ TAG_HANDLER_BEGIN(PRE, "PRE")
c = m_WParser->OpenContainer();
c->SetAlignHor(wxHTML_ALIGN_LEFT);
- wxString src, srcMid;
-
- src = *m_WParser->GetSource();
- srcMid = src.Mid(tag.GetBeginPos(),
- tag.GetEndPos1() - tag.GetBeginPos());
- srcMid.Replace(wxT("\t"), wxT(" "));
- srcMid.Replace(wxT(" "), wxT(" "));
- srcMid.Replace(wxT("\n"), wxT("
"));
-
+ wxString srcMid =
+ m_WParser->GetSource()->Mid(tag.GetBeginPos(),
+ tag.GetEndPos1() - tag.GetBeginPos());
// It is safe to temporarily change the source being parsed,
// provided we restore the state back after parsing
- m_Parser->SetSource(srcMid);
+ m_Parser->SetSourceAndSaveState(HtmlizeWhitespaces(srcMid));
m_Parser->DoParsing();
- m_Parser->SetSource(src);
-
+ m_Parser->RestoreState();
+
m_WParser->CloseContainer();
c = m_WParser->OpenContainer();