]>
Commit | Line | Data |
---|---|---|
1 | wxWindows 2 Change Log | |
2 | ---------------------- | |
3 | ||
4 | INCOMPATIBLE CHANGES SINCE 2.2.x | |
5 | ================================ | |
6 | ||
7 | Please take a few minutes to read the following list, especially | |
8 | paying attention to the most important changes which are marked | |
9 | with '!' in the first column. | |
10 | ||
11 | Also please note that you should ensure that WXWIN_COMPATIBILITY_2_2 | |
12 | is defined to 1 if you wish to retain maximal compatibility with 2.2 | |
13 | series -- however you are also strongly encouraged to try to compile | |
14 | your code without this define as it won't be default any longer in | |
15 | 2.6 release. | |
16 | ||
17 | ||
18 | wxBase: | |
19 | ||
20 | ! wxArray<T>::Remove(size_t) has been removed to fix compilation problems | |
21 | under 64 bit architectures, please replace it with RemoveAt() in your | |
22 | code. | |
23 | ||
24 | ! wxArray<T> macros have been changed to fix runtime problems under 64 bit | |
25 | architectures and as a side effect of this WX_DEFINE_ARRAY() can only be | |
26 | used now for the pointer types, WX_DEFINE_ARRAY_INT should be used for the | |
27 | arrays containing non-pointers. | |
28 | ||
29 | - wxObject::CopyObject() and Clone() methods were removed because they | |
30 | simply don't make sense for all objects | |
31 | ||
32 | - wxEvent now has a pure virtual Clone() method which must be implemented | |
33 | by all derived classes, if you have user-defined event classes please | |
34 | add "wxEvent *Clone() const { return new MyEvent(*this); }" line to them | |
35 | ||
36 | - small change to wxStopWatch::Pause() semantics, please see the documentation | |
37 | ||
38 | - unlikely but possible incompatibility: the definition of TRUE has changed | |
39 | from "1" to "(bool)1" (and the same thing for FALSE), so the code which | |
40 | could be erroneously compiled previously such as doing "return FALSE" from | |
41 | a function returning a pointer would stop compiling now (but this change | |
42 | is not supposed to have any effects on valid code) | |
43 | ||
44 | - another minor change: wxApp::OnAssert() has a new "cond" argument, you | |
45 | must modify YourApp::OnAssert() signature if you were using it to override | |
46 | the default assert handling. | |
47 | ||
48 | ||
49 | All (GUI): | |
50 | ||
51 | ! the event type constants are not constants any more but are dynamically | |
52 | allocated during run-time which means that they can't be used as case labels | |
53 | in the switch()es, you must rewrite them to use if()s instead | |
54 | ||
55 | You may also define WXWIN_COMPATIBILITY_EVENT_TYPES to get the old behaviour | |
56 | but this is strongly discouraged, please consider changing your code | |
57 | instead! | |
58 | ||
59 | ! wxDialog does not derive from wxPanel any longer - if you were using it in | |
60 | your code, please update it. The quick fix for the most cases is to replace | |
61 | the occurrences of wxPanel with wxWindow. | |
62 | ||
63 | ! if you handle (and don't skip) EVT_KEY_DOWN, the EVT_CHAR event is not | |
64 | generated at all, so you must call event.Skip() in your OnKeyDown() if | |
65 | you want to get OnChar() as well | |
66 | ||
67 | - wxYES_NO is now wxYES | wxNO and the manifest values of both wxYES and wxNO | |
68 | have changed (to fix some unfortunate clashes), please check your code to | |
69 | ensure that no tests for wxYES or wxNO are broken: for example, the following | |
70 | will *NOT* work any longer: | |
71 | ||
72 | if ( flags & wxYES_NO ) | |
73 | ... do something ... | |
74 | if ( flags & wxYES ) | |
75 | ... do something else ... | |
76 | ||
77 | - wxGLCanvas now derives directly from wxWindow, not wxScrolledWindow | |
78 | ||
79 | - wxGridCellAttrProvider class API changed, you will need to update your code | |
80 | if you derived any classes from it | |
81 | ||
82 | - wxImage::ComputeHistogram()'s signature changed to | |
83 | unsigned long ComputeHistogram(wxImageHistogram&) const | |
84 | ||
85 | - wxEvtHandler cannot be copied/assigned any longer - this never worked but | |
86 | now it results in compile-time error instead of run-time crashes | |
87 | ||
88 | - WXK_NUMLOCK and WXK_SCROLL keys no longer result in EVT_CHAR() events, | |
89 | they only generate EVT_KEY_DOWN/UP() ones | |
90 | ||
91 | - the dialogs use wxApp::GetTopWindow() as the parent implicitly if the | |
92 | parent specified is NULL, use wxDIALOG_NO_PARENT style to prevent this | |
93 | from happening | |
94 | ||
95 | - several obsolete synonyms are only retained in WXWIN_COMPATIBILITY_2_2 mode: | |
96 | for example, use wxScrolledWindow::GetViewStart() now instead of ViewStart() | |
97 | and GetCount() instead of Number() in many classes | |
98 | ||
99 | ||
100 | wxMSW: | |
101 | ||
102 | ! build system changed: setup.h is not a static file in include/wx any more | |
103 | but is created as part of the build process under lib/<toolkit>/wx/include | |
104 | where <toolkit> is of the form (msw|univ)[dll][u][d]. You'll need to update | |
105 | the include path in your make/project files appropriately. Furthermore, | |
106 | xpm.lib is no longer used by wxMSW, it was superseded by the wxXPMDecoder | |
107 | class. You'll need to remove all references to xpm.lib from your | |
108 | make/project files. | |
109 | ||
110 | - child frames appear in the taskbar by default now, use wxFRAME_NO_TASKBAR | |
111 | style to avoid it | |
112 | ||
113 | - all overloads of wxDC::SetClippingRegion() combine the given region with the | |
114 | previously selected one instead of replacing it | |
115 | ||
116 | - wxGetHomeDir() uses HOME environment variable and if it is set will not | |
117 | return the programs directory any longer but its value (this function has | |
118 | never been meant to return the programs directory anyhow) | |
119 | ||
120 | - wxHTML apps don't need to include wx/html/msw/wxhtml.rc in resources file | |
121 | anymore. The file was removed from wxMSW | |
122 | ||
123 | ||
124 | Unix ports: | |
125 | ||
126 | ! You should use `wx-config --cxxflags` in your makefiles instead of | |
127 | `wx-config --cflags` for compiling C++ files. CXXFLAGS contains CFLAGS | |
128 | and the compiler flags for C++ files only, CFLAGS should still be used | |
129 | to compile pure C files. | |
130 | ||
131 | ||
132 | wxThread and related classes: | |
133 | ||
134 | - The thread-related classes have been heavily changed since 2.2.x versions | |
135 | as the old code had many serious problems. This could have resulted in | |
136 | semantical changes other than those mentioned here, please review use of | |
137 | wxThread, wxMutex and wxCondition classes in your code. | |
138 | ||
139 | ! wxCondition now *must* be used with a mutex, please read the (updated) class | |
140 | documentation for details and revise your code accordingly: this change was | |
141 | unfortunately needed as it was impossible to ensure the correct behaviour | |
142 | (i.e. absense of race conditions) using the old API. | |
143 | ||
144 | - wxMutex is not recursive any more in POSIX implementation (it hasn't been | |
145 | recursive in 2.2.x but was in 2.3.1 and 2.3.2), please refer to the class | |
146 | documentation for the discussion of the recursive mutexes. | |
147 | ||
148 | - wxMutex::IsLocked() doesn't exist any more and should have never existed: | |
149 | this is was unique example of a thread-unsafe-by-design method. | |
150 | ||
151 | ||
152 | OTHER CHANGES | |
153 | ============= | |
154 | ||
155 | 2.3.3 | |
156 | ----- | |
157 | ||
158 | wxBase: | |
159 | ||
160 | - wxSemaphore class added, many fixed to wxCondition and wxThread (K.S. Sreeram) | |
161 | - fixes to the command line parsing error and usage messages | |
162 | - modified wxFileName::CreateTempFileName() to open the file atomically | |
163 | (if possible) and, especially, not to leak the file descriptors under Unix | |
164 | - memory leak in wxHTTP fixed (Dimitri) | |
165 | - fixes to AM_PATH_WXCONFIG autoconf macro | |
166 | - added wxHashMap class that replaces type-unsafe wxHashTable and is modelled | |
167 | after (non standard) STL hash_map | |
168 | - wxLocale now works in Unicode mode | |
169 | - wxLocale can now load message catalogs in arbitrary encoding | |
170 | - fixed the bug related to the redrawing on resize introduced in 2.3.2 | |
171 | - added static wxFontMapper::Get() accessor (use of wxTheFontMapper is now | |
172 | deprecated) | |
173 | - added wxShutdown() function (Marco Cavallini) | |
174 | ||
175 | Unix (Base/GUI): | |
176 | ||
177 | - wxWindows may be built using BSD and Solaris (and possibly other) make | |
178 | programs and not only GNU make | |
179 | - wxTCP-based IPC classes now support communicating over Unix domain sockets | |
180 | ||
181 | All (GUI): | |
182 | ||
183 | - it is now possible to set the icons of different sizes for frames (e.g. a | |
184 | small and big ones) using the new wxIconBundle class | |
185 | - implemented radio menu items and radio toolbar buttons | |
186 | - added possibility to show text in the toolbar buttons | |
187 | - added wxArtProvider class that can be used to customize the look of standard | |
188 | wxWindows dialogs | |
189 | - significantly improved native font support | |
190 | - wxImage::ComputeHistogram() now uses wxImageHistogram instead of type-unsafe | |
191 | wxHashTable | |
192 | - added IFF image handler | |
193 | - fixed using custom renderers in wxGrid which was broken in 2.3.2 | |
194 | - support for multiple images in one file added to wxImage (TIFF, GIF and ICO formats) | |
195 | - support for CUR and ANI files in wxImage added (Chris Elliott) | |
196 | - wxTextCtrl::GetRange() added | |
197 | - added wxGetFontFromUser() convenience function | |
198 | - added EVT_MENU_OPEN and EVT_MENU_CLOSE events | |
199 | - added Hungarian translations (Janos Vegh) | |
200 | - added wxImage::SaveFile(filename) method (Chris Elliott) | |
201 | - added wxImage::FloodFill and implemented wxWindowDC::DoFloodFill method | |
202 | for GTK+, Mac, MGL, X11, Motif ports (Chris Elliott) | |
203 | - added (platform-dependent) scan code to wxKeyEvent (Bryce Denney) | |
204 | - added wxTextCtrl::EmulateKeyPress() | |
205 | - Added wxMouseCaptureChangedEvent | |
206 | - Added custom character filtering to wxTextValidator | |
207 | - wxTreeCtrl now supports incremental keyboard search | |
208 | ||
209 | wxMSW: | |
210 | ||
211 | - small appearance fixes for native look under Windows XP | |
212 | - refresh the buttons properly when the window is resized (Hans Van Leemputten) | |
213 | - huge (40*) speed up in wxMask::Create() | |
214 | - changing wxWindows styles also changes the underlying Windows window style | |
215 | - wxTreeCtrl supports wxTR_HIDE_ROOT style (George Policello) | |
216 | - fixed flicker in wxTreeCtrl::SetItemXXX() | |
217 | - fixed redraw problems in dynamically resized wxStaticText | |
218 | - improvements to wxWindows applications behaviour when the system colours | |
219 | are changed | |
220 | - fixed wxProgressDialog for ranges > 65535 | |
221 | - wxSpinButton and wxSpinCtrl now support full 32 bit range (if the version | |
222 | of comctl32.dll installed on the system supports it) | |
223 | - wxFontEnumerator now returns all fonts, not only TrueType ones | |
224 | - bugs in handling wxFrame styles (border/caption related) fixed | |
225 | - showing a dialog from EVT_RADIOBUTTON handler doesn't lead to an infinite | |
226 | recursion any more | |
227 | - wxTextCtrl with wxTE_RICH flag scrolls to the end when text is appended to it | |
228 | - the separators are not seen behind the controls added to the toolbar any more | |
229 | - wxLB_SORT style can be used with wxCheckListBox | |
230 | - wxWindowDC and wxClientDC::GetSize() works correctly now | |
231 | - Added wxTB_NODIVIDER and wxTB_NOALIGN so native toolbar can be used in FL | |
232 | - Multiline labels in buttons are now supoprted (simply use "\n" in the label) | |
233 | - Implemented wxMouseCaptureChangedEvent and made wxGenericDragImage check it | |
234 | has the capture before release it. | |
235 | - fixed bugs in multiple selection wxCheckListBox | |
236 | - default button handling is now closer to expected | |
237 | ||
238 | wxGTK: | |
239 | ||
240 | - wxDirDialog now presents the file system in standard Unix way | |
241 | - wxButton now honours wxBU_EXACTFIT | |
242 | - wxStaticBox now honours wxALIGN_XXX styles | |
243 | - added support for non alphanumeric simple character accelerators ('-', '=') | |
244 | - new behaviour for wxWindow::Refresh() as it now produces a delayed refresh. | |
245 | Call the new wxWindow::Update() to force an immediate update | |
246 | - support for more SGI hardware (12-bit mode among others) | |
247 | - fixed wxDC::Blit() to honour source DC's logical coordinates | |
248 | - implemented wxIdleEvent::RequestMore() for simple background tasks | |
249 | - implemented wxChoice::Delete() | |
250 | - fixed bad memory leak in wxFileDialog (Chris Elliott) | |
251 | ||
252 | wxHTML: | |
253 | ||
254 | - fixed wxHtmlHelpController's cache files handling on big endian machines | |
255 | - added blocking and redirecting capabilities to wxHtmlWindow via | |
256 | wxHtmlWindow::OnOpeningURL() | |
257 | - fixed alignment handling in tables | |
258 | - fixed <font face="..."> handling to be case insensitive | |
259 | ||
260 | 2.3.2 | |
261 | ----- | |
262 | ||
263 | New port: wxUniv for Win32/GTK+ is now included in the distribution. | |
264 | ||
265 | wxBase: | |
266 | ||
267 | - wxRegEx class added | |
268 | - wxGetDiskSpace() function added (Jonothan Farr, Markus Fieber) | |
269 | - wxTextBuffer and wxTextFile(wxStream) added (Morten Hanssen) | |
270 | - more fixes to wxMBConv classes. Conversion to and from wchar_t now works with | |
271 | glibc 2.2 as well as with glibc 2.1. Unix version now checks for iconv()'s | |
272 | capabilities at runtime instead of in the configure script. | |
273 | ||
274 | All (GUI): | |
275 | ||
276 | - support for virtual list control added | |
277 | - column images in report mode of the list control | |
278 | - wxFindReplaceDialog added (based on work of Markus Greither) | |
279 | - wxTextCtrl::SetMaxLength() added (wxMSW/wxGTK) | |
280 | - polygon support in wxRegion (Klaas Holwerda) | |
281 | - wxStreamToTextRedirector to allow easily redirect cout to wxTextCtrl added | |
282 | - fixed bug with using wxExecute() to capture huge amounts of output | |
283 |