Imt.Base C++ API V4.1.1.0
Loading...
Searching...
No Matches
OneShotTimer.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_ONESHOTTIMER_H
37#define IMT_BASE_DFF_ACTIVEPARTS_ONESHOTTIMER_H
38
42
43namespace imt {
44namespace base {
45namespace dff {
46namespace activeparts {
47
53
54public:
55
62
67
71 void stop();
72
77 bool isRunning() const;
78
84
89
90private:
91
93 uint32_t const m_timeoutMs;
95 // AXIVION Next Codeline AutosarC++19_03-A12.1.3: All data members initialized in custom constructor
96 bool m_isRunning;
97};
98
99} // namespace activeparts
100} // namespace dff
101} // namespace base
102} // namespace imt
103
104#endif // IMT_BASE_DFF_ACTIVEPARTS_ONESHOTTIMER_H
Base class for a not movable class that disables copy, assignment and move of instances.
Definition Nonmovable.h:51
A one shot timer to be used in an active part.
bool isRunning() const
Check if the timer is running.
void clearTimerHandle()
Clear the timer handle.
void stop()
Stop the oneshot timer.
::imt::base::dff::runtime::RuntimeTimer::TimerHandle getTimerId() const
Get the handle to identify the timer.
OneShotTimer(::imt::base::dff::runtime::TimerServiceIfc &timer, uint32_t const timeoutMs)
Constructor.
void startTimeout()
Start the oneshot timer.
int16_t TimerHandle
A TimerHandle is used to identify a timer with a unique number.
This is a application specific file which is used to configure Imt.Base.Core.Math.
unsigned __int32 uint32_t
Definition stdint.h:64