The Gaudi Framework  v36r4 (0a924e98)
Gaudi::Functional::details Namespace Reference

Namespaces

 detail2
 
 details2
 
 zip
 

Classes

struct  Consumer
 
struct  Consumer< void(const In &...), Traits_, false >
 
struct  Consumer< void(const In &...), Traits_, true >
 
class  DataHandleMixin
 
class  DataHandleMixin< std::tuple< Out... >, std::tuple< In... >, Traits_ >
 
class  DataHandleMixin< std::tuple< Out... >, std::tuple<>, Traits_ >
 
class  DataHandleMixin< std::tuple< void >, std::tuple<>, Traits_ >
 
class  DataHandleMixin< std::tuple<>, std::tuple< In... >, Traits_ >
 
class  DataHandleMixin< std::tuple<>, std::tuple<>, Traits_ >
 
struct  deref_t
 
struct  filter_evtcontext_t
 
struct  filter_evtcontext_t< EventContext, In... >
 
struct  FilterPredicate
 
struct  FilterPredicate< bool(const In &...), Traits_, false >
 
struct  FilterPredicate< bool(const In &...), Traits_, true >
 
struct  insert_t
 
struct  invoke_optionally_t
 
struct  is_void_fun
 
struct  is_void_fun< void(Args...)>
 
struct  MergingTransformer
 
struct  MergingTransformer< Out(const vector_of_const_< In > &), Traits_, true >
 
struct  MergingTransformer< Out(const vector_of_const_< Ins > &...), Traits_, false >
 
struct  Producer
 
class  SplittingTransformer
 
class  SplittingTransformer< vector_of_< Out >(const In &...), Traits_, false >
 
class  SplittingTransformer< vector_of_< Out >(const In &...), Traits_, true >
 
class  ToolBinder
 
class  ToolBinder< Gaudi::Interface::Bind::Box< IFace >(Args const &...), Traits >
 
class  vector_of_const_
 

Typedefs

template<typename Arg >
using require_is_optional = std::enable_if_t< is_optional_v< Arg > >
 
template<typename Arg >
using require_is_not_optional = std::enable_if_t<!is_optional_v< Arg > >
 
template<typename T >
using remove_optional_t = std::conditional_t< is_optional_v< T >, typename T::value_type, T >
 
template<typename Value , auto N>
using RepeatValues_ = decltype(get_values_helper< Value >(std::make_index_sequence< N >()))
 
template<typename Tr , typename Base = GaudiAlgorithm>
using BaseClass_t = Gaudi::cpp17::detected_or_t< Base, detail2::BaseClass_t, Tr >
 
template<typename Tr , typename T >
using OutputHandle_t = Gaudi::cpp17::detected_or_t< DataObjectWriteHandle< T >, detail2::OutputHandle_t, Tr, T >
 
template<typename Tr , typename T >
using InputHandle_t = Gaudi::cpp17::detected_or_t< detail2::DefaultInputHandle< T >, detail2::InputHandle_t, Tr, T >
 
template<typename... In>
using filter_evtcontext = typename filter_evtcontext_t< In... >::type
 
template<typename Tr , typename Base = FixTESPath<AlgTool>>
using add_base_t = std::conditional_t< Gaudi::cpp17::is_detected_v< detail2::BaseClass_t, Tr >, Tr, Traits::use_< Tr, BaseClass_t< Base > >>
 

Functions

std::vector< DataObjIDto_DataObjID (const std::vector< std::string > &in)
 
template<typename Value , std::size_t... I>
auto get_values_helper (std::index_sequence< I... >)
 
template<typename Out1 , typename Out2 , typename = std::enable_if_t<std::is_constructible_v<Out1, Out2> && std::is_base_of_v<DataObject, Out1>>>
auto put (const DataObjectHandle< Out1 > &out_handle, Out2 &&out)
 
template<typename Out1 , typename Out2 , typename = std::enable_if_t<std::is_constructible_v<Out1, Out2>>>
auto put (const DataObjectHandle< AnyDataWrapper< Out1 >> &out_handle, Out2 &&out)
 
template<typename OutHandle , typename OptOut , typename = require_is_optional<OptOut>>
void put (const OutHandle &out_handle, OptOut &&out)
 
