| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236 |
- #include "stdafx.h"
- #include "MainFrmThread.h"
- #include "DatabaseUtilities.h"
- #include "Options.h"
- #include "Misc.h"
- #include "cp_main.h"
- CMainFrmThread::CMainFrmThread(void)
- {
- m_threadName = "CMainFrmThread";
- for(int eventEnum = 0; eventEnum < ECMAINFRMTHREADEVENTS_COUNT; eventEnum++)
- {
- AddEvent(eventEnum);
- }
- }
- CMainFrmThread::~CMainFrmThread(void)
- {
- }
- void CMainFrmThread::AddClipToSave(CClip *pClip)
- {
- ATL::CCritSecLock csLock(m_cs.m_sect);
- Log(_T("Adding clip to thread for save to db"));
- m_saveClips.AddTail(pClip);
- FireEvent(SAVE_CLIPS);
- }
- void CMainFrmThread::AddRemoteClipToSave(CClipList *pClipList)
- {
- ATL::CCritSecLock csLock(m_cs.m_sect);
- Log(_T("Adding REMOTE clip to thread for save to db"));
-
- POSITION pos = pClipList->GetHeadPosition();
- while(pos)
- {
- CClip *pClip = pClipList->GetNext(pos);
- m_saveRemoteClips.AddTail(pClip);
- }
- //local cliplist now owns the clip memory
- pClipList->RemoveAll();
-
- FireEvent(SAVE_REMOTE_CLIPS);
- }
- void CMainFrmThread::OnEvent(int eventId, void *param)
- {
- switch((eCMainFrmThreadEvents)eventId)
- {
- case DELETE_ENTRIES:
- OnDeleteEntries();
- break;
- case REMOVE_TEMP_FILES:
- OnRemoveTempFiles();
- break;
- case SAVE_CLIPS:
- OnSaveClips();
- break;
- case SAVE_REMOTE_CLIPS:
- OnSaveRemoteClips();
- break;
- case READ_DB_FILE:
- OnReadDbFile();
- break;
- }
- }
- //try and keep our db file in windows cache by randomly reading some data
- //not sure if this does what i think it does but looking into issues with slow access on large dbs
- void CMainFrmThread::OnReadDbFile()
- {
- double idle = IdleSeconds();
- if (idle < CGetSetOptions::ReadRandomFileIdleMin())
- {
- CString dbFile = CGetSetOptions::GetDBPath();
- __int64 dbSize = FileSize(dbFile);
- srand((UINT)time(NULL));
- int random = rand() % (dbSize - 1024) + 1;
- CFile f;
- if (f.Open(dbFile, CFile::modeRead | CFile::shareDenyNone))
- {
- f.Seek(random, 0);
- char data[1024];
- f.Read(&data, 1024);
- f.Close();
- }
- }
- }
- void CMainFrmThread::OnDeleteEntries()
- {
- RemoveOldEntries(true);
- }
- void CMainFrmThread::OnRemoveTempFiles()
- {
- DeleteDittoTempFiles(TRUE);
- }
- void CMainFrmThread::OnSaveClips()
- {
- CClipList *pLocalClips = new CClipList();
- //Save the clips locally
- {
- ATL::CCritSecLock csLock(m_cs.m_sect);
- POSITION pos;
- CClip* pClip;
- pos = m_saveClips.GetHeadPosition();
- while(pos)
- {
- pClip = m_saveClips.GetNext(pos);
- pLocalClips->AddTail(pClip);
- }
- //pLocalClips now own, the clips
- m_saveClips.RemoveAll();
- }
- Log(_T("SaveCopyClips Before AddToDb"));
- int count = pLocalClips->AddToDB(true);
- Log(StrF(_T("SaveCopyclips After AddToDb, Count: %d"), count));
- if(count > 0)
- {
- int Id = pLocalClips->GetTail()->m_id;
- Log(StrF(_T("SaveCopyclips After AddToDb, Id: %d Before OnCopyCopyCompleted"), Id));
- theApp.OnCopyCompleted(Id, count);
- Log(StrF(_T("SaveCopyclips After AddToDb, Id: %d After OnCopyCopyCompleted"), Id));
- if (pLocalClips->GetTail()->m_copyReason == CopyReasonEnum::COPY_TO_GROUP &&
- CGetSetOptions::GetShowMsgWndOnCopyToGroup())
- {
- CString groupName;
- CppSQLite3Query q = theApp.m_db.execQueryEx(_T("SELECT mText FROM Main WHERE lID = %d"), pLocalClips->GetTail()->m_parentId);
- if (q.eof() == false)
- {
- groupName = q.getStringField(0);
- }
- CString *pMsg = new CString();
- pMsg->Format(_T("Saved new clip \"%s\"\r\ndirectly to the group \"%s\""), pLocalClips->GetTail()->m_Desc.Left(35), groupName);
- theApp.m_pMainFrame->PostMessageW(WM_SHOW_MSG_WINDOW, (WPARAM) pMsg, pLocalClips->GetTail()->m_parentId);
- }
-
- if(g_Opt.m_lAutoSendClientCount > 0)
- {
- m_sendToClientThread.FireSendToClient(pLocalClips);
- }
- }
- delete pLocalClips;
- }
- void CMainFrmThread::OnSaveRemoteClips()
- {
- LogSendRecieveInfo("---------Start of OnSaveRemoteClips");
- CClipList *pLocalClips = new CClipList();
- //Save the clips locally
- {
- ATL::CCritSecLock csLock(m_cs.m_sect);
- POSITION pos;
- CClip* pClip;
- pos = m_saveRemoteClips.GetHeadPosition();
- while(pos)
- {
- pClip = m_saveRemoteClips.GetNext(pos);
- pLocalClips->AddTail(pClip);
- }
- //pLocalClips now own, the clips
- m_saveRemoteClips.RemoveAll();
- }
- LogSendRecieveInfo("---------OnSaveRemoteClips - Before AddToDB");
- int count = pLocalClips->AddToDB(true);
- LogSendRecieveInfo("---------OnSaveRemoteClips - After AddToDB");
- //are we supposed to add this clip to the clipboard
- CClip *pLastClip = pLocalClips->GetTail();
- if (CGetSetOptions::GetShowMsgWhenReceivingManualSentClip())
- {
- if (pLastClip && (pLastClip->m_param1 & REMOTE_CLIP_MANUAL_SEND))
- {
- CString *pMsg = new CString();
- //baloon message can only show 254 characters
- pMsg->Format(_T("Received remote clip\r\n\r\n%s"), pLastClip->m_Desc.Left(225));
- theApp.m_pMainFrame->PostMessageW(WM_SHOW_MSG_WINDOW, (WPARAM)pMsg, pLocalClips->GetTail()->m_parentId);
- }
- }
- if(pLastClip && (pLastClip->m_param1 & REMOTE_CLIP_ADD_TO_CLIPBOARD))
- {
- LogSendRecieveInfo("---------OnSaveRemoteClips - Before Posting msg to main thread to set clipboard");
- //set the clipboard on the main thread, i was having a problem with setting the clipboard on a thread
- //guess it needs to be set on the main thread
- //main window will clear this memory
- PostMessage(theApp.m_MainhWnd, WM_LOAD_ClIP_ON_CLIPBOARD, (LPARAM)pLastClip, 0);
- LogSendRecieveInfo("---------OnSaveRemoteClips - After Posting msg to main thread to set clipboard");
- pLocalClips->RemoveTail();
- }
- theApp.RefreshView();
- delete pLocalClips;
- LogSendRecieveInfo("---------End of OnSaveRemoteClips");
- }
|