diff options
-rw-r--r-- | include/m_plugin.h | 369 |
1 files changed, 186 insertions, 183 deletions
diff --git a/include/m_plugin.h b/include/m_plugin.h index 4b0b968c1d..5b85b6450c 100644 --- a/include/m_plugin.h +++ b/include/m_plugin.h @@ -11,187 +11,190 @@ template<class T> class PLUGIN { protected: - CMStringA m_moduleName; - HNETLIBUSER m_hNetlibUser = nullptr; - - PLUGIN(const char *moduleName) : - m_moduleName(moduleName) - { - } - - __inline void debugLogA(LPCSTR szFormat, ...) - { - va_list args; - va_start(args, szFormat); - char buf[4096]; - int res = vsnprintf_s(buf, _TRUNCATE, szFormat, args); - Netlib_Log(this->m_hNetlibUser, (res != -1) ? buf : CMStringA().FormatV(szFormat, args)); - va_end(args); - } - - __inline void debugLogW(LPCWSTR wszFormat, ...) - { - va_list args; - va_start(args, wszFormat); - WCHAR buf[4096]; - int res = _vsnwprintf_s(buf, _TRUNCATE, wszFormat, args); - Netlib_LogW(this->m_hNetlibUser, ptrA(Utf8EncodeW((res != -1) ? buf : CMStringW().FormatV(wszFormat, args)))); - va_end(args); - } - - __forceinline INT_PTR delSetting(const char *name) - { - return db_unset(0, m_moduleName, name); - } - __forceinline INT_PTR delSetting(MCONTACT hContact, const char *name) - { - return db_unset(hContact, m_moduleName, name); - } - - __forceinline bool getBool(const char *name, bool defaultValue = false) - { - return db_get_b(0, m_moduleName, name, defaultValue) != 0; - } - __forceinline bool getBool(MCONTACT hContact, const char *name, bool defaultValue = false) - { - return db_get_b(hContact, m_moduleName, name, defaultValue) != 0; - } - - __forceinline int getByte(const char *name, BYTE defaultValue = 0) - { - return db_get_b(0, m_moduleName, name, defaultValue); - } - __forceinline int getByte(MCONTACT hContact, const char *name, BYTE defaultValue = 0) - { - return db_get_b(hContact, m_moduleName, name, defaultValue); - } - - __forceinline int getWord(const char *name, WORD defaultValue = 0) - { - return db_get_w(0, m_moduleName, name, defaultValue); - } - __forceinline int getWord(MCONTACT hContact, const char *name, WORD defaultValue = 0) - { - return db_get_w(hContact, m_moduleName, name, defaultValue); - } - - __forceinline DWORD getDword(const char *name, DWORD defaultValue = 0) - { - return db_get_dw(0, m_moduleName, name, defaultValue); - } - __forceinline DWORD getDword(MCONTACT hContact, const char *name, DWORD defaultValue = 0) - { - return db_get_dw(hContact, m_moduleName, name, defaultValue); - } - - __forceinline INT_PTR getString(const char *name, DBVARIANT *result) - { - return db_get_s(0, m_moduleName, name, result); - } - __forceinline INT_PTR getString(MCONTACT hContact, const char *name, DBVARIANT *result) - { - return db_get_s(hContact, m_moduleName, name, result); - } - - __forceinline INT_PTR getWString(const char *name, DBVARIANT *result) - { - return db_get_ws(0, m_moduleName, name, result); - } - __forceinline INT_PTR getWString(MCONTACT hContact, const char *name, DBVARIANT *result) - { - return db_get_ws(hContact, m_moduleName, name, result); - } - - __forceinline char* getStringA(const char *name) - { - return db_get_sa(0, m_moduleName, name); - } - __forceinline char* getStringA(MCONTACT hContact, const char *name) - { - return db_get_sa(hContact, m_moduleName, name); - } - - __forceinline wchar_t* getWStringA(const char *name) - { - return db_get_wsa(0, m_moduleName, name); - } - __forceinline wchar_t* getWStringA(MCONTACT hContact, const char *name) - { - return db_get_wsa(hContact, m_moduleName, name); - } - - __forceinline void setByte(const char *name, BYTE value) - { - db_set_b(0, m_moduleName, name, value); - } - __forceinline void setByte(MCONTACT hContact, const char *name, BYTE value) - { - db_set_b(hContact, m_moduleName, name, value); - } - - __forceinline void setWord(const char *name, WORD value) - { - db_set_w(0, m_moduleName, name, value); - } - __forceinline void setWord(MCONTACT hContact, const char *name, WORD value) - { - db_set_w(hContact, m_moduleName, name, value); - } - - __forceinline void setDword(const char *name, DWORD value) - { - db_set_dw(0, m_moduleName, name, value); - } - __forceinline void setDword(MCONTACT hContact, const char *name, DWORD value) - { - db_set_dw(hContact, m_moduleName, name, value); - } - - __forceinline void setString(const char *name, const char* value) - { - db_set_s(0, m_moduleName, name, value); - } - __forceinline void setString(MCONTACT hContact, const char *name, const char* value) - { - db_set_s(hContact, m_moduleName, name, value); - } - - __forceinline void setWString(const char *name, const wchar_t* value) - { - db_set_ws(0, m_moduleName, name, value); - } - __forceinline void setWString(MCONTACT hContact, const char *name, const wchar_t* value) - { - db_set_ws(hContact, m_moduleName, name, value); - } - - __forceinline HANDLE CreatePluginEvent(const char *name) - { - CMStringA str(m_moduleName); - str.Append(name); - - return CreateHookableEvent(str); - } - - typedef int(__cdecl T::*MyEventFunc)(WPARAM, LPARAM); - __forceinline void HookPluginEvent(const char *name, MyEventFunc pFunc) - { - ::HookEventObj(name, (MIRANDAHOOKOBJ)*(void**)&pFunc, this); - } - - typedef INT_PTR(__cdecl T::*MyServiceFunc)(WPARAM, LPARAM); - __forceinline void CreatePluginService(const char *name, MyServiceFunc pFunc) - { - CMStringA str(m_moduleName); - str.Append(name); - ::CreateServiceFunctionObj(str, (MIRANDASERVICEOBJ)*(void**)&pFunc, this); - } - - typedef INT_PTR(__cdecl T::*MyServiceFuncParam)(WPARAM, LPARAM, LPARAM); - __forceinline void CreateProtoServiceParam(const char *name, MyServiceFuncParam pFunc, LPARAM param) - { - CMStringA str(m_moduleName); - str.Append(name); - ::CreateServiceFunctionObjParam(str, (MIRANDASERVICEOBJPARAM)*(void**)&pFunc, this, param); - } + CMStringA m_moduleName; + HANDLE m_hLogger = nullptr; + + PLUGIN(const char *moduleName) : + m_moduleName(moduleName) + { + wchar_t path[MAX_PATH]; + mir_snwprintf(path, "%s\%s.txt", VARSW("%miranda_logpath%"), moduleName); + m_hLogger = mir_createLog(moduleName, nullptr, path) + } + + ~PLUGIN() + { + if (m_hLogger) { + mir_closeLog(m_hLogger); + m_hLogger = nullptr; + } + } + + __inline void debugLogA(LPCSTR szFormat, ...) + { + va_list args; + va_start(args, szFormat); + mir_writeLogVA(m_hLogger, args); + va_end(args); + } + + __inline void debugLogW(LPCWSTR wszFormat, ...) + { + va_list args; + va_start(args, wszFormat); + mir_writeLogVW(m_hLogger, args); + va_end(args); + } + + __forceinline INT_PTR delSetting(const char *name) + { + return db_unset(0, m_moduleName, name); + } + __forceinline INT_PTR delSetting(MCONTACT hContact, const char *name) + { + return db_unset(hContact, m_moduleName, name); + } + + __forceinline bool getBool(const char *name, bool defaultValue = false) + { + return db_get_b(0, m_moduleName, name, defaultValue) != 0; + } + __forceinline bool getBool(MCONTACT hContact, const char *name, bool defaultValue = false) + { + return db_get_b(hContact, m_moduleName, name, defaultValue) != 0; + } + + __forceinline int getByte(const char *name, BYTE defaultValue = 0) + { + return db_get_b(0, m_moduleName, name, defaultValue); + } + __forceinline int getByte(MCONTACT hContact, const char *name, BYTE defaultValue = 0) + { + return db_get_b(hContact, m_moduleName, name, defaultValue); + } + + __forceinline int getWord(const char *name, WORD defaultValue = 0) + { + return db_get_w(0, m_moduleName, name, defaultValue); + } + __forceinline int getWord(MCONTACT hContact, const char *name, WORD defaultValue = 0) + { + return db_get_w(hContact, m_moduleName, name, defaultValue); + } + + __forceinline DWORD getDword(const char *name, DWORD defaultValue = 0) + { + return db_get_dw(0, m_moduleName, name, defaultValue); + } + __forceinline DWORD getDword(MCONTACT hContact, const char *name, DWORD defaultValue = 0) + { + return db_get_dw(hContact, m_moduleName, name, defaultValue); + } + + __forceinline INT_PTR getString(const char *name, DBVARIANT *result) + { + return db_get_s(0, m_moduleName, name, result); + } + __forceinline INT_PTR getString(MCONTACT hContact, const char *name, DBVARIANT *result) + { + return db_get_s(hContact, m_moduleName, name, result); + } + + __forceinline INT_PTR getWString(const char *name, DBVARIANT *result) + { + return db_get_ws(0, m_moduleName, name, result); + } + __forceinline INT_PTR getWString(MCONTACT hContact, const char *name, DBVARIANT *result) + { + return db_get_ws(hContact, m_moduleName, name, result); + } + + __forceinline char* getStringA(const char *name) + { + return db_get_sa(0, m_moduleName, name); + } + __forceinline char* getStringA(MCONTACT hContact, const char *name) + { + return db_get_sa(hContact, m_moduleName, name); + } + + __forceinline wchar_t* getWStringA(const char *name) + { + return db_get_wsa(0, m_moduleName, name); + } + __forceinline wchar_t* getWStringA(MCONTACT hContact, const char *name) + { + return db_get_wsa(hContact, m_moduleName, name); + } + + __forceinline void setByte(const char *name, BYTE value) + { + db_set_b(0, m_moduleName, name, value); + } + __forceinline void setByte(MCONTACT hContact, const char *name, BYTE value) + { + db_set_b(hContact, m_moduleName, name, value); + } + + __forceinline void setWord(const char *name, WORD value) + { + db_set_w(0, m_moduleName, name, value); + } + __forceinline void setWord(MCONTACT hContact, const char *name, WORD value) + { + db_set_w(hContact, m_moduleName, name, value); + } + + __forceinline void setDword(const char *name, DWORD value) + { + db_set_dw(0, m_moduleName, name, value); + } + __forceinline void setDword(MCONTACT hContact, const char *name, DWORD value) + { + db_set_dw(hContact, m_moduleName, name, value); + } + + __forceinline void setString(const char *name, const char* value) + { + db_set_s(0, m_moduleName, name, value); + } + __forceinline void setString(MCONTACT hContact, const char *name, const char* value) + { + db_set_s(hContact, m_moduleName, name, value); + } + + __forceinline void setWString(const char *name, const wchar_t* value) + { + db_set_ws(0, m_moduleName, name, value); + } + __forceinline void setWString(MCONTACT hContact, const char *name, const wchar_t* value) + { + db_set_ws(hContact, m_moduleName, name, value); + } + + __forceinline HANDLE CreatePluginEvent(const char *name) + { + CMStringA str(FORMAT, "%s\%s", m_moduleName, name); + return CreateHookableEvent(str); + } + + typedef int(__cdecl T::*MyEventFunc)(WPARAM, LPARAM); + __forceinline void HookPluginEvent(const char *name, MyEventFunc pFunc) + { + HookEventObj(name, (MIRANDAHOOKOBJ)*(void**)&pFunc, this); + } + + typedef INT_PTR(__cdecl T::*MyServiceFunc)(WPARAM, LPARAM); + __forceinline void CreatePluginService(const char *name, MyServiceFunc pFunc) + { + CMStringA str(FORMAT, "%s\%s", m_moduleName, name); + CreateServiceFunctionObj(str, (MIRANDASERVICEOBJ)*(void**)&pFunc, this); + } + + typedef INT_PTR(__cdecl T::*MyServiceFuncParam)(WPARAM, LPARAM, LPARAM); + __forceinline void CreatePluginServiceParam(const char *name, MyServiceFuncParam pFunc, LPARAM param) + { + CMStringA str(FORMAT, "%s\%s", m_moduleName, name); + CreateServiceFunctionObjParam(str, (MIRANDASERVICEOBJPARAM)*(void**)&pFunc, this, param); + } }; |