mirror of
https://github.com/Naios/continuable.git
synced 2025-12-06 16:56:44 +08:00
Move the new remapping functionality to its own header
This commit is contained in:
parent
b3a4a3d359
commit
b1d7a76c8f
@ -1,4 +1,12 @@
|
|||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
||||||
|
/~` _ _ _|_. _ _ |_ | _
|
||||||
|
\_,(_)| | | || ||_|(_||_)|(/_
|
||||||
|
|
||||||
|
https://github.com/Naios/continuable
|
||||||
|
v3.0.0
|
||||||
|
|
||||||
Copyright(c) 2015 - 2018 Denis Blank <denis.blank at outlook dot com>
|
Copyright(c) 2015 - 2018 Denis Blank <denis.blank at outlook dot com>
|
||||||
|
|
||||||
Permission is hereby granted, free of charge, to any person obtaining a copy
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
||||||
@ -20,31 +28,31 @@
|
|||||||
SOFTWARE.
|
SOFTWARE.
|
||||||
**/
|
**/
|
||||||
|
|
||||||
|
#ifndef CONTINUABLE_DETAIL_COMPOSITION_REMAPPING_HPP_INCLUDED
|
||||||
|
#define CONTINUABLE_DETAIL_COMPOSITION_REMAPPING_HPP_INCLUDED
|
||||||
|
|
||||||
#include <tuple>
|
#include <tuple>
|
||||||
|
#include <type_traits>
|
||||||
|
#include <utility>
|
||||||
|
|
||||||
#include <continuable/continuable-traverse.hpp>
|
#include <continuable/continuable-traverse.hpp>
|
||||||
#include <continuable/detail/base.hpp>
|
#include <continuable/detail/base.hpp>
|
||||||
#include <continuable/detail/container-category.hpp>
|
#include <continuable/detail/container-category.hpp>
|
||||||
#include <continuable/detail/traits.hpp>
|
#include <continuable/detail/traits.hpp>
|
||||||
|
|
||||||
// Devel
|
|
||||||
#include <continuable/continuable-base.hpp>
|
|
||||||
#include <vector>
|
|
||||||
|
|
||||||
namespace cti {
|
namespace cti {
|
||||||
namespace detail {
|
namespace detail {
|
||||||
|
namespace composition {
|
||||||
/// This namespace provides utilities for performing compound
|
/// This namespace provides utilities for performing compound
|
||||||
/// connections between deeply nested continuables and values.
|
/// connections between deeply nested continuables and values.
|
||||||
///
|
///
|
||||||
/// 0. We create the result pack from the provides values and
|
/// We create the result pack from the provides values and
|
||||||
/// the async values if those are default constructible,
|
/// the async values if those are default constructible,
|
||||||
/// otherwise use a lazy initialization wrapper and unwrap
|
/// otherwise use a lazy initialization wrapper and unwrap
|
||||||
/// the whole pack when the composition is finished.
|
/// the whole pack when the composition is finished.
|
||||||
/// - value -> value
|
/// - value -> value
|
||||||
/// - single async value -> single value
|
/// - single async value -> single value
|
||||||
/// - multiple async value -> tuple of async values.
|
/// - multiple async value -> tuple of async values.
|
||||||
///
|
|
||||||
/// 1.
|
|
||||||
namespace remapping {
|
namespace remapping {
|
||||||
// Guard object for representing void results
|
// Guard object for representing void results
|
||||||
struct void_result_guard {};
|
struct void_result_guard {};
|
||||||
@ -221,25 +229,15 @@ struct index_relocator {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
} // namespace remapping
|
} // namespace remapping
|
||||||
|
} // namespace composition
|
||||||
} // namespace detail
|
} // namespace detail
|
||||||
} // namespace cti
|
} // namespace cti
|
||||||
|
|
||||||
int main(int, char**) {
|
// auto p = std::make_tuple(cti::make_ready_continuable(0) /*, 0, 4,
|
||||||
|
// std::make_tuple(1, 2), cti::make_ready_continuable(0)*/);
|
||||||
|
|
||||||
using namespace cti::detail;
|
// auto r = create_result_pack(std::move(p));
|
||||||
using namespace remapping;
|
// auto i = create_index_pack(std::move(p));
|
||||||
|
// relocate_index_pack(index_relocator{}, &i, &r);
|
||||||
|
|
||||||
std::vector<int> vc{1, 2, 3};
|
#endif // CONTINUABLE_DETAIL_COMPOSITION_REMAPPING_HPP_INCLUDED
|
||||||
|
|
||||||
// std::tuple<c, c, c> t;
|
|
||||||
// std::tuple<loc<c, ct<0>>, c, c> loc;
|
|
||||||
|
|
||||||
auto p = std::make_tuple(cti::make_ready_continuable(0) /*, 0, 4,
|
|
||||||
std::make_tuple(1, 2), cti::make_ready_continuable(0)*/);
|
|
||||||
|
|
||||||
auto r = create_result_pack(std::move(p));
|
|
||||||
auto i = create_index_pack(std::move(p));
|
|
||||||
relocate_index_pack(index_relocator{}, &i, &r);
|
|
||||||
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
@ -4,8 +4,7 @@ file(GLOB LIB_SOURCES ${INCLUDE_DIR}/*.hpp)
|
|||||||
file(GLOB_RECURSE LIB_SOURCES_DETAIL ${INCLUDE_DIR}/detail/*.hpp)
|
file(GLOB_RECURSE LIB_SOURCES_DETAIL ${INCLUDE_DIR}/detail/*.hpp)
|
||||||
|
|
||||||
set(TEST
|
set(TEST
|
||||||
${CMAKE_CURRENT_LIST_DIR}/test-playground.cpp
|
${CMAKE_CURRENT_LIST_DIR}/test-playground.cpp)
|
||||||
${CMAKE_CURRENT_LIST_DIR}/comp.cpp)
|
|
||||||
|
|
||||||
add_executable(test-playground
|
add_executable(test-playground
|
||||||
${LIB_SOURCES}
|
${LIB_SOURCES}
|
||||||
|
|||||||
@ -68,7 +68,7 @@ struct my_callable {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
void some_requests() {
|
int main(int, char**) {
|
||||||
http_request("github.com").next(my_callable{});
|
http_request("github.com").next(my_callable{});
|
||||||
|
|
||||||
http_request("github.com") | [](std::string) {
|
http_request("github.com") | [](std::string) {
|
||||||
|
|||||||
Loading…
x
Reference in New Issue
Block a user