diff options
author | nyamatongwe <unknown> | 2003-01-03 02:45:30 +0000 |
---|---|---|
committer | nyamatongwe <unknown> | 2003-01-03 02:45:30 +0000 |
commit | 5374c3fabbc53e567c55cb9546e705b49791a1c7 (patch) | |
tree | d3c8c057328f8cbba002e33559f9f608a3bb9fdc /src | |
parent | 4ccb201634926f148ead6154e25b6ebeceb442ab (diff) | |
download | scintilla-mirror-5374c3fabbc53e567c55cb9546e705b49791a1c7.tar.gz |
Enable text form XPM for autocompletion lists.
Enable line form XPM for markers.
Diffstat (limited to 'src')
-rw-r--r-- | src/LineMarker.cxx | 15 | ||||
-rw-r--r-- | src/ScintillaBase.cxx | 2 |
2 files changed, 13 insertions, 4 deletions
diff --git a/src/LineMarker.cxx b/src/LineMarker.cxx index 99e54072f..faf265475 100644 --- a/src/LineMarker.cxx +++ b/src/LineMarker.cxx @@ -5,6 +5,7 @@ // Copyright 1998-2001 by Neil Hodgson <neilh@scintilla.org> // The License.txt file describes the conditions under which this software may be distributed. +#include <string.h> #include <stdlib.h> #include "Platform.h" @@ -151,9 +152,17 @@ void LineMarker::RefreshColourPalette(Palette &pal, bool want) { } void LineMarker::SetXPM(const char *textForm) { - delete pxpm; - pxpm = new XPM(textForm); - markType = SC_MARK_PIXMAP; + // Test done is two parts to avoid possibility of overstepping the memory + // if memcmp implemented strangely. Must be 4 bytes at least at destination. + if ((0 == memcmp(textForm, "/* X", 4)) && (0 == memcmp(textForm, "/* XPM */", 9))) { + // It is in text form + delete pxpm; + pxpm = new XPM(textForm); + markType = SC_MARK_PIXMAP; + } else { + // It is really in line form + SetXPM(reinterpret_cast<const char * const *>(textForm)); + } } void LineMarker::SetXPM(const char * const *linesForm) { diff --git a/src/ScintillaBase.cxx b/src/ScintillaBase.cxx index 1c44b0bd6..620513b4f 100644 --- a/src/ScintillaBase.cxx +++ b/src/ScintillaBase.cxx @@ -510,7 +510,7 @@ sptr_t ScintillaBase::WndProc(unsigned int iMessage, uptr_t wParam, sptr_t lPara return ac.dropRestOfWord; case SCI_REGISTERIMAGE: - ac.lb.SetTypeXpm(wParam, reinterpret_cast<const char **>(lParam)); + ac.lb.SetTypeXpm(wParam, reinterpret_cast<const char *>(lParam)); break; case SCI_CALLTIPSHOW: { |