template<typename Handles >
Handles make_vector_of_handles (IDataHandleHolder *owner, const std::vector< DataObjID > &init)
 
template<typename Handle , typename Algo >
auto get (const Handle &handle, const Algo &, const EventContext &) -> decltype(details::deref(handle.get()))
 
template<typename IFace , typename Algo >
auto get (const ToolHandle< Gaudi::Interface::Bind::IBinder< IFace >> &handle, const Algo &, const EventContext &ctx)
 
template<typename Handle >
auto getKey (const Handle &h) -> decltype(h.objKey())
 
template<typename Out , typename In , typename Tr >
void updateHandleLocation (DataHandleMixin< Out, In, Tr > &parent, const std::string &prop, const std::string &newLoc)
 
template<typename Out , typename In , typename Tr >
void updateHandleLocations (DataHandleMixin< Out, In, Tr > &parent, const std::string &prop, const std::vector< std::string > &newLocs)
 
template<typename Fun , typename Container , typename... Args>
constexpr void applyPostProcessing (const Fun &, Container &, Args...)
 
template<typename Fun , typename Container >
auto applyPostProcessing (const Fun &fun, Container &c) -> decltype(fun.postprocess(c), void())
 
template<typename F , size_t... Is>
auto for_impl (F &&f, std::index_sequence< Is... >)
 
template<auto N, typename F >
decltype(auto) for_ (F &&f)
 

Variables

template<typename Arg >
constexpr bool is_optional_v = Gaudi::cpp17::is_detected_v<details2::is_optional_, Arg>
 
constexpr struct Gaudi::Functional::details::invoke_optionally_t invoke_optionally
 
constexpr struct Gaudi::Functional::details::insert_t insert
 
constexpr struct Gaudi::Functional::details::deref_t deref
 
template<typename Traits >
constexpr bool isLegacy
 
template<typename Sig >
constexpr bool is_void_fun_v = is_void_fun<Sig>::value
 

Typedef Documentation

◆ add_base_t

template<typename Tr , typename Base = FixTESPath<AlgTool>>
using Gaudi::Functional::details::add_base_t = typedef std::conditional_t<Gaudi::cpp17::is_detected_v<detail2::BaseClass_t, Tr>, Tr, Traits::use_<Tr, BaseClass_t<Base> >>

Definition at line 20 of file FunctionalTool.h.

◆ BaseClass_t

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

Definition at line 395 of file FunctionalDetails.h.

◆ filter_evtcontext

template<typename... In>
using Gaudi::Functional::details::filter_evtcontext = typedef typename filter_evtcontext_t<In...>::type

Definition at line 482 of file FunctionalDetails.h.

◆ InputHandle_t

Definition at line 404 of file FunctionalDetails.h.

◆ OutputHandle_t

Definition at line 402 of file FunctionalDetails.h.

◆ remove_optional_t

template<typename T >
using Gaudi::Functional::details::remove_optional_t = typedef std::conditional_t<is_optional_v<T>, typename T::value_type, T>

Definition at line 144 of file FunctionalDetails.h.

◆ RepeatValues_

template<typename Value , auto N>
using Gaudi::Functional::details::RepeatValues_ = typedef decltype( get_values_helper<Value>( std::make_index_sequence<N>() ) )

Definition at line 164 of file FunctionalDetails.h.

◆ require_is_not_optional

template<typename Arg >
using Gaudi::Functional::details::require_is_not_optional = typedef std::enable_if_t<!is_optional_v<Arg> >

Definition at line 141 of file FunctionalDetails.h.

◆ require_is_optional

template<typename Arg >
using Gaudi::Functional::details::require_is_optional = typedef std::enable_if_t<is_optional_v<Arg> >

Definition at line 138 of file FunctionalDetails.h.

Function Documentation

◆ applyPostProcessing() [1/2]

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

Definition at line 680 of file FunctionalDetails.h.

680  {
681  static_assert( sizeof...( Args ) == 0, "Args should not be used!" );
682  }

◆ applyPostProcessing() [2/2]

