summaryrefslogtreecommitdiff
path: root/ui/progress_indicator.h
diff options
context:
space:
mode:
authorDaniel Wilhelm <daniel@wili.li>2014-04-18 17:19:49 +0200
committerDaniel Wilhelm <daniel@wili.li>2014-04-18 17:19:49 +0200
commitc8e0e909b4a8d18319fc65434a10dc446434817c (patch)
treeeee91e7d2ce229dd043811eae8f1e2bd78061916 /ui/progress_indicator.h
parent5.2 (diff)
downloadFreeFileSync-c8e0e909b4a8d18319fc65434a10dc446434817c.tar.gz
FreeFileSync-c8e0e909b4a8d18319fc65434a10dc446434817c.tar.bz2
FreeFileSync-c8e0e909b4a8d18319fc65434a10dc446434817c.zip
5.3
Diffstat (limited to 'ui/progress_indicator.h')
-rw-r--r--ui/progress_indicator.h43
1 files changed, 15 insertions, 28 deletions
diff --git a/ui/progress_indicator.h b/ui/progress_indicator.h
index 858f6ce9..cd974408 100644
--- a/ui/progress_indicator.h
+++ b/ui/progress_indicator.h
@@ -18,18 +18,13 @@ class CompareStatus
{
public:
CompareStatus(wxTopLevelWindow& parentWindow); //CompareStatus will be owned by parentWindow!
- ~CompareStatus();
wxWindow* getAsWindow(); //convenience! don't abuse!
- void init(); //make visible, initialize all status values
- void finalize(); //hide again
+ void init(const zen::Statistics& syncStat); //begin of sync: make visible, set pointer to "syncStat", initialize all status values
+ void finalize(); //end of sync: hide again, clear pointer to "syncStat"
- void switchToCompareBytewise(int totalObjectsToProcess, zen::Int64 totalDataToProcess);
- void incScannedObjects_NoUpdate(int number);
- void incProcessedCmpData_NoUpdate(int objectsDelta, zen::Int64 dataDelta);
- void incTotalCmpData_NoUpdate (int objectsDelta, zen::Int64 dataDelta);
- void setStatusText_NoUpdate(const wxString& text);
+ void switchToCompareBytewise();
void updateStatusPanelNow();
private:
@@ -41,20 +36,9 @@ private:
class SyncStatus
{
public:
- enum SyncStatusID
- {
- ABORTED,
- FINISHED_WITH_SUCCESS,
- FINISHED_WITH_ERROR,
- PAUSE,
- SCANNING,
- COMPARING_CONTENT,
- SYNCHRONIZING
- };
-
- SyncStatus(AbortCallback& abortCb,
+ SyncStatus(zen::AbortCallback& abortCb,
+ const zen::Statistics& syncStat,
MainDialog* parentWindow, //may be nullptr
- SyncStatusID startStatus,
bool showProgress,
const wxString& jobName,
const std::wstring& execWhenFinished,
@@ -63,22 +47,25 @@ public:
wxWindow* getAsWindow(); //convenience! don't abuse!
- void initNewProcess(SyncStatusID id, int totalObjectsToProcess, zen::Int64 totalDataToProcess);
+ void initNewPhase(); //call after "StatusHandler::initNewPhase"
- void incScannedObjects_NoUpdate(int number);
- void incProcessedData_NoUpdate(int objectsDelta, zen::Int64 dataDelta);
- void incTotalData_NoUpdate (int objectsDelta, zen::Int64 dataDelta);
- void setStatusText_NoUpdate(const wxString& text);
- void updateStatusDialogNow();
+ void reportCurrentBytes(zen::Int64 currentData); //throw (), required by graph!
+ void updateProgress();
std::wstring getExecWhenFinishedCommand() const; //final value (after possible user modification)
void stopTimer(); //halt all internal counters!
void resumeTimer(); //
+ enum SyncResult
+ {
+ RESULT_ABORTED,
+ RESULT_FINISHED_WITH_ERROR,
+ RESULT_FINISHED_WITH_SUCCESS
+ };
//essential to call one of these two methods in StatusUpdater derived class destructor at the LATEST(!)
//to prevent access to callback to updater (e.g. request abort)
- void processHasFinished(SyncStatusID id, const zen::ErrorLog& log);
+ void processHasFinished(SyncResult resultId, const zen::ErrorLog& log); //sync finished, still dialog may live on
void closeWindowDirectly(); //don't wait for user
private:
bgstack15