blob: 771a09cbe4d1c73adf42c7fc4713c25fa46690bd (
plain) (
blame)
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
|
/*
SPDX-FileCopyrightText: 2014-2015 Harald Sitter <sitter@kde.org>
SPDX-License-Identifier: LGPL-2.1-only OR LGPL-3.0-only OR LicenseRef-KDE-Accepted-LGPL
*/
#ifndef OPERATION_H
#define OPERATION_H
#include <pulse/operation.h>
namespace PulseAudioQt
{
/**
* @brief The PAOperation class
* Helps with management of pa_operations. pa_operations need to be expicitly
* unref'd after use, so this class is essentially a fancy scoping helper where
* destruction of an instance would also unref the held operation (if there is
* one).
*/
class PAOperation
{
public:
/**
* @brief PAOperation
* @param operation operation to manage the scope of
*/
PAOperation(pa_operation *operation = nullptr);
~PAOperation();
PAOperation &operator=(pa_operation *operation);
/**
* @brief operator !
* @return whether or not there is an operation pointer
*/
bool operator!();
/**
* @brief operator bool representing whether there is an operation
*/
operator bool();
/**
* @brief operator *
* @return pointer to internal pa_operation object
*/
pa_operation *&operator*();
private:
pa_operation *m_operation;
};
} // PulseAudioQt
#endif // OPERATION_H
|