Imt.Base C++ API V4.1.1.0
Loading...
Searching...
No Matches
ChannelConnectionVerifier.h
Go to the documentation of this file.
1// (c) IMT - Information Management Technology AG, CH-9470 Buchs, www.imt.ch.
2//
3// ActiveParts (AP) and the corresponding Data Flow Framework (DFF) is invented and designed by Jakob Daescher.
4// ANY USE OF THIS CODE CONSTITUTES ACCEPTANCE OF THE TERMS OF THE COPYRIGHT NOTICE.
5// ===================================================================================================
6// COPYRIGHT NOTICE
7// ===================================================================================================
8// Copyright (C) 2005-2075, IMT Information Management Technology AG, 9470 Buchs, Switzerland
9// All rights reserved.
10// This code is proprietary software of IMT Information Management Technology AG (hereinafter: "IMT").
11// Proprietary software is computer software licensed under exclusive legal right of IMT.
12//
13// The licensee is given the irrevocable, perpetual, worldwide, non-exclusive right and license to use,
14// execute and reproduce the software in binary form within the licensed products.
15//
16// Redistribution and use in source forms, without modification, are permitted provided that the following conditions are met:
17// (1) Copying of source code must retain the above copyright notice, this list of conditions and the following disclaimer.
18// (2) Copying of source code is only allowed for regulatory documentation and archiving purposes
19// (3) Redistributions in binary form must reproduce the above copyright notice,
20// this list of conditions and the following disclaimer in the documentation and/or other materials provided with the distribution.
21//
22// IMT provide no reassurances that the source code provided does not infringe
23// any patent, copyright, or any other intellectual property rights of third parties.
24// IMT disclaim any liability to any recipient for claims brought against
25// recipient by any third party for infringement of that parties intellectual property rights.
26//
27// THIS SOFTWARE IS PROVIDED BY IMT AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
28// INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
29// IN NO EVENT SHALL IMT OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY,
30// OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCURE-MENT OF SUBSTITUTE GOODS OR SERVICES;
31// LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
32// WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
33// IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
34// ===================================================================================================
35
36#ifndef IMT_BASE_DFF_ACTIVEPARTS_TEST_CHANNELCONNECTIONVERIFIER_H
37#define IMT_BASE_DFF_ACTIVEPARTS_TEST_CHANNELCONNECTIONVERIFIER_H
38
45
46namespace imt {
47namespace base {
48namespace dff {
49namespace activeparts {
50namespace test {
51
56
57public:
58
65 static bool testChannelOneToOne(PortOutput const& outputPort, ReceiverIfc const& inputPort) {
66 if (outputPort.getChannel() == nullptr) {
67 return false;
68 }
69 ChannelOneToOne const* pChannel = dynamic_cast<ChannelOneToOne const*>(outputPort.getChannel());
70 if (pChannel == nullptr) {
71 return false;
72 }
73 return (pChannel->getReceiveHandle() == inputPort.getReceiveHandle());
74 }
75
84 template<uint32_t NumberOfReceivers>
85 static bool testChannelOneToAny(PortOutput const& outputPort, ReceiverIfc const& inputPort, uint32_t receiverIndex) {
86 if (outputPort.getChannel() == nullptr) {
87 return false;
88 }
89 ChannelOneToAny<NumberOfReceivers> const* pChannel = dynamic_cast<ChannelOneToAny<NumberOfReceivers> const*>(outputPort.getChannel());
90 if (pChannel == nullptr) {
91 return false;
92 }
93 return (pChannel->getReceiveHandle(receiverIndex) == inputPort.getReceiveHandle());
94 }
95
104 template<uint32_t NumberOfReceivers>
105 static bool testChannelOneToAny(PortOutput const& outputPort, ReceiverIfc const& inputPort) {
106 if (outputPort.getChannel() == nullptr) {
107 return false;
108 }
109 ChannelOneToAny<NumberOfReceivers> const* pChannel = dynamic_cast<ChannelOneToAny<NumberOfReceivers> const*>(outputPort.getChannel());
110 if (pChannel == nullptr) {
111 return false;
112 }
113 for (uint32_t receiverIndex = 0U; receiverIndex < NumberOfReceivers; ++receiverIndex) {
114 if (pChannel->getReceiveHandle(receiverIndex) == inputPort.getReceiveHandle()) {
115 return true;
116 }
117 }
118
119 return false;
120 }
121
131 template<uint32_t NumberOfReceivers>
132 static bool testChannelInternalForwarder(PortOutput const& outputPort, ReceiverIfc const& inputPort, uint32_t receiverIndex, PortOutput const& forwarderPortOut) {
133 if (outputPort.getChannel() == nullptr) {
134 return false;
135 }
137 if (pChannel == nullptr) {
138 return false;
139 }
140
141 return (pChannel->getReceiveHandle(receiverIndex) == inputPort.getReceiveHandle()) && (pChannel->getForwarderPortOut() == &forwarderPortOut);
142 }
143
152 template<uint32_t NumberOfReceivers>
153 static bool testChannelInternalForwarder(PortOutput const& outputPort, ReceiverIfc const& inputPort, PortOutput const& forwarderPortOut) {
154 if (outputPort.getChannel() == nullptr) {
155 return false;
156 }
158 if (pChannel == nullptr || pChannel->getForwarderPortOut() != &forwarderPortOut) {
159 return false;
160 }
161 for (uint32_t receiverIndex = 0U; receiverIndex < NumberOfReceivers; ++receiverIndex) {
162 if (pChannel->getReceiveHandle(receiverIndex) == inputPort.getReceiveHandle()) {
163 return true;
164 }
165 }
166
167 return false;
168 }
169};
170
171} // namespace test
172} // namespace activeparts
173} // namespace dff
174} // namespace base
175} // namespace imt
176
177#endif // IMT_BASE_DFF_ACTIVEPARTS_TEST_CHANNELCONNECTIONVERIFIER_H
ChannelInternalForwarder handles the following situations.
Send the message on a One-to-Any channel (multiple receivers).
Send the message on a One-to-One channel.
Messages can be sent on the output port.
Definition PortOutput.h:54
ChannelIfc const * getChannel() const
Get the read only pointer to the channel.
Interface for any receiver to be called on received serialized data.s.
Definition ReceiverIfc.h:53
virtual ::imt::base::dff::runtime::RuntimeCore::CoreHandle getReceiveHandle() const =0
Get the handle of this input.
Helper class to verify that the ports are properly connected with channels.
static bool testChannelOneToOne(PortOutput const &outputPort, ReceiverIfc const &inputPort)
Test that a connection exists between the output port and the input port with a ChannelOneToOne.
static bool testChannelInternalForwarder(PortOutput const &outputPort, ReceiverIfc const &inputPort, PortOutput const &forwarderPortOut)
Test that a connection exists between the output port, the input port and the forwarder output port w...
static bool testChannelInternalForwarder(PortOutput const &outputPort, ReceiverIfc const &inputPort, uint32_t receiverIndex, PortOutput const &forwarderPortOut)
Test that a connection exists between the output port, the input port and the forwarder output port w...
static bool testChannelOneToAny(PortOutput const &outputPort, ReceiverIfc const &inputPort)
Test that a connection exists between the output port and the input port with a ChannelOneToAny.
static bool testChannelOneToAny(PortOutput const &outputPort, ReceiverIfc const &inputPort, uint32_t receiverIndex)
Test that a connection exists between the output port and the input port with a ChannelOneToAny at th...
This is a application specific file which is used to configure Imt.Base.Core.Math.
unsigned __int32 uint32_t
Definition stdint.h:64