Added support for more special characters
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@9858 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
@@ -135,41 +135,72 @@ wxHtmlWordCell::wxHtmlWordCell(const wxString& word, wxDC& dc) : wxHtmlCell()
|
||||
if (m_Word.Find(wxT('&')) != -1)
|
||||
{
|
||||
#define ESCSEQ(escape, subst) \
|
||||
{ _T("&") _T(escape) _T(";"), _T("&") _T(escape) _T(" "), _T(subst) }
|
||||
static wxChar* substitutions[][3] =
|
||||
{ _T("&") _T(escape) _T(";"), _T("&") _T(escape) _T(" "), _T("&") _T(escape), _T(subst) }
|
||||
static wxChar* substitutions[][4] =
|
||||
{
|
||||
ESCSEQ("quot", "\""),
|
||||
ESCSEQ("#34", "\""),
|
||||
ESCSEQ("lt", "<"),
|
||||
ESCSEQ("#60", "<"),
|
||||
ESCSEQ("gt", ">"),
|
||||
ESCSEQ("#62", ">"),
|
||||
|
||||
ESCSEQ("#94", "^"), /* ^ */
|
||||
|
||||
ESCSEQ("nbsp", " "),
|
||||
ESCSEQ("#32", " "),
|
||||
ESCSEQ("iexcl", "!"),
|
||||
ESCSEQ("cent", "\242"/* <20> */),
|
||||
ESCSEQ("#33", "!"),
|
||||
ESCSEQ("cent", "<EFBFBD>"/* <20> */),
|
||||
ESCSEQ("#162", "<EFBFBD>"/* <20> */),
|
||||
|
||||
ESCSEQ("yen", " "),
|
||||
ESCSEQ("brkbar", " "),
|
||||
ESCSEQ("sect", " "),
|
||||
ESCSEQ("uml", " "),
|
||||
ESCSEQ("trade", "(TM)"),
|
||||
ESCSEQ("#153", "(TM)"),
|
||||
|
||||
ESCSEQ("yen", "<EFBFBD>"),
|
||||
ESCSEQ("#165", "<EFBFBD>"),
|
||||
ESCSEQ("brkbar", "<EFBFBD>"),
|
||||
ESCSEQ("#166", "<EFBFBD>"),
|
||||
ESCSEQ("sect", "<EFBFBD>"),
|
||||
ESCSEQ("#167", "<EFBFBD>"),
|
||||
ESCSEQ("uml", "<EFBFBD>"),
|
||||
ESCSEQ("#168", "<EFBFBD>"),
|
||||
|
||||
ESCSEQ("copy", "(c)"),
|
||||
ESCSEQ("ordf", " "),
|
||||
ESCSEQ("laquo", " "),
|
||||
ESCSEQ("not", " "),
|
||||
ESCSEQ("copy", "<EFBFBD>"), /* <20> */
|
||||
ESCSEQ("#169", "<EFBFBD>"),
|
||||
ESCSEQ("ordf", "<EFBFBD>"),
|
||||
ESCSEQ("#170", "<EFBFBD>"),
|
||||
ESCSEQ("laquo", "<EFBFBD>"), /* <20> */
|
||||
ESCSEQ("#171", "<EFBFBD>"),
|
||||
ESCSEQ("not", "<EFBFBD>"),
|
||||
ESCSEQ("#172", "<EFBFBD>"),
|
||||
|
||||
ESCSEQ("reg", "(r)"),
|
||||
ESCSEQ("reg", "<EFBFBD>"), /* <20> */
|
||||
ESCSEQ("#174", "<EFBFBD>"),
|
||||
|
||||
ESCSEQ("deg", " "),
|
||||
ESCSEQ("plusm", " "),
|
||||
ESCSEQ("deg", "<EFBFBD>"), /* <20> */
|
||||
ESCSEQ("#176", "<EFBFBD>"),
|
||||
ESCSEQ("plusm", "<EFBFBD>"), /* <20> */
|
||||
ESCSEQ("#177", "<EFBFBD>"),
|
||||
|
||||
ESCSEQ("acute", " "),
|
||||
ESCSEQ("micro", " "),
|
||||
ESCSEQ("para", " "),
|
||||
ESCSEQ("acute", "<EFBFBD>"),
|
||||
ESCSEQ("#180", "<EFBFBD>"),
|
||||
ESCSEQ("macron", "<EFBFBD>"),
|
||||
ESCSEQ("#175", "<EFBFBD>"),
|
||||
ESCSEQ("micro", "<EFBFBD>"), /* <20> */
|
||||
ESCSEQ("#181", "<EFBFBD>"),
|
||||
ESCSEQ("para", "<EFBFBD>"), /* <20> */
|
||||
ESCSEQ("#182", "<EFBFBD>"),
|
||||
|
||||
ESCSEQ("ordm", " "),
|
||||
ESCSEQ("raquo", " "),
|
||||
ESCSEQ("ordm", "<EFBFBD>"), /* <20> */
|
||||
ESCSEQ("#186", "<EFBFBD>"),
|
||||
ESCSEQ("raquo", "<EFBFBD>"), /* <20> */
|
||||
ESCSEQ("#187", "<EFBFBD>"),
|
||||
|
||||
ESCSEQ("iquest", " "),
|
||||
ESCSEQ("iquest", "<EFBFBD>"), /* <20> */
|
||||
ESCSEQ("#191", "<EFBFBD>"),
|
||||
ESCSEQ("Agrave", "\300"/* <20> */),
|
||||
ESCSEQ("#193", "\300"/* <20> */),
|
||||
|
||||
ESCSEQ("Acirc", "\302"/* <20> */),
|
||||
ESCSEQ("Atilde", "\303"/* <20> */),
|
||||
@@ -232,16 +263,21 @@ wxHtmlWordCell::wxHtmlWordCell(const wxString& word, wxDC& dc) : wxHtmlCell()
|
||||
|
||||
ESCSEQ("yuml", ""),
|
||||
|
||||
ESCSEQ("#60", "<"),
|
||||
ESCSEQ("#62", ">"),
|
||||
|
||||
/* this one should ALWAYS stay the last one!!! */
|
||||
ESCSEQ("amp", "&"),
|
||||
ESCSEQ("#38", "&"),
|
||||
|
||||
{ NULL, NULL, NULL }
|
||||
};
|
||||
|
||||
for (int i = 0; substitutions[i][0] != NULL; i++)
|
||||
{
|
||||
m_Word.Replace(substitutions[i][0], substitutions[i][2], TRUE);
|
||||
m_Word.Replace(substitutions[i][1], substitutions[i][2], TRUE);
|
||||
m_Word.Replace(substitutions[i][0], substitutions[i][3], TRUE);
|
||||
m_Word.Replace(substitutions[i][1], substitutions[i][3], TRUE);
|
||||
m_Word.Replace(substitutions[i][2], substitutions[i][3], TRUE);
|
||||
}
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user