LeechCraft
0.6.70-13605-g8cd066ad6a
Modular cross-platform feature rich live environment.
notificationactionhandler.h
Go to the documentation of this file.
1
/**********************************************************************
2
* LeechCraft - modular cross-platform feature rich internet client.
3
* Copyright (C) 2006-2014 Georg Rudoy
4
*
5
* Boost Software License - Version 1.0 - August 17th, 2003
6
*
7
* Permission is hereby granted, free of charge, to any person or organization
8
* obtaining a copy of the software and accompanying documentation covered by
9
* this license (the "Software") to use, reproduce, display, distribute,
10
* execute, and transmit the Software, and to prepare derivative works of the
11
* Software, and to permit third-parties to whom the Software is furnished to
12
* do so, all subject to the following:
13
*
14
* The copyright notices in the Software and this entire statement, including
15
* the above license grant, this restriction and the following disclaimer,
16
* must be included in all copies of the Software, in whole or in part, and
17
* all derivative works of the Software, unless such copies or derivative
18
* works are solely in the form of machine-executable object code generated by
19
* a source language processor.
20
*
21
* THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
22
* IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
23
* FITNESS FOR A PARTICULAR PURPOSE, TITLE AND NON-INFRINGEMENT. IN NO EVENT
24
* SHALL THE COPYRIGHT HOLDERS OR ANYONE DISTRIBUTING THE SOFTWARE BE LIABLE
25
* FOR ANY DAMAGES OR OTHER LIABILITY, WHETHER IN CONTRACT, TORT OR OTHERWISE,
26
* ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER
27
* DEALINGS IN THE SOFTWARE.
28
**********************************************************************/
29
30
#pragma once
31
32
#include <functional>
33
#include <QObject>
34
#include <
interfaces/structures.h
>
35
#include "
xpcconfig.h
"
36
37
namespace
LC
38
{
39
namespace
Util
40
{
73
class
NotificationActionHandler :
public
QObject
74
{
75
Q_OBJECT
76
77
Entity& Entity_;
78
public
:
81
typedef
std::function<void ()>
Callback_t
;
82
private
:
83
QList<QPair<QString, Callback_t>
> ActionName2Callback_;
84
85
QList<QPointer<QObject>
> DependentObjects_;
86
public
:
93
UTIL_XPC_API
NotificationActionHandler
(Entity& entity, QObject* = 0);
94
105
UTIL_XPC_API
void
AddFunction
(
const
QString& name,
Callback_t
action);
106
111
UTIL_XPC_API
void
AddDependentObject
(QObject *
object
);
112
public
slots:
113
void
notificationActionTriggered
(
int
);
114
};
115
}
116
}
QList
Definition:
ianrulesstorage.h:34
LC::Util::NotificationActionHandler::AddDependentObject
UTIL_XPC_API void AddDependentObject(QObject *object)
Adds an object as a dependent object.
Definition:
notificationactionhandler.cpp:102
xpcconfig.h
structures.h
LC::Util::NotificationActionHandler::notificationActionTriggered
void notificationActionTriggered(int)
Definition:
notificationactionhandler.cpp:107
LC::Util::NotificationActionHandler::Callback_t
std::function< void()> Callback_t
Type of functions used as actions in the handler.
Definition:
notificationactionhandler.h:158
LC::Util::NotificationActionHandler::AddFunction
UTIL_XPC_API void AddFunction(const QString &name, Callback_t action)
Adds an action with the given name.
Definition:
notificationactionhandler.cpp:95
LC::Util::NotificationActionHandler::NotificationActionHandler
UTIL_XPC_API NotificationActionHandler(Entity &entity, QObject *=0)
Creates the handler on the given entity.
Definition:
notificationactionhandler.cpp:89
LC
Definition:
constants.h:34
UTIL_XPC_API
#define UTIL_XPC_API
Definition:
xpcconfig.h:36
src
util
xpc
notificationactionhandler.h
Generated by
1.8.16