]> git.saurik.com Git - wxWidgets.git/blob - interface/platinfo.h
a1b0060ee95565bf07c78d27fdf7282a455b3a34
[wxWidgets.git] / interface / platinfo.h
1 /////////////////////////////////////////////////////////////////////////////
2 // Name: platinfo.h
3 // Purpose: interface of wxPlatformInfo
4 // Author: wxWidgets team
5 // RCS-ID: $Id$
6 // Licence: wxWindows license
7 /////////////////////////////////////////////////////////////////////////////
8
9
10 /**
11 The following are the operating systems which are recognized by wxWidgets and
12 whose version can be detected at run-time.
13
14 The values of the constants are chosen so that they can be combined as flags;
15 this allows to check for operating system families like e.g. wxOS_MAC and wxOS_UNIX.
16 */
17 enum wxOperatingSystemId
18 {
19 wxOS_UNKNOWN = 0, //!< returned on error
20
21 wxOS_MAC_OS = 1 << 0, //!< Apple Mac OS 8/9/X with Mac paths
22 wxOS_MAC_OSX_DARWIN = 1 << 1, //!< Apple Mac OS X with Unix paths
23 wxOS_MAC = wxOS_MAC_OS|wxOS_MAC_OSX_DARWIN,
24
25 wxOS_WINDOWS_9X = 1 << 2, //!< Windows 9x family (95/98/ME)
26 wxOS_WINDOWS_NT = 1 << 3, //!< Windows NT family (NT/2000/XP)
27 wxOS_WINDOWS_MICRO = 1 << 4, //!< MicroWindows
28 wxOS_WINDOWS_CE = 1 << 5, //!< Windows CE (Window Mobile)
29 wxOS_WINDOWS = wxOS_WINDOWS_9X |
30 wxOS_WINDOWS_NT |
31 wxOS_WINDOWS_MICRO |
32 wxOS_WINDOWS_CE,
33
34 wxOS_UNIX_LINUX = 1 << 6, //!< Linux
35 wxOS_UNIX_FREEBSD = 1 << 7, //!< FreeBSD
36 wxOS_UNIX_OPENBSD = 1 << 8, //!< OpenBSD
37 wxOS_UNIX_NETBSD = 1 << 9, //!< NetBSD
38 wxOS_UNIX_SOLARIS = 1 << 10, //!< SunOS
39 wxOS_UNIX_AIX = 1 << 11, //!< AIX
40 wxOS_UNIX_HPUX = 1 << 12, //!< HP/UX
41 wxOS_UNIX = wxOS_UNIX_LINUX |
42 wxOS_UNIX_FREEBSD |
43 wxOS_UNIX_OPENBSD |
44 wxOS_UNIX_NETBSD |
45 wxOS_UNIX_SOLARIS |
46 wxOS_UNIX_AIX |
47 wxOS_UNIX_HPUX,
48
49 wxOS_DOS = 1 << 15, //!< Microsoft DOS
50 wxOS_OS2 = 1 << 16 //!< OS/2
51 };
52
53 /**
54 The list of wxWidgets ports.
55
56 Some of them can be used with more than a single (native) toolkit;
57 e.g. wxWinCE port sources can be used with smartphones, pocket PCs
58 and handheld devices SDKs.
59 */
60 enum wxPortId
61 {
62 wxPORT_UNKNOWN = 0, //!< returned on error
63
64 wxPORT_BASE = 1 << 0, //!< wxBase, no native toolkit used
65
66 wxPORT_MSW = 1 << 1, //!< wxMSW, native toolkit is Windows API
67 wxPORT_MOTIF = 1 << 2, //!< wxMotif, using [Open]Motif or Lesstif
68 wxPORT_GTK = 1 << 3, //!< wxGTK, using GTK+ 1.x, 2.x, GPE or Maemo
69 wxPORT_MGL = 1 << 4, //!< wxMGL, using wxUniversal
70 wxPORT_X11 = 1 << 5, //!< wxX11, using wxUniversal
71 wxPORT_OS2 = 1 << 6, //!< wxOS2, using OS/2 Presentation Manager
72 wxPORT_MAC = 1 << 7, //!< wxMac, using Carbon or Classic Mac API
73 wxPORT_COCOA = 1 << 8, //!< wxCocoa, using Cocoa NextStep/Mac API
74 wxPORT_WINCE = 1 << 9, //!< wxWinCE, toolkit is WinCE SDK API
75 wxPORT_PALMOS = 1 << 10, //!< wxPalmOS, toolkit is PalmOS API
76 wxPORT_DFB = 1 << 11 //!< wxDFB, using wxUniversal
77 };
78
79
80 /**
81 The architecture of the operating system
82 (regardless of the build environment of wxWidgets library - see ::wxIsPlatform64bit()
83 documentation for more info).
84 */
85 enum wxArchitecture
86 {
87 wxARCH_INVALID = -1, //!< returned on error
88
89 wxARCH_32, //!< 32 bit
90 wxARCH_64,
91
92 wxARCH_MAX
93 }
94
95
96 /**
97 The endian-ness of the machine.
98 */
99 enum wxEndianness
100 {
101 wxENDIAN_INVALID = -1, //!< returned on error
102
103 wxENDIAN_BIG, //!< 4321
104 wxENDIAN_LITTLE, //!< 1234
105 wxENDIAN_PDP, //!< 3412
106
107 wxENDIAN_MAX
108 }
109
110
111 /**
112 @class wxPlatformInfo
113 @wxheader{platinfo.h}
114
115 This class holds informations about the operating system and the toolkit that
116 the application is running under and some basic architecture info of the machine
117 where it's running.
118
119 @library{wxbase}
120 @category{misc}
121
122 @see ::wxGetOsVersion(), wxIsPlatformLittleEndian(), wxIsPlatform64Bit(),
123 wxAppTraits
124 */
125 class wxPlatformInfo : public wxObject
126 {
127 public:
128
129 /**
130 Initializes the instance with the values corresponding to the currently
131 running platform.
132
133 This is a fast operation because it only requires to copy the values
134 internally cached for the currently running platform.
135
136 @see Get()
137 */
138 wxPlatformInfo();
139
140 /**
141 Initializes the object using given values.
142 */
143 wxPlatformInfo(wxPortId pid = wxPORT_UNKNOWN,
144 int tkMajor = -1,
145 int tkMinor = -1,
146 wxOperatingSystemId id = wxOS_UNKNOWN,
147 int osMajor = -1,
148 int osMinor = -1,
149 wxArchitecture arch = wxARCH_INVALID,
150 wxEndianness endian = wxENDIAN_INVALID);
151
152
153 /**
154 Returns @true if the OS version is at least @c major.minor.
155
156 @see GetOSMajorVersion(), GetOSMinorVersion(),
157 CheckToolkitVersion()
158 */
159 bool CheckOSVersion(int major, int minor) const;
160
161 /**
162 Returns @true if the toolkit version is at least @c major.minor.
163
164 @see GetToolkitMajorVersion(),
165 GetToolkitMinorVersion(), CheckOSVersion()
166 */
167 bool CheckToolkitVersion(int major, int minor) const;
168
169 /**
170 Returns the global wxPlatformInfo object, initialized with the values
171 for the currently running platform.
172 */
173 static const wxPlatformInfo Get();
174
175 /**
176 Converts the given string to a wxArchitecture enum value or to
177 @c wxARCH_INVALID if the given string is not a valid architecture string
178 (i.e. does not contain nor @c 32 nor @c 64 strings).
179 */
180 static wxArchitecture GetArch(const wxString& arch);
181
182 /**
183 Returns the name for the given wxArchitecture enumeration value.
184 */
185 static wxString GetArchName(wxArchitecture arch) const;
186
187 /**
188 Returns the name for the architecture of this wxPlatformInfo instance.
189 */
190 wxString GetArchName() const;
191
192 /**
193 Returns the architecture ID of this wxPlatformInfo instance.
194 */
195 wxArchitecture GetArchitecture() const;
196
197 /**
198 Converts the given string to a wxEndianness enum value or to
199 @c wxENDIAN_INVALID if the given string is not a valid endianness
200 string (i.e. does not contain nor little nor big strings).
201 */
202 static wxEndianness GetEndianness(const wxString& end) const;
203
204 /**
205 Returns the endianness ID of this wxPlatformInfo instance.
206 */
207 wxEndianness GetEndianness() const;
208
209 /**
210 Returns name for the given wxEndianness enumeration value.
211 */
212 static wxString GetEndiannessName(wxEndianness end) const;
213
214 /**
215 Returns the name for the endianness of this wxPlatformInfo instance.
216 */
217 wxString GetEndiannessName() const;
218
219 /**
220 Returns the run-time major version of the OS associated with this
221 wxPlatformInfo instance.
222
223 @see ::wxGetOsVersion(), CheckOSVersion()
224 */
225 int GetOSMajorVersion() const;
226
227 /**
228 Returns the run-time minor version of the OS associated with this
229 wxPlatformInfo instance.
230
231 @see ::wxGetOsVersion(), CheckOSVersion()
232 */
233 int GetOSMinorVersion() const;
234
235 /**
236 Returns the operating system family name for the given wxOperatingSystemId
237 enumeration value: @c Unix for @c wxOS_UNIX, @c Macintosh for @c wxOS_MAC,
238 @c Windows for @c wxOS_WINDOWS, @c DOS for @c wxOS_DOS, @c OS/2 for @c wxOS_OS2.
239 */
240 static wxString GetOperatingSystemFamilyName(wxOperatingSystemId os) const;
241
242 /**
243 Returns the operating system family name of the OS associated with this
244 wxPlatformInfo instance.
245 */
246 wxString GetOperatingSystemFamilyName() const;
247
248 /**
249 Converts the given string to a wxOperatingSystemId enum value or to @c
250 wxOS_UNKNOWN if the given string is not a valid operating system name.
251 */
252 static wxOperatingSystemId GetOperatingSystemId(const wxString& name) const;
253
254 /**
255 Returns the operating system ID of this wxPlatformInfo instance.
256 */
257 wxOperatingSystemId GetOperatingSystemId() const;
258
259 /**
260 Returns the name for the given operating system ID value.
261
262 This can be a long name (e.g. <tt>Microsoft Windows NT</tt>);
263 use GetOperatingSystemFamilyName() to retrieve a short, generic name.
264 */
265 static wxString GetOperatingSystemIdName(wxOperatingSystemId os) const;
266
267 /**
268 Returns the operating system name of the OS associated with this wxPlatformInfo
269 instance.
270 */
271 wxString GetOperatingSystemIdName() const;
272
273
274 /**
275 Converts the given string to a wxWidgets port ID value or to @c wxPORT_UNKNOWN
276 if the given string does not match any of the wxWidgets canonical name ports
277 ("wxGTK", "wxMSW", etc) nor any of the short wxWidgets name ports ("gtk", "msw", etc).
278 */
279 static wxPortId GetPortId(const wxString& portname) const;
280
281 /**
282 Returns the wxWidgets port ID associated with this wxPlatformInfo instance.
283 */
284 wxPortId GetPortId() const;
285
286 /**
287 Returns the name of the given wxWidgets port ID value.
288 The @a usingUniversal argument specifies whether the port is in its native
289 or wxUniversal variant.
290
291 The returned string always starts with the "wx" prefix and is a mixed-case string.
292 */
293 static wxString GetPortIdName(wxPortId port, bool usingUniversal) const;
294
295 /**
296 Returns the name of the wxWidgets port ID associated with this wxPlatformInfo
297 instance.
298 */
299 wxString GetPortIdName() const;
300
301 /**
302 Returns the short name of the given wxWidgets port ID value.
303 The @a usingUniversal argument specifies whether the port is in its native
304 or wxUniversal variant.
305
306 The returned string does not start with the "wx" prefix and is always lower case.
307 */
308 static wxString GetPortIdShortName(wxPortId port,
309 bool usingUniversal) const;
310
311 /**
312 Returns the short name of the wxWidgets port ID associated with this
313 wxPlatformInfo instance.
314 */
315 wxString GetPortIdShortName() const;
316
317 /**
318 Returns the run-time major version of the toolkit associated with this
319 wxPlatformInfo instance.
320
321 Note that if GetPortId() returns @c wxPORT_BASE, then this value is zero
322 (unless externally modified with SetToolkitVersion()); that is, no native
323 toolkit is in use.
324 See wxAppTraits::GetToolkitVersion() for more info.
325
326 @see CheckToolkitVersion()
327 */
328 int GetToolkitMajorVersion() const;
329
330 /**
331 Returns the run-time minor version of the toolkit associated with this
332 wxPlatformInfo instance.
333
334 Note that if GetPortId() returns @c wxPORT_BASE, then this value is zero
335 (unless externally modified with SetToolkitVersion()); that is, no native
336 toolkit is in use.
337 See wxAppTraits::GetToolkitVersion() for more info.
338
339 @see CheckToolkitVersion()
340 */
341 int GetToolkitMinorVersion() const;
342
343 /**
344 Returns @true if this instance is fully initialized with valid values.
345 */
346 bool IsOk() const;
347
348 /**
349 Returns @true if this wxPlatformInfo describes wxUniversal build.
350 */
351 bool IsUsingUniversalWidgets() const;
352
353 /**
354 Sets the architecture enum value associated with this wxPlatformInfo instance.
355 */
356 void SetArchitecture(wxArchitecture n);
357
358 /**
359 Sets the endianness enum value associated with this wxPlatformInfo instance.
360 */
361 void SetEndianness(wxEndianness n);
362
363 /**
364 Sets the version of the operating system associated with this wxPlatformInfo
365 instance.
366 */
367 void SetOSVersion(int major, int minor);
368
369 /**
370 Sets the operating system associated with this wxPlatformInfo instance.
371 */
372 void SetOperatingSystemId(wxOperatingSystemId n);
373
374 /**
375 Sets the wxWidgets port ID associated with this wxPlatformInfo instance.
376 */
377 void SetPortId(wxPortId n);
378
379 /**
380 Sets the version of the toolkit associated with this wxPlatformInfo instance.
381 */
382 void SetToolkitVersion(int major, int minor);
383
384 /**
385 Inequality operator. Tests all class' internal variables.
386 */
387 bool operator!=(const wxPlatformInfo& t) const;
388
389 /**
390 Equality operator. Tests all class' internal variables.
391 */
392 bool operator==(const wxPlatformInfo& t) const;
393 };
394