mirror of
https://github.com/Homebrew/brew.git
synced 2025-07-14 16:09:03 +08:00

Rather than using the name of the keg for the key use the full path. This provides several advantages: - there's no need to invalidate the cache on a `brew upgrade` or `brew switch` - it's easier to figure out what cache entries can be removed and this can be done whenever a keg is removed by `brew uninstall` or `brew cleanup`. Also, ensure that an `install` (or `reinstall`, `upgrade`) always results in the cache being rebuilt for that keg (in case different options were used).
73 lines
1.8 KiB
Ruby
73 lines
1.8 KiB
Ruby
require "set"
|
|
require "cache_store"
|
|
|
|
#
|
|
# `LinkageCacheStore` provides methods to fetch and mutate linkage-specific data used
|
|
# by the `brew linkage` command
|
|
#
|
|
class LinkageCacheStore < CacheStore
|
|
# @param [String] keg_path
|
|
# @param [CacheStoreDatabase] database
|
|
# @return [nil]
|
|
def initialize(keg_path, database)
|
|
@keg_path = keg_path
|
|
super(database)
|
|
end
|
|
|
|
# Returns `true` if the database has any value for the current `keg_path`
|
|
#
|
|
# @return [Boolean]
|
|
def keg_exists?
|
|
!database.get(@keg_path).nil?
|
|
end
|
|
|
|
# Inserts dylib-related information into the cache if it does not exist or
|
|
# updates data into the linkage cache if it does exist
|
|
#
|
|
# @param [Hash] hash_values: hash containing KVPs of { :type => Hash }
|
|
# @return [nil]
|
|
def update!(hash_values)
|
|
hash_values.each_key do |type|
|
|
next if HASH_LINKAGE_TYPES.include?(type)
|
|
|
|
raise TypeError, <<~EOS
|
|
Can't update types that are not defined for the linkage store
|
|
EOS
|
|
end
|
|
|
|
database.set @keg_path, ruby_hash_to_json_string(hash_values)
|
|
end
|
|
|
|
# @param [Symbol] the type to fetch from the `LinkageCacheStore`
|
|
# @raise [TypeError] error if the type is not in `HASH_LINKAGE_TYPES`
|
|
# @return [Hash]
|
|
def fetch_type(type)
|
|
unless HASH_LINKAGE_TYPES.include?(type)
|
|
raise TypeError, <<~EOS
|
|
Can't fetch types that are not defined for the linkage store
|
|
EOS
|
|
end
|
|
|
|
return {} unless keg_exists?
|
|
|
|
fetch_hash_values(type)
|
|
end
|
|
|
|
# @return [nil]
|
|
def flush_cache!
|
|
database.delete(@keg_path)
|
|
end
|
|
|
|
private
|
|
|
|
HASH_LINKAGE_TYPES = [:keg_files_dylibs].freeze
|
|
|
|
# @param [Symbol] type
|
|
# @return [Hash]
|
|
def fetch_hash_values(type)
|
|
keg_cache = database.get(@keg_path)
|
|
return {} unless keg_cache
|
|
json_string_to_ruby_hash(keg_cache)[type.to_s]
|
|
end
|
|
end
|