Skip to content

Commit

Permalink
Only treat symlinks in taps as alias paths.
Browse files Browse the repository at this point in the history
  • Loading branch information
reitermarkus committed Feb 17, 2024
1 parent 17dba5c commit ad61e5b
Showing 1 changed file with 22 additions and 8 deletions.
30 changes: 22 additions & 8 deletions Library/Homebrew/formulary.rb
Original file line number Diff line number Diff line change
Expand Up @@ -599,10 +599,26 @@ def self.try_new(ref, from: T.unsafe(nil), warn: false)

return unless path.expand_path.exist?

options = if path.symlink?
alias_path = path
path = alias_path.resolved_path
{ alias_path: alias_path }
options = if (tap = Tap.from_path(path))
# Only treat symlinks in taps as aliases.
if path.symlink?
alias_path = path
path = alias_path.resolved_path

{
alias_path: alias_path,
tap: tap,
}
else
{
tap: tap,
}
end
elsif (tap = Homebrew::API.tap_from_source_download(path))
# Don't treat cache symlinks as aliases.
{
tap: tap,
}
else
{}
end
Expand All @@ -612,15 +628,13 @@ def self.try_new(ref, from: T.unsafe(nil), warn: false)
new(path, **options)
end

sig { params(path: T.any(Pathname, String), alias_path: Pathname).void }
def initialize(path, alias_path: T.unsafe(nil))
sig { params(path: T.any(Pathname, String), alias_path: Pathname, tap: Tap).void }
def initialize(path, alias_path: T.unsafe(nil), tap: T.unsafe(nil))
path = Pathname(path).expand_path
name = path.basename(".rb").to_s
alias_path = alias_path&.expand_path
alias_dir = alias_path&.dirname

tap = Tap.from_path(path) || Homebrew::API.tap_from_source_download(path)

options = {
alias_path: (alias_path if alias_dir == tap&.alias_dir),
tap: tap,
Expand Down

0 comments on commit ad61e5b

Please sign in to comment.