forked from OSchip/llvm-project
[llvm-strip] Add --strip-symbol
Differential revision: https://reviews.llvm.org/D57440 llvm-svn: 352746
This commit is contained in:
parent
a001008a09
commit
2267c58aea
|
@ -1,6 +1,8 @@
|
|||
# RUN: yaml2obj %s > %t
|
||||
# RUN: llvm-objcopy --strip-symbol baz -N bar %t %t2
|
||||
# RUN: llvm-readobj --symbols --sections %t2 | FileCheck %s
|
||||
# RUN: llvm-strip --strip-symbol baz -N bar %t -o %t3
|
||||
# RUN: llvm-readobj --symbols --sections %t3 | FileCheck %s
|
||||
|
||||
!ELF
|
||||
FileHeader:
|
||||
|
|
|
@ -480,19 +480,22 @@ DriverConfig parseStripOptions(ArrayRef<const char *> ArgsArr) {
|
|||
Config.StripAll = InputArgs.hasArg(STRIP_strip_all);
|
||||
Config.StripAllGNU = InputArgs.hasArg(STRIP_strip_all_gnu);
|
||||
|
||||
if (!Config.StripDebug && !Config.StripUnneeded &&
|
||||
Config.DiscardMode == DiscardType::None && !Config.StripAllGNU)
|
||||
Config.StripAll = true;
|
||||
|
||||
for (auto Arg : InputArgs.filtered(STRIP_keep_section))
|
||||
Config.KeepSection.push_back(Arg->getValue());
|
||||
|
||||
for (auto Arg : InputArgs.filtered(STRIP_remove_section))
|
||||
Config.ToRemove.push_back(Arg->getValue());
|
||||
|
||||
for (auto Arg : InputArgs.filtered(STRIP_strip_symbol))
|
||||
Config.SymbolsToRemove.push_back(Arg->getValue());
|
||||
|
||||
for (auto Arg : InputArgs.filtered(STRIP_keep_symbol))
|
||||
Config.SymbolsToKeep.push_back(Arg->getValue());
|
||||
|
||||
if (!Config.StripDebug && !Config.StripUnneeded &&
|
||||
Config.DiscardMode == DiscardType::None && !Config.StripAllGNU && Config.SymbolsToRemove.empty())
|
||||
Config.StripAll = true;
|
||||
|
||||
Config.DeterministicArchives =
|
||||
InputArgs.hasFlag(STRIP_enable_deterministic_archives,
|
||||
STRIP_disable_deterministic_archives, /*default=*/true);
|
||||
|
|
|
@ -51,6 +51,10 @@ defm remove_section : Eq<"remove-section", "Remove <section>">,
|
|||
MetaVarName<"section">;
|
||||
def R : JoinedOrSeparate<["-"], "R">, Alias<remove_section>;
|
||||
|
||||
defm strip_symbol : Eq<"strip-symbol", "Strip <symbol>">,
|
||||
MetaVarName<"symbol">;
|
||||
def N : JoinedOrSeparate<["-"], "N">, Alias<strip_symbol>;
|
||||
|
||||
defm keep_section : Eq<"keep-section", "Keep <section>">,
|
||||
MetaVarName<"section">;
|
||||
defm keep_symbol : Eq<"keep-symbol", "Do not remove symbol <symbol>">,
|
||||
|
|
Loading…
Reference in New Issue