Line data Source code
1 :
2 : /* Copyright (c) 2013-2014, Stefan.Eilemann@epfl.ch
3 : *
4 : * This library is free software; you can redistribute it and/or modify it under
5 : * the terms of the GNU Lesser General Public License version 2.1 as published
6 : * by the Free Software Foundation.
7 : *
8 : * This library is distributed in the hope that it will be useful, but WITHOUT
9 : * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS
10 : * FOR A PARTICULAR PURPOSE. See the GNU Lesser General Public License for more
11 : * details.
12 : *
13 : * You should have received a copy of the GNU Lesser General Public License
14 : * along with this library; if not, write to the Free Software Foundation, Inc.,
15 : * 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
16 : */
17 :
18 : #ifndef LUNCHBOX_READYFUTURE_H
19 : #define LUNCHBOX_READYFUTURE_H
20 :
21 : #include <lunchbox/future.h> // base class
22 :
23 : namespace lunchbox
24 : {
25 :
26 : /** A boolean future with a known value. Fully thread safe. */
27 6000006 : template< bool value > class FutureBool : public FutureImpl< bool >
28 : {
29 : protected:
30 2 : bool wait( const uint32_t ) final { return value; }
31 2 : bool isReady() const final { return true; }
32 : };
33 :
34 : /** @return a boolean future being true. */
35 2000001 : inline Future< bool > makeTrueFuture()
36 2000001 : { return Future< bool >( new FutureBool< true >); }
37 :
38 : /** @return a boolean future being false. */
39 1 : inline Future< bool > makeFalseFuture()
40 1 : { return Future< bool >( new FutureBool< false >); }
41 :
42 : }
43 : #endif //LUNCHBOX_READYFUTURE_H
|