forked from PLCnext/CppExamples
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathThreadExampleComponent.hpp
131 lines (106 loc) · 4.53 KB
/
ThreadExampleComponent.hpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
/******************************************************************************
*
* Copyright (c) Phoenix Contact GmbH & Co. KG. All rights reserved.
* Licensed under the MIT. See LICENSE file in the project root for full license information.
*
* ThreadExampleComponent.hpp
*
* Created on: 16.05.2019
* Author: Eduard Münz, Oliver Warneke
*
******************************************************************************/
/******************************************************************************/
/* INCLUDES */
/******************************************************************************/
#pragma once
#include "Arp/System/Core/Arp.h"
#include "Arp/System/Acf/ComponentBase.hpp"
#include "Arp/System/Acf/IApplication.hpp"
#include "Arp/Plc/Commons/Esm/ProgramComponentBase.hpp"
#include "ThreadExampleComponentProgramProvider.hpp"
#include "Arp/Plc/Commons/Meta/MetaLibraryBase.hpp"
#include "Arp/System/Commons/Logging.h"
//ADDED
#include "Arp/System/Acf/IControllerComponent.hpp"
#include "Arp/System/Commons/Threading/WorkerThread.hpp"
#include "Arp/System/Commons/Threading/Thread.hpp"
#include "Arp/System/Commons/Threading/ThreadSettings.hpp"
//ADDED
namespace ThreadExample
{
using namespace Arp;
using namespace Arp::System::Acf;
using namespace Arp::Plc::Commons::Esm;
using namespace Arp::Plc::Commons::Meta;
using namespace Arp::System::Commons::Threading;
//#component
class ThreadExampleComponent : public ComponentBase
, public ProgramComponentBase
, public IControllerComponent
, private Loggable<ThreadExampleComponent>
{
public: // typedefs
public: // construction/destruction
ThreadExampleComponent(IApplication& application, const String& name);
virtual ~ThreadExampleComponent() = default;
public: // IComponent operations
void Initialize() override;
void LoadConfig() override;
void SetupConfig() override;
void ResetConfig() override;
public: // IControllerComponent operations
void Start(void);
void Stop(void);
public: // ProgramComponentBase operations
void RegisterComponentPorts() override;
int GetCounterValue();
private: // methods
ThreadExampleComponent(const ThreadExampleComponent& arg) = delete;
ThreadExampleComponent& operator= (const ThreadExampleComponent& arg) = delete;
public: // static factory operations
static IComponent::Ptr Create(Arp::System::Acf::IApplication& application, const String& name);
private: // Thread Bodys
void workerThreadBody(void);
void delegateThreadBody(void * pParameter);
static void staticThreadBody(void* pParameter);
private: // fields
ThreadExampleComponentProgramProvider programProvider;
// WorkerThread Example
WorkerThread workerThreadInstance;
int iStartValue = 0;
int iEndValue = 1000;
int iCountervalue = 0;
bool xStopThread = false;
// delegate Thread Example
Thread delegateThreadInstance;
// static Thread Example
int myparameter{123};
Thread staticThreadInstance;
public: /* Ports
=====
Component ports are defined in the following way:
//#attributes(Hidden)
struct Ports
{
//#name(NameOfPort)
//#attributes(Input|Retain|Opc)
Arp::boolean portField = false;
// The GDS name is "<componentName>/NameOfPort" if the struct is declared as Hidden
// otherwise the GDS name is "<componentName>/PORTS.NameOfPort"
};
//#port
Ports ports;
Create one (and only one) instance of this struct.
Apart from this single struct instance, there must be no other Component variables declared with the #port comment.
The only attribute that is allowed on the struct instance is "Hidden", and this is optional.
The struct can contain as many members as necessary.
The #name comment can be applied to each member of the struct, and is optional.
The #name comment defines the GDS name of an individual port element. If omitted, the member variable name is used as the GDS name.
The members of the struct can be declared with any of the attributes allowed for a Program port.
*/
};
inline IComponent::Ptr ThreadExampleComponent::Create(Arp::System::Acf::IApplication& application, const String& name)
{
return IComponent::Ptr(new ThreadExampleComponent(application, name));
}
} // end of namespace ThreadExample