Namespaces | |
namespace | filter |
Classes | |
class | DispatchException |
Functions | |
template<typename Result, template< class > class Predicate, typename Callable, typename... Args> | |
auto | singleDispatch (DataFormatId format, Callable &&obj, Args &&... args) -> Result |
template<typename Result, template< class > class Predicate1, template< class > class Predicate2, typename Callable, typename... Args> | |
auto | doubleDispatch (DataFormatId format1, DataFormatId format2, Callable &&obj, Args &&... args) -> Result |
template<typename Result, template< class > class Predicate1, template< class > class Predicate2, template< class > class Predicate3, typename Callable, typename... Args> | |
auto | tripleDispatch (DataFormatId format1, DataFormatId format2, DataFormatId format3, Callable &&obj, Args &&... args) -> Result |
template<typename Result, template< class > class Predicate, typename Callable, typename... Args> | |
auto | dispatch (DataFormatId format, Callable &&obj, Args &&... args) -> Result |
dispatching
auto inviwo::dispatching::dispatch | ( | DataFormatId | format, |
Callable && | obj, | ||
Args &&... | args ) -> Result |
Same functionality as singleDispatch, but the callable is passed both the dispatch type and the return type as template arguments. And the dispatch type is passed as a DataFormat<T> where as singleDispatch passes T directly.
auto inviwo::dispatching::doubleDispatch | ( | DataFormatId | format1, |
DataFormatId | format2, | ||
Callable && | obj, | ||
Args &&... | args ) -> Result |
Function for dispatching on two DataFormats
Add two VolumeRAMPrecisions with different runtime types
Result | the return type of the lambda. |
Predicate1 | a type that is used to filter the list of types to consider in the dispatching for the first format1. The dispatching::filter namespace have a few standard ones predefined. |
Predicate2 | a type that is used to filter the list of types to consider in the dispatching for the second format2. The dispatching::filter namespace have a few standard ones predefined. |
format1 | ID if for the first dataformat to dispatch on |
format2 | ID if for the second dataformat to dispatch on |
obj | This should be a callable with a generic call operator taking two template arguments T1 and T2 of the dispatch types. The callable will be called with the supplied arguments (args ). For example []<typename T1, typename T2>() {}. T1 and T2 here will be, float, double, int, ... vec2, dvec2, etc. |
args | Any arguments that should be passed on to the callable. |
dispatching::DispatchException | in the case that the format is not in the list of formats after the filtering. |
auto inviwo::dispatching::singleDispatch | ( | DataFormatId | format, |
Callable && | obj, | ||
Args &&... | args ) -> Result |
Function for dispatching on a DataFormat
Create a VolumeRAMPrecision<T> with the type of T given by the runtime dataFormatId.
Result | the return type of the lambda. |
Predicate | a type that is used to filter the list of types to consider in the dispatching. The dispatching::filter namespace have a few standard ones predefined. |
format | ID if for the dataformat to dispatch on |
obj | This should be a callable with a generic call operator taking a template argument T of the dispatch type. The callable will be called with the supplied arguments (args ). For example []<typename T>() {}. T here will be, float, double, int, ... vec2, dvec2, etc. |
args | Any arguments that should be passed on to the callable. |
dispatching::DispatchException | in the case that the format is not in the list of formats after the filtering. |
auto inviwo::dispatching::tripleDispatch | ( | DataFormatId | format1, |
DataFormatId | format2, | ||
DataFormatId | format3, | ||
Callable && | obj, | ||
Args &&... | args ) -> Result |
Function for dispatching on three DataFormats
Add two VolumeRAMPrecisions with different runtime types and a runtime result type
Result | the return type of the lambda. |
Predicate1 | a type that is used to filter the list of types to consider in the dispatching for the first format1. The dispatching::filter namespace have a few standard ones predefined. |
Predicate2 | a type that is used to filter the list of types to consider in the dispatching for the second format2. The dispatching::filter namespace have a few standard ones predefined. |
Predicate3 | a type that is used to filter the list of types to consider in the dispatching for the third format3. The dispatching::filter namespace have a few standard ones predefined. |
format1 | ID if for the first dataformat to dispatch on |
format2 | ID if for the second dataformat to dispatch on |
format3 | ID if for the third dataformat to dispatch on |
obj | This should be a callable with a generic call operator taking three template arguments T1, T2 and T3 of the dispatch types. The callable will be called with the supplied arguments (args ). For example []<typename T1, typename T2, typename T3>() {}. T1 and T2 here will be, float, double, int, ... vec2, dvec2, etc. |
args | Any arguments that should be passed on to the callable. |
dispatching::DispatchException | in the case that the format is not in the list of formats after the filtering. |