| RetroLinker
    Linker for several 8-bit, 16-bit and 32-bit formats | 
A class that provides a general interface to setting up generation for a format. More...
#include <format.h>
 
  
| Public Member Functions | |
| virtual bool | AddSupplementaryOutputFormat (std::string subformat) | 
| If the output format actually drives multiple output formats (resource file, apple double, etc.), specify multiple types, return false if unknown. | |
| virtual std::vector< OptionDescription< void > > | GetMemoryModelNames () | 
| Returns a list of the supported memory models, used for documentation. | |
| virtual std::vector< OptionDescription< void > * > | GetLinkerScriptParameterNames () | 
| Returns a list of the parameters used in the linker scripts, used for documentation. | |
| virtual std::vector< OptionDescription< void > > | GetSpecialSymbolNames () | 
| Returns a list of special symbol names recognized by the format, used for documentation. | |
| virtual std::shared_ptr< OptionCollector > | GetOptions () | 
| Returns object containing a sequence of option fields provided with the -S command line flag. | |
| virtual void | SetOptions (std::map< std::string, std::string > &options) | 
| Passes command line parameters as settings over to format object. | |
| std::optional< std::string > | FetchOption (std::map< std::string, std::string > &options, std::string name) | 
| Convenience method to look up option by name. | |
| std::string | FetchOption (std::map< std::string, std::string > &options, std::string name, std::string default_value) | 
| Convenience method to look up option by name, returning default value if name is missing. | |
| std::optional< offset_t > | FetchIntegerOption (std::map< std::string, std::string > &options, std::string name) | 
| Convenience method to look up option by name and convert it to integer. | |
| virtual void | SetModel (std::string model) | 
| Sets the way memory is organized, typically modifying a built-in script. | |
| virtual void | SetLinkScript (std::string script_file, std::map< std::string, std::string > &options) | 
| Selects a script file to use for linking. | |
| virtual void | ProcessModule (Module &object) | 
| Processes the module object and initializes format fields. | |
| virtual void | CalculateValues () | 
| Intermediate step between processing module and generating output file to set up headers and management sections It is expected that after a module is processed, additional steps are required to evaluate the final values of the fields. | |
| virtual void | GenerateFile (std::string filename, Module &module) | 
| The main function that handles processing, calculating and generating the final image. | |
| virtual std::string | GetDefaultExtension (Module &module, std::string filename) const | 
| Appends a default extension to the filename. | |
| virtual std::string | GetDefaultExtension (Module &module) const | 
| Provides a default filename for the output file. | |
| virtual bool | FormatSupportsSegmentation () const | 
| Whether the format supports multiple segments. | |
| virtual bool | FormatIs16bit () const | 
| Whether the format is 16-bit or not. | |
| virtual bool | FormatIsProtectedMode () const | 
| Whether the format is in protected mode or not (x86 only) | |
| virtual bool | FormatIsLinear () const | 
| Whether the address space is linear or segmented. | |
| virtual bool | FormatSupportsResources () const | 
| Whether the format supports resources. | |
| virtual bool | FormatSupportsLibraries () const | 
| Whether the format supports libraries. | |
| virtual unsigned | FormatAdditionalSectionFlags (std::string section_name) const | 
|  Public Member Functions inherited from Linker::Format | |
| Format (offset_t file_offset=0) | |
| virtual void | Clear () | 
| Resets all fields to their default values, deallocate memory. | |
| virtual void | ReadFile (Reader &rd)=0 | 
| Loads file into memory. | |
| offset_t | WriteFile (Writer &wr) const override=0 | 
| Stores data in memory to file. | |
| virtual void | Dump (Dumper::Dumper &dump) const | 
| Display file contents in a nice manner. | |
| offset_t | ImageSize () const override | 
| Retrieves size of stored data. | |
| offset_t | WriteFile (Writer &wr, offset_t count, offset_t offset=0) const override | 
| Writes data of non-zero filled sections. | |
|  Public Member Functions inherited from Linker::Image | |
| virtual std::shared_ptr< const ActualImage > | AsImage () const | 
| Retrieves a randomly accessible image. | |
| std::shared_ptr< ActualImage > | AsImage () | 
| Retrieves a randomly accessible image. | |
| Additional Inherited Members | |
|  Public Attributes inherited from Linker::Format | |
| offset_t | file_offset | 
A class that provides a general interface to setting up generation for a format.
| 
 | virtual | 
If the output format actually drives multiple output formats (resource file, apple double, etc.), specify multiple types, return false if unknown.
Reimplemented in Apple::MacDriver.
| 
 | virtual | 
