Compare commits

..

2 Commits

Author SHA1 Message Date
copilot-swe-agent[bot]
6b58dbd7d6 Fix thread-safety issue in GetRouteToSource - snapshot TieLineCollection before enumeration
Co-authored-by: ngenovese11 <23391587+ngenovese11@users.noreply.github.com>
2026-03-18 19:18:12 +00:00
copilot-swe-agent[bot]
de70740e3b Initial plan 2026-03-18 19:14:43 +00:00

View File

@@ -339,17 +339,21 @@ namespace PepperDash.Essentials.Core
RoutingInputPort goodInputPort = null;
// Take a snapshot to avoid InvalidOperationException if TieLineCollection.Default is
// modified concurrently (e.g. NVX tie line registration during route requests).
var tieLines = TieLineCollection.Default.ToList();
IEnumerable<TieLine> destinationTieLines;
TieLine directTie = null;
if (destinationPort == null)
{
destinationTieLines = TieLineCollection.Default.Where(t =>
destinationTieLines = tieLines.Where(t =>
t.DestinationPort.ParentDevice.Key == destination.Key && (t.Type.HasFlag(signalType) || signalType == eRoutingSignalType.AudioVideo));
}
else
{
destinationTieLines = TieLineCollection.Default.Where(t => t.DestinationPort.ParentDevice.Key == destination.Key && t.DestinationPort.Key == destinationPort.Key && (t.Type.HasFlag(signalType)));
destinationTieLines = tieLines.Where(t => t.DestinationPort.ParentDevice.Key == destination.Key && t.DestinationPort.Key == destinationPort.Key && (t.Type.HasFlag(signalType)));
}
// find the TieLine without a port