Class: MachO::FatFile
- Inherits:
-
Object
- Object
- MachO::FatFile
- Defined in:
- lib/macho/fat_file.rb
Overview
Represents a “Fat” file, which contains a header, a listing of available architectures, and one or more Mach-O binaries.
Instance Attribute Summary collapse
-
#fat_archs ⇒ Array<MachO::FatArch>
readonly
An array of fat architectures.
-
#header ⇒ MachO::FatHeader
readonly
The file’s header.
-
#machos ⇒ Array<MachO::MachOFile>
readonly
An array of Mach-O binaries.
Instance Method Summary collapse
-
#change_install_name(old_name, new_name) ⇒ Object
(also: #change_dylib)
Changes all dependent shared library install names from ‘old_name` to `new_name`.
-
#dylib_id ⇒ String?
The file’s dylib ID.
-
#dylib_id=(new_id) ⇒ void
Changes the file’s dylib ID to ‘new_id`.
-
#extract(cputype) ⇒ MachO::MachOFile?
Extract a Mach-O with the given CPU type from the file.
-
#filetype ⇒ String
The file’s type.
-
#initialize(filename) ⇒ FatFile
constructor
Creates a new FatFile from the given filename.
-
#linked_dylibs ⇒ Array<String>
All shared libraries linked to the file’s Mach-Os.
-
#serialize ⇒ String
The file’s raw fat data.
-
#write(filename) ⇒ Object
Write all (fat) data to the given filename.
-
#write! ⇒ Object
Write all (fat) data to the file used to initialize the instance.
Constructor Details
#initialize(filename) ⇒ FatFile
Creates a new FatFile from the given filename.
19 20 21 22 23 24 25 26 27 |
# File 'lib/macho/fat_file.rb', line 19 def initialize(filename) raise ArgumentError.new("#{filetype}: no such file") unless File.exist?(filename) @filename = filename @raw_data = open(@filename, "rb") { |f| f.read } @header = get_fat_header @fat_archs = get_fat_archs @machos = get_machos end |
Instance Attribute Details
#fat_archs ⇒ Array<MachO::FatArch> (readonly)
Returns an array of fat architectures.
11 12 13 |
# File 'lib/macho/fat_file.rb', line 11 def fat_archs @fat_archs end |
#header ⇒ MachO::FatHeader (readonly)
Returns the file’s header.
8 9 10 |
# File 'lib/macho/fat_file.rb', line 8 def header @header end |
#machos ⇒ Array<MachO::MachOFile> (readonly)
Returns an array of Mach-O binaries.
14 15 16 |
# File 'lib/macho/fat_file.rb', line 14 def machos @machos end |
Instance Method Details
#change_install_name(old_name, new_name) ⇒ Object Also known as: change_dylib
incomplete
Changes all dependent shared library install names from ‘old_name` to `new_name`. In a fat file, this changes install names in all internal Mach-Os.
87 88 89 90 91 92 93 |
# File 'lib/macho/fat_file.rb', line 87 def change_install_name(old_name, new_name) machos.each do |macho| macho.change_install_name(old_name, new_name) end synchronize_raw_data end |
#dylib_id ⇒ String?
The file’s dylib ID. If the file is not a dylib, returns ‘nil`.
45 46 47 |
# File 'lib/macho/fat_file.rb', line 45 def dylib_id machos.first.dylib_id end |
#dylib_id=(new_id) ⇒ void
This method returns an undefined value.
Changes the file’s dylib ID to ‘new_id`. If the file is not a dylib, does nothing.
55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 |
# File 'lib/macho/fat_file.rb', line 55 def dylib_id=(new_id) if !new_id.is_a?(String) raise ArgumentError.new("argument must be a String") end if !machos.all?(&:dylib?) return nil end machos.each do |macho| macho.dylib_id = new_id end synchronize_raw_data end |
#extract(cputype) ⇒ MachO::MachOFile?
Extract a Mach-O with the given CPU type from the file.
102 103 104 |
# File 'lib/macho/fat_file.rb', line 102 def extract(cputype) machos.select { |macho| macho.cputype == cputype }.first end |
#filetype ⇒ String
The file’s type. Assumed to be the same for every Mach-O within.
37 38 39 |
# File 'lib/macho/fat_file.rb', line 37 def filetype machos.first.filetype end |
#linked_dylibs ⇒ Array<String>
All shared libraries linked to the file’s Mach-Os.
73 74 75 76 77 78 |
# File 'lib/macho/fat_file.rb', line 73 def linked_dylibs dylibs = machos.map(&:linked_dylibs).flatten # can machos inside fat binaries have different dylibs? dylibs.uniq! end |
#serialize ⇒ String
The file’s raw fat data.
31 32 33 |
# File 'lib/macho/fat_file.rb', line 31 def serialize @raw_data end |
#write(filename) ⇒ Object
Write all (fat) data to the given filename.
108 109 110 |
# File 'lib/macho/fat_file.rb', line 108 def write(filename) File.open(filename, "wb") { |f| f.write(@raw_data) } end |
#write! ⇒ Object
Overwrites all data in the file!
Write all (fat) data to the file used to initialize the instance.
114 115 116 |
# File 'lib/macho/fat_file.rb', line 114 def write! File.open(@filename, "wb") { |f| f.write(@raw_data) } end |