public void Initialise(EngineRoomServiceDB erdb) { DBRow row = erdb.GetLatestEvent(EngineRoomServiceDB.LogEventType.ON, ID); if (row != null) { LastOn = row.GetDateTime("created"); } row = erdb.GetLatestEvent(EngineRoomServiceDB.LogEventType.OFF, ID); if (row != null) { LastOff = row.GetDateTime("created"); } DBRow enabled = erdb.GetLatestEvent(EngineRoomServiceDB.LogEventType.ENABLE, ID); DBRow disabled = erdb.GetLatestEvent(EngineRoomServiceDB.LogEventType.DISABLE, ID); bool enable = true; if (disabled != null) { enable = enabled == null ? false : enabled.GetDateTime("created").Ticks > disabled.GetDateTime("created").Ticks; } else if (enabled != null) { enable = true; } Enable(enable); String desc = String.Format("Initialised engine {0} ... engine is {1}", ID, Enabled ? "enabled" : "disabled"); erdb.LogEvent(EngineRoomServiceDB.LogEventType.INITIALISE, ID, desc); }
public void Initialise(EngineRoomServiceDB erdb) { DBRow enabled = erdb.GetLatestEvent(EngineRoomServiceDB.LogEventType.ENABLE, ID); DBRow disabled = erdb.GetLatestEvent(EngineRoomServiceDB.LogEventType.DISABLE, ID); bool enable = true; if (disabled != null) { enable = enabled == null ? false : enabled.GetDateTime("created").Ticks > disabled.GetDateTime("created").Ticks; } else if (enabled != null) { enable = true; } Enable(enable); _initialisedAt = DateTime.Now; String desc = String.Format("Initialised {0} water tanks ... tanks are {1}", Tanks.Count, Enabled ? "enabled" : "disabled"); erdb.LogEvent(EngineRoomServiceDB.LogEventType.INITIALISE, ID, desc); }