register message types at init time instead of runtime
parent
36621c2fe7
commit
539d6de247
4
TODO
4
TODO
|
@ -1,4 +1,6 @@
|
||||||
- look at test coverage
|
- look at test coverage
|
||||||
- docs
|
- docs
|
||||||
|
|
||||||
- emit two packages: one for dev, which includes expensive runtime validation checks, and one for release, which disables them
|
- emit two packages: one for dev, which includes expensive runtime validation checks, and one for release, which disables them
|
||||||
|
|
||||||
|
- thread safety
|
||||||
|
|
|
@ -8,25 +8,22 @@ namespace Encompass
|
||||||
{
|
{
|
||||||
private readonly Dictionary<Type, List<IMessage>> messageTypeToMessages = new Dictionary<Type, List<IMessage>>();
|
private readonly Dictionary<Type, List<IMessage>> messageTypeToMessages = new Dictionary<Type, List<IMessage>>();
|
||||||
|
|
||||||
|
internal void RegisterMessageType(Type messageType)
|
||||||
|
{
|
||||||
|
if (!messageTypeToMessages.ContainsKey(messageType)) {
|
||||||
|
messageTypeToMessages.Add(messageType, new List<IMessage>());
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
internal void AddMessage(IMessage message)
|
internal void AddMessage(IMessage message)
|
||||||
{
|
{
|
||||||
var type = message.GetType();
|
var type = message.GetType();
|
||||||
|
|
||||||
if (!messageTypeToMessages.ContainsKey(type))
|
|
||||||
{
|
|
||||||
messageTypeToMessages.Add(type, new List<IMessage>());
|
|
||||||
}
|
|
||||||
|
|
||||||
messageTypeToMessages[type].Add(message);
|
messageTypeToMessages[type].Add(message);
|
||||||
}
|
}
|
||||||
|
|
||||||
internal void AddMessage<TMessage>(TMessage message) where TMessage : struct, IMessage
|
internal void AddMessage<TMessage>(TMessage message) where TMessage : struct, IMessage
|
||||||
{
|
{
|
||||||
if (!messageTypeToMessages.ContainsKey(typeof(TMessage)))
|
|
||||||
{
|
|
||||||
messageTypeToMessages.Add(typeof(TMessage), new List<IMessage>());
|
|
||||||
}
|
|
||||||
|
|
||||||
messageTypeToMessages[typeof(TMessage)].Add(message);
|
messageTypeToMessages[typeof(TMessage)].Add(message);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -91,6 +91,11 @@ namespace Encompass
|
||||||
var messageReceiveTypes = engine.receiveTypes;
|
var messageReceiveTypes = engine.receiveTypes;
|
||||||
var messageSendTypes = engine.sendTypes;
|
var messageSendTypes = engine.sendTypes;
|
||||||
|
|
||||||
|
foreach (var messageType in messageReceiveTypes.Union(messageSendTypes))
|
||||||
|
{
|
||||||
|
messageManager.RegisterMessageType(messageType);
|
||||||
|
}
|
||||||
|
|
||||||
foreach (var messageType in messageReceiveTypes.Intersect(messageSendTypes))
|
foreach (var messageType in messageReceiveTypes.Intersect(messageSendTypes))
|
||||||
{
|
{
|
||||||
if ((messageType.IsGenericType && messageType.GetGenericTypeDefinition() == typeof(PendingComponentMessage<>)))
|
if ((messageType.IsGenericType && messageType.GetGenericTypeDefinition() == typeof(PendingComponentMessage<>)))
|
||||||
|
|
Loading…
Reference in New Issue