#include <IntegralPointerInstruction.h>
Inheritance diagram for IntegralPointerInstructionRegister:
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 204 of file IntegralPointerInstruction.h.
static void IntegralPointerInstructionRegister::registerTypes | ( | vector< StandardTypeDescriptorOrdinal > const & | t | ) | [inline, static, private] |
Definition at line 210 of file IntegralPointerInstruction.h.
00210 { 00211 00212 for (uint i = 0; i < t.size(); i++) { 00213 StandardTypeDescriptorOrdinal type = t[i]; 00214 // Type <char> below is a placeholder and is ignored. 00215 InstructionSignature sig = INSTCLASS2<char>::signature(type); 00216 switch (type) { 00217 // Array_Text, below, does not allow assembly programs 00218 // of to have say, pointer to int16s, but the language 00219 // does not have pointers defined other than 00220 // c,vc,b,vb, so this is OK for now. 00221 #define Fennel_InstructionRegisterSwitch_Array 1 00222 #include "fennel/calculator/InstructionRegisterSwitch.h" 00223 default: 00224 throw std::logic_error("Default InstructionRegister"); 00225 } 00226 } 00227 }
static void IntegralPointerInstructionRegister::registerInstructions | ( | ) | [inline, static] |
Definition at line 231 of file IntegralPointerInstruction.h.
References StandardTypeDescriptor::isArray(), and InstructionSignature::typeVector().
Referenced by InstructionFactory::registerInstructions().
00231 { 00232 vector<StandardTypeDescriptorOrdinal> t; 00233 // isArray, below, does not allow assembly programs of to 00234 // have say, pointer to int16s, but the language does not have 00235 // pointers defined other than c,vc,b,vb, so this is OK for now. 00236 t = InstructionSignature::typeVector(StandardTypeDescriptor::isArray); 00237 00238 // Have to do full fennel:: qualification of template 00239 // arguments below to prevent template argument 'TMPLT', of 00240 // this encapsulating class, from perverting NativeAdd into 00241 // NativeAdd<TMPLT> or something like 00242 // that. Anyway. Fennel::NativeAdd works just fine. 00243 registerTypes<fennel::PointerGetSize>(t); 00244 registerTypes<fennel::PointerGetMaxSize>(t); 00245 }
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 }