Setting up the use of this module.
§1. This section simply sets up the module in ways expected by foundation, and contains no code of interest. The following constant exists only in tools which use this module:
define PIPELINE_MODULE TRUE
void PipelineModule::start(void) { Register this module's memory allocation reasons2.1; Register this module's stream writers2.2; Register this module's debugging log aspects2.3; Register this module's debugging log writers2.4; } void PipelineModule::end(void) { }
§2.1. Register this module's memory allocation reasons2.1 =
;
- This code is used in §2.
§2.2. Register this module's stream writers2.2 =
;
- This code is used in §2.
enumerate TEMPLATE_READING_DA
enumerate RESOLVING_CONDITIONAL_COMPILATION_DA
enumerate EXTERNAL_SYMBOL_RESOLUTION_DA
enumerate ELIMINATION_DA
Register this module's debugging log aspects2.3 =
Log::declare_aspect(TEMPLATE_READING_DA, U"template reading", FALSE, FALSE); Log::declare_aspect(RESOLVING_CONDITIONAL_COMPILATION_DA, U"resolving conditional compilation", FALSE, FALSE); Log::declare_aspect(EXTERNAL_SYMBOL_RESOLUTION_DA, U"external symbol resolution", FALSE, FALSE); Log::declare_aspect(ELIMINATION_DA, U"code elimination", FALSE, FALSE);
- This code is used in §2.
§2.4. Register this module's debugging log writers2.4 =
;
- This code is used in §2.
§3. Somewhere, we need to store the architecture set on the command line of either inter or inform7 (whichever one we are currently running inside). This is where:
inter_architecture *architecture_set_at_command_line = NULL; int PipelineModule::set_architecture(text_stream *name) { architecture_set_at_command_line = Architectures::from_codename(name); if (architecture_set_at_command_line) return TRUE; return FALSE; } void PipelineModule::set_architecture_to(inter_architecture *A) { architecture_set_at_command_line = A; } inter_architecture *PipelineModule::get_architecture(void) { return architecture_set_at_command_line; }