2
0
mirror of https://github.com/9ParsonsB/Pulsar.git synced 2025-10-25 12:39:49 -04:00

Revert PluginCore use of event listening for current LogMonitor state (#64)

The order that listeners get notified isn't deterministic and as a result plugins which read the current state from PluginCore during the handling of a state change event may read a stale state resulting in unexpected results. PluginCore now reads a property directly from LogMonitor to avoid such inconsistencies.
This commit is contained in:
F K
2022-03-15 09:44:20 -04:00
committed by GitHub
parent 4f4ba88878
commit fa5c978b34
3 changed files with 9 additions and 9 deletions

View File

@@ -38,6 +38,13 @@ namespace Observatory
#endregion #endregion
#region Public properties
public LogMonitorState CurrentState
{
get => currentState;
}
#endregion
#region Public Methods #region Public Methods
public void Start() public void Start()

View File

@@ -11,7 +11,6 @@ namespace Observatory.PluginManagement
private readonly NativeVoice NativeVoice; private readonly NativeVoice NativeVoice;
private readonly NativePopup NativePopup; private readonly NativePopup NativePopup;
private LogMonitorState currentLogMonitorState = LogMonitorState.Idle;
public PluginCore() public PluginCore()
{ {
@@ -19,11 +18,6 @@ namespace Observatory.PluginManagement
NativePopup = new(); NativePopup = new();
} }
internal void OnLogMonitorStateChanged(object sender, LogMonitorStateChangedEventArgs e)
{
currentLogMonitorState = e.NewState;
}
public string Version => System.Reflection.Assembly.GetEntryAssembly().GetName().Version.ToString(); public string Version => System.Reflection.Assembly.GetEntryAssembly().GetName().Version.ToString();
public Status GetStatus() public Status GetStatus()
@@ -142,12 +136,12 @@ namespace Observatory.PluginManagement
public LogMonitorState CurrentLogMonitorState public LogMonitorState CurrentLogMonitorState
{ {
get => currentLogMonitorState; get => LogMonitor.GetInstance.CurrentState;
} }
public bool IsLogMonitorBatchReading public bool IsLogMonitorBatchReading
{ {
get => LogMonitorStateChangedEventArgs.IsBatchRead(currentLogMonitorState); get => LogMonitorStateChangedEventArgs.IsBatchRead(LogMonitor.GetInstance.CurrentState);
} }
public event EventHandler<NotificationArgs> Notification; public event EventHandler<NotificationArgs> Notification;

View File

@@ -49,7 +49,6 @@ namespace Observatory.PluginManagement
logMonitor.LogMonitorStateChanged += pluginHandler.OnLogMonitorStateChanged; logMonitor.LogMonitorStateChanged += pluginHandler.OnLogMonitorStateChanged;
var core = new PluginCore(); var core = new PluginCore();
logMonitor.LogMonitorStateChanged += core.OnLogMonitorStateChanged;
List<IObservatoryPlugin> errorPlugins = new(); List<IObservatoryPlugin> errorPlugins = new();