summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--plugins/SendScreenshotPlus/src/CSendDropbox.cpp34
-rw-r--r--plugins/SendScreenshotPlus/src/CSendDropbox.h5
2 files changed, 27 insertions, 12 deletions
diff --git a/plugins/SendScreenshotPlus/src/CSendDropbox.cpp b/plugins/SendScreenshotPlus/src/CSendDropbox.cpp
index 507d61497a..400deea5fb 100644
--- a/plugins/SendScreenshotPlus/src/CSendDropbox.cpp
+++ b/plugins/SendScreenshotPlus/src/CSendDropbox.cpp
@@ -35,21 +35,19 @@ CSendDropbox::CSendDropbox(HWND Owner, MCONTACT hContact, bool bAsync)
{
/// @todo : re-enable SS_DLG_DELETEAFTERSSEND with full implemention of Dropbox upload with progress, msg and sounds
m_EnableItem = SS_DLG_DESCRIPTION | SS_DLG_AUTOSEND/* | SS_DLG_DELETEAFTERSSEND*/;
- m_pszSendTyp = LPGENT("Dropbox transfer");
+ m_pszSendTyp = TranslateT("Dropbox transfer");
+ m_hEvent = CreateEvent(NULL, 0, 0, NULL);
}
CSendDropbox::~CSendDropbox()
{
+ CloseHandle(m_hEvent);
}
//---------------------------------------------------------------------------
int CSendDropbox::Send()
{
- if (!m_bAsync) {
- SendThread();
- return 1;
- }
mir_forkthread(&CSendDropbox::SendThreadWrapper, this);
return 0;
}
@@ -59,17 +57,29 @@ int CSendDropbox::Send()
void CSendDropbox::SendThread()
{
/// @todo : SS_DLG_DESCRIPTION and SS_DLG_DELETEAFTERSSEND are of no use as of now since we don't track upload progress
- INT_PTR ret = 0;
- if (!m_hContact)
- SetContact(db_find_first("Dropbox"));
- if (m_hContact)
- ret = CallService(MS_DROPBOX_SEND_FILE, (WPARAM)m_hContact, (LPARAM)m_pszFile);
+ INT_PTR ret = CallService(MS_DROPBOX_SEND_FILE, (WPARAM)m_hContact, (LPARAM)m_pszFile);
if (!ret) {
Error(LPGENT("%s (%i):\nCould not add a share to the Dropbox plugin."), TranslateTS(m_pszSendTyp), ret);
Exit(ACKRESULT_FAILED); return;
}
- m_bSilent = true;
- Exit(ACKRESULT_SUCCESS);
+ m_hDropSend = (HANDLE)ret;
+ //m_bSilent = true;
+ m_hDropHook = HookEventObj(ME_DROPBOX_SENT, OnDropSend, this);
+ WaitForSingleObject(m_hEvent, INFINITE);
+}
+
+int CSendDropbox::OnDropSend(void *obj, WPARAM, LPARAM lParam)
+{
+ CSendDropbox *self = (CSendDropbox*)obj;
+ TRANSFERINFO *info = (TRANSFERINFO*)lParam;
+ if (info->hProcess == self->m_hDropSend && !info->status)
+ {
+ UnhookEvent(self->m_hDropHook);
+ self->m_URL = mir_strdup(info->data[0]);
+ self->svcSendMsgExit(self->m_URL);
+ SetEvent(self->m_hEvent);
+ }
+ return 0;
}
void CSendDropbox::SendThreadWrapper(void * Obj)
diff --git a/plugins/SendScreenshotPlus/src/CSendDropbox.h b/plugins/SendScreenshotPlus/src/CSendDropbox.h
index 0e439d57d0..cade8e9d8e 100644
--- a/plugins/SendScreenshotPlus/src/CSendDropbox.h
+++ b/plugins/SendScreenshotPlus/src/CSendDropbox.h
@@ -38,8 +38,13 @@ class CSendDropbox : public CSend {
int Send();
protected:
+ HANDLE m_hEvent;
+ HANDLE m_hDropHook;
+ HANDLE m_hDropSend;
+
void SendThread();
static void SendThreadWrapper(void *Obj);
+ static int OnDropSend(void*, WPARAM, LPARAM);
};
//---------------------------------------------------------------------------