caching more info in ComponentMessageManager
parent
bea247e896
commit
1b30f3bd39
|
@ -9,7 +9,10 @@ namespace Encompass
|
|||
class ComponentMessageManager
|
||||
{
|
||||
private readonly Dictionary<Guid, IComponent> componentIDToComponent = new Dictionary<Guid, IComponent>();
|
||||
private readonly Dictionary<Guid, Type> componentIDToType = new Dictionary<Guid, Type>();
|
||||
|
||||
private readonly Dictionary<Guid, Guid> componentIDToEntityID = new Dictionary<Guid, Guid>();
|
||||
|
||||
private readonly Dictionary<Type, HashSet<Guid>> componentMessageTypeToExistingComponentIDs = new Dictionary<Type, HashSet<Guid>>();
|
||||
private readonly Dictionary<Type, HashSet<Guid>> componentMessageTypeToPendingComponentIDs = new Dictionary<Type, HashSet<Guid>>();
|
||||
private readonly Dictionary<Type, HashSet<Guid>> componentMessageTypeToComponentIDs = new Dictionary<Type, HashSet<Guid>>();
|
||||
|
@ -40,6 +43,8 @@ namespace Encompass
|
|||
internal void ClearMessages()
|
||||
{
|
||||
componentIDToComponent.Clear();
|
||||
componentIDToType.Clear();
|
||||
componentIDToEntityID.Clear();
|
||||
|
||||
foreach (var set in componentMessageTypeToExistingComponentIDs.Values)
|
||||
{
|
||||
|
@ -117,7 +122,9 @@ namespace Encompass
|
|||
private void RegisterExistingOrPendingComponentMessage<TComponent>(Entity entity, Guid componentID, TComponent component) where TComponent: struct, IComponent
|
||||
{
|
||||
componentIDToComponent[componentID] = component;
|
||||
|
||||
componentIDToEntityID[componentID] = entity.ID;
|
||||
componentIDToType[componentID] = typeof(TComponent);
|
||||
|
||||
if (!componentMessageTypeToComponentIDs.ContainsKey(typeof(TComponent)))
|
||||
{
|
||||
componentMessageTypeToComponentIDs.Add(typeof(TComponent), new HashSet<Guid>());
|
||||
|
@ -250,5 +257,20 @@ namespace Encompass
|
|||
{
|
||||
return entityToTypeToPendingComponentID.ContainsKey(entity) && entityToTypeToPendingComponentID[entity].ContainsKey(typeof(TComponent));
|
||||
}
|
||||
|
||||
internal IComponent GetComponentByID(Guid componentID)
|
||||
{
|
||||
return componentIDToComponent[componentID];
|
||||
}
|
||||
|
||||
internal Type GetComponentTypeByID(Guid componentID)
|
||||
{
|
||||
return componentIDToType[componentID];
|
||||
}
|
||||
|
||||
internal Guid GetEntityIDByComponentID(Guid componentID)
|
||||
{
|
||||
return componentIDToEntityID[componentID];
|
||||
}
|
||||
}
|
||||
}
|
||||
|
|
|
@ -12,8 +12,8 @@ namespace Encompass
|
|||
internal readonly HashSet<Type> receiveTypes = new HashSet<Type>();
|
||||
|
||||
private EntityManager entityManager;
|
||||
private ComponentManager componentManager;
|
||||
private MessageManager messageManager;
|
||||
private ComponentManager componentManager;
|
||||
private ComponentMessageManager componentMessageManager;
|
||||
|
||||
protected Engine()
|
||||
|
@ -94,7 +94,7 @@ namespace Encompass
|
|||
|
||||
protected Guid GetEntityIDByComponentID(Guid componentID)
|
||||
{
|
||||
return componentManager.GetEntityIDByComponentID(componentID);
|
||||
return componentMessageManager.GetEntityIDByComponentID(componentID);
|
||||
}
|
||||
|
||||
protected Entity GetEntityByComponentID(Guid componentID)
|
||||
|
@ -104,12 +104,12 @@ namespace Encompass
|
|||
|
||||
protected TComponent GetComponentByID<TComponent>(Guid componentID) where TComponent : struct, IComponent
|
||||
{
|
||||
if (componentManager.GetComponentTypeByID(componentID) != typeof(TComponent))
|
||||
if (componentMessageManager.GetComponentTypeByID(componentID) != typeof(TComponent))
|
||||
{
|
||||
throw new ComponentTypeMismatchException("Expected Component to be of type {0} but was actually of type {1}", typeof(TComponent).Name, componentManager.GetComponentTypeByID(componentID).Name);
|
||||
throw new ComponentTypeMismatchException("Expected Component to be of type {0} but was actually of type {1}", typeof(TComponent).Name, componentMessageManager.GetComponentTypeByID(componentID).Name);
|
||||
}
|
||||
|
||||
return (TComponent)componentManager.GetComponentByID(componentID);
|
||||
return (TComponent)componentMessageManager.GetComponentByID(componentID);
|
||||
}
|
||||
|
||||
internal IEnumerable<(Guid, TComponent)> ReadComponentsFromWorld<TComponent>() where TComponent : struct, IComponent
|
||||
|
@ -117,6 +117,11 @@ namespace Encompass
|
|||
return componentManager.GetComponentsByType<TComponent>();
|
||||
}
|
||||
|
||||
internal Entity ReadEntityFromWorld(Guid componentID)
|
||||
{
|
||||
return GetEntity(componentManager.GetEntityIDByComponentID(componentID));
|
||||
}
|
||||
|
||||
protected Guid AddComponent<TComponent>(Entity entity, TComponent component) where TComponent : struct, IComponent
|
||||
{
|
||||
var componentID = componentManager.MarkComponentForAdd(entity, component);
|
||||
|
|
|
@ -14,7 +14,7 @@ namespace Encompass.Engines
|
|||
foreach (var (componentID, component) in ReadComponentsFromWorld<TComponent>())
|
||||
{
|
||||
ComponentMessage<TComponent> componentMessage;
|
||||
componentMessage.entity = GetEntityByComponentID(componentID);
|
||||
componentMessage.entity = ReadEntityFromWorld(componentID);
|
||||
componentMessage.componentID = componentID;
|
||||
componentMessage.component = component;
|
||||
SendMessage(componentMessage);
|
||||
|
|
Loading…
Reference in New Issue