mirror of
https://github.com/MindWorkAI/AI-Studio.git
synced 2025-04-28 15:39:46 +00:00
Added option to defer messages
This commit is contained in:
parent
4293ae6850
commit
44ccac8127
@ -11,6 +11,7 @@ public sealed class MessageBus
|
|||||||
|
|
||||||
private readonly ConcurrentDictionary<IMessageBusReceiver, ComponentBase[]> componentFilters = new();
|
private readonly ConcurrentDictionary<IMessageBusReceiver, ComponentBase[]> componentFilters = new();
|
||||||
private readonly ConcurrentDictionary<IMessageBusReceiver, Event[]> componentEvents = new();
|
private readonly ConcurrentDictionary<IMessageBusReceiver, Event[]> componentEvents = new();
|
||||||
|
private readonly ConcurrentDictionary<Event, ConcurrentQueue<Message>> deferredMessages = new();
|
||||||
private readonly ConcurrentQueue<Message> messageQueue = new();
|
private readonly ConcurrentQueue<Message> messageQueue = new();
|
||||||
private readonly SemaphoreSlim sendingSemaphore = new(1, 1);
|
private readonly SemaphoreSlim sendingSemaphore = new(1, 1);
|
||||||
|
|
||||||
@ -65,6 +66,24 @@ public sealed class MessageBus
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public void DeferMessage<T>(ComponentBase? sendingComponent, Event triggeredEvent, T? data = default)
|
||||||
|
{
|
||||||
|
if (this.deferredMessages.TryGetValue(triggeredEvent, out var queue))
|
||||||
|
queue.Enqueue(new Message(sendingComponent, triggeredEvent, data));
|
||||||
|
else
|
||||||
|
{
|
||||||
|
this.deferredMessages[triggeredEvent] = new();
|
||||||
|
this.deferredMessages[triggeredEvent].Enqueue(new Message(sendingComponent, triggeredEvent, data));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
public IEnumerable<T?> CheckDeferredMessages<T>(Event triggeredEvent)
|
||||||
|
{
|
||||||
|
if (this.deferredMessages.TryGetValue(triggeredEvent, out var queue))
|
||||||
|
while (queue.TryDequeue(out var message))
|
||||||
|
yield return message.Data is T data ? data : default;
|
||||||
|
}
|
||||||
|
|
||||||
public async Task<TResult?> SendMessageUseFirstResult<TPayload, TResult>(ComponentBase? sendingComponent, Event triggeredEvent, TPayload? data = default)
|
public async Task<TResult?> SendMessageUseFirstResult<TPayload, TResult>(ComponentBase? sendingComponent, Event triggeredEvent, TPayload? data = default)
|
||||||
{
|
{
|
||||||
foreach (var (receiver, componentFilter) in this.componentFilters)
|
foreach (var (receiver, componentFilter) in this.componentFilters)
|
||||||
|
Loading…
Reference in New Issue
Block a user