]>
git.saurik.com Git - wxWidgets.git/blob - interface/wx/platinfo.h
1 /////////////////////////////////////////////////////////////////////////////
3 // Purpose: interface of wxPlatformInfo
4 // Author: wxWidgets team
6 // Licence: wxWindows license
7 /////////////////////////////////////////////////////////////////////////////
11 The following are the operating systems which are recognized by wxWidgets and
12 whose version can be detected at run-time.
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.
17 enum wxOperatingSystemId
19 wxOS_UNKNOWN
= 0, //!< returned on error
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
,
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
|
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
|
49 wxOS_DOS
= 1 << 15, //!< Microsoft DOS
50 wxOS_OS2
= 1 << 16 //!< OS/2
54 The list of wxWidgets ports.
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.
62 wxPORT_UNKNOWN
= 0, //!< returned on error
64 wxPORT_BASE
= 1 << 0, //!< wxBase, no native toolkit used
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
81 The architecture of the operating system
82 (regardless of the build environment of wxWidgets library - see ::wxIsPlatform64bit()
83 documentation for more info).
87 wxARCH_INVALID
= -1, //!< returned on error
89 wxARCH_32
, //!< 32 bit
90 wxARCH_64
, //!< 64 bit
97 The endian-ness of the machine.
101 wxENDIAN_INVALID
= -1, //!< returned on error
103 wxENDIAN_BIG
, //!< 4321
104 wxENDIAN_LITTLE
, //!< 1234
105 wxENDIAN_PDP
, //!< 3412
111 A structure containing informations about a Linux distribution as returned
112 by the @c lsb_release utility.
114 See wxGetLinuxDistributionInfo() or wxPlatformInfo::GetLinuxDistributionInfo()
117 struct wxLinuxDistributionInfo
119 wxString Id
; //!< The id of the distribution; e.g. "Ubuntu"
120 wxString Release
; //!< The version of the distribution; e.g. "9.04"
121 wxString CodeName
; //!< The code name of the distribution; e.g. "jaunty"
122 wxString Description
; //!< The description of the distribution; e.g. "Ubuntu 9.04"
124 bool operator==(const wxLinuxDistributionInfo
& ldi
) const;
125 bool operator!=(const wxLinuxDistributionInfo
& ldi
) const;
130 @class wxPlatformInfo
132 This class holds informations about the operating system, the toolkit and the
133 basic architecture of the machine where the application is currently running.
135 This class does not only have @e getters for the informations above, it also has
136 @e setters. This allows you to e.g. save the current platform informations in a
137 data file (maybe in string form) so that when you later load it, you can easily
138 retrieve (see the static getters for string->enum conversion functions) and store
139 inside a wxPlatformInfo instance (using its setters) the signature of the system
142 In general however you only need to use the static Get() function and then
143 access the various informations for the current platform:
145 wxLogMessage("This application is running under %s.",
146 wxPlatformInfo::Get().GetOperatingSystemIdName());
152 @see ::wxGetOsVersion(), wxIsPlatformLittleEndian(), wxIsPlatform64Bit(),
153 wxAppTraits, @ref group_funcmacro_networkuseros
155 class wxPlatformInfo
: public wxObject
160 Initializes the instance with the values corresponding to the currently
163 This is a fast operation because it only requires to copy the values
164 internally cached for the currently running platform.
171 Initializes the object using given values.
173 wxPlatformInfo(wxPortId pid
= wxPORT_UNKNOWN
,
176 wxOperatingSystemId id
= wxOS_UNKNOWN
,
179 wxArchitecture arch
= wxARCH_INVALID
,
180 wxEndianness endian
= wxENDIAN_INVALID
);
184 Returns @true if the OS version is at least @c major.minor.
186 @see GetOSMajorVersion(), GetOSMinorVersion(),
187 CheckToolkitVersion()
189 bool CheckOSVersion(int major
, int minor
) const;
192 Returns @true if the toolkit version is at least @c major.minor.
194 @see GetToolkitMajorVersion(),
195 GetToolkitMinorVersion(), CheckOSVersion()
197 bool CheckToolkitVersion(int major
, int minor
) const;
201 Returns @true if this instance is fully initialized with valid values.
206 Returns @true if this wxPlatformInfo describes wxUniversal build.
208 bool IsUsingUniversalWidgets() const;
211 Inequality operator. Tests all class' internal variables.
213 bool operator!=(const wxPlatformInfo
& t
) const;
216 Equality operator. Tests all class' internal variables.
218 bool operator==(const wxPlatformInfo
& t
) const;
221 Returns the global wxPlatformInfo object, initialized with the values
222 for the currently running platform.
224 static const wxPlatformInfo
& Get();
227 @name Static enum getters
229 These getters allow for easy string-to-enumeration-value conversion.
234 Converts the given string to a wxArchitecture enum value or to
235 @c wxARCH_INVALID if the given string is not a valid architecture string
236 (i.e. does not contain nor @c 32 nor @c 64 strings).
238 static wxArchitecture
GetArch(const wxString
& arch
);
241 Converts the given string to a wxEndianness enum value or to
242 @c wxENDIAN_INVALID if the given string is not a valid endianness
243 string (i.e. does not contain nor little nor big strings).
245 static wxEndianness
GetEndianness(const wxString
& end
);
248 Converts the given string to a wxOperatingSystemId enum value or to @c
249 wxOS_UNKNOWN if the given string is not a valid operating system name.
251 static wxOperatingSystemId
GetOperatingSystemId(const wxString
& name
);
254 Converts the given string to a wxWidgets port ID value or to @c wxPORT_UNKNOWN
255 if the given string does not match any of the wxWidgets canonical name ports
256 ("wxGTK", "wxMSW", etc) nor any of the short wxWidgets name ports ("gtk", "msw", etc).
258 static wxPortId
GetPortId(const wxString
& portname
);
264 @name Static string-form getters
266 These getters allow for easy enumeration-value-to-string conversion.
271 Returns the name for the given wxArchitecture enumeration value.
273 static wxString
GetArchName(wxArchitecture arch
);
276 Returns name for the given wxEndianness enumeration value.
278 static wxString
GetEndiannessName(wxEndianness end
);
281 Returns the operating system family name for the given wxOperatingSystemId
282 enumeration value: @c Unix for @c wxOS_UNIX, @c Macintosh for @c wxOS_MAC,
283 @c Windows for @c wxOS_WINDOWS, @c DOS for @c wxOS_DOS, @c OS/2 for @c wxOS_OS2.
285 static wxString
GetOperatingSystemFamilyName(wxOperatingSystemId os
);
288 Returns the name for the given operating system ID value.
290 This can be a long name (e.g. <tt>Microsoft Windows NT</tt>);
291 use GetOperatingSystemFamilyName() to retrieve a short, generic name.
293 static wxString
GetOperatingSystemIdName(wxOperatingSystemId os
);
296 Returns the name of the given wxWidgets port ID value.
297 The @a usingUniversal argument specifies whether the port is in its native
298 or wxUniversal variant.
300 The returned string always starts with the "wx" prefix and is a mixed-case string.
302 static wxString
GetPortIdName(wxPortId port
, bool usingUniversal
);
305 Returns the short name of the given wxWidgets port ID value.
306 The @a usingUniversal argument specifies whether the port is in its native
307 or wxUniversal variant.
309 The returned string does not start with the "wx" prefix and is always lower case.
311 static wxString
GetPortIdShortName(wxPortId port
,
312 bool usingUniversal
);
315 Returns the operating system directory.
317 See wxGetOSDirectory() for more info.
319 static wxString
GetOperatingSystemDirectory();
330 Returns the architecture ID of this wxPlatformInfo instance.
332 wxArchitecture
GetArchitecture() const;
335 Returns the endianness ID of this wxPlatformInfo instance.
337 wxEndianness
GetEndianness() const;
340 Returns the run-time major version of the OS associated with this
341 wxPlatformInfo instance.
343 @see ::wxGetOsVersion(), CheckOSVersion()
345 int GetOSMajorVersion() const;
348 Returns the run-time minor version of the OS associated with this
349 wxPlatformInfo instance.
351 @see ::wxGetOsVersion(), CheckOSVersion()
353 int GetOSMinorVersion() const;
356 Returns the operating system ID of this wxPlatformInfo instance.
358 wxOperatingSystemId
GetOperatingSystemId() const;
361 Returns the description of the operating system of this wxPlatformInfo instance.
363 See wxGetOSDescription() for more info.
365 wxString
GetOperatingSystemDescription() const;
368 Returns the wxWidgets port ID associated with this wxPlatformInfo instance.
370 wxPortId
GetPortId() const;
373 Returns the Linux distribution info associated with this wxPlatformInfo instance.
375 See wxGetLinuxDistributionInfo() for more info.
377 wxLinuxDistributionInfo
GetLinuxDistributionInfo() const;
380 Returns the desktop environment associated with this wxPlatformInfo instance.
382 See wxAppTraits::GetDesktopEnvironment() for more info.
384 wxString
GetDesktopEnvironment() const;
387 Returns the run-time major version of the toolkit associated with this
388 wxPlatformInfo instance.
390 Note that if GetPortId() returns @c wxPORT_BASE, then this value is zero
391 (unless externally modified with SetToolkitVersion()); that is, no native
393 See wxAppTraits::GetToolkitVersion() for more info.
395 @see CheckToolkitVersion()
397 int GetToolkitMajorVersion() const;
400 Returns the run-time minor version of the toolkit associated with this
401 wxPlatformInfo instance.
403 Note that if GetPortId() returns @c wxPORT_BASE, then this value is zero
404 (unless externally modified with SetToolkitVersion()); that is, no native
406 See wxAppTraits::GetToolkitVersion() for more info.
408 @see CheckToolkitVersion()
410 int GetToolkitMinorVersion() const;
416 @name String-form getters
421 Returns the name for the architecture of this wxPlatformInfo instance.
423 wxString
GetArchName() const;
426 Returns the name for the endianness of this wxPlatformInfo instance.
428 wxString
GetEndiannessName() const;
431 Returns the operating system family name of the OS associated with this
432 wxPlatformInfo instance.
434 wxString
GetOperatingSystemFamilyName() const;
437 Returns the operating system name of the OS associated with this wxPlatformInfo
440 wxString
GetOperatingSystemIdName() const;
443 Returns the name of the wxWidgets port ID associated with this wxPlatformInfo
446 wxString
GetPortIdName() const;
449 Returns the short name of the wxWidgets port ID associated with this
450 wxPlatformInfo instance.
452 wxString
GetPortIdShortName() const;
464 Sets the architecture enum value associated with this wxPlatformInfo instance.
466 void SetArchitecture(wxArchitecture n
);
469 Sets the endianness enum value associated with this wxPlatformInfo instance.
471 void SetEndianness(wxEndianness n
);
474 Sets the version of the operating system associated with this wxPlatformInfo
477 void SetOSVersion(int major
, int minor
);
480 Sets the operating system associated with this wxPlatformInfo instance.
482 void SetOperatingSystemId(wxOperatingSystemId n
);
485 Sets the wxWidgets port ID associated with this wxPlatformInfo instance.
487 void SetPortId(wxPortId n
);
490 Sets the version of the toolkit associated with this wxPlatformInfo instance.
492 void SetToolkitVersion(int major
, int minor
);
495 Sets the operating system description associated with this wxPlatformInfo instance.
497 void SetOperatingSystemDescription(const wxString
& desc
);
500 Sets the desktop environment associated with this wxPlatformInfo instance.
502 void SetDesktopEnvironment(const wxString
& de
);
505 Sets the linux distribution info associated with this wxPlatformInfo instance.
507 void SetLinuxDistributionInfo(const wxLinuxDistributionInfo
& di
);