Imt.Base C++ API V4.1.1.0
Loading...
Searching...
No Matches
RuntimeCore.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_RUNTIME_RUNTIMECORE_H
37#define IMT_BASE_DFF_RUNTIME_RUNTIMECORE_H
38
45
46namespace imt {
47namespace base {
48namespace dff {
49namespace runtime {
50
57
58public:
59
65
69 static constexpr CoreHandle COREHANDLE_INVALID {-1};
70
77 static void init(IdleCallbackIfc* const pIdleCallback = nullptr, EventPoolCapacityCallbackIfc* const pEventPoolCapacityCallback = nullptr);
78
87 static CoreHandle create(ExecutableIfc& executable);
88
93 static void start();
94
99 static void stop();
100
108 static void sendEvent(CoreHandle const receiverHandle, uint16_t const protocolIdentifier, ::imt::base::core::serialization::SerializableIfc const* const pEventData, size_t const eventDataSizeBytes);
109};
110
111} // namespace runtime
112} // namespace dff
113} // namespace base
114} // namespace imt
115
116#endif // IMT_BASE_DFF_RUNTIME_RUNTIMECORE_H
Base class for a static class that disables construction, copy, assignment and move of instances.
Definition StaticClass.h:48
Serialization is the process of translating data structures into a binary representation.
Interface for callback about the event pool capacity.
Interface of an executable which is called by the runtime once an event has to be processed.
Interface for idle processing.
RuntimeCore defines the basic Application Interface (API) to the core part of the event-based run to ...
Definition RuntimeCore.h:56
static void start()
Start the core.
static constexpr CoreHandle COREHANDLE_INVALID
Constant which represents an invalid CoreHandle.
Definition RuntimeCore.h:69
static void init(IdleCallbackIfc *const pIdleCallback=nullptr, EventPoolCapacityCallbackIfc *const pEventPoolCapacityCallback=nullptr)
Initialize the core.
int16_t CoreHandle
A CoreHandle is used to identify an executable with a unique number (similar to a phone number).
Definition RuntimeCore.h:64
static void sendEvent(CoreHandle const receiverHandle, uint16_t const protocolIdentifier, ::imt::base::core::serialization::SerializableIfc const *const pEventData, size_t const eventDataSizeBytes)
Send an event to the given receiver (the scheduler will determinate when the event will be processed ...
static CoreHandle create(ExecutableIfc &executable)
Register the given executable in the core.
static void stop()
Stops the core.
This is a application specific file which is used to configure Imt.Base.Core.Math.
__int16 int16_t
Definition stdint.h:59
unsigned __int16 uint16_t
Definition stdint.h:63