 05568420c0
			
		
	
	
		05568420c0
		
	
	
	
	
		
			
			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
 |