/
abstractchain.h
100 lines (82 loc) · 2.77 KB
/
abstractchain.h
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
/**
@file abstractchain.h
@brief Base class for sensor chains
<p>
Copyright (C) 2009-2010 Nokia Corporation
@author Timo Rongas <ext-timo.2.rongas@nokia.com>
@author Antti Virtanen <antti.i.virtanen@nokia.com>
This file is part of Sensord.
Sensord is free software; you can redistribute it and/or modify
it under the terms of the GNU Lesser General Public License
version 2.1 as published by the Free Software Foundation.
Sensord is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public
License along with Sensord. If not, see <http://www.gnu.org/licenses/>.
</p>
*/
#ifndef ABSTRACT_CHAIN_H
#define ABSTRACT_CHAIN_H
#include <QMap>
#include "ringbuffer.h"
#include "abstractsensor.h"
/**
* AbstractChain is a container for filterchain ending in one or more named buffers.
* It allows sharing of commmon processing easily, without having to rewrite
* or recalculate filterchains.
*
* Due to the idea that processing should be shared, each chain is a chain
* from HW to processed data. It is not possible to change inputs, as that
* would make sharing difficult.
*/
class AbstractChain : public AbstractSensorChannel
{
Q_OBJECT
Q_DISABLE_COPY(AbstractChain)
public:
/**
* Destructor
*/
virtual ~AbstractChain();
/**
* Locate a named end buffer of the chain. Buffer names \em should be
* available from documentation of the given chain.
*
* @param name Name of the buffer.
* @return Pointer to the buffer. If named buffer is not found
* NULL is returned.
*/
RingBufferBase* findBuffer(const QString& name) const;
/**
* List of available buffers.
*
* @return available buffers.
*/
const QMap<QString, RingBufferBase*>& buffers() const;
protected:
/**
* Constructor.
*
* @param id identifier of the chain.
* @param deleteBuffers delete attached buffers automatically when
* chain is deleted.
*/
AbstractChain(const QString& id, bool deleteBuffers = false);
/**
* Attach buffer with given name.
*
* @param name Name of the buffer.
* @param buffer Pointer to buffer.
*/
void nameOutputBuffer(const QString& name, RingBufferBase* buffer);
private:
QMap<QString, RingBufferBase*> outputBufferMap_; /**< buffers */
const bool deleteBuffers_; /**< are buffers deleted automatically */
};
/**
* Factory type for constructing chain.
*/
typedef AbstractChain* (*ChainFactoryMethod)(const QString& id);
#endif // ABSTRACT_CHAIN_H