]> git.saurik.com Git - wxWidgets.git/blob - docs/gtk/changes.txt
9212a4d8d3168c25f74409c7ae24b3b04868bc5e
[wxWidgets.git] / docs / gtk / changes.txt
1
2 29th July '99: Eight wxGTK 2.1 snapshot released
3
4 The new makefile system is not able to produce shared libraries
5 on Unix with the exception of Linux - libtool is really great.
6 Therefore, the build system defaults to static libraries on
7 anything but Linux for now.
8
9 Work in wxPen, wxBrush and wxDC to match wxMSW more exactly and
10 to implement missing feature etc.
11
12 Reimplemented radio buttons. The first of a group of such buttons
13 is now marked by having the wxRB_GROUP style.
14
15 Complete redesign of all stream classes, including tests for them
16 in the samples.
17
18 Controls now send the same messages (or more importantly none if
19 changed programmatically) as per wxMSW.
20
21 New implementation of wxSocket using an intermediate library called
22 GSocket. This willl hopefully change in the future.
23
24 Reworked in-place editing of wxListCtrl and wxTreeCtrl.
25
26 Fixed bug reporting two refreshes when scrolling.
27
28 Corrected bug in wxComboBox client data code.
29
30 Corrected reported but unverified bug in BMP loading code.
31
32 Added a few more methods to wxStaticBitmap.
33
34 Integration of wxHTML code in the main library, including wxZIPStream,
35 wxFilesystem, wxHTMLHelpController and others.
36
37 Added a wrapper for ffile() etc functions.
38
39 Updateds to wxDynamicLibrary.
40
41 New documentation.
42
43 Fixed in unenclosed number of other bugs...
44
45 25th June '99: Seventh wxGTK 2.1 snapshot released
46
47 Many fixes to th new makefile system. The last version gave
48 immediate crashes on all Unices except Linux when linked
49 dynamically against an application. I reordered the object
50 files in the library as I guess that this was the cause.
51
52 Added icons to message box. This also slightly killed the
53 layout so this needs to be changed again.
54
55 wxGTK now chooses the best visual available on the display instead
56 of the default one.
57
58 Fixed wxProgressDialog again.
59
60 Some more corrections I forgot.
61
62 New wxPython (includes new layout system and printing).
63
64 15th June '99: Sixth wxGTK 2.1 snapshot released
65
66
67 The biggest change is the completely rewritten configure/makefile
68 system using automake. The main argument for switching to automake
69 is that the resulting makefiles should be more portable so that
70 people can use the native make utilities instead of GNU make. The
71 new makefile sytem also handles dependencies correctly, allows for
72 shared-only compilation, can be invoked from any directory for
73 concurrent builds wihtin one source tree, uses libtool for greater
74 shared-library platform support, has a functinonal "make uninstall",
75 works with GTK, Motif and WINE, conforms better to GNU standards
76 as far as configure option names are concerned and is easier to
77 maintain.
78
79 Applied patches to compile wxGTK on OS/2.
80
81 Configure checks for byte-order and new defines for byte swapping
82 with respect to the byte-order. Added test for this to typetest sample.
83 Also made BMP handler bigendian safe so that it should work on
84 Solaris and such.
85
86 Small changes to basic drawing stuff: made wxColour actually compare
87 RGB values in the == operator, added new constructor to wxMask,
88 corrected initial background colour for DCs, it is now possible
89 to use a wxWindowDC etc before there is any window (this doesn't
90 make any sense, but it is what wxMSW does.)
91
92 Added support for the PRIMARY SELECTION to the wxClipboard
93 class.
94
95 Fixed redraw bug when scrolling window-less widgets out
96 of the visible area (actually a work-around for a GTK bug).
97
98 Regrouped some samples, created new one for various versions
99 of the wxTextCtrl.
100
101 Added wxWindow::Reparent() and wxFrame::MakeModal().
102
103 Improved handling of column width in wxListCtrl and made
104 this more compatible with the wxMSW version. Also removed
105 a bug from the wxImageList returning an off-by-one id for
106 added images.
107
108 Fixed keyboard hotkeys and resizing for wxMDIChildFrame
109 menu bars.
110
111 Added flag to wxSplitterWindow to update its children's
112 sizes "live" instead of moving a XOR'ed bar around - this
113 is a resource-draining option. Also corrected cursors
114 in splitter window.
115
116 New way to show "disabled" or greyed toolbar items.
117
118 Rewrote parts of the tree ctrl to allow multiple selections
119 and variable size items (Sylvain). These new function do not
120 exist in the native Win32 tree control.
121
122 Implemented global cursors and wxBusyCursor etc. Also removed
123 another cursor misbehaviour.
124
125 Updated many parts of the documentation to reflect changes
126 in wxWindows 2.1, wxPython and more exact description of
127 cross-platform issues as well as platform differences.
128
129 Many other fixes, mainly by others...
130
131 Further compile fixes for different architectures.
132
133
134
135 25th May '99: Fifth wxGTK 2.1 snapshot released
136
137
138
139 This is mostly a bug-fix release. We are having funny
140 times to make wxGTK work well with different micro
141 versions of GTK 1.2 - which is very close to impossible.
142 All versions give warnings, although their number might
143 vary a lot. I use GTK 1.2.3 and only get wanrnings in
144 one sample (notebook) and that one is due to a bug in
145 GTK - some people using GTK 1.2.2 reported hundreds of warnings
146 getting spitted out for what seems like no reason.
147
148 This snapshot contains the beginnings of our merging of
149 headers, meaning that in the future all ports will
150 use the same headers and will share a lot more code.
151 We have taken this moment to reorganize some code and
152 hope to have eliminated much bad C++ code, as reported
153 primarily by SGI's compilers (Vadim Zeitlin).
154
155 Rewritten char and key event propagation routines
156 to reflect documentation and do the same on wxGTK
157 as on wxMSW. If you are interested in ascii chars
158 and cursor key etc, intercept EVT_CHAR, if you
159 are interested in which key actually got pressed,
160 intercept EVT_KEYDOWN (Norbert Irmer).
161
162 Control that are given -1 as their ID no longer
163 get arbitrary positive IDs assigned but arbitrary
164 negative IDs. This had caused some trouble with ID clashes.
165
166 wxWindow and wxScrolledWindow no longer use the
167 wxScrollEvent, but the newly invented wxScrollWinEvent
168 so that no mixing up of events sent from wxSliders
169 or wxScrollbars placed in a wxWindow can occur.
170
171 Added wxProgressDialog for use with long background
172 work such as printing.
173
174 Added drawing sample and scrolling sample, both of
175 which show some misbehaviours...
176
177 When drawing with the wxXOR logical mode, wxGTK now uses
178 GdkXOR (instead of GdkInvert) and when drawing in wxINVERT logical
179 mode, wxGTK now uses GdkInvert (as before). When you did some
180 rubberband dragging and you used wxXOR and a black pen, then
181 you should change wxINVERT.
182
183 Applied more patches for SGI and HP-UX compilation.
184
185 More updates for wxSockets (Guilhem Lavaux). Seems to be nearly
186 finished.
187
188 You can now use threads within your GUI again. Well,
189 at least if you know what you are doing and you had a look
190 at the threads sample.
191
192 wxGLCanvas updated so that it can share display lists
193 over several windows and to not exhibit any flicker.
194 (Norber Irmer).
195
196 wxNotebook revamped so that its process of creation matches
197 wxMSW's more closely, also avoiding problems with wrong page
198 number. Added InsertPage() and the possibility to prevent
199 switching pages by intercepting the PAGE_CHANGING event. Also,
200 wxNotebooks now get shown even if all pages are empty.
201
202 Added Activate() to wxMDIChildFrame (Russel).
203
204 Improved wxSplitterWindow behaviour and visual feed-back when
205 given a minimal size etc (Bruce DeVisser).
206
207 Minor updates to wxTreeCtrl, wxListBox, printing, wxClipboard,
208 wxString, wxThreads and many others.
209
210 Also wxMSW got a big face-lift, not to mention the new wxMac release...
211
212
213
214 11th May '99: Fourth wxGTK 2.1 snapshot released
215
216
217 This is mostly a bug-fix release. This affects wxSocket, wxThread,
218 and a few GUI classes. Also more work has been done and window
219 placement and decorations etc. which we hope to have finished now.
220
221 Applied patches for FreeBSD and SGI compilation (not yet finshed).
222
223 Updated wxPython to beta 9.
224
225 Made wxGLCanvas work again - strangely it flickers now...
226
227 wxStaticText is currently broken with GTK 1.2.2 (which I don't
228 yet have and thus could not fix). Also, scrolling subwindows
229 (although much improved including a sample) doesn't work perfectly
230 due to a bug in GTK 1.2.1 (probably 1.2.2 as well).
231
232 Added wxStaticLine.
233
234 Note that the next release might bring about changes to keyboard
235 handling and scroll event intercepting from wxScrolledWindow.
236
237 By and large much of the code has stabilized and won't be much
238 different in the final wxWindows 2.1 release. Please test as
239 much as you can.
240
241 The next release will have a new build system.
242
243
244
245 3rd May '99: Third wxGTK 2.1 snapshot released
246
247
248 Updated INSTALL.txt and SYMBOLS.txt.
249
250 Support for Unicode is now almost complete. Most samples work in
251 both Unicode and non-Unicode mode. Thanks to Ove Kaaven and Vadim.
252
253 Internal changes required for wxOLE and addition of a very experimental
254 wxOLE code section using GNOME's Bonobo library (from GNOME's CVS).
255
256 New version of wxPython that works with the wxGTK 2.1.
257 This now includes a very comprensive test/demo suite. Thanks to
258 Robin Dunn, Harm v.d. Heijden and others. Beware of the hang-man...
259
260 More fine tuning of focus handling and GUI widgets.
261
262 Complete rewrite of wxSocket classes (still experimental).
263 Thanks to Guilhem Lavaux.
264
265 wxMenuBar supports underlined shortcuts like Windows does,
266 indicated by a leading & character. wxMenus now have hotkeys
267 such as in wxXt and wxMSW.
268
269 Rewritten MDI subsystem.
270
271 Correcetions and additions to the printing framework including
272 a paper type database (Julian).
273
274 Several controls now support more style flags for modifying
275 look (and feel) of the controls and windows.
276
277 New implementation of idle handlers, which now send an idle
278 event only once after the event queue has been emptied (which
279 is what happens in the wxMSW port as well), not regularly.
280 This no longer forces wxGTK applications to sleep (by having
281 to call usleep()) in idle time - giving more CPU slices to
282 the application if desired.
283
284 wxGLCanvas (the OpenGl for wxWindows) now accepts keyboard input.
285
286 The usual number of compile and bug fixes from all involved.
287
288
289
290 21st April '99: Second wxGTK 2.1 snapshot released
291
292
293 Added much code for Unicode support. Still experimental, but looks very
294 cool - thanks to Ove Kaaven and Vadim Zeitlin. If you are very brave, then
295 you can compile wxGTK with "configure --with-unicode".
296
297 More updates on the dreaded issue of making frames and dialogs impossible
298 to resize etc.
299
300 Drag and Drop works now under GTK 1.2 - at least basically when dragging
301 and dropping text. The API is not entirely fixed yet but seems quite
302 good now. Support for different actions (copy/move/link/..) still missing.
303 I also removed support for GTK 1.0 Drag and Drop - this is just broken
304 and unusable in GTK 1.0 and I don't want to fix it.
305
306 I now embed the JPEG library and handlers for JPEG and GIF have been
307 added to the existing PNG and BMP (and XPM for GTK version only). In
308 the future, the RPMs will not contain these libraries but depend on
309 the image libraries to be preinstalled whereas the source *.tgz will
310 ship with everything that is needed for wxGTK so that no downloading
311 of ten image libs will be required - also avoiding problems with ten
312 different kinds of libJPEG-6.0.1.7.IV beta 7. We also updated the
313 PNG code to the newest PNG version.
314
315 wxImage now makes use of the fast rendering code as provided by
316 GTK 1.2 whenever possible. This should mean a speed-up for graphics
317 heavy apps.
318
319 Many fixes all over. Also should compile with GTK 1.2.0 as opposed
320 to only with GTK 1.2.1 now.
321
322 wxPython still doesn't compile, I think.
323
324
325
326 12th April '99: First wxGTK 2.1 snapshot released
327
328
329 This is the first developers' version of wxWindows 2.1 for GTK. It's main
330 new feature is that it supports GTK 1.2 (as opposed to GTK 1.0) which
331 will make development within the GNOME evironment a lot easier.
332
333 Apart from the move to GTK 1.2 and the changes (some major) that were
334 required as part of that work, enhancement or corrections have been
335 made to many of the non-GUI classes and functions (such as wxClipboard,
336 wxThread, wxSocket, wxConfig)
337 and a few GUI classes (accelerators in menus, listbox always with
338 scrollbar, wxFrame honours Motif Window Manager hints, corrected tab
339 traversal for broken GTK 1.0 widgets).
340
341 There have been slight changes to the priting dialogs and their
342 setup data (which might break apps using this code in previous
343 versions). Also, a bug concerning printing white has been fixed
344 (actually not tested).
345
346 Although this is only the first 2.1 snapshot, there is little reason not
347 to use it as many bugs from version 2.0 have been corrected. There are,
348 pf course, still a few problem left with GTK 1.2 (some of which relate
349 to bugs in GTK).
350
351 I think I preserved backward compatility with GTK 1.0 and if not it
352 should be easy to fix - but mostly I don't care.
353
354 Drag'N'Drop is currently completely broken. Also, wxPython currently
355 doesn't compile with this release. The OpenGL canvas still seems to
356 work.
357
358 Major targets for the final release (still a long way): a new configure
359 system, support JPEG and GIF formats, wxHTML, super-duppah frame layout
360 stuff, syntax-highlighting editor, possibly Unicode, possibly some GNOME
361 gooddies, possibly world domination.
362
363
364
365 5th March '99: wxWindows 2.0 released
366
367
368 This is the final version of wxWindows 2.0 for GTK. The versions for
369 Windows and Motif (and also this version) are available form Julian Smart's
370 site. The Mac version is still under development.
371
372
373
374 19th February '99: wxWindows 2.0 beta 5
375
376
377 This is the fifth beta release and it contains mostly bug fixes and
378 updates for documentation.
379
380 Applied compile fixes for Solaris (different flavours and compilers).
381
382
383
384 12th February '99: wxWindows 2.0 beta 4
385
386
387 This is the fourth beta release and it contains mostly bug fixes and
388 updates for documentation.
389
390 Tracked a few more cases, where the bahaviour between wxMSW and wxGTK
391 differed. This was the case for closing a dialog or frame as well as
392 for clearing a device context or setting its background colour and some
393 other minor details.
394
395 Most standard dialogs have been face-liftet a little.
396
397 Implememted default buttons for GTK.
398
399 Fixed many bugs. You guessed it.
400
401
402
403 29th January '99: wxWindows 2.0 beta 3
404
405
406 This is the third beta release and it contains mostly bug fixes.
407
408 There is one field where we haven't been able to fix the API yet, and that
409 it Drag'n'Drop. This is mostly due to the fact that DnD in
410 GTK 1.0 is hardly usable and much different from GTK 1.2 which means that
411 we have to design a common API for Windows, GTK 1.0 and GTK 1.2. Although
412 we are trying to prevent that, it is possible that wxWindows 2.0 (being
413 based on GTK 1.0) will not have proper DnD support.
414
415 The major changes are that tool tips have been added, threads have been completely
416 rewritten, the ODBC code has been updated and improved, the socket code works
417 better now.
418
419 Classes for managing MIME-types under Windows and Unix have been added.
420
421 There is now a wxGLCanvas class for OpenGl/Mesa for the Windows, GTK and
422 Motif ports. Come see the penguins flying...
423
424 Documentation has received a big face lift - it now covers nearly all the
425 classes, at least.
426
427 The usual amount of bug fixes. Countless.
428
429 A few member functions of wxString have been renamed.
430
431 For those who are using the ever-so-popular wxImage class (which
432 now available on Motif and Windows as well) in 8-bit mode: wxGTK
433 now creates a color cube upon start-up in 8-bit mode and thus the
434 generation of bitmaps from images has been speeded up 20 times.
435
436 It is now possible to develop with wxGTK without having the GTK 1.0 header
437 files installed so that having the GTK 1.2 header files installed no longer
438 is any problem. We also provide RPMs for RedHat glibc 2 based systems, compiled
439 with egcs 1.1.1 on SuSE 6.0. Note that the RPM will not work in
440 SuSE 6.0 as SuSE decided to ship 6.0 with a broken GTK+ package.
441
442
443
444 6th January '99: wxWindows 2.0 beta 2
445
446
447 This is the second beta release and contains it mostly build and
448 bug fixes. Threads work well now on (up-to-date) glibc 2 systems,
449 commercial Unices and Windows.
450
451
452
453 20th December '98: wxWindows 2.0 beta 1
454
455
456 This is the first beta release and we have used the time before
457 this release to tidy up some parts of the API. All releases from
458 now on will be source code compatible but we reserve binary compatibility
459 for the final release. Because of this, the actual library name of
460 the beta version will not be 2.0 but 1.99, so that we prevent
461 conflicts with the final library later on. After the final release
462 we'll only fix bugs so that there will be no reason to link any
463 program statically with wxGTK.
464
465 We changed the name of the shared library to include the version of
466 the GTK used so that no conflicts emerge with simultaneous
467 versions of wxWindows for GTK 1.0 and for GTK 1.2 and so on.
468
469 As you can see, we have not moved to GTK 1.1.X as the different
470 development versions are too different and buggy to be useful. We'll
471 wait for a stable GTK 1.2 release (hardly 1.2.0) and start porting
472 then.
473
474 wxGTK now compiles without problems on anything between gcc 2.7.2 on
475 Linux-x86 and egcs 1.1 on Linux-Alpha and egcs 1.0 on Sparc. This isn't
476 as easy as it sounds...
477
478 Available form this site are the Python bindings of wxWindows.
479 Thanks to Robin Dunn for this tremendous contribution.
480 Tkinter is dead, Java is dead, wxPython rules! That's all there is to say.
481
482 Although only a few new classes have been added, many have been polished
483 up substantially, the most visible are wxListCtrl, wxTreeCtrl and
484 all classes related to printing. Also the DialogEd now functions
485 much better than before. Drag'n'Drop is fucntional but probably won't
486 be perfect until we use GTK 1.2 and its much improved DnD features.
487
488 wxClipboard has arrived and works for text. Other formats have not been
489 tested carefully yet.
490
491 wxMiniFrame has been added which might be useful for docking toolbars
492 etc. Someone has already done that for the MSW port and we hope to
493 include his very nice work later.
494
495 wxDirDialog has been added (thanks to Harm von der Heijden).
496
497 The entite "tab traveral" system for moving from item to item in
498 a dialog has been rewritten. It now completely overrides the
499 not-so-well-done GTK native tab system.
500
501 Quite much has been done to improve the wxImage class, which is now
502 available in the Windows port as well. Very useful for anything related
503 to image processing. wxGTK also uses this class internally e.g. to scale
504 bitmaps when the scale factor (e.g. zooming) of a drawing context
505 has changed.
506
507 Some of the small and handy classes (wxDate, wxTime, wxVariant) have
508 received a face-lift. wxList has been rewritten to make it possible
509 to write type-safe lists. The collection of utility functions (wxFileFind etc)
510 has been revamped and cleaned-up (thanks to Vadim Zeitlin, who has also
511 greatly enhanced many basic classes, ranging wxString to the debug and
512 log system).
513
514 We removed some constructors of GDI classes (such as wxPen, wxColour)
515 which took a pointer as a parameter. This lead to many errors among users
516 resulting in unexpected behaviour so it was decided to remove these
517 constructors.
518
519 As the number of users and the number of test programs and samples
520 is steadialy rising the core classes of wxWindows for MSW and GTK 1.0
521 can be considered to be very stable if not outright bug-free. I haven't
522 seen a crash for weeks now and wxWindows' internal debug features also
523 have improved every week, making stepping-through with a debugger almost
524 completely unnecessary as the library reports possible errors itself
525 (when in debug mode).
526