From 1ec8a0488f2151ec96660ea966724493ad3b1f59 Mon Sep 17 00:00:00 2001 From: Caleb Xu Date: Sun, 12 Jan 2025 01:56:15 -0500 Subject: [PATCH] shims/super/cc: handle double dash in args --- Library/Homebrew/shims/super/cc | 17 +++++++++++++++-- 1 file changed, 15 insertions(+), 2 deletions(-) diff --git a/Library/Homebrew/shims/super/cc b/Library/Homebrew/shims/super/cc index 458a5dc236fa2..038eb59e0d58f 100755 --- a/Library/Homebrew/shims/super/cc +++ b/Library/Homebrew/shims/super/cc @@ -40,7 +40,9 @@ class Cmd def initialize(arg0, args) @arg0 = arg0 - @args = args.freeze + split_args = split_args_at_double_dash(args) + @args = split_args[0].freeze + @positional_args = split_args[1].freeze @config = ENV.fetch("HOMEBREW_CCCFG", "") @prefix = ENV["HOMEBREW_PREFIX"] @cellar = ENV["HOMEBREW_CELLAR"] @@ -57,6 +59,15 @@ class Cmd @keg_regex = %r{(#{Regexp.escape(opt)}|#{Regexp.escape(cellar)})/([\w+-.@]+)} end + def split_args_at_double_dash(args) + double_dash_index = args.find_index("--") + if double_dash_index + [args[...double_dash_index], args[double_dash_index..]] + else + [args, []] + end + end + def mode if @arg0 == "cpp" :cpp @@ -130,7 +141,7 @@ class Cmd end end - case mode + optional_args = case mode when :ccld cflags + args + cppflags + ldflags when :cxxld @@ -146,6 +157,8 @@ class Cmd when :ld ldflags + args end + + optional_args + @positional_args end def refurbished_args