/* * Copyright (c) Contributors to the Open 3D Engine Project. * For complete copyright and license terms please see the LICENSE at the root of this distribution. * * SPDX-License-Identifier: Apache-2.0 OR MIT * */ #include #include #include #include #include #include namespace GraphCanvas { /////////////////////////// // ExecutionSlotComponent /////////////////////////// void ExecutionSlotComponent::Reflect(AZ::ReflectContext* reflectContext) { AZ::SerializeContext* serializeContext = azrtti_cast(reflectContext); if (serializeContext) { serializeContext->Class() ->Version(1) ; } } AZ::Entity* ExecutionSlotComponent::CreateExecutionSlot(const AZ::EntityId& nodeId, const SlotConfiguration& slotConfiguration) { AZ::Entity* entity = SlotComponent::CreateCoreSlotEntity(); ExecutionSlotComponent* executionSlot = entity->CreateComponent(slotConfiguration); entity->CreateComponent(); AZStd::string styleClass; StyledEntityRequestBus::EventResult(styleClass, nodeId, &StyledEntityRequests::GetClass); entity->CreateComponent(Styling::Elements::ExecutionSlot, nodeId, styleClass); SlotConnectionFilterComponent* connectionFilter = entity->CreateComponent(); SlotTypeFilter* slotTypeFilter = aznew SlotTypeFilter(ConnectionFilterType::Include); slotTypeFilter->AddSlotType(SlotTypes::ExecutionSlot); connectionFilter->AddFilter(slotTypeFilter); ConnectionTypeFilter* connectionTypeFilter = aznew ConnectionTypeFilter(ConnectionFilterType::Include); switch (executionSlot->GetConnectionType()) { case ConnectionType::CT_Input: connectionTypeFilter->AddConnectionType(CT_Output); break; case ConnectionType::CT_Output: connectionTypeFilter->AddConnectionType(CT_Input); break; default: break; }; connectionFilter->AddFilter(connectionTypeFilter); return entity; } ExecutionSlotComponent::ExecutionSlotComponent() : SlotComponent(SlotTypes::ExecutionSlot) { if (m_slotConfiguration.m_slotGroup == SlotGroups::Invalid) { m_slotConfiguration.m_slotGroup = SlotGroups::ExecutionGroup; } } ExecutionSlotComponent::ExecutionSlotComponent(const SlotConfiguration& slotConfiguration) : SlotComponent(SlotTypes::ExecutionSlot, slotConfiguration) { if (m_slotConfiguration.m_slotGroup == SlotGroups::Invalid) { m_slotConfiguration.m_slotGroup = SlotGroups::ExecutionGroup; } } ExecutionSlotComponent::~ExecutionSlotComponent() { } SlotConfiguration* ExecutionSlotComponent::CloneSlotConfiguration() const { ExecutionSlotConfiguration* executionConfiguration = aznew ExecutionSlotConfiguration(); PopulateSlotConfiguration((*executionConfiguration)); return executionConfiguration; } AZ::Entity* ExecutionSlotComponent::ConstructConnectionEntity(const Endpoint& sourceEndpoint, const Endpoint& targetEndpoint, bool createModelConnection) { const AZStd::string k_connectionSubStyle = ".logicFlow"; return ConnectionComponent::CreateGeneralConnection(sourceEndpoint, targetEndpoint, createModelConnection, k_connectionSubStyle); } }