dlr::common::UnaryComposeFunctor< Functor0, Functor1 > Class Template Reference

Functor template for composing two unary functions functor0(x) and functor1(x) so that the result is functor0(functor1(x)). More...

#include <functional.h>

List of all members.

Public Member Functions

 UnaryComposeFunctor (const Functor0 &functor0, const Functor1 &functor1)
 Constructor accepts instances of the two functor types to be composed, and makes local copies of them for use in operator()(.
Functor0::result_type operator() (const typename Functor1::argument_type &argument)
 This operator passes its argument to the operator()(.

Protected Attributes

Functor0 m_functor0
 This protected member stores a copy of functor0.
Functor1 m_functor1
 This protected member stores a copy of functor1.


Detailed Description

template<class Functor0, class Functor1>
class dlr::common::UnaryComposeFunctor< Functor0, Functor1 >

Functor template for composing two unary functions functor0(x) and functor1(x) so that the result is functor0(functor1(x)).

Definition at line 377 of file functional.h.


Constructor & Destructor Documentation

template<class Functor0, class Functor1>
dlr::common::UnaryComposeFunctor< Functor0, Functor1 >::UnaryComposeFunctor ( const Functor0 &  functor0,
const Functor1 &  functor1 
) [inline]

Constructor accepts instances of the two functor types to be composed, and makes local copies of them for use in operator()(.

..).

Parameters:
functor0 During evaluation of operator()(...), the return value of a copy of functor1 will be passed to this functor (or rather, a copy of this functor) and the return value of the copy of this functor will be passed to the calling context.
functor1 During evaluation of operator()(...), the return value of this functor (or rather, a copy of this functor) will be passed to a copy of functor0, and the return value of the functor0 copy will be passed to the calling context.

Definition at line 399 of file functional.h.


Member Function Documentation

template<class Functor0, class Functor1>
Functor0::result_type dlr::common::UnaryComposeFunctor< Functor0, Functor1 >::operator() ( const typename Functor1::argument_type &  argument  )  [inline]

This operator passes its argument to the operator()(.

..) method of a copy of constructor argument functor1, then passes the result to the operator()(...) method of a copy of constructor argument functor0, and returns the result.

Parameters:
argument This argument will be passed as input to the functor1 copy.
Returns:
The result of processing the argument with the two composed functors: returnValue = functor0(functor1(argument)).

Definition at line 414 of file functional.h.

References dlr::common::UnaryComposeFunctor< Functor0, Functor1 >::m_functor0, and dlr::common::UnaryComposeFunctor< Functor0, Functor1 >::m_functor1.


Member Data Documentation

template<class Functor0, class Functor1>
Functor0 dlr::common::UnaryComposeFunctor< Functor0, Functor1 >::m_functor0 [protected]

This protected member stores a copy of functor0.

Definition at line 421 of file functional.h.

Referenced by dlr::common::UnaryComposeFunctor< Functor0, Functor1 >::operator()().

template<class Functor0, class Functor1>
Functor1 dlr::common::UnaryComposeFunctor< Functor0, Functor1 >::m_functor1 [protected]

This protected member stores a copy of functor1.

Definition at line 424 of file functional.h.

Referenced by dlr::common::UnaryComposeFunctor< Functor0, Functor1 >::operator()().


The documentation for this class was generated from the following file:

Generated on Tue Nov 24 23:57:57 2009 for dlrCommon Utility Library by  doxygen 1.5.8