X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/424f5e27007ebf54b3b186e48d05d1c039c8e6ea..e1b8d4d841979b9fed749e1f8a18abc58975a4d9:/src/common/imagxpm.cpp diff --git a/src/common/imagxpm.cpp b/src/common/imagxpm.cpp index 7abef62368..19ae615e70 100644 --- a/src/common/imagxpm.cpp +++ b/src/common/imagxpm.cpp @@ -94,7 +94,7 @@ IMPLEMENT_DYNAMIC_CLASS(wxXPMHandler,wxImageHandler) #if wxUSE_STREAMS -bool wxXPMHandler::LoadFile(wxImage *image, +bool wxXPMHandler::LoadFile(wxImage *image, wxInputStream& stream, bool verbose, int WXUNUSED(index)) { @@ -108,32 +108,36 @@ bool wxXPMHandler::LoadFile(wxImage *image, } bool wxXPMHandler::SaveFile(wxImage * image, - wxOutputStream& stream, bool verbose) + wxOutputStream& stream, bool WXUNUSED(verbose)) { wxString tmp; char tmp_c; - + // 1. count colours: #define MaxCixels 92 - static const char Cixel[MaxCixels+1] = + static const char Cixel[MaxCixels+1] = " .XoO+@#$%&*=-;:>,<1234567890qwertyuipasdfghjk" "lzxcvbnmMNBVCZASDFGHJKLPIUYTREWQ!~^/()_`'][{}|"; int chars_per_pixel; int cols; int i, j, k; - + cols = image->CountColours(); chars_per_pixel = 1; for ( k = MaxCixels; cols > k; k *= MaxCixels) chars_per_pixel++; // 2. write the header: - tmp.Printf("/* XPM */\n" + char tmpbuf[200]; + // VS: 200b is safe upper bound for anything produced by sprintf bellow + // (101 bytes the string, neither %i can expand into more than 10 chars) + sprintf(tmpbuf, + "/* XPM */\n" "static char *xpm_data[] = {\n" "/* columns rows colors chars-per-pixel */\n" - "\"%i %i %i %i\",\n", + "\"%i %i %i %i\",\n", image->GetWidth(), image->GetHeight(), cols, chars_per_pixel); - stream.Write(tmp.mb_str(), tmp.Length()); + stream.Write(tmpbuf, strlen(tmpbuf)); // 3. create color symbols table: wxHashTable table(wxKEY_INTEGER); @@ -147,7 +151,7 @@ bool wxXPMHandler::SaveFile(wxImage * image, if (image->HasMask()) mask_key = (image->GetMaskRed() << 16) | (image->GetMaskGreen() << 8) | image->GetMaskBlue(); - + // 2b. generate colour table: table.BeginFind(); wxNode *node = NULL; @@ -174,7 +178,7 @@ bool wxXPMHandler::SaveFile(wxImage * image, else if (key == mask_key) tmp.Printf(wxT("\"%s c None\",\n"), sym); else - tmp.Printf(wxT("\"%s c #%s%s%s\",\n"), sym, + tmp.Printf(wxT("\"%s c #%s%s%s\",\n"), sym, wxDecToHex((unsigned char)(key >> 16)).c_str(), wxDecToHex((unsigned char)(key >> 8)).c_str(), wxDecToHex((unsigned char)(key)).c_str()); @@ -203,7 +207,7 @@ bool wxXPMHandler::SaveFile(wxImage * image, } tmp = wxT("};\n"); stream.Write(tmp.mb_str(), 3); - + delete[] symbols; delete[] symbols_data;