message improvements

pull/5/head
Evan Hemsley 2019-07-28 19:17:00 -07:00
parent ed965d43a3
commit bd7c316ea8
3 changed files with 14 additions and 12 deletions

2
TODO
View File

@ -1,2 +1,2 @@
- look at test coverage
- docs
- docs

View File

@ -8,28 +8,25 @@ namespace Encompass
{
private readonly Dictionary<Type, List<IMessage>> messageTypeToMessages = new Dictionary<Type, List<IMessage>>();
internal void AddMessage<TMessage>(TMessage message) where TMessage : struct, IMessage
internal void RegisterMessageType(Type messageType)
{
if (!messageTypeToMessages.ContainsKey(typeof(TMessage)))
{
messageTypeToMessages.Add(typeof(TMessage), new List<IMessage>());
if (!messageTypeToMessages.ContainsKey(messageType)) {
messageTypeToMessages.Add(messageType, new List<IMessage>());
}
messageTypeToMessages[typeof(TMessage)].Add(message);
}
internal void AddMessage(IMessage message)
{
var type = message.GetType();
if (!messageTypeToMessages.ContainsKey(type))
{
messageTypeToMessages.Add(type, new List<IMessage>());
}
messageTypeToMessages[type].Add(message);
}
internal void AddMessage<TMessage>(IMessage message) where TMessage : struct, IMessage
{
messageTypeToMessages[typeof(TMessage)].Add(message);
}
internal void ClearMessages()
{
foreach (var entry in messageTypeToMessages)

View File

@ -86,6 +86,11 @@ namespace Encompass
var messageReceiveTypes = engine.receiveTypes;
var messageSendTypes = engine.sendTypes;
foreach (var messageType in messageReceiveTypes.Union(messageSendTypes))
{
messageManager.RegisterMessageType(messageType);
}
foreach (var messageType in messageReceiveTypes.Intersect(messageSendTypes))
{
if ((messageType.IsGenericType && messageType.GetGenericTypeDefinition() == typeof(PendingComponentMessage<>)))