RetroLinker
Linker for several 8-bit, 16-bit and 32-bit formats
Loading...
Searching...
No Matches
Classes | Public Types | Public Member Functions | Public Attributes | List of all members
Apple::ResourceFork Class Reference

A Macintosh resource fork. More...

#include <macos.h>

Inheritance diagram for Apple::ResourceFork:
Apple::AppleSingleDouble::Entry Linker::OutputFormat Linker::LinkerManager Linker::Format Linker::Format

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::ListGetScript (Linker::Module &module)
 
void Link (Linker::Module &module)
 
void ProcessModule (Linker::Module &module) override
 
void CalculateValues () override
 
offset_t GetLength () override
 
void WriteFile (Linker::Writer &wr) override
 Stores data in memory to file.
 
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) override
 Provides a default filename for the output file.
 
- Public Member Functions inherited from Apple::AppleSingleDouble::Entry
void ReadFile (Linker::Reader &rd) override
 Loads file into memory.
 
- 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 Dump (Dumper::Dumper &dump)
 Display file contents in a nice manner.
 
- Public Member Functions inherited from Linker::OutputFormat
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 void SetLinkScript (std::string script_file, std::map< std::string, std::string > &options)
 Selects a script file to use for linking.
 
virtual std::string GetDefaultExtension (Linker::Module &module, std::string filename)
 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 Member Functions inherited from Linker::LinkerManager
void ClearLinkerManager ()
 
void SetLinkScript (std::string script_file, std::map< std::string, std::string > &options)
 Sets up the linker script and linker parameters.
 
bool SetLinkerParameter (std::map< std::string, std::string > &options, std::string key)
 Sets a single linker parameter, if inside options.
 
bool SetLinkerParameter (std::map< std::string, std::string > &options, std::string key, std::string variable)
 Sets a single linker parameter, if inside options.
 
std::unique_ptr< Script::ListGetScript (Linker::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< SegmentAppendSegment (std::string name)
 Terminates the current segment (if there is one), creates a new segment and attaches it to the image.
 
std::shared_ptr< SegmentFetchSegment (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)
 

Public Attributes

memory_model_t memory_model
 
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< JumpTableCodeResourcejump_table
 
std::vector< std::shared_ptr< CodeResource > > codes
 
std::map< std::shared_ptr< Linker::Segment >, std::shared_ptr< CodeResource > > segments
 
std::shared_ptr< Linker::Segmenta5world
 
- Public Attributes inherited from Apple::AppleSingleDouble::Entry
const uint32_t id
 
- Public Attributes inherited from Linker::Format
offset_t file_offset
 
- Public Attributes inherited from Linker::LinkerManager
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< Segmentcurrent_segment
 Currently processed segment.
 
std::map< std::string, Locationlinker_parameters
 Parameters that permit customizing the linker script.
 
std::string linker_script
 Contents of the linker script.
 

Additional Inherited Members

- Protected Member Functions inherited from Apple::AppleSingleDouble::Entry
 Entry (uint32_t id)
 
- Protected Attributes inherited from Linker::LinkerManager
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
 

Detailed Description

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.

Member Function Documentation

◆ CalculateValues()

void ResourceFork::CalculateValues ( )
overridevirtual

Reimplemented from Apple::AppleSingleDouble::Entry.

◆ FormatSupportsResources()

bool Apple::ResourceFork::FormatSupportsResources ( ) const
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.

◆ GenerateFile()

void ResourceFork::GenerateFile ( std::string filename,
Linker::Module & module )
overridevirtual

The main function that handles processing, calculating and generating the final image.

Reimplemented from Linker::OutputFormat.

◆ GetDefaultExtension()

std::string ResourceFork::GetDefaultExtension ( Linker::Module & module)
overridevirtual

Provides a default filename for the output file.

Typically a.out or some other extension, such as a.exe.

Reimplemented from Linker::OutputFormat.

◆ GetLength()

offset_t ResourceFork::GetLength ( )
overridevirtual

Reimplemented from Apple::AppleSingleDouble::Entry.

◆ OnNewSegment()

void ResourceFork::OnNewSegment ( std::shared_ptr< Linker::Segment > segment)
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::LinkerManager.

◆ ProcessModule()

void ResourceFork::ProcessModule ( Linker::Module & module)
overridevirtual

Reimplemented from Apple::AppleSingleDouble::Entry.

◆ SetModel()

void ResourceFork::SetModel ( std::string model)
overridevirtual

Sets the way memory is organized, typically modifying a built-in script.

Reimplemented from Linker::OutputFormat.

◆ SetOptions()

void ResourceFork::SetOptions ( std::map< std::string, std::string > & options)
overridevirtual

Passes command line parameters as settings over to format object.

Reimplemented from Linker::OutputFormat.

◆ WriteFile()

void ResourceFork::WriteFile ( Linker::Writer & out)
overridevirtual

Stores data in memory to file.

Reimplemented from Apple::AppleSingleDouble::Entry.


The documentation for this class was generated from the following files: