Module: MachOShim Private
- Extended by:
- Forwardable
- Includes:
- Kernel
- Included in:
- Pathname
- Defined in:
- os/mac/mach.rb,
os/mac/mach.rbi,
sorbet/rbi/parlour.rbi
This module is part of a private API. This module may only be used in the Homebrew/brew repository. Third parties should avoid using this module if possible, as it may be removed or changed without warning.
Instance Method Summary collapse
- #arch ⇒ Object private
- #archs ⇒ Object private
- #change_dylib_id(id, **options) ⇒ Object private
- #change_install_name(old, new, **options) ⇒ Object private
- #change_rpath(old, new, **options) ⇒ Object private
-
#delete_rpath(rpath, **options) ⇒ Object
private
we know we're not making any changes to the rpaths.
- #dylib? ⇒ Boolean private
- #dylib_id(*args, **options, &block) ⇒ T.untyped private
- #dynamically_linked_libraries(except: :none, resolve_variable_references: true) ⇒ Object private
- #i386? ⇒ Boolean private
- #mach_o_bundle? ⇒ Boolean private
- #mach_o_executable? ⇒ Boolean (also: #binary_executable?) private
- #ppc64? ⇒ Boolean private
- #ppc7400? ⇒ Boolean private
- #resolve_rpath(name) ⇒ Object private
- #resolve_variable_name(name, resolve_rpaths: true) ⇒ Object private
- #rpaths(resolve_variable_references: true) ⇒ Object private
- #universal? ⇒ Boolean private
- #x86_64? ⇒ Boolean private
Methods included from Kernel
#disk_usage_readable, #ensure_executable!, #ensure_formula_installed!, #exec_browser, #exec_editor, #ignore_interrupts, #interactive_shell, #number_readable, #odebug, #odeprecated, #odie, #odisabled, #ofail, #oh1, #oh1_title, #ohai, #ohai_title, #onoe, #opoo, #paths, #pretty_duration, #pretty_installed, #pretty_outdated, #pretty_uninstalled, #quiet_system, #redact_secrets, #redirect_stdout, #require?, #safe_system, #tap_and_name_comparison, #truncate_text_to_approximate_size, #which, #which_all, #which_editor, #with_custom_locale, #with_env, #with_homebrew_path
Instance Method Details
#arch ⇒ Object
This method is part of a private API. This method may only be used in the Homebrew/brew repository. Third parties should avoid using this method if possible, as it may be removed or changed without warning.
129 130 131 132 133 134 135 |
# File 'os/mac/mach.rb', line 129 def arch case archs.length when 0 then :dunno when 1 then archs.first else :universal end end |
#archs ⇒ Object
This method is part of a private API. This method may only be used in the Homebrew/brew repository. Third parties should avoid using this method if possible, as it may be removed or changed without warning.
125 126 127 |
# File 'os/mac/mach.rb', line 125 def archs mach_data.map { |m| m.fetch :arch } end |
#change_dylib_id(id, **options) ⇒ Object
This method is part of a private API. This method may only be used in the Homebrew/brew repository. Third parties should avoid using this method if possible, as it may be removed or changed without warning.
78 79 80 81 |
# File 'os/mac/mach.rb', line 78 def change_dylib_id(id, **) macho.change_dylib_id(id, ) macho.write! end |
#change_install_name(old, new, **options) ⇒ Object
This method is part of a private API. This method may only be used in the Homebrew/brew repository. Third parties should avoid using this method if possible, as it may be removed or changed without warning.
83 84 85 86 |
# File 'os/mac/mach.rb', line 83 def change_install_name(old, new, **) macho.change_install_name(old, new, ) macho.write! end |
#change_rpath(old, new, **options) ⇒ Object
This method is part of a private API. This method may only be used in the Homebrew/brew repository. Third parties should avoid using this method if possible, as it may be removed or changed without warning.
73 74 75 76 |
# File 'os/mac/mach.rb', line 73 def change_rpath(old, new, **) macho.change_rpath(old, new, ) macho.write! end |
#delete_rpath(rpath, **options) ⇒ Object
This method is part of a private API. This method may only be used in the Homebrew/brew repository. Third parties should avoid using this method if possible, as it may be removed or changed without warning.
See if the #write!
call can be delayed until
we know we're not making any changes to the rpaths.
60 61 62 63 64 65 66 67 68 69 70 71 |
# File 'os/mac/mach.rb', line 60 def delete_rpath(rpath, **) candidates = rpaths(resolve_variable_references: false).select do |r| resolve_variable_name(r) == resolve_variable_name(rpath) end # Delete the last instance to avoid changing the order in which rpaths are searched. rpath_to_delete = candidates.last [:last] = true macho.delete_rpath(rpath_to_delete, ) macho.write! end |
#dylib? ⇒ Boolean
This method is part of a private API. This method may only be used in the Homebrew/brew repository. Third parties should avoid using this method if possible, as it may be removed or changed without warning.
157 158 159 |
# File 'os/mac/mach.rb', line 157 def dylib? mach_data.any? { |m| m.fetch(:type) == :dylib } end |
#dylib_id(*args, **options, &block) ⇒ T.untyped
This method is part of a private API. This method may only be used in the Homebrew/brew repository. Third parties should avoid using this method if possible, as it may be removed or changed without warning.
237 |
# File 'sorbet/rbi/parlour.rbi', line 237 def dylib_id(*args, **, &block); end |
#dynamically_linked_libraries(except: :none, resolve_variable_references: true) ⇒ Object
This method is part of a private API. This method may only be used in the Homebrew/brew repository. Third parties should avoid using this method if possible, as it may be removed or changed without warning.
88 89 90 91 92 93 94 |
# File 'os/mac/mach.rb', line 88 def dynamically_linked_libraries(except: :none, resolve_variable_references: true) lcs = macho.dylib_load_commands.reject { |lc| lc.type == except } names = lcs.map { |lc| lc.name.to_s }.uniq names.map! { resolve_variable_name(_1) } if resolve_variable_references names end |
#i386? ⇒ Boolean
This method is part of a private API. This method may only be used in the Homebrew/brew repository. Third parties should avoid using this method if possible, as it may be removed or changed without warning.
141 142 143 |
# File 'os/mac/mach.rb', line 141 def i386? arch == :i386 end |
#mach_o_bundle? ⇒ Boolean
This method is part of a private API. This method may only be used in the Homebrew/brew repository. Third parties should avoid using this method if possible, as it may be removed or changed without warning.
167 168 169 |
# File 'os/mac/mach.rb', line 167 def mach_o_bundle? mach_data.any? { |m| m.fetch(:type) == :bundle } end |
#mach_o_executable? ⇒ Boolean Also known as: binary_executable?
This method is part of a private API. This method may only be used in the Homebrew/brew repository. Third parties should avoid using this method if possible, as it may be removed or changed without warning.
161 162 163 |
# File 'os/mac/mach.rb', line 161 def mach_o_executable? mach_data.any? { |m| m.fetch(:type) == :executable } end |
#ppc64? ⇒ Boolean
This method is part of a private API. This method may only be used in the Homebrew/brew repository. Third parties should avoid using this method if possible, as it may be removed or changed without warning.
153 154 155 |
# File 'os/mac/mach.rb', line 153 def ppc64? arch == :ppc64 end |
#ppc7400? ⇒ Boolean
This method is part of a private API. This method may only be used in the Homebrew/brew repository. Third parties should avoid using this method if possible, as it may be removed or changed without warning.
149 150 151 |
# File 'os/mac/mach.rb', line 149 def ppc7400? arch == :ppc7400 end |
#resolve_rpath(name) ⇒ Object
This method is part of a private API. This method may only be used in the Homebrew/brew repository. Third parties should avoid using this method if possible, as it may be removed or changed without warning.
116 117 118 119 120 121 122 123 |
# File 'os/mac/mach.rb', line 116 def resolve_rpath(name) target = T.let(nil, T.nilable(String)) return unless rpaths(resolve_variable_references: true).find do |rpath| File.exist?(target = File.join(rpath, name.delete_prefix("@rpath"))) end target end |
#resolve_variable_name(name, resolve_rpaths: true) ⇒ Object
This method is part of a private API. This method may only be used in the Homebrew/brew repository. Third parties should avoid using this method if possible, as it may be removed or changed without warning.
104 105 106 107 108 109 110 111 112 113 114 |
# File 'os/mac/mach.rb', line 104 def resolve_variable_name(name, resolve_rpaths: true) if name.start_with? "@loader_path" Pathname(name.sub("@loader_path", dirname)).cleanpath.to_s elsif name.start_with?("@executable_path") && binary_executable? Pathname(name.sub("@executable_path", dirname)).cleanpath.to_s elsif resolve_rpaths && name.start_with?("@rpath") && (target = resolve_rpath(name)).present? target else name end end |
#rpaths(resolve_variable_references: true) ⇒ Object
This method is part of a private API. This method may only be used in the Homebrew/brew repository. Third parties should avoid using this method if possible, as it may be removed or changed without warning.
96 97 98 99 100 101 102 |
# File 'os/mac/mach.rb', line 96 def rpaths(resolve_variable_references: true) names = macho.rpaths # Don't recursively resolve rpaths to avoid infinite loops. names.map! { |name| resolve_variable_name(name, resolve_rpaths: false) } if resolve_variable_references names end |
#universal? ⇒ Boolean
This method is part of a private API. This method may only be used in the Homebrew/brew repository. Third parties should avoid using this method if possible, as it may be removed or changed without warning.
137 138 139 |
# File 'os/mac/mach.rb', line 137 def universal? arch == :universal end |
#x86_64? ⇒ Boolean
This method is part of a private API. This method may only be used in the Homebrew/brew repository. Third parties should avoid using this method if possible, as it may be removed or changed without warning.
145 146 147 |
# File 'os/mac/mach.rb', line 145 def x86_64? arch == :x86_64 end |