This revision was landed with ongoing or failed builds. This revision was automatically updated to reflect the committed changes. Closed by commit rGdcd7664f92d3: Add -fno-visibility-inlines-hidden option (authored by kongyi). Herald added a project: clang. Herald added a subscriber: cfe-commits.
Changed prior to commit: https://reviews.llvm.org/D103537?vs=349470&id=349492#toc Repository: rG LLVM Github Monorepo CHANGES SINCE LAST ACTION https://reviews.llvm.org/D103537/new/ https://reviews.llvm.org/D103537 Files: clang/include/clang/Driver/Options.td clang/lib/Driver/ToolChains/Clang.cpp clang/test/Driver/visibility-inlines-hidden.cpp Index: clang/test/Driver/visibility-inlines-hidden.cpp =================================================================== --- /dev/null +++ clang/test/Driver/visibility-inlines-hidden.cpp @@ -0,0 +1,7 @@ +// RUN: %clang -### -S -fno-visibility-inlines-hidden -fvisibility-inlines-hidden %s 2>&1 | \ +// RUN: FileCheck -check-prefix=CHECK-1 %s +// CHECK-1: "-fvisibility-inlines-hidden" + +// RUN: %clang -### -S -fvisibility-inlines-hidden -fno-visibility-inlines-hidden %s 2>&1 | \ +// RUN: FileCheck -check-prefix=CHECK-2 %s +// CHECK-2-NOT: "-fvisibility-inlines-hidden" Index: clang/lib/Driver/ToolChains/Clang.cpp =================================================================== --- clang/lib/Driver/ToolChains/Clang.cpp +++ clang/lib/Driver/ToolChains/Clang.cpp @@ -5644,7 +5644,11 @@ << A->getAsString(Args) << TripleStr; } - Args.AddLastArg(CmdArgs, options::OPT_fvisibility_inlines_hidden); + + if (Args.hasFlag(options::OPT_fvisibility_inlines_hidden, + options::OPT_fno_visibility_inlines_hidden, false)) + CmdArgs.push_back("-fvisibility-inlines-hidden"); + Args.AddLastArg(CmdArgs, options::OPT_fvisibility_inlines_hidden_static_local_var, options::OPT_fno_visibility_inlines_hidden_static_local_var); Args.AddLastArg(CmdArgs, options::OPT_fvisibility_global_new_delete_hidden); Index: clang/include/clang/Driver/Options.td =================================================================== --- clang/include/clang/Driver/Options.td +++ clang/include/clang/Driver/Options.td @@ -2675,9 +2675,10 @@ ShouldParseIf<fvisibility_from_dllstorageclass.KeyPath>; def fvisibility_EQ : Joined<["-"], "fvisibility=">, Group<f_Group>, HelpText<"Set the default symbol visibility for all global declarations">, Values<"hidden,default">; -def fvisibility_inlines_hidden : Flag<["-"], "fvisibility-inlines-hidden">, Group<f_Group>, - HelpText<"Give inline C++ member functions hidden visibility by default">, - Flags<[CC1Option]>, MarshallingInfoFlag<LangOpts<"InlineVisibilityHidden">>; +defm visibility_inlines_hidden : BoolFOption<"visibility-inlines-hidden", + LangOpts<"InlineVisibilityHidden">, DefaultFalse, + PosFlag<SetTrue, [CC1Option], "Give inline C++ member functions hidden visibility by default">, + NegFlag<SetFalse>>; defm visibility_inlines_hidden_static_local_var : BoolFOption<"visibility-inlines-hidden-static-local-var", LangOpts<"VisibilityInlinesHiddenStaticLocalVar">, DefaultFalse, PosFlag<SetTrue, [CC1Option], "When -fvisibility-inlines-hidden is enabled, static variables in"
Index: clang/test/Driver/visibility-inlines-hidden.cpp =================================================================== --- /dev/null +++ clang/test/Driver/visibility-inlines-hidden.cpp @@ -0,0 +1,7 @@ +// RUN: %clang -### -S -fno-visibility-inlines-hidden -fvisibility-inlines-hidden %s 2>&1 | \ +// RUN: FileCheck -check-prefix=CHECK-1 %s +// CHECK-1: "-fvisibility-inlines-hidden" + +// RUN: %clang -### -S -fvisibility-inlines-hidden -fno-visibility-inlines-hidden %s 2>&1 | \ +// RUN: FileCheck -check-prefix=CHECK-2 %s +// CHECK-2-NOT: "-fvisibility-inlines-hidden" Index: clang/lib/Driver/ToolChains/Clang.cpp =================================================================== --- clang/lib/Driver/ToolChains/Clang.cpp +++ clang/lib/Driver/ToolChains/Clang.cpp @@ -5644,7 +5644,11 @@ << A->getAsString(Args) << TripleStr; } - Args.AddLastArg(CmdArgs, options::OPT_fvisibility_inlines_hidden); + + if (Args.hasFlag(options::OPT_fvisibility_inlines_hidden, + options::OPT_fno_visibility_inlines_hidden, false)) + CmdArgs.push_back("-fvisibility-inlines-hidden"); + Args.AddLastArg(CmdArgs, options::OPT_fvisibility_inlines_hidden_static_local_var, options::OPT_fno_visibility_inlines_hidden_static_local_var); Args.AddLastArg(CmdArgs, options::OPT_fvisibility_global_new_delete_hidden); Index: clang/include/clang/Driver/Options.td =================================================================== --- clang/include/clang/Driver/Options.td +++ clang/include/clang/Driver/Options.td @@ -2675,9 +2675,10 @@ ShouldParseIf<fvisibility_from_dllstorageclass.KeyPath>; def fvisibility_EQ : Joined<["-"], "fvisibility=">, Group<f_Group>, HelpText<"Set the default symbol visibility for all global declarations">, Values<"hidden,default">; -def fvisibility_inlines_hidden : Flag<["-"], "fvisibility-inlines-hidden">, Group<f_Group>, - HelpText<"Give inline C++ member functions hidden visibility by default">, - Flags<[CC1Option]>, MarshallingInfoFlag<LangOpts<"InlineVisibilityHidden">>; +defm visibility_inlines_hidden : BoolFOption<"visibility-inlines-hidden", + LangOpts<"InlineVisibilityHidden">, DefaultFalse, + PosFlag<SetTrue, [CC1Option], "Give inline C++ member functions hidden visibility by default">, + NegFlag<SetFalse>>; defm visibility_inlines_hidden_static_local_var : BoolFOption<"visibility-inlines-hidden-static-local-var", LangOpts<"VisibilityInlinesHiddenStaticLocalVar">, DefaultFalse, PosFlag<SetTrue, [CC1Option], "When -fvisibility-inlines-hidden is enabled, static variables in"
_______________________________________________ cfe-commits mailing list cfe-commits@lists.llvm.org https://lists.llvm.org/cgi-bin/mailman/listinfo/cfe-commits