speed up XPM decoding 30-40% by not creating temporary wxString for each pixel

git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@50922 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
Paul Cornett
2007-12-27 03:04:56 +00:00
parent 309bd665c4
commit a59e42ee31

View File

@@ -664,7 +664,7 @@ wxImage wxXPMDecoder::ReadData(const char* const* xpm_data)
int count; int count;
unsigned width, height, colors_cnt, chars_per_pixel; unsigned width, height, colors_cnt, chars_per_pixel;
size_t i, j, i_key; size_t i, j, i_key;
wxChar key[64]; char key[64];
const char *clr_def; const char *clr_def;
bool hasMask; bool hasMask;
wxXPMColourMap clr_tbl; wxXPMColourMap clr_tbl;
@@ -692,7 +692,7 @@ wxImage wxXPMDecoder::ReadData(const char* const* xpm_data)
return wxNullImage; return wxNullImage;
img.SetMask(false); img.SetMask(false);
key[chars_per_pixel] = wxT('\0'); key[chars_per_pixel] = '\0';
hasMask = false; hasMask = false;
/* /*
@@ -712,7 +712,7 @@ wxImage wxXPMDecoder::ReadData(const char* const* xpm_data)
} }
for (i_key = 0; i_key < chars_per_pixel; i_key++) for (i_key = 0; i_key < chars_per_pixel; i_key++)
key[i_key] = (wxChar)xmpColLine[i_key]; key[i_key] = xmpColLine[i_key];
clr_def = ParseColor(xmpColLine + chars_per_pixel); clr_def = ParseColor(xmpColLine + chars_per_pixel);
if ( clr_def == NULL ) if ( clr_def == NULL )
@@ -766,6 +766,7 @@ wxImage wxXPMDecoder::ReadData(const char* const* xpm_data)
unsigned char *img_data = img.GetData(); unsigned char *img_data = img.GetData();
wxXPMColourMap::iterator entry; wxXPMColourMap::iterator entry;
wxXPMColourMap::iterator end = clr_tbl.end(); wxXPMColourMap::iterator end = clr_tbl.end();
wxString keyString;
for (j = 0; j < height; j++) for (j = 0; j < height; j++)
{ {
@@ -781,10 +782,11 @@ wxImage wxXPMDecoder::ReadData(const char* const* xpm_data)
for (i_key = 0; i_key < chars_per_pixel; i_key++) for (i_key = 0; i_key < chars_per_pixel; i_key++)
{ {
key[i_key] = (wxChar)xpmImgLine[chars_per_pixel * i + i_key]; key[i_key] = xpmImgLine[chars_per_pixel * i + i_key];
} }
entry = clr_tbl.find(key); keyString = key;
entry = clr_tbl.find(keyString);
if ( entry == end ) if ( entry == end )
{ {
wxLogError(_("XPM: Malformed pixel data!")); wxLogError(_("XPM: Malformed pixel data!"));