Gaudi::Functional::details Namespace Reference

Namespaces

 detail2
 
 details2
 
 zip
 

Classes

class  DataHandleMixin
 
class  DataHandleMixin< std::tuple< Out... >, std::tuple< In... >, Traits_ >
 
class  DataHandleMixin< std::tuple< Out... >, void, Traits_ >
 
class  DataHandleMixin< void, std::tuple< In... >, Traits_ >
 
struct  deref_t
 
struct  insert_t
 
struct  is_optional
 
struct  is_optional< boost::optional< T > >
 
class  vector_of_const_
 

Typedefs

template<typename T >
using remove_optional_t = typename details2::remove_optional< T >::type
 
template<typename Default , template< typename... > class Op, typename... Args>
using detected_or_t = typename detail2::detector< Default, void, Op, Args... >::type
 
template<template< typename... > class Default, template< typename... > class Op, typename Tr , typename T >
using detected_or_t_ = detected_or_t< Default< Tr, T >, Op, Tr, T >
 
template<typename Tr >
using BaseClass_t = detected_or_t< GaudiAlgorithm, detail2::BaseClass_, Tr >
 
template<typename Tr , typename T >
using OutputHandle_t = detected_or_t_< detail2::defaultHandle_, detail2::OutputHandle_, Tr, T >
 
template<typename Tr , typename T >
using InputHandle_t = detected_or_t_< detail2::defaultHandle_, detail2::InputHandle_, Tr, T >
 

Functions

template<typename T >
constexpr std::add_const< T >::type & as_const (T &t) noexcept
 
template<typename T >
void as_const (T &&t)=delete
 
template<typename Out1 , typename Out2 , typename = typename std::enable_if<std::is_constructible<Out1,Out2>::value>::type>
Out1 * put (DataObjectHandle< Out1 > &out_handle, Out2 &&out)
 
template<typename Out1 , typename Out2 , typename = typename std::enable_if<std::is_constructible<Out1,Out2>::value>::type>
void put (AnyDataHandle< Out1 > &out_handle, Out2 &&out)
 
template<typename OutHandle , typename Out >
void put (OutHandle &out_handle, boost::optional< Out > &&out)
 
template<typename Tuple , typename KeyValues >
Tuple make_tuple_of_handles (IDataHandleHolder *owner, const KeyValues &initvalue, Gaudi::DataHandle::Mode mode)
 
template<typename KeyValues , typename Properties >
void declare_tuple_of_properties (GaudiAlgorithm *owner, const KeyValues &inputs, Properties &props)
 
template<typename Handles >
Handles make_vector_of_handles (IDataHandleHolder *owner, const std::vector< std::string > &init, Gaudi::DataHandle::Mode mode)
 
template<typename Fun , typename Container , typename... Args>
constexpr void apply (const Fun &, Container &, Args...)
 
template<typename Fun , typename Container >
auto apply (const Fun &fun, Container &c) -> decltype(fun(c), void())
 

Variables

constexpr struct Gaudi::Functional::details::insert_t insert
 
constexpr struct Gaudi::Functional::details::deref_t deref
 

Typedef Documentation

template<typename Tr >
using Gaudi::Functional::details::BaseClass_t = typedef detected_or_t< GaudiAlgorithm, detail2::BaseClass_, Tr >

Definition at line 263 of file FunctionalDetails.h.

template<typename Default , template< typename... > class Op, typename... Args>
using Gaudi::Functional::details::detected_or_t = typedef typename detail2::detector<Default, void, Op, Args...>::type

Definition at line 241 of file FunctionalDetails.h.

template<template< typename... > class Default, template< typename... > class Op, typename Tr , typename T >
using Gaudi::Functional::details::detected_or_t_ = typedef detected_or_t<Default<Tr, T>, Op, Tr, T>

Definition at line 247 of file FunctionalDetails.h.

template<typename Tr , typename T >
using Gaudi::Functional::details::InputHandle_t = typedef detected_or_t_< detail2::defaultHandle_, detail2::InputHandle_, Tr, T>

Definition at line 269 of file FunctionalDetails.h.

template<typename Tr , typename T >
using Gaudi::Functional::details::OutputHandle_t = typedef detected_or_t_< detail2::defaultHandle_, detail2::OutputHandle_, Tr, T>

Definition at line 268 of file FunctionalDetails.h.

template<typename T >
using Gaudi::Functional::details::remove_optional_t = typedef typename details2::remove_optional<T>::type

