diff options
author | George Hazan <george.hazan@gmail.com> | 2014-11-08 20:04:24 +0000 |
---|---|---|
committer | George Hazan <george.hazan@gmail.com> | 2014-11-08 20:04:24 +0000 |
commit | 75b84796d6d14b9df136f4ea47d87aff3cfa5c90 (patch) | |
tree | e9e1d95081758aacc58bfb8173c974009a5e9c53 /plugins/AVS/src/utils.cpp | |
parent | 0f869bffb767a7fb2e3ceb4b081ba1ec6953dbfd (diff) |
code cleaning:
- (MCONTACT)-1 replaced with INVALID_CONTACT_ID;
- DBVARIANT+db_get_ts replaced with ptrT+db_get_tsa;
- VARST added for path reading;
- version bump
git-svn-id: http://svn.miranda-ng.org/main/trunk@10932 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c
Diffstat (limited to 'plugins/AVS/src/utils.cpp')
-rw-r--r-- | plugins/AVS/src/utils.cpp | 90 |
1 files changed, 40 insertions, 50 deletions
diff --git a/plugins/AVS/src/utils.cpp b/plugins/AVS/src/utils.cpp index 945b11db2b..a59f46af50 100644 --- a/plugins/AVS/src/utils.cpp +++ b/plugins/AVS/src/utils.cpp @@ -26,6 +26,14 @@ void mir_sleep(int time) }
/////////////////////////////////////////////////////////////////////////////////////////
+// substitutes variables and passes our own data path as base
+
+void MyPathToAbsolute(const TCHAR *ptszPath, TCHAR *ptszDest)
+{
+ PathToAbsoluteT(VARST(ptszPath), ptszDest, g_szDataPath);
+}
+
+/////////////////////////////////////////////////////////////////////////////////////////
// convert the avatar image path to a relative one...
// given: contact handle, path to image
@@ -59,13 +67,12 @@ void MakePathRelative(MCONTACT hContact) int CreateAvatarInCache(MCONTACT hContact, avatarCacheEntry *ace, char *szProto)
{
- DBVARIANT dbv = { 0 };
char *szExt = NULL;
- TCHAR tszFilename[MAX_PATH];
HANDLE hFile = INVALID_HANDLE_VALUE;
DWORD dwFileSizeHigh = 0, dwFileSize = 0, sizeLimit = 0;
- tszFilename[0] = 0;
+ ptrT tszValue;
+ TCHAR tszFilename[MAX_PATH]; tszFilename[0] = 0;
ace->hbmPic = 0;
ace->dwFlags = 0;
@@ -79,57 +86,42 @@ int CreateAvatarInCache(MCONTACT hContact, avatarCacheEntry *ace, char *szProto) if (proto == NULL || !db_get_b(NULL, AVS_MODULE, proto, 1))
return -1;
- if (db_get_b(hContact, "ContactPhoto", "Locked", 0) && !db_get_ts(hContact, "ContactPhoto", "Backup", &dbv)) {
- PathToAbsoluteT(dbv.ptszVal, tszFilename, g_szDataPath);
- db_free(&dbv);
- }
- else if (!db_get_ts(hContact, "ContactPhoto", "RFile", &dbv)) {
- PathToAbsoluteT(dbv.ptszVal, tszFilename, g_szDataPath);
- db_free(&dbv);
- }
- else if (!db_get_ts(hContact, "ContactPhoto", "File", &dbv)) {
- PathToAbsoluteT(dbv.ptszVal, tszFilename, g_szDataPath);
- db_free(&dbv);
- }
+ if (db_get_b(hContact, "ContactPhoto", "Locked", 0) && (tszValue = db_get_tsa(hContact, "ContactPhoto", "Backup")))
+ MyPathToAbsolute(tszValue, tszFilename);
+ else if (tszValue = db_get_tsa(hContact, "ContactPhoto", "RFile"))
+ MyPathToAbsolute(tszValue, tszFilename);
+ else if (tszValue = db_get_tsa(hContact, "ContactPhoto", "File"))
+ MyPathToAbsolute(tszValue, tszFilename);
else return -2;
}
else {
if (hContact == 0) { // create a protocol picture in the proto picture cache
- if (!db_get_ts(NULL, PPICT_MODULE, szProto, &dbv)) {
- PathToAbsoluteT(dbv.ptszVal, tszFilename, g_szDataPath);
- db_free(&dbv);
- }
- else {
- if (lstrcmpA(szProto, AVS_DEFAULT)) {
- if (!db_get_ts(NULL, PPICT_MODULE, AVS_DEFAULT, &dbv)) {
- PathToAbsoluteT(dbv.ptszVal, tszFilename, g_szDataPath);
- db_free(&dbv);
- }
-
- if (!strstr(szProto, "Global avatar for")) {
- PROTOACCOUNT* pdescr = (PROTOACCOUNT*)CallService(MS_PROTO_GETACCOUNT, 0, (LPARAM)szProto);
- if (pdescr == NULL)
- return -1;
- char key[MAX_PATH];
- mir_snprintf(key, SIZEOF(key), "Global avatar for %s accounts", pdescr->szProtoName);
- if (!db_get_ts(NULL, PPICT_MODULE, key, &dbv)) {
- PathToAbsoluteT(dbv.ptszVal, tszFilename, g_szDataPath);
- db_free(&dbv);
- }
- }
+ if (tszValue = db_get_tsa(NULL, PPICT_MODULE, szProto))
+ MyPathToAbsolute(tszValue, tszFilename);
+ else if (lstrcmpA(szProto, AVS_DEFAULT)) {
+ if (tszValue = db_get_tsa(NULL, PPICT_MODULE, AVS_DEFAULT))
+ MyPathToAbsolute(tszValue, tszFilename);
+
+ if (!strstr(szProto, "Global avatar for")) {
+ PROTOACCOUNT* pdescr = (PROTOACCOUNT*)CallService(MS_PROTO_GETACCOUNT, 0, (LPARAM)szProto);
+ if (pdescr == NULL)
+ return -1;
+ char key[MAX_PATH];
+ mir_snprintf(key, SIZEOF(key), "Global avatar for %s accounts", pdescr->szProtoName);
+ if (tszValue = db_get_tsa(NULL, PPICT_MODULE, key))
+ MyPathToAbsolute(tszValue, tszFilename);
}
}
}
- else if (hContact == (MCONTACT)-1) {
+ else if (hContact == INVALID_CONTACT_ID) {
// create own picture - note, own avatars are not on demand, they are loaded once at
// startup and everytime they are changed.
if (szProto[0] == '\0') {
// Global avatar
- if (db_get_ts(NULL, AVS_MODULE, "GlobalUserAvatarFile", &dbv))
+ if (tszValue = db_get_tsa(NULL, AVS_MODULE, "GlobalUserAvatarFile"))
+ MyPathToAbsolute(tszValue, tszFilename);
+ else
return -10;
-
- PathToAbsoluteT(dbv.ptszVal, tszFilename, g_szDataPath);
- db_free(&dbv);
}
else if (ProtoServiceExists(szProto, PS_GETMYAVATART)) {
if (CallProtoService(szProto, PS_GETMYAVATART, (WPARAM)tszFilename, (LPARAM)MAX_PATH))
@@ -142,10 +134,8 @@ int CreateAvatarInCache(MCONTACT hContact, avatarCacheEntry *ace, char *szProto) else
MultiByteToWideChar(CP_ACP, 0, szFileName, -1, tszFilename, SIZEOF(tszFilename));
}
- else if (!db_get_ts(NULL, szProto, "AvatarFile", &dbv)) {
- PathToAbsoluteT(dbv.ptszVal, tszFilename, g_szDataPath);
- db_free(&dbv);
- }
+ else if (tszValue = db_get_tsa(NULL, szProto, "AvatarFile"))
+ MyPathToAbsolute(tszValue, tszFilename);
else return -1;
}
}
@@ -184,7 +174,7 @@ int CreateAvatarInCache(MCONTACT hContact, avatarCacheEntry *ace, char *szProto) BOOL noTransparency = db_get_b(0, AVS_MODULE, "RemoveAllTransparency", 0);
// Calc image hash
- if (hContact != 0 && hContact != (MCONTACT)-1) {
+ if (hContact != 0 && hContact != INVALID_CONTACT_ID) {
// Have to reset settings? -> do it if image changed
DWORD imgHash = GetImgHash(ace->hbmPic);
if (imgHash != db_get_dw(hContact, "ContactPhoto", "ImageHash", 0)) {
@@ -206,7 +196,7 @@ int CreateAvatarInCache(MCONTACT hContact, avatarCacheEntry *ace, char *szProto) }
}
}
- else if (hContact == (MCONTACT)-1) { // My avatars
+ else if (hContact == INVALID_CONTACT_ID) { // My avatars
if (!noTransparency && !isTransparentImage
&& db_get_b(0, AVS_MODULE, "MakeTransparentBkg", 0)
&& db_get_b(0, AVS_MODULE, "MakeMyAvatarsTransparent", 0)) {
@@ -237,7 +227,7 @@ int CreateAvatarInCache(MCONTACT hContact, avatarCacheEntry *ace, char *szProto) protoPicCacheEntry *pAce = (protoPicCacheEntry *)ace;
if (hContact == 0)
pAce->dwFlags |= AVS_PROTOPIC;
- else if (hContact == (MCONTACT)-1)
+ else if (hContact == INVALID_CONTACT_ID)
pAce->dwFlags |= AVS_OWNAVATAR;
}
@@ -454,7 +444,7 @@ void DeleteGlobalUserAvatar() return;
TCHAR szFilename[MAX_PATH];
- PathToAbsoluteT(dbv.ptszVal, szFilename, g_szDataPath);
+ MyPathToAbsolute(dbv.ptszVal, szFilename);
db_free(&dbv);
DeleteFile(szFilename);
|