123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210 |
- #include "stdafx.h"
- #include "MainFrmThread.h"
- #include "DatabaseUtilities.h"
- #include "Options.h"
- #include "Misc.h"
- #include "cp_main.h"
- CMainFrmThread::CMainFrmThread(void)
- {
- 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_REMOTE_FILES:
- OnRemoveRemoteFiles();
- 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(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::OnRemoveRemoteFiles()
- {
- CString csDir = CGetSetOptions::GetPath(PATH_REMOTE_FILES);
- if(FileExists(csDir))
- {
- DeleteReceivedFiles(csDir);
- }
- }
- 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(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(pLastClip && pLastClip->m_param1 == TRUE)
- {
- 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");
- }
|