Commit | Line | Data |
---|---|---|
18efb19f JS |
1 | Enhancements for wxWindows 3.0 |
2 | ============================== | |
3 | ||
13acdb7d VZ |
4 | This table contains the brief summary of the issues below. Priority and |
5 | Difficulty are values from 1 to 10 with 1 being the least important/difficult | |
6 | and 10 the most. | |
7 | ||
8 | Item Prio Diff | |
9 | ---------------------------------------------------------------------------- | |
10 | Namespaces 8 6 | |
11 | STLization 10 8 | |
12 | Making code exception-friendly 8 10 | |
13 | Native RTTI 7 7 | |
14 | TRUE/true 9 1 | |
15 | ||
18efb19f | 16 | |
5e284dd5 SC |
17 | C++ Features |
18 | ============ | |
19 | ||
13acdb7d VZ |
20 | - Namespaces: |
21 | We want to have all wxWindows identifiers in "wx" namespace but provide | |
22 | typedefs/#defines for backwards compatibility. This can be done easily | |
23 | for the classes and the only real problem are the enums as they would | |
24 | all have to be duplicated at both the global scope (with "wx" prefix) and | |
25 | in wx namespace (without it) | |
26 | ||
27 | - STLization | |
28 | This involves providing optional wxString implementation using std::string | |
29 | and doing the same for all our containers with the exception of wxHashMap | |
30 | which should simply be rewritten using templates (but keeping the old | |
31 | version for backwards compatibility -- ideally wx 3.0 would still be usable | |
32 | without templates, even if not all of its features would be available then) | |
33 | ||
34 | - Exceptions | |
35 | We are not going to use exceptions in wxWindows itself but our code should | |
36 | become exception safe. This is a very difficult task as it means that no | |
37 | resource allocations (including memory, files, whatever) should be done | |
38 | without using a smart pointer-like object to store the result as it is the | |
39 | only way to prevent resource leaks in presence of exceptions | |
40 | ||
41 | - Real RTTI | |
42 | Optionally use the real RTTI instead of wx emulation of it. Keep the | |
43 | current stuff for backwards compatibility. | |
44 | ||
45 | - Complete replacing TRUE/FALSE with true/false | |
46 | Trivial | |
47 | ||
5e284dd5 SC |
48 | |
49 | Core | |
50 | ==== | |
51 | ||
13acdb7d VZ |
52 | - use wxEventLoop in all builds |
53 | wxApp and wxDialog should use wxEventLoop objects (the exact class can be | |
54 | customized by user code by overriding some wxApp::CreateEventLoop()) | |
55 | instead of duplicating the same code | |
56 | ||
57 | - remove wxCOMPATIBILITY (1.X) | |
58 | At least WXWIN_COMPATIBILITY and maybe WXWIN_COMPATIBILITY_2 code should be | |
59 | removed from the library. wxDEPRECATED() should be used with everything | |
60 | inside WXWIN_COMPATIBILITY_2_2. The stuff inside WXWIN_COMPATIBILITY_2_4 | |
61 | probably should not be deprecated (yet?) because this would give thousands | |
62 | of warnings for the existing code. | |
63 | ||
64 | - Modularization/Build System | |
65 | Candidates for components: | |
66 | + contrib widgets (and maybe some of the ones currently in the core) | |
67 | + wxHTML | |
68 | + network stuff | |
69 | + printing (?) | |
70 | + ODBC classes | |
71 | + ... | |
72 | ||
73 | - Project File Generation | |
74 | We need a (GUI) tool to generate the project/makefiles for all supported | |
75 | platforms/compilers. Not sure if it should be used for the library itself | |
76 | (would be nice to have something like "make menuconfig" for Linux kernel | |
77 | which allows you to navigate easily amon all of the configure/setup.h | |
78 | options but there is a problem with distributing such tool as it can't be | |
79 | compiled by the user because it is needed before the library is built) but | |
80 | we definitely need it for the users makefiles. | |
81 | ||
82 | - Properties/Member-Metadata, 2-Step Init with virtual create | |
83 | TODO: still unclear what do we need exactly | |
84 | ||
7ebcb584 JS |
85 | - Tidy code and add comments to headers (preferably in |
86 | Doxygen/Javadoc style) | |
87 | ||
5e284dd5 SC |
88 | |
89 | Documentation | |
90 | ============= | |
91 | ||
94af6953 JS |
92 | - The possibility of moving doc into header files with tool |
93 | support. | |
94 | - Detailed review of doc accuracy. | |
5e284dd5 | 95 | - wxDC : Precise definition of default/initial state. |
94af6953 JS |
96 | - wxDC : Pixelwise definition of operations (e.g. last point of a |
97 | line not drawn). | |
13acdb7d VZ |
98 | - Events: |
99 | For all controls state clearly when calling a member function results in an | |
100 | event being generated and when it doesn't. | |
101 | - Update the coding standards guide | |
102 | ||
5e284dd5 SC |
103 | |
104 | wxEvents | |
105 | ======== | |
106 | ||
13acdb7d VZ |
107 | - Change Idle Handling |
108 | Current Implementation is using too many CPU cycles | |
5e284dd5 | 109 | |
13acdb7d VZ |
110 | - Loose Coupling Event-Source Event-Sink |
111 | kind of the NextStep/C# very performant coupling, exposing events via | |
112 | Metadata | |
5e284dd5 | 113 | |
13acdb7d | 114 | - Add Lazy Init of Eventtables |
5e284dd5 SC |
115 | |
116 | ||
117 | Modules/Plugins | |
118 | =============== | |
119 | ||
120 | Architecture | |
121 | ------------ | |
122 | ||
94af6953 JS |
123 | We aim to arrive at a lazy initializiation of modules only when they are first |
124 | needed. Dependency information between modules is needed. Dynamic Plug-In | |
125 | loading and unloading must be compatible with that. | |
5e284dd5 | 126 | |
68fcaeb9 | 127 | |
5e284dd5 SC |
128 | wxUniversal |
129 | =========== | |
130 | ||
94af6953 | 131 | - Renderers within native ports. |
5e284dd5 | 132 | |
68fcaeb9 | 133 | |
5e284dd5 SC |
134 | wxPrinting |
135 | ========== | |
136 | ||
94af6953 JS |
137 | - Page preflighting capabilities in order to determine number |
138 | of pages. | |
139 | - Preview UI enhancement. | |
5e284dd5 | 140 | |
68fcaeb9 | 141 | |
5e284dd5 SC |
142 | wxStaticBox |
143 | =========== | |
144 | ||
94af6953 JS |
145 | Hide the platform problems (GTK: 'children' must be siblings) in encapsulation |
146 | in order to avoid problems on ports where the hierarchy must be | |
147 | 'correct'. | |
5e284dd5 | 148 | |
68fcaeb9 JS |
149 | |
150 | Removal of old code | |
151 | =================== | |
152 | ||
153 | In addition to wxCOMPATIBILITY code: | |
154 | ||
155 | - wxProperty classes. | |
156 | - All wxCOMPATIBILITY (1.X) code. | |
157 | - contrib/src/canvas? | |
158 | - contrib/src/mmedia | |
159 | - contrib/src/applet? | |
68fcaeb9 | 160 | - Old wxODBC code |
7ebcb584 | 161 | - Dialog Editor |
68fcaeb9 | 162 | |
13acdb7d VZ |
163 | wxMiscellaneous |
164 | =============== | |
5e284dd5 | 165 | |
13acdb7d VZ |
166 | - wxDC Support for point to char-position with text rendering |
167 | - wxLocale Extension (eg Currency) | |
168 | - wxStreams review | |
169 | - wxURL? | |
1cfa5d8e JS |
170 | - a way to tell wxWindows to check for any non-portable usage, |
171 | for a given set of platforms. Sometimes you want to be able | |
172 | to get away with non-portable usage, and sometimes not. | |
173 | This is probably way too time-consuming to implement. | |
174 | - In headers, don't silently omit contents if the features for this | |
175 | header is switched off. Instead, emit an error message. | |
7ebcb584 | 176 | - Implement native tree view and colour dialog in wxGTK. |
e8737b66 JS |
177 | - Better way to specify About, Preferences menu ids under wxMac. |
178 | - Must be able to portably specify relaying out a frame after the toolbar | |
179 | has been destroyed or recreated. On wxMSW, this is done in | |
180 | ~wxToolBar. On wxGTK, in SetToolBar. In wxMac, not at all, | |
181 | but sending a wxSizeEvent will do it. | |
182 | - wxMac font selector dialog is the generic font selector - | |
183 | horrible. | |
afd366a7 JS |
184 | - No Append(wxArrayString&) for wxChoice and wxComboBox in wxGTK. |
185 | Probably other functions too. Consider adding Insert to | |
186 | these classes, as per the patch on SF. | |
187 | - Rewrite wxFileHistory using wxString and wxArrayString, and | |
188 | put in separate file. | |
c2d48b36 JS |
189 | - Add wxArrayString methods to wxTextValidator and any other |
190 | class that needs them. | |
191 | - Add wxNotebook::GetTabRect or similar so we can estimate | |
192 | page size better in wxNotebookBase::CalcSizeFromPage. | |
193 | - Add function to clear all wxNotebook tabs without | |
194 | destroying the pages. | |
195 | - Add individual setters to wxScrollBar and other classes | |
196 | that use a combined setter. | |
197 | - Remove traces of old resource system from wxWizard. | |
d7260478 JS |
198 | - Have wxDirCtrl as alias for wxGenericDirCtrl. |
199 | - Allow instant reaction to left-up in a wxGrid cell | |
200 | (extend editor API) to work around bad checkbox | |
201 | behaviour (click, click, click, click away...) and | |
202 | reduce checkbox size on non-Windows platforms. | |
5c5428f9 | 203 | - Add wxNotebook::HitTest for non-Windows platforms. |
5e284dd5 | 204 | |
13acdb7d | 205 | Version: $Id$ |