template<typename Fun , typename Container >
auto Gaudi::Functional::details::applyPostProcessing ( const Fun &  fun,
Container &  c 
) -> decltype( fun.postprocess( c ), void() )

Definition at line 685 of file FunctionalDetails.h.

685  {
686  fun.postprocess( c );
687  }

◆ for_()

template<auto N, typename F >
decltype( auto ) Gaudi::Functional::details::for_ ( F &&  f)

Definition at line 38 of file MergingTransformer.h.

38  {
39  return for_impl( std::forward<F>( f ), std::make_index_sequence<N>{} );
40  }

◆ for_impl()

template<typename F , size_t... Is>
auto Gaudi::Functional::details::for_impl ( F &&  f,
std::index_sequence< Is... >   
)

Definition at line 29 of file MergingTransformer.h.

29  {
30  if constexpr ( std::disjunction_v<std::is_void<std::invoke_result_t<F, std::integral_constant<int, Is>>>...> ) {
31  ( std::invoke( f, std::integral_constant<int, Is>{} ), ... );
32  } else {
33  return std::array{ std::invoke( f, std::integral_constant<int, Is>{} )... };
34  }
35  }

◆ get() [1/2]

template<typename Handle , typename Algo >
auto Gaudi::Functional::details::get ( const Handle &  handle,
const Algo &  ,
const EventContext  
) -> decltype( details::deref( handle.get() ) )

Definition at line 425 of file FunctionalDetails.h.

427  {
428  return details::deref( handle.get() );
429  }

◆ get() [2/2]

template<typename IFace , typename Algo >
auto Gaudi::Functional::details::get ( const ToolHandle< Gaudi::Interface::Bind::IBinder< IFace >> &  handle,
const Algo &  ,
const EventContext ctx 
)

Definition at line 432 of file FunctionalDetails.h.

432  {
433  return handle.bind( ctx );
434  }

◆ get_values_helper()

template<typename Value , std::size_t... I>
auto Gaudi::Functional::details::get_values_helper ( std::index_sequence< I... >  )

Definition at line 159 of file FunctionalDetails.h.

159  {
160  return std::make_tuple( ( (void)I, Value{} )... );
161  }

◆ getKey()

template<typename Handle >
auto Gaudi::Functional::details::getKey ( const Handle &  h) -> decltype( h.objKey() )

Definition at line 437 of file FunctionalDetails.h.

437  {
438  return h.objKey();
439  }

◆ make_vector_of_handles()

template<typename Handles >
Handles Gaudi::Functional::details::make_vector_of_handles ( IDataHandleHolder owner,
const std::vector< DataObjID > &  init 
)

Definition at line 414 of file FunctionalDetails.h.

414  {
415  Handles handles;
416  handles.reserve( init.size() );
417  std::transform( init.begin(), init.end(), std::back_inserter( handles ),
418  [&]( const auto& loc ) -> typename Handles::value_type {
419  return { loc, owner };
420  } );
421  return handles;
422  }

◆ put() [1/3]

template<typename Out1 , typename Out2 , typename = std::enable_if_t<std::is_constructible_v<Out1, Out2>>>
auto Gaudi::Functional::details::put ( const DataObjectHandle< AnyDataWrapper< Out1 >> &  out_handle,
Out2 &&  out 
)

Definition at line 175 of file FunctionalDetails.h.

175  {
176  return out_handle.put( std::forward<Out2>( out ) );
177  }

◆ put() [2/3]

template<typename Out1 , typename Out2 , typename = std::enable_if_t<std::is_constructible_v<Out1, Out2> && std::is_base_of_v<DataObject, Out1>>>
auto Gaudi::Functional::details::put ( const DataObjectHandle< Out1 > &  out_handle,
Out2 &&  out 
)

Definition at line 170 of file FunctionalDetails.h.

170  {
171  return out_handle.put( std::make_unique<Out1>( std::forward<Out2>( out ) ) );
172  }

◆ put() [3/3]

template<typename OutHandle , typename OptOut , typename = require_is_optional<OptOut>>
void Gaudi::Functional::details::put ( const OutHandle &  out_handle,
OptOut &&  out 
)

Definition at line 181 of file FunctionalDetails.h.

181  {
182  if ( out ) put( out_handle, *std::forward<OptOut>( out ) );
183  }

