mirror of
https://github.com/jellyfin/jellyfin.git
synced 2024-07-23 06:00:47 +02:00
update socket send functions
This commit is contained in:
parent
07c43a1cd3
commit
8a68c23838
|
@ -145,31 +145,84 @@ namespace Emby.Common.Implementations.Net
|
||||||
if (buffer == null) throw new ArgumentNullException("messageData");
|
if (buffer == null) throw new ArgumentNullException("messageData");
|
||||||
if (endPoint == null) throw new ArgumentNullException("endPoint");
|
if (endPoint == null) throw new ArgumentNullException("endPoint");
|
||||||
|
|
||||||
cancellationToken.ThrowIfCancellationRequested();
|
var ipEndPoint = NetworkManager.ToIPEndPoint(endPoint);
|
||||||
|
|
||||||
var tcs = new TaskCompletionSource<int>();
|
#if NETSTANDARD1_6
|
||||||
|
|
||||||
cancellationToken.Register(() => tcs.TrySetCanceled());
|
if (size != buffer.Length)
|
||||||
|
|
||||||
_sendSocketAsyncEventArgs.SetBuffer(buffer, 0, size);
|
|
||||||
_sendSocketAsyncEventArgs.RemoteEndPoint = NetworkManager.ToIPEndPoint(endPoint);
|
|
||||||
_currentSendTaskCompletionSource = tcs;
|
|
||||||
|
|
||||||
var willRaiseEvent = _Socket.SendAsync(_sendSocketAsyncEventArgs);
|
|
||||||
|
|
||||||
if (!willRaiseEvent)
|
|
||||||
{
|
{
|
||||||
_sendSocketAsyncEventArgs_Completed(this, _sendSocketAsyncEventArgs);
|
byte[] copy = new byte[size];
|
||||||
|
Buffer.BlockCopy(buffer, 0, copy, 0, size);
|
||||||
|
buffer = copy;
|
||||||
}
|
}
|
||||||
|
|
||||||
return tcs.Task;
|
cancellationToken.ThrowIfCancellationRequested();
|
||||||
|
|
||||||
|
_Socket.SendTo(buffer, ipEndPoint);
|
||||||
|
return Task.FromResult(true);
|
||||||
|
#else
|
||||||
|
var taskSource = new TaskCompletionSource<bool>();
|
||||||
|
|
||||||
|
try
|
||||||
|
{
|
||||||
|
_Socket.BeginSendTo(buffer, 0, size, SocketFlags.None, ipEndPoint, result =>
|
||||||
|
{
|
||||||
|
if (cancellationToken.IsCancellationRequested)
|
||||||
|
{
|
||||||
|
taskSource.TrySetCanceled();
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
try
|
||||||
|
{
|
||||||
|
_Socket.EndSend(result);
|
||||||
|
taskSource.TrySetResult(true);
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
taskSource.TrySetException(ex);
|
||||||
|
}
|
||||||
|
|
||||||
|
}, null);
|
||||||
|
}
|
||||||
|
catch (Exception ex)
|
||||||
|
{
|
||||||
|
taskSource.TrySetException(ex);
|
||||||
|
}
|
||||||
|
|
||||||
|
//_Socket.SendTo(messageData, new System.Net.IPEndPoint(IPAddress.Parse(RemoteEndPoint.IPAddress), RemoteEndPoint.Port));
|
||||||
|
|
||||||
|
return taskSource.Task;
|
||||||
|
#endif
|
||||||
|
//ThrowIfDisposed();
|
||||||
|
|
||||||
|
//if (buffer == null) throw new ArgumentNullException("messageData");
|
||||||
|
//if (endPoint == null) throw new ArgumentNullException("endPoint");
|
||||||
|
|
||||||
|
//cancellationToken.ThrowIfCancellationRequested();
|
||||||
|
|
||||||
|
//var tcs = new TaskCompletionSource<int>();
|
||||||
|
|
||||||
|
//cancellationToken.Register(() => tcs.TrySetCanceled());
|
||||||
|
|
||||||
|
//_sendSocketAsyncEventArgs.SetBuffer(buffer, 0, size);
|
||||||
|
//_sendSocketAsyncEventArgs.RemoteEndPoint = NetworkManager.ToIPEndPoint(endPoint);
|
||||||
|
//_currentSendTaskCompletionSource = tcs;
|
||||||
|
|
||||||
|
//var willRaiseEvent = _Socket.SendAsync(_sendSocketAsyncEventArgs);
|
||||||
|
|
||||||
|
//if (!willRaiseEvent)
|
||||||
|
//{
|
||||||
|
// _sendSocketAsyncEventArgs_Completed(this, _sendSocketAsyncEventArgs);
|
||||||
|
//}
|
||||||
|
|
||||||
|
//return tcs.Task;
|
||||||
}
|
}
|
||||||
|
|
||||||
public async Task SendWithLockAsync(byte[] buffer, int size, IpEndPointInfo endPoint, CancellationToken cancellationToken)
|
public async Task SendWithLockAsync(byte[] buffer, int size, IpEndPointInfo endPoint, CancellationToken cancellationToken)
|
||||||
{
|
{
|
||||||
ThrowIfDisposed();
|
ThrowIfDisposed();
|
||||||
|
|
||||||
await _sendLock.WaitAsync(cancellationToken).ConfigureAwait(false);
|
//await _sendLock.WaitAsync(cancellationToken).ConfigureAwait(false);
|
||||||
|
|
||||||
try
|
try
|
||||||
{
|
{
|
||||||
|
@ -177,7 +230,7 @@ namespace Emby.Common.Implementations.Net
|
||||||
}
|
}
|
||||||
finally
|
finally
|
||||||
{
|
{
|
||||||
_sendLock.Release();
|
//_sendLock.Release();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -505,7 +505,13 @@ namespace Emby.Server.Implementations.LiveTv.TunerHosts.HdHomerun
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
//return new HdHomerunHttpStream(mediaSource, streamId, _fileSystem, _httpClient, Logger, Config.ApplicationPaths, _appHost);
|
var enableHttpStream = false;
|
||||||
|
|
||||||
|
if (enableHttpStream)
|
||||||
|
{
|
||||||
|
return new HdHomerunHttpStream(mediaSource, streamId, _fileSystem, _httpClient, Logger, Config.ApplicationPaths, _appHost);
|
||||||
|
}
|
||||||
|
|
||||||
return new HdHomerunUdpStream(mediaSource, streamId, new HdHomerunChannelCommands(hdhomerunChannel.Number), modelInfo.TunerCount, _fileSystem, _httpClient, Logger, Config.ApplicationPaths, _appHost, _socketFactory, _networkManager);
|
return new HdHomerunUdpStream(mediaSource, streamId, new HdHomerunChannelCommands(hdhomerunChannel.Number), modelInfo.TunerCount, _fileSystem, _httpClient, Logger, Config.ApplicationPaths, _appHost, _socketFactory, _networkManager);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue