LeechCraft  %{LEECHCRAFT_VERSION}
Modular cross-platform feature rich live environment.
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
queuemanager.h
Go to the documentation of this file.
1 /**********************************************************************
2  * LeechCraft - modular cross-platform feature rich internet client.
3  * Copyright (C) 2006-2013 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 <boost/optional.hpp>
34 #include <QObject>
35 #include <QDateTime>
36 #include <QPointer>
37 #include <QPair>
38 #include "utilconfig.h"
39 
40 namespace LeechCraft
41 {
42 namespace Util
43 {
49  class QueueManager : public QObject
50  {
51  Q_OBJECT
52 
53  const int Timeout_;
54  QDateTime LastRequest_;
55 
56  typedef boost::optional<QPointer<QObject>> OptionalTracker_t;
57  QList<QPair<std::function<void ()>, boost::optional<QPointer<QObject>>>> Queue_;
58  public:
65  UTIL_API QueueManager (int timeout, QObject *parent = 0);
66 
82  UTIL_API void Schedule (std::function<void ()> functor, QObject *dependent = 0);
83  private slots:
84  void exec ();
85  };
86 }
87 }
#define UTIL_API
Definition: utilconfig.h:37
UTIL_API void Schedule(std::function< void()> functor, QObject *dependent=0)
Adds the given functor.
A simple scheduling manager for a queue of functors.
Definition: queuemanager.h:49
UTIL_API QueueManager(int timeout, QObject *parent=0)
Creates a queue manager with the given timeout.