blob: 2f07c1cc203d7db634bf6c588b83d56f5af8c405 (
plain)
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
|
/*
* This file was generated by the CommonAPI Generators.
* Used org.genivi.commonapi.core 3.1.2.v201506150834.
* Used org.franca.core 0.9.1.201412191134.
*
* This Source Code Form is subject to the terms of the Mozilla Public License, v. 2.0.
* If a copy of the MPL was not distributed with this file, You can obtain one at
* http://mozilla.org/MPL/2.0/.
*/
#ifndef COMMONAPI_TESTS_MANAGED_Second_Root_STUB_HPP_
#define COMMONAPI_TESTS_MANAGED_Second_Root_STUB_HPP_
#include <functional>
#include <v1_0/commonapi/tests/managed/LeafInterfaceStub.hpp>
#include <v1_0/commonapi/tests/managed/SecondRoot.hpp>
#if !defined (COMMONAPI_INTERNAL_COMPILATION)
#define COMMONAPI_INTERNAL_COMPILATION
#endif
#include <CommonAPI/Stub.hpp>
#undef COMMONAPI_INTERNAL_COMPILATION
namespace v1_0 {
namespace commonapi {
namespace tests {
namespace managed {
/**
* Receives messages from remote and handles all dispatching of deserialized calls
* to a stub for the service SecondRoot. Also provides means to send broadcasts
* and attribute-changed-notifications of observable attributes as defined by this service.
* An application developer should not need to bother with this class.
*/
class SecondRootStubAdapter
: virtual public CommonAPI::StubAdapter,
public SecondRoot {
public:
virtual bool registerManagedStubLeafInterface(std::shared_ptr<LeafInterfaceStub>, const std::string&) = 0;
virtual bool deregisterManagedStubLeafInterface(const std::string&) = 0;
virtual std::set<std::string>& getLeafInterfaceInstances() = 0;
virtual void deactivateManagedInstances() = 0;
protected:
/**
* Defines properties for storing the ClientIds of clients / proxies that have
* subscribed to the selective broadcasts
*/
};
/**
* Defines the necessary callbacks to handle remote set events related to the attributes
* defined in the IDL description for SecondRoot.
* For each attribute two callbacks are defined:
* - a verification callback that allows to verify the requested value and to prevent setting
* e.g. an invalid value ("onRemoteSet<AttributeName>").
* - an action callback to do local work after the attribute value has been changed
* ("onRemote<AttributeName>Changed").
*
* This class and the one below are the ones an application developer needs to have
* a look at if he wants to implement a service.
*/
class SecondRootStubRemoteEvent
{
public:
virtual ~SecondRootStubRemoteEvent() { }
};
/**
* Defines the interface that must be implemented by any class that should provide
* the service SecondRoot to remote clients.
* This class and the one above are the ones an application developer needs to have
* a look at if he wants to implement a service.
*/
class SecondRootStub
: public virtual CommonAPI::Stub<SecondRootStubAdapter, SecondRootStubRemoteEvent>
{
public:
virtual ~SecondRootStub() {}
virtual const CommonAPI::Version& getInterfaceVersion(std::shared_ptr<CommonAPI::ClientId> clientId) = 0;
virtual bool registerManagedStubLeafInterface(std::shared_ptr<LeafInterfaceStub>, const std::string&) = 0;
virtual bool deregisterManagedStubLeafInterface(const std::string&) = 0;
virtual std::set<std::string>& getLeafInterfaceInstances() = 0;
using CommonAPI::Stub<SecondRootStubAdapter, SecondRootStubRemoteEvent>::initStubAdapter;
typedef CommonAPI::Stub<SecondRootStubAdapter, SecondRootStubRemoteEvent>::StubAdapterType StubAdapterType;
typedef CommonAPI::Stub<SecondRootStubAdapter, SecondRootStubRemoteEvent>::RemoteEventHandlerType RemoteEventHandlerType;
typedef SecondRootStubRemoteEvent RemoteEventType;
typedef SecondRoot StubInterface;
};
} // namespace managed
} // namespace tests
} // namespace commonapi
} // namespace v1_0
#endif // COMMONAPI_TESTS_MANAGED_Second_Root_STUB_HPP_
|