Imt.Base C++ API V4.1.1.0
Loading...
Searching...
No Matches
ActivePartAbs.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_ACTIVEPARTABS_H
37#define IMT_BASE_DFF_ACTIVEPARTS_ACTIVEPARTABS_H
38
44
45#ifdef USE_BUFFERPOOL
48#endif // USE_BUFFERPOOL
49
50namespace imt {
51namespace base {
52namespace dff {
53namespace activeparts {
54
63
64public:
65
72
77
81 ::imt::base::dff::runtime::RuntimePriority getPriority() const final;
82
87 void initialize();
88
93 void start();
94
99 bool isInitialized() const;
100
105 bool isStarted() const;
106
114 ::imt::base::dff::runtime::RuntimeTimer::TimerHandle startOneShotTimer(::imt::base::dff::runtime::RuntimeTimer::TimerHandle timerToStart, uint32_t const timerTicksMs) const final;
115
123 ::imt::base::dff::runtime::RuntimeTimer::TimerHandle startPeriodicTimer(::imt::base::dff::runtime::RuntimeTimer::TimerHandle timerToStart, uint32_t const intervalMs) const final;
124
130 ::imt::base::dff::runtime::RuntimeTimer::TimerHandle killTimer(::imt::base::dff::runtime::RuntimeTimer::TimerHandle timerToKill) const final;
131
132#ifdef USE_BUFFERPOOL
139 virtual void registerBuffer(::imt::base::dff::runtime::BufferAbs& buffer, uint16_t const eventSettings) const;
140#endif // USE_BUFFERPOOL
141
142protected:
143
149 virtual void onInitialize() = 0;
150
156 virtual void onStart() = 0;
157
158private:
159
160 PortInput m_input;
162 ::imt::base::dff::runtime::ExecutableConfiguration const m_executableConfiguration;
163 // AXIVION Next Codeline AutosarC++19_03-A12.1.3: All data members initialized in custom constructor
164 bool m_isInitialized;
165 // AXIVION Next Codeline AutosarC++19_03-A12.1.3: All data members initialized in custom constructor
166 bool m_isStarted;
167
168public:
169
174 // AXIVION Next Codeline AutosarC++19_03-M11.0.1: Allowed usage, compatibility purposes / PortIn port must always be defined
175 // AXIVION Next Codeline CodingStyle-Naming.ClassField: Naming exception for dff components
176 // AXIVION Next Codeline AutosarC++19_03-M0.1.4: field will be reference in the projects
178};
179
180} // namespace activeparts
181} // namespace dff
182} // namespace base
183} // namespace imt
184
185#endif // IMT_BASE_DFF_ACTIVEPARTS_ACTIVEPARTABS_H
Base class for a not movable class that disables copy, assignment and move of instances.
Definition Nonmovable.h:51
Abstract base class for an ActivePart.
::imt::base::dff::runtime::RuntimeTimer::TimerHandle startOneShotTimer(::imt::base::dff::runtime::RuntimeTimer::TimerHandle timerToStart, uint32_t const timerTicksMs) const final
Starts or restarts the given one shot timer for this active part.
void initialize()
Initialize the active part.
::imt::base::dff::runtime::RuntimeTimer::TimerHandle startPeriodicTimer(::imt::base::dff::runtime::RuntimeTimer::TimerHandle timerToStart, uint32_t const intervalMs) const final
Start a periodic timer for this active part.
virtual void onStart()=0
2nd step = called by start().
bool isStarted() const
Check if active part is started.
::imt::base::dff::runtime::RuntimePriority getPriority() const final
::imt::base::dff::runtime::RuntimeTimer::TimerHandle killTimer(::imt::base::dff::runtime::RuntimeTimer::TimerHandle timerToKill) const final
Kill the given timer (if required).
virtual void onInitialize()=0
1st step = called by initialize().
ActivePartAbs(::imt::base::dff::runtime::RuntimePriority const priority, ::imt::base::dff::runtime::ExecutableConfiguration const configuration=::imt::base::dff::runtime::ExecutableConfiguration())
Constructor.
PortInput const & PortIn
Input Port of the active part (as a public visible read-only reference).
bool isInitialized() const
Check if active part is initialized.
void start()
Start the active part.
::imt::base::dff::runtime::ExecutableConfiguration const & getExecutableConfiguration() const final
Messages can be received on the input port.
Definition PortInput.h:57
Optional parameters that can be passed from the active part to the runtime to be considered when crea...
Interface of an executable which is called by the runtime once an event has to be processed.
RuntimePriority
Runtime executable priorities (=software priorities) The priorities start at 1 with lowest priority,...
This is a application specific file which is used to configure Imt.Base.Core.Math.
unsigned __int16 uint16_t
Definition stdint.h:63
unsigned __int32 uint32_t
Definition stdint.h:64