blob: 7789e5de6d0a8a43e1efe2ec2591d4dd64b57b5f (
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
|
/*
* This file was generated by the CommonAPI Generators.
* Used org.genivi.commonapi.core 2.1.3.qualifier.
* Used org.franca.core 0.8.10.201309262002.
*
* 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_H_
#define COMMONAPI_TESTS_MANAGED_Second_Root_STUB_H_
#include <commonapi/tests/managed/LeafInterfaceStub.h>
#include "SecondRoot.h"
#if !defined (COMMONAPI_INTERNAL_COMPILATION)
#define COMMONAPI_INTERNAL_COMPILATION
#endif
#include <CommonAPI/Stub.h>
#undef COMMONAPI_INTERNAL_COMPILATION
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 CommonAPI::Stub<SecondRootStubAdapter , SecondRootStubRemoteEvent> {
public:
virtual ~SecondRootStub() { }
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;
};
} // namespace managed
} // namespace tests
} // namespace commonapi
#endif // COMMONAPI_TESTS_MANAGED_Second_Root_STUB_H_
|