#include <IntegralNativeInstruction.h>
Inheritance diagram for IntegralNativeInstructionRegister:

| Static Public Member Functions | |
| static void | registerInstructions () | 
| Static Private Member Functions | |
| template<template< typename > class INSTCLASS2> | |
| static void | registerTypes (vector< StandardTypeDescriptorOrdinal > const &t) | 
| template<typename TYPE1, template< typename > class INSTCLASS> | |
| static void | registerInstance (StandardTypeDescriptorOrdinal type) | 
| template<typename IGNOREDDATATYPE, class INSTCLASS> | |
| static void | registerInstance (StandardTypeDescriptorOrdinal type) | 
| template<typename TYPE1, typename TYPE2, template< typename, typename > class INSTCLASS> | |
| static void | registerInstance2 (StandardTypeDescriptorOrdinal type1, StandardTypeDescriptorOrdinal type2) | 
Definition at line 455 of file IntegralNativeInstruction.h.
| static void IntegralNativeInstructionRegister::registerTypes | ( | vector< StandardTypeDescriptorOrdinal > const & | t | ) |  [inline, static, private] | 
Definition at line 461 of file IntegralNativeInstruction.h.
00461 { 00462 00463 for (uint i = 0; i < t.size(); i++) { 00464 StandardTypeDescriptorOrdinal type = t[i]; 00465 // Type <char> below is a placeholder and is ignored. 00466 InstructionSignature sig = INSTCLASS2<char>::signature(type); 00467 switch (type) { 00468 #define Fennel_InstructionRegisterSwitch_Integral 1 00469 #include "fennel/calculator/InstructionRegisterSwitch.h" 00470 default: 00471 throw std::logic_error("Default InstructionRegister"); 00472 } 00473 } 00474 }
| static void IntegralNativeInstructionRegister::registerInstructions | ( | ) |  [inline, static] | 
Definition at line 478 of file IntegralNativeInstruction.h.
References StandardTypeDescriptor::isExact(), and InstructionSignature::typeVector().
Referenced by InstructionFactory::registerInstructions().
00479 { 00480 vector<StandardTypeDescriptorOrdinal> t; 00481 t = InstructionSignature::typeVector(StandardTypeDescriptor::isExact); 00482 00483 // Have to do full fennel:: qualification of template 00484 // arguments below to prevent template argument 'TMPLT', of 00485 // this encapsulating class, from perverting NativeAdd into 00486 // NativeAdd<TMPLT> or something like 00487 // that. Anyway. Fennel::NativeAdd works just fine. 00488 registerTypes<fennel::IntegralNativeMod>(t); 00489 registerTypes<fennel::IntegralNativeAnd>(t); 00490 registerTypes<fennel::IntegralNativeOr>(t); 00491 registerTypes<fennel::IntegralNativeShiftLeft>(t); 00492 registerTypes<fennel::IntegralNativeShiftRight>(t); 00493 }
| static void InstructionRegister::registerInstance | ( | StandardTypeDescriptorOrdinal | type | ) |  [inline, static, protected, inherited] | 
Definition at line 139 of file Instruction.h.
References InstructionFactory::getInstructionTable().
Referenced by ReturnInstructionRegister::registerInstructions().
00140 { 00141 StringToCreateFn* instMap = InstructionFactory::getInstructionTable(); 00142 (*instMap)[INSTCLASS<TYPE1>::signature(type).compute()] = 00143 &INSTCLASS<TYPE1>::create; 00144 }
| static void InstructionRegister::registerInstance | ( | StandardTypeDescriptorOrdinal | type | ) |  [inline, static, protected, inherited] | 
Definition at line 161 of file Instruction.h.
References InstructionFactory::getInstructionTable().
00162 { 00163 StringToCreateFn* instMap = InstructionFactory::getInstructionTable(); 00164 (*instMap)[INSTCLASS::signature(type).compute()] = 00165 &INSTCLASS::create; 00166 }
| static void InstructionRegister::registerInstance2 | ( | StandardTypeDescriptorOrdinal | type1, | |
| StandardTypeDescriptorOrdinal | type2 | |||
| ) |  [inline, static, protected, inherited] | 
Definition at line 150 of file Instruction.h.
References InstructionFactory::getInstructionTable().
00153 { 00154 StringToCreateFn* instMap = InstructionFactory::getInstructionTable(); 00155 (*instMap)[INSTCLASS<TYPE1,TYPE2>::signature(type1, type2).compute()] = 00156 &INSTCLASS<TYPE1,TYPE2>::create; 00157 }
 1.5.1
 1.5.1