Definition at line 145 of file FunctionalDetails.h.

Function Documentation

template<typename Fun , typename Container , typename... Args>
constexpr void Gaudi::Functional::details::apply ( const Fun &  ,
Container &  ,
Args...   
)

Definition at line 444 of file FunctionalDetails.h.

445  { static_assert(sizeof...(Args)==0,"Args should not be used!");}
template<typename Fun , typename Container >
auto Gaudi::Functional::details::apply ( const Fun &  fun,
Container &  c 
) -> decltype(fun(c),void())

Definition at line 449 of file FunctionalDetails.h.

450  { fun(c); }
double fun(const std::vector< double > &x)
Definition: PFuncTest.cpp:26
template<typename T >
constexpr std::add_const<T>::type& Gaudi::Functional::details::as_const ( T &  t)
noexcept

Definition at line 77 of file FunctionalDetails.h.

78  { return t; }
template<typename T >
void Gaudi::Functional::details::as_const ( T &&  t)
delete
template<typename KeyValues , typename Properties >
void Gaudi::Functional::details::declare_tuple_of_properties ( GaudiAlgorithm owner,
const KeyValues inputs,
Properties props 
)

Definition at line 299 of file FunctionalDetails.h.

299  {
300  static_assert( std::tuple_size<KeyValues>::value == std::tuple_size<Properties>::value, "Inconsistent lengths" );
301  constexpr auto N = std::tuple_size<KeyValues>::value;
302  details2::declare_tuple_of_properties_helper( owner, inputs, props, std::make_index_sequence<N>{} );
303  }
void declare_tuple_of_properties_helper(GaudiAlgorithm *owner, const KeyValues &inputs, Properties &props, std::index_sequence< I... >)
int N
Definition: IOTest.py:90
template<typename Tuple , typename KeyValues >
Tuple Gaudi::Functional::details::make_tuple_of_handles ( IDataHandleHolder owner,
const KeyValues initvalue,
Gaudi::DataHandle::Mode  mode 
)

Definition at line 294 of file FunctionalDetails.h.

294  {
295  return details2::make_tuple_of_handles_helper<Tuple>( owner, initvalue, mode, std::make_index_sequence<std::tuple_size<Tuple>::value>{} );
296  }
template<typename Handles >
Handles Gaudi::Functional::details::make_vector_of_handles ( IDataHandleHolder owner,
const std::vector< std::string > &  init,
Gaudi::DataHandle::Mode  mode 
)

Definition at line 306 of file FunctionalDetails.h.

306  {
307  Handles handles; handles.reserve(init.size());
308  std::transform( init.begin(), init.end(), std::back_inserter(handles),
309  [&](const std::string& loc) -> typename Handles::value_type
310  { return {loc,mode, owner}; });
311  return handles;
312  }
T end(T...args)
STL class.
T size(T...args)
T begin(T...args)
T back_inserter(T...args)
T transform(T...args)
template<typename Out1 , typename Out2 , typename = typename std::enable_if<std::is_constructible<Out1,Out2>::value>::type>
Out1* Gaudi::Functional::details::put ( DataObjectHandle< Out1 > &  out_handle,
Out2 &&  out 
)

Definition at line 87 of file FunctionalDetails.h.

87  {
88  return out_handle.put( new Out1( std::forward<Out2>(out) ) );
89  }
T * put(T *object)
Register object in transient store.
template<typename Out1 , typename Out2 , typename = typename std::enable_if<std::is_constructible<Out1,Out2>::value>::type>
void Gaudi::Functional::details::put ( AnyDataHandle< Out1 > &  out_handle,
Out2 &&  out 
)

Definition at line 93 of file FunctionalDetails.h.

93  {
94  out_handle.put( std::forward<Out2>(out) );
95  }
const T * put(T &&object)
Register object in transient store.
Definition: AnyDataHandle.h:41
template<typename OutHandle , typename Out >
void Gaudi::Functional::details::put ( OutHandle &  out_handle,
boost::optional< Out > &&  out 
)

Definition at line 99 of file FunctionalDetails.h.

99  {
100  if (out) put(out_handle,std::move(*out));
101  }
T move(T...args)
void put(OutHandle &out_handle, boost::optional< Out > &&out)

Variable Documentation

constexpr struct Gaudi::Functional::details::deref_t Gaudi::Functional::details::deref
constexpr struct Gaudi::Functional::details::insert_t Gaudi::Functional::details::insert