RetroLinker
Linker for several 8-bit, 16-bit and 32-bit formats
|
A Macintosh resource fork. More...
#include <macos.h>
Classes | |
class | CodeResource |
class | GenericResource |
class | JumpTableCodeResource |
class | Resource |
Public Types | |
enum | memory_model_t { MODEL_DEFAULT , MODEL_TINY } |
Public Member Functions | |
bool | FormatSupportsResources () const override |
Whether the format supports resources. | |
void | SetOptions (std::map< std::string, std::string > &options) override |
Passes command line parameters as settings over to format object. | |
void | SetModel (std::string model) override |
Sets the way memory is organized, typically modifying a built-in script. | |
void | AddResource (std::shared_ptr< Resource > resource) |
void | OnNewSegment (std::shared_ptr< Linker::Segment > segment) override |
Callback function when allocating a new segment When the linker script runs, it creates segments consecutively. Overriding this method permits the output format to handle the allocated segment. | |
std::unique_ptr< Script::List > | GetScript (Linker::Module &module) |
void | Link (Linker::Module &module) |
void | ProcessModule (Linker::Module &module) override |
void | CalculateValues () override |
offset_t | ImageSize () const override |
Retrieves size of stored data. | |
offset_t | WriteFile (Linker::Writer &wr) const override |
Stores data in memory to file. | |
void | Dump (Dumper::Dumper &dump) const override |
Display file contents in a nice manner. | |
void | GenerateFile (std::string filename, Linker::Module &module) override |
The main function that handles processing, calculating and generating the final image. | |
std::string | GetDefaultExtension (Linker::Module &module) const override |
Provides a default filename for the output file. | |
![]() | |
void | ReadFile (Linker::Reader &rd) override |
Loads file into memory. | |
![]() | |
Format (offset_t file_offset=0) | |
virtual void | Clear () |
Resets all fields to their default values, deallocate memory. | |
offset_t | WriteFile (Writer &wr, offset_t count, offset_t offset=0) const override |
Writes data of non-zero filled sections. | |
![]() | |
virtual std::shared_ptr< const ActualImage > | AsImage () const |
Retrieves a randomly accessible image. | |
std::shared_ptr< ActualImage > | AsImage () |
Retrieves a randomly accessible image. | |
![]() | |
void | ClearSegmentManager () |
void | SetLinkScript (std::string script_file, std::map< std::string, std::string > &options) override |
Sets up the linker script and linker parameters. | |
std::unique_ptr< Script::List > | GetScript (Module &module) |
Compiles the linker script into an internal format. | |
offset_t | GetCurrentAddress () const |
Retrieves current address pointer. | |
void | SetCurrentAddress (offset_t address) |
Moves the current address pointer further, and if the current segment already contains data, fill it up to the point. | |
void | AlignCurrentAddress (offset_t align) |
Aligns current address to alignment, using SetCurrentAddress. | |
void | SetLatestBase (offset_t address) |
Sets the base of the current section (the value from which offsets are counted from) | |
void | FinishCurrentSegment () |
Closes the current segment, sets current_segment to null. | |
std::shared_ptr< Segment > | AppendSegment (std::string name) |
Terminates the current segment (if there is one), creates a new segment and attaches it to the image. | |
std::shared_ptr< Segment > | FetchSegment (std::string name) |
Attempts to fetch a segment, returns null if not found. | |
void | AppendSection (std::shared_ptr< Section > section) |
Adds a new section to the current segment, sets the base to the same as the segment. | |
void | ProcessScript (std::unique_ptr< Script::List > &directives, Module &module) |
Executes a parsed linker script on a module and collects segments The function OnNewSegment can be defined to handle each newly allocated segment. | |
void | ProcessAction (std::unique_ptr< Script::Node > &action, Module &module) |
void | PostProcessAction (std::unique_ptr< Script::Node > &action, Module &module) |
void | ProcessCommand (std::unique_ptr< Script::Node > &command, Module &module) |
bool | CheckPredicate (std::unique_ptr< Script::Node > &predicate, std::shared_ptr< Section > section, Module &module) |
offset_t | EvaluateExpression (std::unique_ptr< Script::Node > &expression, Module &module) |
![]() | |
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. | |
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 std::string | GetDefaultExtension (Module &module, std::string filename) const |
Appends a default extension to the filename. | |
virtual bool | FormatSupportsSegmentation () const |
Whether the format supports multiple segments. | |
virtual bool | FormatIs16bit () const |
Whether the format is 16-bit or not. | |
virtual bool | FormatIsLinear () const |
Whether the address space is linear or segmented. | |
virtual bool | FormatSupportsLibraries () const |
Whether the format supports libraries. | |
virtual unsigned | FormatAdditionalSectionFlags (std::string section_name) const |
Public Attributes | |
memory_model_t | memory_model = MODEL_DEFAULT |
uint16_t | attributes = 0 |
std::map< uint32_t, std::map< uint16_t, std::shared_ptr< Resource > > > | resources |
uint32_t | data_offset = 0 |
uint32_t | data_length = 0 |
uint32_t | map_offset = 0 |
uint32_t | map_length = 0 |
uint16_t | name_list_offset = 0 |
std::map< uint32_t, uint16_t > | reference_list_offsets |
std::shared_ptr< JumpTableCodeResource > | jump_table |
std::vector< std::shared_ptr< CodeResource > > | codes |
std::map< std::shared_ptr< Linker::Segment >, std::shared_ptr< CodeResource > > | segments |
std::shared_ptr< Linker::Segment > | a5world |
![]() | |
const uint32_t | id |
![]() | |
offset_t | file_offset |
![]() | |
offset_t | current_base = 0 |
The base address of the current section. | |
std::vector< std::shared_ptr< Segment > > | segment_vector |
Ordered sequence of segments. | |
std::map< std::string, std::shared_ptr< Segment > > | segment_map |
Map of segments from their names. | |
std::shared_ptr< Segment > | current_segment |
Currently processed segment. | |
std::map< std::string, Location > | linker_parameters |
Parameters that permit customizing the linker script. | |
std::string | linker_script |
Contents of the linker script. | |
Additional Inherited Members | |
![]() | |
Entry (uint32_t id) | |
![]() | |
offset_t | current_address = 0 |
Holds the current address value when there is no current_segment. | |
bool | current_is_template = false |
bool | current_is_template_head = false |
offset_t | template_counter = 0 |
std::string | current_template_name |
A Macintosh resource fork.
Macintosh classic applications are stored as CODE resources inside a file's resource fork. When generating a binary image, the resource fork is usually bundled up in an AppleSingle or AppleDouble file.
This format has been obsoleted in favor of the PEF format, used on PowerPC based Macintosh computers.
|
overridevirtual |
Reimplemented from Apple::AppleSingleDouble::Entry.
|
overridevirtual |
Display file contents in a nice manner.
Reimplemented from Apple::AppleSingleDouble::Entry.
|
inlineoverridevirtual |
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 from Linker::OutputFormat.
|
overridevirtual |
The main function that handles processing, calculating and generating the final image.
Reimplemented from Linker::OutputFormat.
|
overridevirtual |
Provides a default filename for the output file.
Typically a.out or some other extension, such as a.exe.
Reimplemented from Linker::OutputFormat.
|
overridevirtual |
Retrieves size of stored data.
Reimplemented from Apple::AppleSingleDouble::Entry.
|
overridevirtual |
Callback function when allocating a new segment When the linker script runs, it creates segments consecutively. Overriding this method permits the output format to handle the allocated segment.
Reimplemented from Linker::SegmentManager.
|
overridevirtual |
Reimplemented from Apple::AppleSingleDouble::Entry.
|
overridevirtual |
Sets the way memory is organized, typically modifying a built-in script.
Reimplemented from Linker::OutputFormat.
|
overridevirtual |
Passes command line parameters as settings over to format object.
Reimplemented from Linker::OutputFormat.
|
overridevirtual |
Stores data in memory to file.
Reimplemented from Apple::AppleSingleDouble::Entry.