/////////////////////////////////////////////////////////////////////////////
// Name: platinfo.h
-// Purpose: documentation for wxPlatformInfo class
+// Purpose: interface of wxPlatformInfo
// Author: wxWidgets team
// RCS-ID: $Id$
// Licence: wxWindows license
/////////////////////////////////////////////////////////////////////////////
+
+/**
+ The following are the operating systems which are recognized by wxWidgets and
+ whose version can be detected at run-time.
+
+ The values of the constants are chosen so that they can be combined as flags;
+ this allows to check for operating system families like e.g. wxOS_MAC and wxOS_UNIX.
+*/
+enum wxOperatingSystemId
+{
+ wxOS_UNKNOWN = 0, //!< returned on error
+
+ wxOS_MAC_OS = 1 << 0, //!< Apple Mac OS 8/9/X with Mac paths
+ wxOS_MAC_OSX_DARWIN = 1 << 1, //!< Apple Mac OS X with Unix paths
+ wxOS_MAC = wxOS_MAC_OS|wxOS_MAC_OSX_DARWIN,
+
+ wxOS_WINDOWS_9X = 1 << 2, //!< Windows 9x family (95/98/ME)
+ wxOS_WINDOWS_NT = 1 << 3, //!< Windows NT family (NT/2000/XP)
+ wxOS_WINDOWS_MICRO = 1 << 4, //!< MicroWindows
+ wxOS_WINDOWS_CE = 1 << 5, //!< Windows CE (Window Mobile)
+ wxOS_WINDOWS = wxOS_WINDOWS_9X |
+ wxOS_WINDOWS_NT |
+ wxOS_WINDOWS_MICRO |
+ wxOS_WINDOWS_CE,
+
+ wxOS_UNIX_LINUX = 1 << 6, //!< Linux
+ wxOS_UNIX_FREEBSD = 1 << 7, //!< FreeBSD
+ wxOS_UNIX_OPENBSD = 1 << 8, //!< OpenBSD
+ wxOS_UNIX_NETBSD = 1 << 9, //!< NetBSD
+ wxOS_UNIX_SOLARIS = 1 << 10, //!< SunOS
+ wxOS_UNIX_AIX = 1 << 11, //!< AIX
+ wxOS_UNIX_HPUX = 1 << 12, //!< HP/UX
+ wxOS_UNIX = wxOS_UNIX_LINUX |
+ wxOS_UNIX_FREEBSD |
+ wxOS_UNIX_OPENBSD |
+ wxOS_UNIX_NETBSD |
+ wxOS_UNIX_SOLARIS |
+ wxOS_UNIX_AIX |
+ wxOS_UNIX_HPUX,
+
+ wxOS_DOS = 1 << 15, //!< Microsoft DOS
+ wxOS_OS2 = 1 << 16 //!< OS/2
+};
+
+/**
+ The list of wxWidgets ports.
+
+ Some of them can be used with more than a single (native) toolkit;
+ e.g. wxWinCE port sources can be used with smartphones, pocket PCs
+ and handheld devices SDKs.
+*/
+enum wxPortId
+{
+ wxPORT_UNKNOWN = 0, //!< returned on error
+
+ wxPORT_BASE = 1 << 0, //!< wxBase, no native toolkit used
+
+ wxPORT_MSW = 1 << 1, //!< wxMSW, native toolkit is Windows API
+ wxPORT_MOTIF = 1 << 2, //!< wxMotif, using [Open]Motif or Lesstif
+ wxPORT_GTK = 1 << 3, //!< wxGTK, using GTK+ 1.x, 2.x, GPE or Maemo
+ wxPORT_MGL = 1 << 4, //!< wxMGL, using wxUniversal
+ wxPORT_X11 = 1 << 5, //!< wxX11, using wxUniversal
+ wxPORT_OS2 = 1 << 6, //!< wxOS2, using OS/2 Presentation Manager
+ wxPORT_MAC = 1 << 7, //!< wxMac, using Carbon or Classic Mac API
+ wxPORT_COCOA = 1 << 8, //!< wxCocoa, using Cocoa NextStep/Mac API
+ wxPORT_WINCE = 1 << 9, //!< wxWinCE, toolkit is WinCE SDK API
+ wxPORT_PALMOS = 1 << 10, //!< wxPalmOS, toolkit is PalmOS API
+ wxPORT_DFB = 1 << 11 //!< wxDFB, using wxUniversal
+};
+
+
+/**
+ The architecture of the operating system
+ (regardless of the build environment of wxWidgets library - see ::wxIsPlatform64bit()
+ documentation for more info).
+*/
+enum wxArchitecture
+{
+ wxARCH_INVALID = -1, //!< returned on error
+
+ wxARCH_32, //!< 32 bit
+ wxARCH_64,
+
+ wxARCH_MAX
+};
+
+
+/**
+ The endian-ness of the machine.
+*/
+enum wxEndianness
+{
+ wxENDIAN_INVALID = -1, //!< returned on error
+
+ wxENDIAN_BIG, //!< 4321
+ wxENDIAN_LITTLE, //!< 1234
+ wxENDIAN_PDP, //!< 3412
+
+ wxENDIAN_MAX
+};
+
+
/**
@class wxPlatformInfo
@wxheader{platinfo.h}
-
+
This class holds informations about the operating system and the toolkit that
- the application
- is running under and some basic architecture info of the machine where it's
- running.
-
+ the application is running under and some basic architecture info of the machine
+ where it's running.
+
@library{wxbase}
- @category{FIXME}
-
- @seealso
- wxGetOSVersion, wxIsPlatformLittleEndian, wxIsPlatform64Bit, wxAppTraits
+ @category{misc}
+
+ @see ::wxGetOsVersion(), wxIsPlatformLittleEndian(), wxIsPlatform64Bit(),
+ wxAppTraits
*/
class wxPlatformInfo : public wxObject
{
public:
- //@{
+
/**
- Initializes the object using given values.
+ Initializes the instance with the values corresponding to the currently
+ running platform.
+
+ This is a fast operation because it only requires to copy the values
+ internally cached for the currently running platform.
+
+ @see Get()
*/
wxPlatformInfo();
- wxPlatformInfo(wxPortId pid = wxPORT_UNKNOWN,
- int tkMajor = -1,
- int tkMinor = -1,
- wxOperatingSystemId id = wxOS_UNKNOWN,
- int osMajor = -1,
- int osMinor = -1,
- wxArchitecture arch = wxARCH_INVALID,
- wxEndianness endian = wxENDIAN_INVALID);
- //@}
+
+ /**
+ Initializes the object using given values.
+ */
+ wxPlatformInfo(wxPortId pid = wxPORT_UNKNOWN,
+ int tkMajor = -1,
+ int tkMinor = -1,
+ wxOperatingSystemId id = wxOS_UNKNOWN,
+ int osMajor = -1,
+ int osMinor = -1,
+ wxArchitecture arch = wxARCH_INVALID,
+ wxEndianness endian = wxENDIAN_INVALID);
+
/**
Returns @true if the OS version is at least @c major.minor.
-
- @sa GetOSMajorVersion(), GetOSMinorVersion(),
- CheckToolkitVersion()
+
+ @see GetOSMajorVersion(), GetOSMinorVersion(),
+ CheckToolkitVersion()
*/
- bool CheckOSVersion(int major, int minor);
+ bool CheckOSVersion(int major, int minor) const;
/**
Returns @true if the toolkit version is at least @c major.minor.
-
- @sa GetToolkitMajorVersion(),
- GetToolkitMinorVersion(),
- CheckOSVersion()
+
+ @see GetToolkitMajorVersion(),
+ GetToolkitMinorVersion(), CheckOSVersion()
*/
- bool CheckToolkitVersion(int major, int minor);
+ bool CheckToolkitVersion(int major, int minor) const;
/**
- Returns the global wxPlatformInfo object, initialized with the values for the
- currently running platform.
+ Returns the global wxPlatformInfo object, initialized with the values
+ for the currently running platform.
*/
-#define static const wxPlatformInfo Get() /* implementation is private */
+ static const wxPlatformInfo Get();
/**
Converts the given string to a wxArchitecture enum value or to
- wxARCH_INVALID if the given string is not a valid architecture string
+ @c wxARCH_INVALID if the given string is not a valid architecture string
(i.e. does not contain nor @c 32 nor @c 64 strings).
*/
static wxArchitecture GetArch(const wxString& arch);
- //@{
+ /**
+ Returns the name for the given wxArchitecture enumeration value.
+ */
+ static wxString GetArchName(wxArchitecture arch) const;
+
/**
Returns the name for the architecture of this wxPlatformInfo instance.
*/
- static wxString GetArchName(wxArchitecture arch);
- wxString GetArchName();
- //@}
+ wxString GetArchName() const;
/**
Returns the architecture ID of this wxPlatformInfo instance.
*/
- wxArchitecture GetArchitecture();
+ wxArchitecture GetArchitecture() const;
+
+ /**
+ Converts the given string to a wxEndianness enum value or to
+ @c wxENDIAN_INVALID if the given string is not a valid endianness
+ string (i.e. does not contain nor little nor big strings).
+ */
+ static wxEndianness GetEndianness(const wxString& end) const;
- //@{
/**
Returns the endianness ID of this wxPlatformInfo instance.
*/
- static wxEndianness GetEndianness(const wxString& end);
- wxEndianness GetEndianness();
- //@}
+ wxEndianness GetEndianness() const;
+
+ /**
+ Returns name for the given wxEndianness enumeration value.
+ */
+ static wxString GetEndiannessName(wxEndianness end) const;
- //@{
/**
Returns the name for the endianness of this wxPlatformInfo instance.
*/
- static wxString GetEndiannessName(wxEndianness end);
- wxString GetEndiannessName();
- //@}
+ wxString GetEndiannessName() const;
/**
Returns the run-time major version of the OS associated with this
wxPlatformInfo instance.
- See wxGetOsVersion for more info.
-
- @sa CheckOSVersion()
+
+ @see ::wxGetOsVersion(), CheckOSVersion()
*/
- int GetOSMajorVersion();
+ int GetOSMajorVersion() const;
/**
Returns the run-time minor version of the OS associated with this
wxPlatformInfo instance.
- See wxGetOsVersion for more info.
-
- @sa CheckOSVersion()
+
+ @see ::wxGetOsVersion(), CheckOSVersion()
*/
- int GetOSMinorVersion();
+ int GetOSMinorVersion() const;
+
+ /**
+ Returns the operating system family name for the given wxOperatingSystemId
+ enumeration value: @c Unix for @c wxOS_UNIX, @c Macintosh for @c wxOS_MAC,
+ @c Windows for @c wxOS_WINDOWS, @c DOS for @c wxOS_DOS, @c OS/2 for @c wxOS_OS2.
+ */
+ static wxString GetOperatingSystemFamilyName(wxOperatingSystemId os) const;
- //@{
/**
Returns the operating system family name of the OS associated with this
wxPlatformInfo instance.
*/
- static wxString GetOperatingSystemFamilyName(wxOperatingSystemId os);
- wxString GetOperatingSystemFamilyName();
- //@}
+ wxString GetOperatingSystemFamilyName() const;
+
+ /**
+ Converts the given string to a wxOperatingSystemId enum value or to @c
+ wxOS_UNKNOWN if the given string is not a valid operating system name.
+ */
+ static wxOperatingSystemId GetOperatingSystemId(const wxString& name) const;
- //@{
/**
Returns the operating system ID of this wxPlatformInfo instance.
*/
- static wxOperatingSystemId GetOperatingSystemId(const wxString& name);
- wxOperatingSystemId GetOperatingSystemId();
- //@}
+ wxOperatingSystemId GetOperatingSystemId() const;
+
+ /**
+ Returns the name for the given operating system ID value.
+
+ This can be a long name (e.g. <tt>Microsoft Windows NT</tt>);
+ use GetOperatingSystemFamilyName() to retrieve a short, generic name.
+ */
+ static wxString GetOperatingSystemIdName(wxOperatingSystemId os) const;
- //@{
/**
Returns the operating system name of the OS associated with this wxPlatformInfo
instance.
*/
- static wxString GetOperatingSystemIdName(wxOperatingSystemId os);
- wxString GetOperatingSystemIdName();
- //@}
+ wxString GetOperatingSystemIdName() const;
+
+
+ /**
+ Converts the given string to a wxWidgets port ID value or to @c wxPORT_UNKNOWN
+ if the given string does not match any of the wxWidgets canonical name ports
+ ("wxGTK", "wxMSW", etc) nor any of the short wxWidgets name ports ("gtk", "msw", etc).
+ */
+ static wxPortId GetPortId(const wxString& portname) const;
- //@{
/**
Returns the wxWidgets port ID associated with this wxPlatformInfo instance.
*/
- static wxPortId GetPortId(const wxString& portname);
- wxPortId GetPortId();
- //@}
+ wxPortId GetPortId() const;
+
+ /**
+ Returns the name of the given wxWidgets port ID value.
+ The @a usingUniversal argument specifies whether the port is in its native
+ or wxUniversal variant.
+
+ The returned string always starts with the "wx" prefix and is a mixed-case string.
+ */
+ static wxString GetPortIdName(wxPortId port, bool usingUniversal) const;
- //@{
/**
Returns the name of the wxWidgets port ID associated with this wxPlatformInfo
instance.
*/
- static wxString GetPortIdName(wxPortId port, bool usingUniversal);
- wxString GetPortIdName();
- //@}
+ wxString GetPortIdName() const;
+
+ /**
+ Returns the short name of the given wxWidgets port ID value.
+ The @a usingUniversal argument specifies whether the port is in its native
+ or wxUniversal variant.
+
+ The returned string does not start with the "wx" prefix and is always lower case.
+ */
+ static wxString GetPortIdShortName(wxPortId port,
+ bool usingUniversal) const;
- //@{
/**
Returns the short name of the wxWidgets port ID associated with this
wxPlatformInfo instance.
*/
- static wxString GetPortIdShortName(wxPortId port,
- bool usingUniversal);
- wxString GetPortIdShortName();
- //@}
+ wxString GetPortIdShortName() const;
/**
Returns the run-time major version of the toolkit associated with this
wxPlatformInfo instance.
- Note that if GetPortId() returns wxPORT_BASE, then this value is zero (unless
- externally modified with wxPlatformInfo::SetToolkitVersion); that is, no native toolkit is in use.
-
- See wxAppTraits::GetToolkitVersion for more info.
-
- @sa CheckToolkitVersion()
+
+ Note that if GetPortId() returns @c wxPORT_BASE, then this value is zero
+ (unless externally modified with SetToolkitVersion()); that is, no native
+ toolkit is in use.
+ See wxAppTraits::GetToolkitVersion() for more info.
+
+ @see CheckToolkitVersion()
*/
- int GetToolkitMajorVersion();
+ int GetToolkitMajorVersion() const;
/**
Returns the run-time minor version of the toolkit associated with this
wxPlatformInfo instance.
- Note that if GetPortId() returns wxPORT_BASE, then this value is zero (unless
- externally modified with wxPlatformInfo::SetToolkitVersion); that is, no native toolkit is in use.
-
- See wxAppTraits::GetToolkitVersion for more info.
-
- @sa CheckToolkitVersion()
+
+ Note that if GetPortId() returns @c wxPORT_BASE, then this value is zero
+ (unless externally modified with SetToolkitVersion()); that is, no native
+ toolkit is in use.
+ See wxAppTraits::GetToolkitVersion() for more info.
+
+ @see CheckToolkitVersion()
*/
- int GetToolkitMinorVersion();
+ int GetToolkitMinorVersion() const;
/**
Returns @true if this instance is fully initialized with valid values.
*/
-#define bool IsOk() /* implementation is private */
+ bool IsOk() const;
/**
Returns @true if this wxPlatformInfo describes wxUniversal build.
*/
- bool IsUsingUniversalWidgets();
+ bool IsUsingUniversalWidgets() const;
/**
Sets the architecture enum value associated with this wxPlatformInfo instance.
/**
Inequality operator. Tests all class' internal variables.
*/
- bool operator!=(const wxPlatformInfo& t);
+ bool operator!=(const wxPlatformInfo& t) const;
/**
Equality operator. Tests all class' internal variables.
*/
- bool operator==(const wxPlatformInfo& t);
+ bool operator==(const wxPlatformInfo& t) const;
};
+