Compare commits

...

3 commits

Author SHA1 Message Date
Ashish
248469544f
Merge 67808c2e4a into 25d7ae8374 2025-09-09 14:29:55 +08:00
Ashish
67808c2e4a
Merge pull request #1 from alahane-techtel/alahane-techtel-patch-1/NamedPipeCleanupRaceCondition
Fixed race condition on Named pipe dispose/disconnect
2025-07-07 17:04:39 +10:00
Ashish
d608026d17
Fixed race condition on Named pipe dispose/disconnect 2025-07-04 23:12:05 +10:00

View file

@ -31,9 +31,13 @@ namespace FFMpegCore.Arguments
public void Post()
{
Debug.WriteLine($"Disposing NamedPipeServerStream on {GetType().Name}");
lock(Pipe)
{
Pipe?.Dispose();
Pipe = null!;
}
}
public async Task During(CancellationToken cancellationToken = default)
{
@ -48,12 +52,18 @@ namespace FFMpegCore.Arguments
finally
{
Debug.WriteLine($"Disconnecting NamedPipeServerStream on {GetType().Name}");
lock (Pipe ?? new object())
//if Pipe is null, then the lock doesnt matter,
//Because the next code will not execute anyways.
//so we can use a new object
{
if (Pipe is { IsConnected: true })
{
Pipe.Disconnect();
}
}
}
}
protected abstract Task ProcessDataAsync(CancellationToken token);
public abstract string Text { get; }