 0efa6aab32
			
		
	
	
		0efa6aab32
		
	
	
	
	
		
			
			Blindly using args[0] misleads users when an env is passed.
Before:
```
==> go build -ldflags=-s -w -X main.version=1.64.8 -X main.commit=8b37f14 -X main.date=2025-03-17T16:54:02Z ./cmd/golangci-lint
brew: command not found: {"SHELL"=>"bash"}
Error: Failure while executing; `\{\"SHELL\"=\>\"bash\"\} /opt/homebrew/Cellar/golangci-lint@1/1.64.8/bin/golangci-lint completion bash` exited with 127. Here's the output:
```
After:
```
==> go build -ldflags=-s -w -X main.version=1.64.8 -X main.commit=8b37f14 -X main.date=2025-03-17T16:54:02Z ./cmd/golangci-lint
brew: command not found: /opt/homebrew/Cellar/golangci-lint@1/1.64.8/bin/golangci-lint
Error: Failure while executing; `\{\"SHELL\"=\>\"bash\"\} /opt/homebrew/Cellar/golangci-lint@1/1.64.8/bin/golangci-lint completion bash` exited with 127. Here's the output:
```
		
	
			
		
			
				
	
	
		
			72 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
			
		
		
	
	
			72 lines
		
	
	
		
			1.9 KiB
		
	
	
	
		
			Ruby
		
	
	
	
	
	
| # typed: true # rubocop:todo Sorbet/StrictSigil
 | |
| # frozen_string_literal: true
 | |
| 
 | |
| module Utils
 | |
|   IO_DEFAULT_BUFFER_SIZE = 4096
 | |
|   private_constant :IO_DEFAULT_BUFFER_SIZE
 | |
| 
 | |
|   def self.popen_read(*args, safe: false, **options, &block)
 | |
|     output = popen(args, "rb", options, &block)
 | |
|     return output if !safe || $CHILD_STATUS.success?
 | |
| 
 | |
|     raise ErrorDuringExecution.new(args, status: $CHILD_STATUS, output: [[:stdout, output]])
 | |
|   end
 | |
| 
 | |
|   def self.safe_popen_read(*args, **options, &block)
 | |
|     popen_read(*args, safe: true, **options, &block)
 | |
|   end
 | |
| 
 | |
|   def self.popen_write(*args, safe: false, **options)
 | |
|     output = ""
 | |
|     popen(args, "w+b", options) do |pipe|
 | |
|       # Before we yield to the block, capture as much output as we can
 | |
|       loop do
 | |
|         output += pipe.read_nonblock(IO_DEFAULT_BUFFER_SIZE)
 | |
|       rescue IO::WaitReadable, EOFError
 | |
|         break
 | |
|       end
 | |
| 
 | |
|       yield pipe
 | |
|       pipe.close_write
 | |
|       pipe.wait_readable
 | |
| 
 | |
|       # Capture the rest of the output
 | |
|       output += pipe.read
 | |
|       output.freeze
 | |
|     end
 | |
|     return output if !safe || $CHILD_STATUS.success?
 | |
| 
 | |
|     raise ErrorDuringExecution.new(args, status: $CHILD_STATUS, output: [[:stdout, output]])
 | |
|   end
 | |
| 
 | |
|   def self.safe_popen_write(*args, **options, &block)
 | |
|     popen_write(*args, safe: true, **options, &block)
 | |
|   end
 | |
| 
 | |
|   def self.popen(args, mode, options = {})
 | |
|     IO.popen("-", mode) do |pipe|
 | |
|       if pipe
 | |
|         return pipe.read unless block_given?
 | |
| 
 | |
|         yield pipe
 | |
|       else
 | |
|         options[:err] ||= File::NULL unless ENV["HOMEBREW_STDERR"]
 | |
|         cmd = if args[0].is_a? Hash
 | |
|           args[1]
 | |
|         else
 | |
|           args[0]
 | |
|         end
 | |
|         begin
 | |
|           exec(*args, options)
 | |
|         rescue Errno::ENOENT
 | |
|           $stderr.puts "brew: command not found: #{cmd}" if options[:err] != :close
 | |
|           exit! 127
 | |
|         rescue SystemCallError
 | |
|           $stderr.puts "brew: exec failed: #{cmd}" if options[:err] != :close
 | |
|           exit! 1
 | |
|         end
 | |
|       end
 | |
|     end
 | |
|   end
 | |
| end
 |