Revert "Fix unhandled monitor initialisation exception"

This reverts commit e1be2b1e55.
This commit is contained in:
abraunegg 2019-10-30 06:33:11 +11:00
parent e1be2b1e55
commit 9b3179540f

View file

@ -671,82 +671,72 @@ int main(string[] args)
signal(SIGINT, &exitHandler); signal(SIGINT, &exitHandler);
signal(SIGTERM, &exitHandler); signal(SIGTERM, &exitHandler);
// attempt to initialise monitor class // initialise the monitor class
try { if (!cfg.getValueBool("download_only")) m.init(cfg, cfg.getValueLong("verbose") > 0, cfg.getValueBool("skip_symlinks"), cfg.getValueBool("check_nosync"));
m.init(cfg, cfg.getValueLong("verbose") > 0, cfg.getValueBool("skip_symlinks"), cfg.getValueBool("check_nosync")); // monitor loop
} catch (MonitorException e) { immutable auto checkInterval = dur!"seconds"(cfg.getValueLong("monitor_interval"));
// monitor initialisation failed immutable auto logInterval = cfg.getValueLong("monitor_log_frequency");
log.error("ERROR: ", e.msg); immutable auto fullScanFrequency = cfg.getValueLong("monitor_fullscan_frequency");
exit(-1); auto lastCheckTime = MonoTime.currTime();
} auto logMonitorCounter = 0;
auto fullScanCounter = 0;
bool fullScanRequired = true;
bool syncListConfiguredOverride = false;
while (true) {
if (!cfg.getValueBool("download_only")) m.update(online);
auto currTime = MonoTime.currTime();
if (currTime - lastCheckTime > checkInterval) {
// log monitor output suppression
logMonitorCounter += 1;
if (logMonitorCounter > logInterval)
logMonitorCounter = 1;
//if (!cfg.getValueBool("download_only")) m.init(cfg, cfg.getValueLong("verbose") > 0, cfg.getValueBool("skip_symlinks"), cfg.getValueBool("check_nosync")); // full scan of sync_dir
if (!cfg.getValueBool("download_only")) { fullScanCounter += 1;
// monitor loop if (fullScanCounter > fullScanFrequency){
immutable auto checkInterval = dur!"seconds"(cfg.getValueLong("monitor_interval")); fullScanCounter = 1;
immutable auto logInterval = cfg.getValueLong("monitor_log_frequency"); fullScanRequired = true;
immutable auto fullScanFrequency = cfg.getValueLong("monitor_fullscan_frequency"); if (syncListConfigured) {
auto lastCheckTime = MonoTime.currTime(); syncListConfiguredOverride = true;
auto logMonitorCounter = 0;
auto fullScanCounter = 0;
bool fullScanRequired = true;
bool syncListConfiguredOverride = false;
while (true) {
if (!cfg.getValueBool("download_only")) m.update(online);
auto currTime = MonoTime.currTime();
if (currTime - lastCheckTime > checkInterval) {
// log monitor output suppression
logMonitorCounter += 1;
if (logMonitorCounter > logInterval)
logMonitorCounter = 1;
// full scan of sync_dir
fullScanCounter += 1;
if (fullScanCounter > fullScanFrequency){
fullScanCounter = 1;
fullScanRequired = true;
if (syncListConfigured) {
syncListConfiguredOverride = true;
}
} }
}
// log.logAndNotify("DEBUG trying to create checkpoint"); // log.logAndNotify("DEBUG trying to create checkpoint");
// auto res = itemdb.db_checkpoint(); // auto res = itemdb.db_checkpoint();
// log.logAndNotify("Checkpoint return: ", res); // log.logAndNotify("Checkpoint return: ", res);
// itemdb.dump_open_statements(); // itemdb.dump_open_statements();
try {
if (!initSyncEngine(sync)) {
oneDrive.http.shutdown();
return EXIT_FAILURE;
}
try { try {
if (!initSyncEngine(sync)) { // perform a --monitor sync
oneDrive.http.shutdown(); performSync(sync, cfg.getValueString("single_directory"), cfg.getValueBool("download_only"), cfg.getValueBool("local_first"), cfg.getValueBool("upload_only"), (logMonitorCounter == logInterval ? MONITOR_LOG_QUIET : MONITOR_LOG_SILENT), fullScanRequired, syncListConfiguredOverride);
return EXIT_FAILURE; if (!cfg.getValueBool("download_only")) {
} // discard all events that may have been generated by the sync
try { m.update(false);
// perform a --monitor sync
performSync(sync, cfg.getValueString("single_directory"), cfg.getValueBool("download_only"), cfg.getValueBool("local_first"), cfg.getValueBool("upload_only"), (logMonitorCounter == logInterval ? MONITOR_LOG_QUIET : MONITOR_LOG_SILENT), fullScanRequired, syncListConfiguredOverride);
if (!cfg.getValueBool("download_only")) {
// discard all events that may have been generated by the sync
m.update(false);
}
} catch (CurlException e) {
// we already tried three times in the performSync routine
// if we still have problems, then the sync handle might have
// gone stale and we need to re-initialize the sync engine
log.log("Persistent connection errors, reinitializing connection");
sync.reset();
} }
} catch (CurlException e) { } catch (CurlException e) {
log.log("Cannot initialize connection to OneDrive"); // we already tried three times in the performSync routine
// if we still have problems, then the sync handle might have
// gone stale and we need to re-initialize the sync engine
log.log("Persistent connection errors, reinitializing connection");
sync.reset();
} }
// performSync complete, set lastCheckTime to current time } catch (CurlException e) {
fullScanRequired = false; log.log("Cannot initialize connection to OneDrive");
if (syncListConfigured) {
syncListConfiguredOverride = false;
}
lastCheckTime = MonoTime.currTime();
GC.collect();
} }
Thread.sleep(dur!"msecs"(500)); // performSync complete, set lastCheckTime to current time
fullScanRequired = false;
if (syncListConfigured) {
syncListConfiguredOverride = false;
}
lastCheckTime = MonoTime.currTime();
GC.collect();
} }
Thread.sleep(dur!"msecs"(500));
} }
} }
} }