ledger-core
algorithm.h
1 /*
2  *
3  * algorithm
4  * ledger-core
5  *
6  * Created by Pierre Pollastri on 25/07/2017.
7  *
8  * The MIT License (MIT)
9  *
10  * Copyright (c) 2016 Ledger
11  *
12  * Permission is hereby granted, free of charge, to any person obtaining a copy
13  * of this software and associated documentation files (the "Software"), to deal
14  * in the Software without restriction, including without limitation the rights
15  * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
16  * copies of the Software, and to permit persons to whom the Software is
17  * furnished to do so, subject to the following conditions:
18  *
19  * The above copyright notice and this permission notice shall be included in all
20  * copies or substantial portions of the Software.
21  *
22  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
23  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
24  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
25  * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
26  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
27  * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
28  * SOFTWARE.
29  *
30  */
31 #ifndef LEDGER_CORE_ALGORITHM_H
32 #define LEDGER_CORE_ALGORITHM_H
33 
34 #include "Future.hpp"
35 #include <utils/ImmediateExecutionContext.hpp>
36 
37 namespace ledger {
38  namespace core {
39  namespace async {
40 
41  namespace internals {
42 
43  template <class T>
44  Future<Unit> sequence_go(const std::shared_ptr<api::ExecutionContext>& context, int index, const std::vector< Future<T> >& futures, std::vector<T>* buffer) {
45  if (index >= futures.size())
46  return Future<Unit>::successful(unit);
47  else {
48  Future<T> fut = futures[index];
49  return fut.template flatMap<Unit>(context, [context, buffer, index, futures](const T &r) -> Future<Unit> {
50  buffer->push_back(r);
51  return sequence_go(context, index + 1, futures, buffer);
52  });
53  }
54  }
55 
56 }
57 
58  template <class T>
59  Future< std::vector<T> > sequence(const std::shared_ptr<api::ExecutionContext>& context, const std::vector< Future<T> >& futures) {
60  auto buffer = new std::vector<T>();
61  return internals::sequence_go<T>(context, 0, futures, buffer).template map< std::vector<T> >(context, [buffer] (const Unit&) -> std::vector<T> {
62  auto res = *buffer;
63  delete buffer;
64  return res;
65  });
66  }
67 
68  }
69  }
70 }
71 
72 #define BEGIN_ASYNC_WHILE()
73 
74 #define ASYNC_FOREACH()
75 
76 #endif //LEDGER_CORE_ALGORITHM_H
Definition: Account.cpp:8