Remove request from requests dict after it was handled. This was a memory leak!
This commit is contained in:
@ -89,27 +89,41 @@ public class JRpcClient
|
||||
|
||||
var task = new TaskCompletionSource<JsonNode?>();
|
||||
this.Requests.Add(id, task);
|
||||
_ = Task.Run(async () =>
|
||||
{
|
||||
await this.Transport.Write(request.ToJsonString());
|
||||
});
|
||||
|
||||
if (this.Timeout.HasValue)
|
||||
try
|
||||
{
|
||||
if (await Task.WhenAny(task.Task, Task.Delay(this.Timeout.Value)) == task.Task)
|
||||
_ = Task.Run(async () =>
|
||||
{
|
||||
return await task.Task;
|
||||
try
|
||||
{
|
||||
await this.Transport.Write(request.ToJsonString());
|
||||
}
|
||||
catch (Exception e)
|
||||
{
|
||||
task.SetException(e);
|
||||
}
|
||||
});
|
||||
|
||||
if (this.Timeout.HasValue)
|
||||
{
|
||||
if (await Task.WhenAny(task.Task, Task.Delay(this.Timeout.Value)) == task.Task)
|
||||
{
|
||||
return await task.Task;
|
||||
}
|
||||
else
|
||||
{
|
||||
throw new JRpcTimeoutException();
|
||||
}
|
||||
|
||||
}
|
||||
else
|
||||
{
|
||||
this.Requests.Remove(id);
|
||||
throw new JRpcTimeoutException();
|
||||
return await task.Task;
|
||||
}
|
||||
|
||||
}
|
||||
else
|
||||
finally
|
||||
{
|
||||
return await task.Task;
|
||||
this.Requests.Remove(id);
|
||||
}
|
||||
}
|
||||
|
||||
|
Reference in New Issue
Block a user