summaryrefslogtreecommitdiff
path: root/protocols/SkypeWeb/src/skype_utils.h
diff options
context:
space:
mode:
authorMikalaiR <nikolay.romanovich@narod.ru>2015-08-09 09:09:29 +0000
committerMikalaiR <nikolay.romanovich@narod.ru>2015-08-09 09:09:29 +0000
commit45898e008336c419f9d4b07ccfa46fde30226db0 (patch)
tree1a3ea8a7e16df2005226c95948f50d5f9e8411ae /protocols/SkypeWeb/src/skype_utils.h
parent37293d2f4ab8a9ed5cb90ae606ff96f01bd72f78 (diff)
SkypeWeb: fix mirver, more optimizations
git-svn-id: http://svn.miranda-ng.org/main/trunk@14880 1316c22d-e87f-b044-9b9b-93d7a3e3ba9c
Diffstat (limited to 'protocols/SkypeWeb/src/skype_utils.h')
-rw-r--r--protocols/SkypeWeb/src/skype_utils.h21
1 files changed, 21 insertions, 0 deletions
diff --git a/protocols/SkypeWeb/src/skype_utils.h b/protocols/SkypeWeb/src/skype_utils.h
index f4f7c14035..b50b65546a 100644
--- a/protocols/SkypeWeb/src/skype_utils.h
+++ b/protocols/SkypeWeb/src/skype_utils.h
@@ -35,6 +35,7 @@ class DB_AUTH_BLOB
pCurBlob += sizeof(DWORD);
*((PDWORD)pCurBlob) = (DWORD)hContact;
pCurBlob += sizeof(DWORD);
+
if (szNick) { mir_strcpy((char*)pCurBlob, szNick ); pCurBlob += mir_strlen(szNick ); } pCurBlob += 1;
if (szFirstName){ mir_strcpy((char*)pCurBlob, szFirstName); pCurBlob += mir_strlen(szFirstName); } pCurBlob += 1;
if (szLastName) { mir_strcpy((char*)pCurBlob, szLastName ); pCurBlob += mir_strlen(szLastName ); } pCurBlob += 1;
@@ -49,10 +50,30 @@ public:
DB_AUTH_BLOB(MCONTACT _hContact, LPCSTR nick, LPCSTR fname, LPCSTR lname, LPCSTR id, LPCSTR reason)
: hContact(_hContact), szNick(mir_strdup(nick)), szFirstName(mir_strdup(fname)), szLastName(mir_strdup(lname)), szId(mir_strdup(id)), szReason(mir_strdup(reason)) {}
+ __inline explicit DB_AUTH_BLOB(PBYTE blob)
+ {
+ PBYTE pCurBlob = blob;
+ pCurBlob += sizeof(DWORD);
+ hContact = *(PDWORD)pCurBlob;
+ pCurBlob += sizeof(DWORD);
+ szNick = mir_strdup((char*)pCurBlob); pCurBlob += mir_strlen((char*)pCurBlob) + 1;
+ szFirstName = mir_strdup((char*)pCurBlob); pCurBlob += mir_strlen((char*)pCurBlob) + 1;
+ szLastName = mir_strdup((char*)pCurBlob); pCurBlob += mir_strlen((char*)pCurBlob) + 1;
+ szId = mir_strdup((char*)pCurBlob); pCurBlob += mir_strlen((char*)pCurBlob) + 1;
+ szReason = mir_strdup((char*)pCurBlob);
+ }
+
__inline size_t size(){ return ((sizeof(DWORD) * 2) + (mir_strlen(szNick) + 1) + (mir_strlen(szFirstName) + 1) + (mir_strlen(szLastName) + 1) + (mir_strlen(szId) + 1) + (mir_strlen(szReason) + 1)); }
__inline operator char*(){ return (char*)makeBlob(); };
__inline operator BYTE*(){ return makeBlob(); };
+
+ __inline MCONTACT get_hcontact() { return hContact; }
+ __inline char *get_nick() { return mir_strdup(szNick); }
+ __inline char *get_firstname() { return mir_strdup(szFirstName); }
+ __inline char *get_lastname() { return mir_strdup(szLastName); }
+ __inline char *get_id() { return mir_strdup(szId); }
+ __inline char *get_reason() { return mir_strdup(szReason); }
};