Class: MachO::LoadCommand

Inherits:
MachOStructure show all
Defined in:
lib/macho/load_commands.rb

Overview

Mach-O load command structure This is the most generic load command - only cmd ID and size are represented, and no actual data. Used when a more specific class isn’t available/implemented.

Defined Under Namespace

Classes: LCStr

Instance Attribute Summary collapse

Class Method Summary collapse

Instance Method Summary collapse

Methods inherited from MachOStructure

bytesize

Constructor Details

#initialize(raw_data, offset, cmd, cmdsize) ⇒ LoadCommand

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Returns a new instance of LoadCommand.

Parameters:

  • offset (Fixnum)

    the offset to initialize with

  • cmd (Fixnum)

    the load command’s identifying number

  • cmdsize (Fixnum)

    the size of the load command in bytes



315
316
317
318
319
320
# File 'lib/macho/load_commands.rb', line 315

def initialize(raw_data, offset, cmd, cmdsize)
	@raw_data = raw_data
	@offset = offset
	@cmd = cmd
	@cmdsize = cmdsize
end

Instance Attribute Details

#cmdFixnum (readonly)

Returns the load command’s identifying number.

Returns:

  • (Fixnum)

    the load command’s identifying number



294
295
296
# File 'lib/macho/load_commands.rb', line 294

def cmd
  @cmd
end

#cmdsizeFixnum (readonly)

Returns the size of the load command, in bytes.

Returns:

  • (Fixnum)

    the size of the load command, in bytes



297
298
299
# File 'lib/macho/load_commands.rb', line 297

def cmdsize
  @cmdsize
end

#offsetFixnum (readonly)

Returns the offset in the file the command was created from.

Returns:

  • (Fixnum)

    the offset in the file the command was created from



291
292
293
# File 'lib/macho/load_commands.rb', line 291

def offset
  @offset
end

Class Method Details

.new_from_bin(raw_data, offset, bin) ⇒ MachO::LoadCommand

This method is part of a private API. You should avoid using this method if possible, as it may be removed or be changed in the future.

Creates a new LoadCommand given an offset and binary string

Parameters:

  • offset (Fixnum)

    the offset to initialize with

  • bin (String)

    the binary string to initialize with

Returns:



307
308
309
# File 'lib/macho/load_commands.rb', line 307

def self.new_from_bin(raw_data, offset, bin)
	self.new(raw_data, offset, *bin.unpack(@format))
end

Instance Method Details

#to_sString

Returns a string representation of the load command’s identifying number.

Returns:

  • (String)

    a string representation of the load command’s identifying number



323
324
325
# File 'lib/macho/load_commands.rb', line 323

def to_s
	LOAD_COMMANDS[cmd]
end