Compare commits

...

2 commits

Author SHA1 Message Date
13bb5ac0dd Updated Program
Added noise for the second condition to show we are checking for
updates.
2025-07-30 12:52:47 -05:00
e2c356a723 Updated Syncer
Added check for syncing.  If we are syncing, we should be expecting file
changes, and not do anything.
2025-07-30 12:52:31 -05:00
2 changed files with 9 additions and 0 deletions

View file

@ -95,9 +95,13 @@ class Program
{
Thread.Sleep(100);
if (lastTime - DateTime.Now <= TimeSpan.FromSeconds(30)) continue;
var start = DateTime.Now;
Console.WriteLine("Checking for updates...");
foreach (var syncer in syncers)
syncer.FetchDatabase().Wait();
lastTime = DateTime.Now;
var end = DateTime.Now - start;
Console.WriteLine($"Check completed. Total Time: {end}");
}
}
}

View file

@ -29,6 +29,7 @@ public class Syncer<T> : ISyncer where T : class, IDataModel, new()
private string _restEndpoint;
private bool _isDirty = false;
private bool _syncing = false;
public Syncer(DBSyncWatcher watcher, string dbPath, string dbName, string restEndpoint)
{
@ -97,6 +98,8 @@ public class Syncer<T> : ISyncer where T : class, IDataModel, new()
{
if (dbName != _dbName)
return;
if (_syncing)
return;
T? entry;
try
@ -129,6 +132,7 @@ public class Syncer<T> : ISyncer where T : class, IDataModel, new()
{
if (!_isDirty)
return;
_syncing = true;
Console.WriteLine($"Syncing {_dbPath}...");
var json = new List<string>();
foreach (var entry in _entries)
@ -136,5 +140,6 @@ public class Syncer<T> : ISyncer where T : class, IDataModel, new()
File.WriteAllLines(_dbPath, json);
Console.WriteLine($"Updated {_dbPath}.");
_isDirty = false;
_syncing = false;
}
}