SEBWIN-312: Ensured already known application instances are not initialized twice.
This commit is contained in:
parent
f1fc27e451
commit
d8a27e9298
1 changed files with 15 additions and 10 deletions
|
@ -108,12 +108,17 @@ namespace SafeExamBrowser.Applications
|
|||
|
||||
private void ApplicationMonitor_InstanceStarted(Guid applicationId, IProcess process)
|
||||
{
|
||||
if (applicationId == Id)
|
||||
lock (@lock)
|
||||
{
|
||||
var isNewInstance = instances.All(i => i.Id != process.Id);
|
||||
|
||||
if (applicationId == Id && isNewInstance)
|
||||
{
|
||||
logger.Info("New application instance was started.");
|
||||
InitializeInstance(process);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
private void Instance_Terminated(int id)
|
||||
{
|
||||
|
@ -126,6 +131,8 @@ namespace SafeExamBrowser.Applications
|
|||
}
|
||||
|
||||
private void InitializeInstance(IProcess process)
|
||||
{
|
||||
lock (@lock)
|
||||
{
|
||||
var instanceLogger = logger.CloneFor($"{Name} ({process.Id})");
|
||||
var instance = new ExternalApplicationInstance(Icon, instanceLogger, nativeMethods, process);
|
||||
|
@ -134,8 +141,6 @@ namespace SafeExamBrowser.Applications
|
|||
instance.WindowsChanged += () => WindowsChanged?.Invoke();
|
||||
instance.Initialize();
|
||||
|
||||
lock (@lock)
|
||||
{
|
||||
instances.Add(instance);
|
||||
}
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue