diff --git a/FFMpegCore/FFMpeg/Arguments/InputExistingPipeArgument.cs b/FFMpegCore/FFMpeg/Arguments/InputExistingPipeArgument.cs new file mode 100644 index 0000000..196c66c --- /dev/null +++ b/FFMpegCore/FFMpeg/Arguments/InputExistingPipeArgument.cs @@ -0,0 +1,46 @@ +using System.Diagnostics; +using FFMpegCore.Pipes; + +namespace FFMpegCore.Arguments +{ + /// + /// Represents input parameter for a specific name pipe + /// + public class InputExistingPipeArgument : IInputArgument + { + public string PipeName { get; } + public string PipePath => PipeHelpers.GetPipePath(PipeName); + public string Text => $"-i \"{PipePath}\""; + + public InputExistingPipeArgument(string pipeName) + { + PipeName = pipeName; + } + + public void Pre() + { + if (string.IsNullOrEmpty(PipeName)) + { + throw new InvalidOperationException("Pipe name cannot be null or empty"); + } + } + + public async Task During(CancellationToken cancellationToken = default) + { + try + { + var tcs = new TaskCompletionSource(); + cancellationToken.Register(() => tcs.TrySetCanceled()); + await tcs.Task; + } + catch(OperationCanceledException) + { + Debug.WriteLine($"{GetType().Name} cancelled"); + } + } + + public void Post() + { + } + } +} diff --git a/FFMpegCore/FFMpeg/FFMpegArguments.cs b/FFMpegCore/FFMpeg/FFMpegArguments.cs index ddb1f72..ca7b116 100644 --- a/FFMpegCore/FFMpeg/FFMpegArguments.cs +++ b/FFMpegCore/FFMpeg/FFMpegArguments.cs @@ -26,6 +26,7 @@ private string GetText() public static FFMpegArguments FromUrlInput(Uri uri, Action? addArguments = null) => new FFMpegArguments().WithInput(new InputArgument(uri.AbsoluteUri, false), addArguments); public static FFMpegArguments FromDeviceInput(string device, Action? addArguments = null) => new FFMpegArguments().WithInput(new InputDeviceArgument(device), addArguments); public static FFMpegArguments FromPipeInput(IPipeSource sourcePipe, Action? addArguments = null) => new FFMpegArguments().WithInput(new InputPipeArgument(sourcePipe), addArguments); + public static FFMpegArguments FromPipeInput(string pipeName, Action? addArguments = null) => new FFMpegArguments().WithInput(new InputExistingPipeArgument(pipeName), addArguments); public FFMpegArguments WithGlobalOptions(Action configureOptions) { @@ -41,6 +42,7 @@ public FFMpegArguments WithGlobalOptions(Action configure public FFMpegArguments AddUrlInput(Uri uri, Action? addArguments = null) => WithInput(new InputArgument(uri.AbsoluteUri, false), addArguments); public FFMpegArguments AddDeviceInput(string device, Action? addArguments = null) => WithInput(new InputDeviceArgument(device), addArguments); public FFMpegArguments AddPipeInput(IPipeSource sourcePipe, Action? addArguments = null) => WithInput(new InputPipeArgument(sourcePipe), addArguments); + public FFMpegArguments AddPipeInput(string pipeName, Action? addArguments = null) => WithInput(new InputExistingPipeArgument(pipeName), addArguments); public FFMpegArguments AddMetaData(string content, Action? addArguments = null) => WithInput(new MetaDataArgument(content), addArguments); public FFMpegArguments AddMetaData(IReadOnlyMetaData metaData, Action? addArguments = null) => WithInput(new MetaDataArgument(MetaDataSerializer.Instance.Serialize(metaData)), addArguments);