◆ to_DataObjID()

std::vector<DataObjID> Gaudi::Functional::details::to_DataObjID ( const std::vector< std::string > &  in)
inline

Definition at line 119 of file FunctionalDetails.h.

119  {
121  out.reserve( in.size() );
123  []( const std::string& i ) { return DataObjID{ i }; } );
124  return out;
125  }

◆ updateHandleLocation()

template<typename Out , typename In , typename Tr >
void Gaudi::Functional::details::updateHandleLocation ( DataHandleMixin< Out, In, Tr > &  parent,
const std::string prop,
const std::string newLoc 
)

Definition at line 488 of file FunctionalDetails.h.

489  {
490  auto sc = parent.setProperty( prop, newLoc );
491  if ( sc.isFailure() ) throw GaudiException( "Could not set Property", prop + " -> " + newLoc, sc );
492  }

◆ updateHandleLocations()

template<typename Out , typename In , typename Tr >
void Gaudi::Functional::details::updateHandleLocations ( DataHandleMixin< Out, In, Tr > &  parent,
const std::string prop,
const std::vector< std::string > &  newLocs 
)

Definition at line 495 of file FunctionalDetails.h.

496  {
499  ss << '[', newLocs, ", ", []( std::ostream & os, const auto& i ) -> auto& { return os << "'" << i << "'"; } )
500  << ']';
501  auto sc = parent.setProperty( prop, ss.str() );
502  if ( sc.isFailure() ) throw GaudiException( "Could not set Property", prop + " -> " + ss.str(), sc );
503  }

Variable Documentation

◆ deref

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

◆ insert

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

◆ invoke_optionally

constexpr struct Gaudi::Functional::details::invoke_optionally_t Gaudi::Functional::details::invoke_optionally

◆ is_optional_v

template<typename Arg >
constexpr bool Gaudi::Functional::details::is_optional_v = Gaudi::cpp17::is_detected_v<details2::is_optional_, Arg>
constexpr

Definition at line 135 of file FunctionalDetails.h.

◆ is_void_fun_v

template<typename Sig >
constexpr bool Gaudi::Functional::details::is_void_fun_v = is_void_fun<Sig>::value
inlineconstexpr

Definition at line 47 of file MergingTransformer.h.

◆ isLegacy

template<typename Traits >
constexpr bool Gaudi::Functional::details::isLegacy
inlineconstexpr
Initial value:
=
std::is_base_of_v<Gaudi::details::LegacyAlgorithmAdapter, details::BaseClass_t<Traits>>

Definition at line 407 of file FunctionalDetails.h.

std::make_tuple
T make_tuple(T... args)
std::integral_constant
std::string
STL class.
std::is_void
std::vector< DataObjID >
std::vector::size
T size(T... args)
std::back_inserter
T back_inserter(T... args)
GaudiException
Definition: GaudiException.h:31
gaudirun.c
c
Definition: gaudirun.py:525
GaudiPython.Pythonizations.ctx
ctx
Definition: Pythonizations.py:588
std::ostream
STL class.
AlgSequencer.h
h
Definition: AlgSequencer.py:32
Gaudi::Functional::details::put
void put(const OutHandle &out_handle, OptOut &&out)
Definition: FunctionalDetails.h:181
std::array
STL class.
Gaudi::Functional::details::for_impl
auto for_impl(F &&f, std::index_sequence< Is... >)
Definition: MergingTransformer.h:29
Gaudi::Functional::details::deref
constexpr struct Gaudi::Functional::details::deref_t deref
std::transform
T transform(T... args)
std::ostringstream
STL class.
DataObjectHandle::put
T * put(std::unique_ptr< T > object) const
Register object in transient store.
Definition: DataObjectHandle.h:176
std::vector::begin
T begin(T... args)
std::ostringstream::str
T str(T... args)
std::vector::end
T end(T... args)
GaudiUtils::details::ostream_joiner
Stream & ostream_joiner(Stream &os, Iterator first, Iterator last, Separator sep, OutputElement output=OutputElement{})
Definition: SerializeSTL.h:73
PrepareBase.out
out
Definition: PrepareBase.py:20