LeechCraft
0.6.70-13605-g8cd066ad6a
Modular cross-platform feature rich live environment.
monadicfuture.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 <QFuture>
33
#include <
util/sll/functor.h
>
34
#include <
util/sll/monad.h
>
35
#include "
futures.h
"
36
37
namespace
LC
38
{
39
namespace
Util
40
{
41
template
<
typename
T>
42
struct
InstanceFunctor<
QFuture
<T>>
43
{
44
template
<
typename
F>
45
using
FmapResult_t
=
QFuture
<std::decay_t<std::result_of_t<F (T)>>>;
46
47
template
<
typename
F>
48
static
FmapResult_t<F>
Apply
(
const
QFuture<T>
& fut,
const
F& func)
49
{
50
return
Sequence (
nullptr
, fut) >>
51
[func] (
const
T& val) {
return
MakeReadyFuture (func (val)); };
52
}
53
};
54
}
55
}
LC::Util::InstanceFunctor::FmapResult_t
detail::ImplementationType FmapResult_t
The type of the functor after its elements were mapped by the function F.
Definition:
functor.h:148
LC::Util::InstanceFunctor::Apply
static FmapResult_t< F > Apply(const T &functor, const F &function)
Applies the function to the each of the elements inside the functor.
futures.h
monad.h
LC
Definition:
constants.h:34
QFuture
Definition:
idownload.h:39
functor.h
src
util
threads
monadicfuture.h
Generated by
1.8.16