Intermediate step between processing module and generating output file to set up headers and management sections It is expected that after a module is processed, additional steps are required to evaluate the final values of the fields.
Reimplemented in Binary::CPM3Format, ARM::AIFFormat, AOut::AOutFormat, Archive::ArchiveFormat, BFLT::BFLTFormat, Binary::GenericBinaryFormat, DOS16M::BWFormat, COFF::COFFFormat, DigitalResearch::CPM68KFormat, DigitalResearch::CPM86Format, DigitalResearch::CPM8KFormat, SeychellDOS32::AdamFormat, ELF::ELFFormat, ELF::FatELFFormat, Apple::OMFFormat, X68000::HUFormat, Amiga::HunkFormat, Microsoft::LEFormat, MachO::FatMachOFormat, Apple::AppleSingleDouble, Apple::ResourceFork::GenericResource, Apple::ResourceFork::JumpTableCodeResource, Apple::ResourceFork::CodeResource, Apple::MacBinary, MINIX::MINIXFormat, Microsoft::MZFormat, Microsoft::NEFormat, PCOS::CMDFormat, Microsoft::PEFormat, PharLap::MPFormat, PharLap::P3Format::Flat, PharLap::P3Format::MultiSegmented, PharLap::P3FormatContainer, PMODE::PMW1Format, and Ergo::XPFormat.
| 
 | virtual | 
Whether the format is 16-bit or not.
This is needed for the ELF parser which can not distinguish between the 8086 and 80386 backends.
Reimplemented in Binary::BinaryFormat, DOS16M::BWFormat, DigitalResearch::CPM86Format, GEOS::GeodeFormat, MINIX::MINIXFormat, Microsoft::MZFormat, Microsoft::NEFormat, PharLap::P3Format, PharLap::P3FormatContainer, and Ergo::XPFormat.
| 
 | virtual | 
Whether the address space is linear or segmented.
This is needed to determine whether symbol relocations are absolute addresses or offsets within their own segments. Typically, Intel 8086 backends are non-linear, the others are linear.
| 
 | virtual | 
Whether the format is in protected mode or not (x86 only)
This is needed for the ELF parser to determine whether segment references are paragraph offsets (16-byte units) or selector indexes.
For non-x86 targets, the result is meaningless.
Reimplemented in Binary::BinaryFormat, DOS16M::BWFormat, DigitalResearch::CPM86Format, GEOS::GeodeFormat, MINIX::MINIXFormat, Microsoft::MZFormat, Microsoft::NEFormat, PharLap::P3Format, PharLap::P3FormatContainer, and Ergo::XPFormat.
| 
 | virtual | 
Whether the format supports libraries.
Reimplemented in DigitalResearch::CPM86Format, Microsoft::LEFormat, and Microsoft::NEFormat.
| 
 | virtual | 
Whether the format supports resources.
Formats such as NE, LE/LX, PE and the Macintosh classic support including resources in the final binary. To simplify writing resources, the ELF parser permits incorporating them directly in the binary image as $$RSRC$_<type>$<id>.
Reimplemented in Apple::AppleSingleDouble, Apple::ResourceFork, and Apple::MacDriver.
| 
 | virtual | 
Whether the format supports multiple segments.
This is typically true for Intel 8086 targets and false for non-Intel targets. The ELF parser uses this to provide extended relocations, including the following:
Reimplemented in Binary::BinaryFormat, DOS16M::BWFormat, DigitalResearch::CPM86Format, DigitalResearch::CPM8KFormat, GEOS::GeodeFormat, Microsoft::LEFormat, Microsoft::MZFormat, Microsoft::NEFormat, PharLap::P3Format, PharLap::P3FormatContainer, and Ergo::XPFormat.
| 
 | virtual | 
The main function that handles processing, calculating and generating the final image.
Reimplemented in AOut::AOutFormat, BFLT::BFLTFormat, Binary::GenericBinaryFormat, COFF::COFFFormat, DigitalResearch::CPM68KFormat, DigitalResearch::CPM86Format, DigitalResearch::CPM8KFormat, X68000::HUFormat, Amiga::HunkFormat, Microsoft::LEFormat, Apple::AppleSingleDouble, Apple::ResourceFork, Apple::MacBinary, Apple::MacDriver, MINIX::MINIXFormat, Microsoft::MZFormat, and Microsoft::NEFormat.
| 
 | virtual | 
Provides a default filename for the output file.
Typically a.out or some other extension, such as a.exe.
Reimplemented in Binary::UZIFormat, Binary::UZI280Format, AOut::AOutFormat, BFLT::BFLTFormat, Amiga::HunkFormat, Apple::AppleSingleDouble, Apple::ResourceFork, and MINIX::MINIXFormat.
| 
 | virtual | 
