2019-10-24 06:36:42 -07:00
|
|
|
/*
|
|
|
|
* Copyright 2019 by its authors. See AUTHORS.
|
|
|
|
*
|
|
|
|
* Licensed under the Apache License, Version 2.0 (the "License");
|
|
|
|
* you may not use this file except in compliance with the License.
|
|
|
|
* You may obtain a copy of the License at
|
|
|
|
*
|
|
|
|
* http://www.apache.org/licenses/LICENSE-2.0
|
|
|
|
*
|
|
|
|
* Unless required by applicable law or agreed to in writing, software
|
|
|
|
* distributed under the License is distributed on an "AS IS" BASIS,
|
|
|
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
|
|
|
|
* See the License for the specific language governing permissions and
|
|
|
|
* limitations under the License.
|
|
|
|
*/
|
2014-05-02 15:52:47 -07:00
|
|
|
#ifndef EINA_CXX_EINA_INTEGER_SEQUENCE_HH
|
|
|
|
#define EINA_CXX_EINA_INTEGER_SEQUENCE_HH
|
|
|
|
|
2014-09-01 11:08:49 -07:00
|
|
|
#include <cstdlib>
|
|
|
|
|
2014-06-04 13:34:42 -07:00
|
|
|
/**
|
|
|
|
* @addtogroup Eina_Cxx_Data_Types_Group
|
|
|
|
*
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
2014-05-02 15:52:47 -07:00
|
|
|
namespace efl { namespace eina {
|
|
|
|
|
2014-06-04 13:34:42 -07:00
|
|
|
/**
|
|
|
|
* @defgroup Eina_Cxx_Integer_Sequence_Group Integer Sequence
|
|
|
|
* @ingroup Eina_Cxx_Data_Types_Group
|
|
|
|
*
|
|
|
|
* @{
|
|
|
|
*/
|
|
|
|
|
|
|
|
/**
|
|
|
|
* Compile-time sequence of integers.
|
|
|
|
*/
|
2014-05-02 15:52:47 -07:00
|
|
|
template <typename T, T... Ints>
|
|
|
|
struct integer_sequence
|
|
|
|
{
|
2014-06-04 13:34:42 -07:00
|
|
|
typedef T value_type; /**< Type of the integers. */
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @brief Get the number of elements in the sequence.
|
|
|
|
* @return <tt>std::size_t</tt> representing the sequence size.
|
|
|
|
*/
|
2014-05-02 15:52:47 -07:00
|
|
|
static constexpr std::size_t size() { return sizeof...(Ints); }
|
2014-06-04 13:34:42 -07:00
|
|
|
typedef integer_sequence<T, Ints...> type; /**< Type for the sequence instantiation. */
|
2014-05-02 15:52:47 -07:00
|
|
|
};
|
|
|
|
|
|
|
|
template<class S1, class S2> struct concat;
|
|
|
|
|
2014-06-04 13:34:42 -07:00
|
|
|
/**
|
|
|
|
* Compile-time concatenation of two integer sequences.
|
|
|
|
*/
|
2014-05-02 15:52:47 -07:00
|
|
|
template<typename T, T... I1, T... I2>
|
|
|
|
struct concat<integer_sequence<T, I1...>, integer_sequence<T, I2...> >
|
|
|
|
: integer_sequence<T, I1..., (sizeof...(I1)+I2)...> {};
|
|
|
|
|
|
|
|
template<class S1, class S2>
|
|
|
|
using Concat = typename concat<S1, S2>::type;
|
|
|
|
|
|
|
|
template<typename T, T N> struct gen_seq;
|
2014-06-04 13:34:42 -07:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Make a compile time sequence of integers from @c 0 to <tt>N-1</tt>.
|
|
|
|
*/
|
2014-05-02 15:52:47 -07:00
|
|
|
template<typename T, T N> using make_integer_sequence = typename gen_seq<T, N>::type;
|
|
|
|
|
|
|
|
template<typename T, T N>
|
|
|
|
struct gen_seq : Concat<make_integer_sequence<T, N/2>
|
|
|
|
, make_integer_sequence<T, N - N/2>>{};
|
|
|
|
|
|
|
|
template<> struct gen_seq<std::size_t, 0> : integer_sequence<std::size_t>{};
|
|
|
|
template<> struct gen_seq<std::size_t, 1> : integer_sequence<std::size_t, 0>{};
|
|
|
|
|
2014-06-04 13:34:42 -07:00
|
|
|
/**
|
|
|
|
* Compile time sequence of indexes.
|
|
|
|
*/
|
2014-05-02 15:52:47 -07:00
|
|
|
template <std::size_t... I>
|
|
|
|
using index_sequence = integer_sequence<std::size_t, I...>;
|
|
|
|
|
2014-06-04 13:34:42 -07:00
|
|
|
/**
|
|
|
|
* Make a compile time sequence of indexes from @c 0 to <tt>N-1</tt>.
|
|
|
|
*/
|
2014-05-02 15:52:47 -07:00
|
|
|
template <std::size_t I>
|
|
|
|
using make_index_sequence = make_integer_sequence<std::size_t, I>;
|
|
|
|
|
eldbus-cxx: Implementation of eldbus C++ API
Summary:
Applications can:
void method_callback(void* data, const Eldbus_Service_Interface* iface,
const Eldbus_Message* message);
struct { ... } data_struct;
Eldbus_Method methods[] =
{
"method1", ELDBUS_ARGS("b", "bool"), ELDBUS_ARGS("b", "bool"), ELDBUS_METHOD_FLAG_HAS_DATA
, (Eldbus_Method_Cb)&method_callback, &data_struct
};
And method_callback will be called with data parameter pointing to data_struct global object.
Also, Eldbus-cxx supports registering an interface passing a lambda or
function object as method. For example:
edb::service_interface iface = edb::service_interface_register
(c, path, interface
, es::method("SendStringAndBool"
, [expected_string, expected_bool] (std::string const& n, bool b
, bool* out)
{
std::cout << "Running SendStringAndBool" << std::endl;
ck_assert(n == expected_string);
ck_assert(b == expected_bool);
*out = b;
return n;
}
, es::ins<std::string, bool>("string", "bool")
, es::outs<std::string, bool>("string", "bool")
)
);
When a request for "SendStringAndBool" with the proper signature is
called, executes the lambda and replies with the return value and
its bool* out parameter value.
Reviewers: cedric, woohyun, raster
CC: savio, cedric
Differential Revision: https://phab.enlightenment.org/D1052
2014-07-03 00:28:22 -07:00
|
|
|
template <typename T, typename U>
|
|
|
|
struct pop_integer_sequence_t;
|
|
|
|
|
|
|
|
template <typename T>
|
|
|
|
struct pop_integer_sequence_t<integer_sequence<T>, integer_sequence<T> >
|
|
|
|
{
|
|
|
|
typedef integer_sequence<T> type;
|
|
|
|
};
|
|
|
|
|
|
|
|
template <typename T, T S0, T... S>
|
|
|
|
struct pop_integer_sequence_t<integer_sequence<T>, integer_sequence<T, S0, S...> >
|
|
|
|
{
|
|
|
|
typedef integer_sequence<T, S...> type;
|
|
|
|
};
|
|
|
|
|
|
|
|
template <typename T, T S0, T... S>
|
|
|
|
struct pop_integer_sequence_t<integer_sequence<T, S0, S...>, integer_sequence<T> >
|
|
|
|
{
|
|
|
|
typedef integer_sequence<T> type;
|
|
|
|
};
|
|
|
|
|
|
|
|
template <typename T, T S, T... Ss1, T... Ss2>
|
|
|
|
struct pop_integer_sequence_t<integer_sequence<T, S, Ss1...>, integer_sequence<T, S, Ss2...> >
|
|
|
|
: pop_integer_sequence_t<integer_sequence<T, Ss1...>, integer_sequence<T, Ss2...> >
|
|
|
|
{
|
|
|
|
};
|
|
|
|
|
|
|
|
template <typename T, typename U>
|
|
|
|
using pop_integer_sequence = typename pop_integer_sequence_t<T, U>::type;
|
|
|
|
|
2014-06-04 13:34:42 -07:00
|
|
|
/**
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
2014-05-02 15:52:47 -07:00
|
|
|
} }
|
|
|
|
|
2014-06-04 13:34:42 -07:00
|
|
|
/**
|
|
|
|
* @}
|
|
|
|
*/
|
|
|
|
|
2014-05-02 15:52:47 -07:00
|
|
|
#endif
|