]> git.saurik.com Git - wxWidgets.git/commitdiff
fix problem with label characters starting with -1 in ANSI build (#9572)
authorVadim Zeitlin <vadim@wxwidgets.org>
Sun, 22 Jun 2008 15:49:12 +0000 (15:49 +0000)
committerVadim Zeitlin <vadim@wxwidgets.org>
Sun, 22 Jun 2008 15:49:12 +0000 (15:49 +0000)
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@54331 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775

src/msw/control.cpp

index 24a4e37f2c4bc20c13d2057137d4e99314696d91..e2e7a25e1c51c345056fd9574e357a4a7cdbdb7b 100644 (file)
@@ -163,6 +163,20 @@ bool wxControl::MSWCreateControl(const wxChar *classname,
         return false;
     }
 
+#if !wxUSE_UNICODE
+    // Text labels starting with the character 0xff (which is a valid character
+    // in many code pages) don't appear correctly as CreateWindowEx() has some
+    // special treatment for this case, apparently the strings starting with -1
+    // are not really strings but something called "ordinals". There is no
+    // documentation about it but the fact is that the label gets mangled or
+    // not displayed at all if we don't do this, see #9572.
+    //
+    // Notice that 0xffff is not a valid Unicode character so the problem
+    // doesn't arise in Unicode build.
+    if ( !label.empty() && label[0] == -1 )
+        ::SetWindowText(GetHwnd(), label);
+#endif // !wxUSE_UNICODE
+
     // saving the label in m_labelOrig to return it verbatim
     // later in GetLabel()
     m_labelOrig = label;