summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--plugins/TabSRMM/src/msgdialog.cpp2
-rw-r--r--plugins/TabSRMM/src/sendqueue.cpp126
-rw-r--r--plugins/TabSRMM/src/sendqueue.h73
3 files changed, 99 insertions, 102 deletions
diff --git a/plugins/TabSRMM/src/msgdialog.cpp b/plugins/TabSRMM/src/msgdialog.cpp
index 96e2477eb1..d8f8d03799 100644
--- a/plugins/TabSRMM/src/msgdialog.cpp
+++ b/plugins/TabSRMM/src/msgdialog.cpp
@@ -2709,7 +2709,7 @@ INT_PTR CALLBACK DlgProcMessage(HWND hwndDlg, UINT msg, WPARAM wParam, LPARAM lP
break;
job->hSendId = (HANDLE) CallContactService(job->hOwner, PSS_MESSAGE,
- (dat->sendMode & SMODE_FORCEANSI) ? (job->dwFlags & ~PREF_UNICODE) : job->dwFlags, (LPARAM)job->sendBuffer);
+ (dat->sendMode & SMODE_FORCEANSI) ? (job->dwFlags & ~PREF_UNICODE) : job->dwFlags, (LPARAM)job->szSendBuffer);
resent++;
}
diff --git a/plugins/TabSRMM/src/sendqueue.cpp b/plugins/TabSRMM/src/sendqueue.cpp
index b6041a8685..0c378c9bdf 100644
--- a/plugins/TabSRMM/src/sendqueue.cpp
+++ b/plugins/TabSRMM/src/sendqueue.cpp
@@ -53,6 +53,7 @@ int SendQueue::findNextFailed(const TWindowData *dat) const
}
return -1;
}
+
void SendQueue::handleError(TWindowData *dat, const int iEntry) const
{
if (dat) {
@@ -101,24 +102,26 @@ entry_found:
_DebugPopup(dat->hContact, _T("Send queue full"));
return 0;
}
+
+ SendJob &job = m_jobs[iFound];
iLength = iLen;
if (iLength > 0) {
- if (m_jobs[iFound].sendBuffer == NULL) {
+ if (job.szSendBuffer == NULL) {
if (iLength < HISTORY_INITIAL_ALLOCSIZE)
iLength = HISTORY_INITIAL_ALLOCSIZE;
- m_jobs[iFound].sendBuffer = (char *)malloc(iLength);
- m_jobs[iFound].dwLen = iLength;
+ job.szSendBuffer = (char*)mir_alloc(iLength);
+ job.dwLen = iLength;
}
else {
- if (iLength > m_jobs[iFound].dwLen) {
- m_jobs[iFound].sendBuffer = (char *)realloc(m_jobs[iFound].sendBuffer, iLength);
- m_jobs[iFound].dwLen = iLength;
+ if (iLength > job.dwLen) {
+ job.szSendBuffer = (char*)mir_realloc(job.szSendBuffer, iLength);
+ job.dwLen = iLength;
}
}
- CopyMemory(m_jobs[iFound].sendBuffer, dat->sendBuffer, iLen);
+ CopyMemory(job.szSendBuffer, dat->sendBuffer, iLen);
}
- m_jobs[iFound].dwFlags = dwFlags;
- m_jobs[iFound].dwTime = time(NULL);
+ job.dwFlags = dwFlags;
+ job.dwTime = time(NULL);
HWND hwndDlg = dat->hwnd;
@@ -160,19 +163,18 @@ static int SendChunkA(char *chunk, HANDLE hContact, char *szSvc, DWORD dwFlags)
static void DoSplitSendW(LPVOID param)
{
struct SendJob *job = sendQueue->getJobByIndex((int)param);
- int id;
BOOL fFirstSend = FALSE;
- WCHAR *wszBegin, *wszTemp, *wszSaved, savedChar;
- int iLen, iCur = 0, iSavedCur = 0, i;
+ WCHAR *wszSaved, savedChar;
+ int iCur = 0, iSavedCur = 0, i;
BOOL fSplitting = TRUE;
HANDLE hContact = job->hOwner;
DWORD dwFlags = job->dwFlags;
int chunkSize = job->chunkSize / 2;
char *szProto = GetContactProto(hContact);
- iLen = lstrlenA(job->sendBuffer);
- wszBegin = (WCHAR *) & job->sendBuffer[iLen + 1];
- wszTemp = (WCHAR *)mir_alloc(sizeof(WCHAR) * (lstrlenW(wszBegin) + 1));
+ int iLen = lstrlenA(job->szSendBuffer);
+ WCHAR *wszBegin = (WCHAR*) & job->szSendBuffer[iLen + 1];
+ WCHAR *wszTemp = (WCHAR*)mir_alloc(sizeof(WCHAR) * (lstrlenW(wszBegin) + 1));
CopyMemory(wszTemp, wszBegin, sizeof(WCHAR) * (lstrlenW(wszBegin) + 1));
wszBegin = wszTemp;
@@ -205,7 +207,7 @@ static void DoSplitSendW(LPVOID param)
}
savedChar = *wszSaved;
*wszSaved = 0;
- id = SendChunkW(wszTemp, hContact, dwFlags);
+ int id = SendChunkW(wszTemp, hContact, dwFlags);
if (!fFirstSend) {
job->hSendId = (HANDLE)id;
fFirstSend = TRUE;
@@ -219,7 +221,7 @@ static void DoSplitSendW(LPVOID param)
}
}
else {
- id = SendChunkW(wszTemp, hContact, dwFlags);
+ int id = SendChunkW(wszTemp, hContact, dwFlags);
if (!fFirstSend) {
job->hSendId = (HANDLE)id;
fFirstSend = TRUE;
@@ -244,9 +246,9 @@ static void DoSplitSendA(LPVOID param)
DWORD dwFlags = job->dwFlags;
int chunkSize = job->chunkSize;
- iLen = lstrlenA(job->sendBuffer);
+ iLen = lstrlenA(job->szSendBuffer);
szTemp = (char *)mir_alloc(iLen + 1);
- CopyMemory(szTemp, job->sendBuffer, iLen + 1);
+ CopyMemory(szTemp, job->szSendBuffer, iLen + 1);
szBegin = szTemp;
do {
@@ -306,18 +308,15 @@ static void DoSplitSendA(LPVOID param)
int SendQueue::getSendLength(const int iEntry, int sendMode)
{
if (m_jobs[iEntry].dwFlags & PREF_UNICODE && !(sendMode & SMODE_FORCEANSI)) {
- int iLen;
- WCHAR *wszBuf;
- char *utf8;
- iLen = lstrlenA(m_jobs[iEntry].sendBuffer);
- wszBuf = (WCHAR *) & m_jobs[iEntry].sendBuffer[iLen + 1];
- utf8 = mir_utf8encodeT(wszBuf);
+ int iLen = lstrlenA(m_jobs[iEntry].szSendBuffer);
+ WCHAR *wszBuf = (WCHAR *) & m_jobs[iEntry].szSendBuffer[iLen + 1];
+ char *utf8 = mir_utf8encodeT(wszBuf);
m_jobs[iEntry].iSendLength = lstrlenA(utf8);
mir_free(utf8);
return(m_jobs[iEntry].iSendLength);
}
else {
- m_jobs[iEntry].iSendLength = lstrlenA(m_jobs[iEntry].sendBuffer);
+ m_jobs[iEntry].iSendLength = lstrlenA(m_jobs[iEntry].szSendBuffer);
return(m_jobs[iEntry].iSendLength);
}
}
@@ -429,7 +428,7 @@ send_unsplitted:
return 0;
}
m_jobs[iEntry].hSendId = (HANDLE) CallContactService(dat->hContact, PSS_MESSAGE,
- (dat->sendMode & SMODE_FORCEANSI) ? (m_jobs[iEntry].dwFlags & ~PREF_UNICODE) : m_jobs[iEntry].dwFlags, (LPARAM)m_jobs[iEntry].sendBuffer);
+ (dat->sendMode & SMODE_FORCEANSI) ? (m_jobs[iEntry].dwFlags & ~PREF_UNICODE) : m_jobs[iEntry].dwFlags, (LPARAM)m_jobs[iEntry].szSendBuffer);
if (dat->sendMode & SMODE_NOACK) { // fake the ack if we are not interested in receiving real acks
ACKDATA ack = {0};
@@ -502,16 +501,15 @@ void SendQueue::checkQueue(const TWindowData *dat) const
void SendQueue::logError(const TWindowData *dat, int iSendJobIndex, const TCHAR *szErrMsg) const
{
- int iMsgLen;
-
if (dat == 0)
return;
+ int iMsgLen;
DBEVENTINFO dbei = { sizeof(dbei) };
dbei.eventType = EVENTTYPE_ERRMSG;
if (iSendJobIndex >= 0) {
- dbei.pBlob = (BYTE *)m_jobs[iSendJobIndex].sendBuffer;
- iMsgLen = lstrlenA(m_jobs[iSendJobIndex].sendBuffer) + 1;
+ dbei.pBlob = (BYTE *)m_jobs[iSendJobIndex].szSendBuffer;
+ iMsgLen = lstrlenA(m_jobs[iSendJobIndex].szSendBuffer) + 1;
}
else {
iMsgLen = 0;
@@ -590,10 +588,10 @@ void SendQueue::recallFailed(const TWindowData *dat, int iEntry) const
if (iLen == 0) { // message area is empty, so we can recall the failed message...
SETTEXTEX stx = {ST_DEFAULT, 1200};
if (m_jobs[iEntry].dwFlags & PREF_UNICODE)
- SendDlgItemMessage(dat->hwnd, IDC_MESSAGE, EM_SETTEXTEX, (WPARAM)&stx, (LPARAM)&m_jobs[iEntry].sendBuffer[lstrlenA(m_jobs[iEntry].sendBuffer) + 1]);
+ SendDlgItemMessage(dat->hwnd, IDC_MESSAGE, EM_SETTEXTEX, (WPARAM)&stx, (LPARAM)&m_jobs[iEntry].szSendBuffer[lstrlenA(m_jobs[iEntry].szSendBuffer) + 1]);
else {
stx.codepage = (m_jobs[iEntry].dwFlags & PREF_UTF) ? CP_UTF8 : CP_ACP;
- SendDlgItemMessage(dat->hwnd, IDC_MESSAGE, EM_SETTEXTEX, (WPARAM)&stx, (LPARAM)m_jobs[iEntry].sendBuffer);
+ SendDlgItemMessage(dat->hwnd, IDC_MESSAGE, EM_SETTEXTEX, (WPARAM)&stx, (LPARAM)m_jobs[iEntry].szSendBuffer);
}
UpdateSaveAndSendButton(const_cast<TWindowData *>(dat));
SendDlgItemMessage(dat->hwnd, IDC_MESSAGE, EM_SETSEL, (WPARAM)- 1, (LPARAM)- 1);
@@ -685,17 +683,16 @@ int SendQueue::RTL_Detect(const WCHAR *pszwText)
int SendQueue::ackMessage(TWindowData *dat, WPARAM wParam, LPARAM lParam)
{
- ACKDATA *ack = (ACKDATA *) lParam;
- HANDLE hNewEvent;
- int iFound = SendQueue::NR_SENDJOBS, iNextFailed;
+ ACKDATA *ack = (ACKDATA *) lParam;
+
TContainerData *m_pContainer = 0;
if (dat)
m_pContainer = dat->pContainer;
- iFound = (int)(LOWORD(wParam));
- //i = (int)(HIWORD(wParam));
+ int iFound = (int)(LOWORD(wParam));
+ SendJob &job = m_jobs[iFound];
- if (m_jobs[iFound].iStatus == SQ_ERROR) { // received ack for a job which is already in error state...
+ if (job.iStatus == SQ_ERROR) { // received ack for a job which is already in error state...
if (dat) { // window still open
if (dat->iCurrentQueueError == iFound) {
dat->iCurrentQueueError = -1;
@@ -706,8 +703,7 @@ int SendQueue::ackMessage(TWindowData *dat, WPARAM wParam, LPARAM lParam)
* we must discard this job, because there is no message window open to handle the
* error properly. But we display a tray notification to inform the user about the problem.
*/
- else
- goto inform_and_discard;
+ else goto inform_and_discard;
}
// failed acks are only handled when the window is still open. with no window open, they will be *silently* discarded
@@ -722,9 +718,9 @@ int SendQueue::ackMessage(TWindowData *dat, WPARAM wParam, LPARAM lParam)
SkinPlaySound("SendError");
TCHAR *szAckMsg = mir_a2t((char *)ack->lParam);
- mir_sntprintf(m_jobs[iFound].szErrorMsg, SIZEOF(m_jobs[iFound].szErrorMsg),
+ mir_sntprintf(job.szErrorMsg, SIZEOF(job.szErrorMsg),
TranslateT("Delivery failure: %s"), szAckMsg);
- m_jobs[iFound].iStatus = SQ_ERROR;
+ job.iStatus = SQ_ERROR;
mir_free(szAckMsg);
KillTimer(dat->hwnd, TIMERID_MSGSEND + iFound);
if (!(dat->dwFlags & MWF_ERRORSTATE))
@@ -733,7 +729,7 @@ int SendQueue::ackMessage(TWindowData *dat, WPARAM wParam, LPARAM lParam)
}
else {
inform_and_discard:
- _DebugPopup(m_jobs[iFound].hOwner, TranslateT("A message delivery has failed after the contacts chat window was closed. You may want to resend the last message"));
+ _DebugPopup(job.hOwner, TranslateT("A message delivery has failed after the contacts chat window was closed. You may want to resend the last message"));
clearJob(iFound);
return 0;
}
@@ -742,46 +738,46 @@ inform_and_discard:
DBEVENTINFO dbei = { sizeof(dbei) };
dbei.eventType = EVENTTYPE_MESSAGE;
dbei.flags = DBEF_SENT;
- dbei.szModule = GetContactProto(m_jobs[iFound].hOwner);
+ dbei.szModule = GetContactProto(job.hOwner);
dbei.timestamp = time(NULL);
- dbei.cbBlob = lstrlenA(m_jobs[iFound].sendBuffer) + 1;
+ dbei.cbBlob = lstrlenA(job.szSendBuffer) + 1;
if (dat)
dat->cache->updateStats(TSessionStats::BYTES_SENT, dbei.cbBlob - 1);
else {
- CContactCache *c = CContactCache::getContactCache(m_jobs[iFound].hOwner);
+ CContactCache *c = CContactCache::getContactCache(job.hOwner);
if (c)
c->updateStats(TSessionStats::BYTES_SENT, dbei.cbBlob - 1);
}
- if (m_jobs[iFound].dwFlags & PREF_UNICODE)
+ if (job.dwFlags & PREF_UNICODE)
dbei.cbBlob *= sizeof(TCHAR) + 1;
- if (m_jobs[iFound].dwFlags & PREF_RTL)
+ if (job.dwFlags & PREF_RTL)
dbei.flags |= DBEF_RTL;
- if (m_jobs[iFound].dwFlags & PREF_UTF)
+ if (job.dwFlags & PREF_UTF)
dbei.flags |= DBEF_UTF;
- dbei.pBlob = (PBYTE) m_jobs[iFound].sendBuffer;
+ dbei.pBlob = (PBYTE)job.szSendBuffer;
- MessageWindowEvent evt = { sizeof(evt), (int)m_jobs[iFound].hSendId, m_jobs[iFound].hOwner, &dbei };
+ MessageWindowEvent evt = { sizeof(evt), (int)job.hSendId, job.hOwner, &dbei };
NotifyEventHooks(PluginConfig.m_event_WriteEvent, 0, (LPARAM)&evt);
- hNewEvent = db_event_add(m_jobs[iFound].hOwner, &dbei);
+ HANDLE hNewEvent = db_event_add(job.hOwner, &dbei);
if (m_pContainer)
if (!nen_options.iNoSounds && !(m_pContainer->dwFlags & CNT_NOSOUND))
SkinPlaySound("SendMsg");
- if (dat && (m_jobs[iFound].hOwner == dat->hContact))
+ if (dat && (job.hOwner == dat->hContact))
if (dat->hDbEventFirst == NULL) {
dat->hDbEventFirst = hNewEvent;
SendMessage(dat->hwnd, DM_REMAKELOG, 0, 0);
}
- m_jobs[iFound].hSendId = NULL;
- m_jobs[iFound].iAcksNeeded--;
+ job.hSendId = NULL;
+ job.iAcksNeeded--;
- if (m_jobs[iFound].iAcksNeeded == 0) { // everything sent
- //if (m_jobs[iFound].hOwner != 0 && dat)
+ if (job.iAcksNeeded == 0) { // everything sent
+ //if (job.hOwner != 0 && dat)
// EnableSending(dat, TRUE);
clearJob(iFound);
if (dat) {
@@ -792,7 +788,9 @@ inform_and_discard:
}
if (dat) {
checkQueue(dat);
- if ((iNextFailed = findNextFailed(dat)) >= 0 && !(dat->dwFlags & MWF_ERRORSTATE))
+
+ int iNextFailed = findNextFailed(dat);
+ if (iNextFailed >= 0 && !(dat->dwFlags & MWF_ERRORSTATE))
handleError(dat, iNextFailed);
//MAD: close on send mode
else {
@@ -880,23 +878,23 @@ int SendQueue::doSendLater(int iJobIndex, TWindowData *dat, HANDLE hContact, boo
if (job->dwFlags & PREF_UTF || !(job->dwFlags & PREF_UNICODE)) {
char *utf_header = mir_utf8encodeT(tszHeader);
- UINT required = lstrlenA(utf_header) + lstrlenA(job->sendBuffer) + 10;
+ UINT required = lstrlenA(utf_header) + lstrlenA(job->szSendBuffer) + 10;
char *tszMsg = reinterpret_cast<char *>(mir_alloc(required));
if (fIsSendLater) {
- mir_snprintf(tszMsg, required, "%s%s", job->sendBuffer, utf_header);
+ mir_snprintf(tszMsg, required, "%s%s", job->szSendBuffer, utf_header);
db_set_s(hContact ? hContact : job->hOwner, "SendLater", szKeyName, tszMsg);
}
else {
- mir_snprintf(tszMsg, required, "%s%s", utf_header, job->sendBuffer);
+ mir_snprintf(tszMsg, required, "%s%s", utf_header, job->szSendBuffer);
sendLater->addJob(tszMsg, (LPARAM)hContact);
}
mir_free(utf_header);
mir_free(tszMsg);
}
else if (job->dwFlags & PREF_UNICODE) {
- int iLen = lstrlenA(job->sendBuffer);
- wchar_t *wszMsg = (wchar_t *)&job->sendBuffer[iLen + 1];
+ int iLen = lstrlenA(job->szSendBuffer);
+ wchar_t *wszMsg = (wchar_t *)&job->szSendBuffer[iLen + 1];
UINT required = sizeof(TCHAR) * (lstrlen(tszHeader) + lstrlenW(wszMsg) + 10);
diff --git a/plugins/TabSRMM/src/sendqueue.h b/plugins/TabSRMM/src/sendqueue.h
index 1eac7f557d..8d6d470fde 100644
--- a/plugins/TabSRMM/src/sendqueue.h
+++ b/plugins/TabSRMM/src/sendqueue.h
@@ -38,21 +38,22 @@ Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
#define SENDJOBS_MAX_SENDS 100
-struct SendJob {
- HANDLE hSendId;
- char *sendBuffer;
- int dwLen; // actual buffer length (checked for reallocs()
+struct SendJob
+{
+ HANDLE hSendId;
+ char *szSendBuffer;
+ int dwLen; // actual buffer length (checked for reallocs()
int iSendLength; // length of message in utf-8 octets (used to check maxlen)
- int sendCount;
- HANDLE hOwner;
- HWND hwndOwner;
- unsigned int iStatus;
- TCHAR szErrorMsg[128];
- DWORD dwFlags;
- int iAcksNeeded;
- HANDLE hEventSplit;
- int chunkSize;
- DWORD dwTime;
+ int sendCount;
+ HANDLE hOwner;
+ HWND hwndOwner;
+ unsigned iStatus;
+ TCHAR szErrorMsg[128];
+ DWORD dwFlags;
+ int iAcksNeeded;
+ HANDLE hEventSplit;
+ int chunkSize;
+ DWORD dwTime;
};
class SendQueue {
@@ -75,36 +76,34 @@ public:
~SendQueue()
{
- for (int i = 0; i < NR_SENDJOBS; i++) {
- if (m_jobs[i].sendBuffer)
- free(m_jobs[i].sendBuffer);
- }
+ for (int i = 0; i < NR_SENDJOBS; i++)
+ free(m_jobs[i].szSendBuffer);
}
SendJob *getJobByIndex(const int index) { return(&m_jobs[index]); }
- void clearJob (const int index);
- int findNextFailed (const TWindowData *dat) const;
- void handleError (TWindowData *dat, const int iEntry) const;
- int addTo (TWindowData *dat, const int iLen, int dwFlags);
- int sendQueued (TWindowData *dat, const int iEntry);
- int getSendLength (const int iEntry, const int sendMode);
- void checkQueue (const TWindowData *dat) const;
- void logError (const TWindowData *dat, int iSendJobIndex,
- const TCHAR *szErrMsg) const;
- void recallFailed (const TWindowData *dat, int iEntry) const;
- void showErrorControls (TWindowData *dat, const int showCmd) const;
- int ackMessage (TWindowData *dat, WPARAM wParam, LPARAM lParam);
- int doSendLater (int iIndex, TWindowData *dat, HANDLE hContact = 0, bool fIsSendLater = true);
+ void clearJob(const int index);
+ int findNextFailed(const TWindowData *dat) const;
+ void handleError(TWindowData *dat, const int iEntry) const;
+ int addTo(TWindowData *dat, const int iLen, int dwFlags);
+ int sendQueued(TWindowData *dat, const int iEntry);
+ int getSendLength(const int iEntry, const int sendMode);
+ void checkQueue(const TWindowData *dat) const;
+ void logError(const TWindowData *dat, int iSendJobIndex, const TCHAR *szErrMsg) const;
+ void recallFailed(const TWindowData *dat, int iEntry) const;
+ void showErrorControls(TWindowData *dat, const int showCmd) const;
+ int ackMessage(TWindowData *dat, WPARAM wParam, LPARAM lParam);
+ int doSendLater(int iIndex, TWindowData *dat, HANDLE hContact = 0, bool fIsSendLater = true);
/*
* static members
*/
- static int TSAPI RTL_Detect (const wchar_t *pszwText);
- static int TSAPI GetProtoIconFromList (const char *szProto, int iStatus);
- static LRESULT TSAPI WarnPendingJobs (unsigned int uNrMessages);
- static void TSAPI NotifyDeliveryFailure (const TWindowData *dat);
- static void TSAPI UpdateSaveAndSendButton (TWindowData *dat);
- static void TSAPI EnableSending (const TWindowData *dat, const int iMode);
+ static int TSAPI RTL_Detect(const wchar_t *pszwText);
+ static int TSAPI GetProtoIconFromList(const char *szProto, int iStatus);
+ static LRESULT TSAPI WarnPendingJobs(unsigned int uNrMessages);
+ static void TSAPI NotifyDeliveryFailure(const TWindowData *dat);
+ static void TSAPI UpdateSaveAndSendButton(TWindowData *dat);
+ static void TSAPI EnableSending(const TWindowData *dat, const int iMode);
+
private:
SendJob m_jobs[NR_SENDJOBS];
int m_currentIndex;