Appends a default extension to the filename.
A typical behavior would be to append .exe at the end of the filename. The default action is to leave it intact.
Reimplemented in Binary::CommodoreFormat, Binary::FLEXFormat, ARM::AIFFormat, AOut::AOutFormat, Binary::GenericBinaryFormat, DOS16M::BWFormat, COFF::COFFFormat, DigitalResearch::CPM68KFormat, DigitalResearch::CPM86Format, DigitalResearch::CPM8KFormat, GEOS::GeodeFormat, X68000::HUFormat, Microsoft::LEFormat, Microsoft::MZFormat, Microsoft::NEFormat, PCOS::CMDFormat, Microsoft::PEFormat, PharLap::MPFormat, PharLap::P3Format, PharLap::P3FormatContainer, PMODE::PMW1Format, and Ergo::XPFormat.
| 
 | virtual | 
Returns a list of the parameters used in the linker scripts, used for documentation.
Reimplemented in AOut::AOutFormat, Binary::GenericBinaryFormat, Binary::BinaryFormat, COFF::COFFFormat, DigitalResearch::CPM68KFormat, X68000::HUFormat, Microsoft::LEFormat, and MINIX::MINIXFormat.
| 
 | virtual | 
Returns a list of the supported memory models, used for documentation.
Reimplemented in Binary::BinaryFormat, DigitalResearch::CPM86Format, Apple::AppleSingleDouble, Apple::ResourceFork, Apple::MacDriver, Microsoft::MZFormat, and Ergo::XPFormat.
| 
 | virtual | 
Returns object containing a sequence of option fields provided with the -S command line flag.
Reimplemented in Binary::CPM3Format, Binary::PRLFormat, AOut::AOutFormat, BFLT::BFLTFormat, DOS16M::BWFormat, COFF::COFFFormat, DigitalResearch::CPM68KFormat, DigitalResearch::CPM86Format, Amiga::HunkFormat, Microsoft::LEFormat, MINIX::MINIXFormat, Microsoft::MZFormat, Microsoft::NEFormat, PharLap::MPFormat, PharLap::P3Format, and Ergo::XPFormat.
| 
 | virtual | 
Processes the module object and initializes format fields.
Reimplemented in Binary::AtariFormat, Binary::CommodoreFormat, Binary::PRLFormat, Binary::UZIFormat, AOut::AOutFormat, BFLT::BFLTFormat, Binary::GenericBinaryFormat, Binary::BinaryFormat, DOS16M::BWFormat, COFF::COFFFormat, DigitalResearch::CPM68KFormat, DigitalResearch::CPM86Format, DigitalResearch::CPM8KFormat, X68000::HUFormat, Amiga::HunkFormat, Microsoft::LEFormat, Apple::AppleSingleDouble, Apple::ResourceFork::GenericResource, Apple::ResourceFork::JumpTableCodeResource, Apple::ResourceFork::CodeResource, MINIX::MINIXFormat, Microsoft::MZFormat, Microsoft::NEFormat, PharLap::MPFormat, PharLap::P3Format::Flat, PharLap::P3Format::MultiSegmented, PharLap::P3FormatContainer, and Ergo::XPFormat.
| 
 | virtual | 
Selects a script file to use for linking.
Reimplemented in BFLT::BFLTFormat, Apple::AppleSingleDouble, Apple::MacDriver, MINIX::MINIXFormat, and Linker::SegmentManager.
| 
 | virtual | 
Sets the way memory is organized, typically modifying a built-in script.
Reimplemented in Binary::BinaryFormat, DigitalResearch::CPM86Format, Apple::AppleSingleDouble, Apple::ResourceFork, Apple::MacDriver, Microsoft::MZFormat, Microsoft::NEFormat, and Ergo::XPFormat.
| 
 | virtual | 
Passes command line parameters as settings over to format object.
Reimplemented in Binary::CPM3Format, Binary::PRLFormat, AOut::AOutFormat, BFLT::BFLTFormat, DOS16M::BWFormat, COFF::COFFFormat, DigitalResearch::CPM68KFormat, DigitalResearch::CPM86Format, DigitalResearch::CPM8KFormat, Amiga::HunkFormat, Microsoft::LEFormat, Apple::AppleSingleDouble, Apple::ResourceFork, Apple::MacDriver, MINIX::MINIXFormat, Microsoft::MZFormat, Microsoft::NEFormat, PharLap::MPFormat, PharLap::P3Format, PharLap::P3FormatContainer, and Ergo::XPFormat.