 97ad3567d1
			
		
	
	
		97ad3567d1
		
			
		
	
	
	
	
		
			
			- in `brew.sh` split the `case` into those cases that take a single or no arguments and those that take multiple arguments or handle multiple commands. This considerably speeds up the `brew shellenv bash` case that wasn't being handled here before. - add `setup-ruby` to the list of commands that can be called quickly by `brew.sh` without additional setup. This speeds up the `brew setup-ruby` no-op case by ~10x. - add a parameter to `setup-ruby` to avoid running Bundler if the command doesn't need it. This makes many more cases for `brew setup-ruby` to be no-op cases. - Remove the (now) unused `HOMEBREW_RUBY3` check in `setup-ruby`. - Improve argument handling in `command_path.sh` to allow it to be used as a function in `setup-ruby.sh`. - Add a new RuboCop to check usage of `install_bundler_gems!` is only inside `dev-cmd` (or a few other acceptable places). - Use new `processed_source.file_path` API in `formula_cop.rb`
		
			
				
	
	
		
			22 lines
		
	
	
		
			573 B
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			22 lines
		
	
	
		
			573 B
		
	
	
	
		
			Ruby
		
	
	
	
	
	
| # typed: true
 | |
| # frozen_string_literal: true
 | |
| 
 | |
| module RuboCop
 | |
|   module Cop
 | |
|     module Homebrew
 | |
|       # Enforces the use of `Homebrew.install_bundler_gems!` in dev-cmd.
 | |
|       class InstallBundlerGems < Base
 | |
|         MSG = "Only use `Homebrew.install_bundler_gems!` in dev-cmd."
 | |
|         RESTRICT_ON_SEND = [:install_bundler_gems!].freeze
 | |
| 
 | |
|         def on_send(node)
 | |
|           file_path = processed_source.file_path
 | |
|           return if file_path.match?(%r{/(dev-cmd/.+|standalone/init|startup/bootsnap)\.rb\z})
 | |
| 
 | |
|           add_offense(node)
 | |
|         end
 | |
|       end
 | |
|     end
 | |
|   end
 | |
| end
 |