OSDN Git Service

Removed perfcounter_read() and perfcounter_freq() functions, since we can use QElapse...
[mutilities/MUtilities.git] / include / MUtils / OSSupport.h
index b5bcaee..fd66c1f 100644 (file)
 
 #pragma once
 
+//MUtils
+#include <MUtils/Global.h>
+
+//Qt
 #include <QString>
+#include <QDate>
 
 ///////////////////////////////////////////////////////////////////////////////
 
@@ -29,6 +34,48 @@ namespace MUtils
 {
        namespace OS
        {
+               namespace Version
+               {
+                       //Supported OS types
+                       typedef enum
+                       {
+                               OS_UNKNOWN = 0,
+                               OS_WINDOWS = 1
+                       }
+                       os_type_t;
+
+                       //OS version struct
+                       typedef struct _os_info_t
+                       {
+                               unsigned int type;
+                               unsigned int versionMajor;
+                               unsigned int versionMinor;
+                               bool overrideFlag;
+
+                               //comparision operators
+                               inline bool operator== (const _os_info_t &rhs) const { return (type == rhs.type) && (versionMajor == rhs.versionMajor) && ((versionMinor == rhs.versionMinor)); }
+                               inline bool operator!= (const _os_info_t &rhs) const { return (type != rhs.type) || (versionMajor != rhs.versionMajor) || ((versionMinor != rhs.versionMinor)); }
+                               inline bool operator>  (const _os_info_t &rhs) const { return (type == rhs.type) && ((versionMajor > rhs.versionMajor) || ((versionMajor == rhs.versionMajor) && (versionMinor >  rhs.versionMinor))); }
+                               inline bool operator>= (const _os_info_t &rhs) const { return (type == rhs.type) && ((versionMajor > rhs.versionMajor) || ((versionMajor == rhs.versionMajor) && (versionMinor >= rhs.versionMinor))); }
+                               inline bool operator<  (const _os_info_t &rhs) const { return (type == rhs.type) && ((versionMajor < rhs.versionMajor) || ((versionMajor == rhs.versionMajor) && (versionMinor <  rhs.versionMinor))); }
+                               inline bool operator<= (const _os_info_t &rhs) const { return (type == rhs.type) && ((versionMajor < rhs.versionMajor) || ((versionMajor == rhs.versionMajor) && (versionMinor <= rhs.versionMinor))); }
+                       }
+                       os_version_t;
+
+                       //Known Windows NT versions
+                       static const os_version_t WINDOWS_WIN2K = { OS_WINDOWS, 5, 0 }; // 2000
+                       static const os_version_t WINDOWS_WINXP = { OS_WINDOWS, 5, 1 }; // XP
+                       static const os_version_t WINDOWS_XPX64 = { OS_WINDOWS, 5, 2 }; // XP_x64
+                       static const os_version_t WINDOWS_VISTA = { OS_WINDOWS, 6, 0 }; // Vista
+                       static const os_version_t WINDOWS_WIN70 = { OS_WINDOWS, 6, 1 }; // 7
+                       static const os_version_t WINDOWS_WIN80 = { OS_WINDOWS, 6, 2 }; // 8
+                       static const os_version_t WINDOWS_WIN81 = { OS_WINDOWS, 6, 3 }; // 8.1
+                       static const os_version_t WINDOWS_WN100 = { OS_WINDOWS, 6, 4 }; // 10
+
+                       //Unknown OS
+                       static const os_version_t UNKNOWN_OPSYS = { OS_UNKNOWN, 0, 0 }; // N/A
+               }
+
                //Known Folders IDs
                typedef enum
                {
@@ -39,8 +86,77 @@ namespace MUtils
                }
                known_folder_t;
                
+               //Network connection types
+               typedef enum
+               {
+                       NETWORK_TYPE_ERR = 0,   /*unknown*/
+                       NETWORK_TYPE_NON = 1,   /*not connected*/
+                       NETWORK_TYPE_YES = 2    /*connected*/
+               }
+               network_type_t;
+                               
+               //System message
+               MUTILS_API void system_message_nfo(const wchar_t *const title, const wchar_t *const text);
+               MUTILS_API void system_message_wrn(const wchar_t *const title, const wchar_t *const text);
+               MUTILS_API void system_message_err(const wchar_t *const title, const wchar_t *const text);
+
+               //CLI Arguments
+               MUTILS_API const QStringList &arguments(void);
+
+               //Get the OS version
+               MUTILS_API const Version::os_version_t &os_version(void);
+               MUTILS_API const char *os_friendly_name(const MUtils::OS::Version::os_version_t &os_version);
+               MUTILS_API const bool &running_on_wine(void);
+
                //Get known Folder
-               const QString &known_folder(known_folder_t folder_id);
+               MUTILS_API const QString &known_folder(known_folder_t folder_id);
+
+               //Current Date & Time
+               MUTILS_API QDate current_date(void);
+               MUTILS_API quint64 current_file_time(void);
+
+               //Check for process elevation
+               MUTILS_API bool is_elevated(bool *bIsUacEnabled = NULL);
+               MUTILS_API bool user_is_admin(void);
+
+               //Network Status
+               MUTILS_API int network_status(void);
+
+               //Message handler
+               MUTILS_API bool handle_os_message(const void *const message, long *result);
+
+               //Sleep
+               MUTILS_API void sleep_ms(const size_t &duration);
+
+               //Is executable file?
+               MUTILS_API bool is_executable_file(const QString &path);
+
+               //Shutdown & Hibernation
+               MUTILS_API bool is_hibernation_supported(void);
+               MUTILS_API bool shutdown_computer(const QString &message, const unsigned long timeout, const bool forceShutdown, const bool hibernate);
+
+               //Free diskspace
+               MUTILS_API bool free_diskspace(const QString &path, quint64 &freeSpace);
+
+               //Shell open
+               MUTILS_API bool shell_open(const QWidget *parent, const QString &url, const bool explore = false);
+               MUTILS_API bool shell_open(const QWidget *parent, const QString &url, const QString &parameters, const QString &directory, const bool explore = false);
+
+               //Open media file
+               MUTILS_API bool open_media_file(const QString &mediaFilePath);
+
+               //Process priority
+               MUTILS_API bool change_process_priority(const int priority);
+               MUTILS_API bool change_process_priority(const QProcess *proc, const int priority);
+
+               //Process ID
+               MUTILS_API quint32 process_id(const QProcess *proc);
+
+               //Check if debugger is present
+               MUTILS_API void check_debugger(void);
+
+               //Error handling
+               MUTILS_API void fatal_exit(const wchar_t* const errorMessage);
        }
 }