| RUN: llvm-cxxfilt -n _Z3fooILZ3BarEET_f _Z3fooIPFcfEET_d _ZN1f2baC2ERKNS_2baIT_EE _Z3foov.123 | FileCheck %s --check-prefix=CHECK-PARAMS |
| RUN: llvm-cxxfilt -p -n _Z3fooILZ3BarEET_f _Z3fooIPFcfEET_d _ZN1f2baC2ERKNS_2baIT_EE _Z3foov.123 | FileCheck %s --check-prefix=CHECK-NO-PARAMS --match-full-lines |
| RUN: llvm-cxxfilt --no-params -n _Z3fooILZ3BarEET_f _Z3fooIPFcfEET_d _ZN1f2baC2ERKNS_2baIT_EE _Z3foov.123 | FileCheck %s --check-prefix=CHECK-NO-PARAMS --match-full-lines |
| |
| # Check that -p or --no-params flag omits function parameters and the return |
| # type. |
| |
| CHECK-PARAMS: Bar foo<Bar>(float) |
| CHECK-NO-PARAMS: foo<Bar> |
| |
| # Check that only the top-level function is impacted by the switch, and that |
| # nested function types in the encoding (e.g. where a function type is being |
| # used as a template parameter) still include their parameters. |
| # |
| # template <typename T> T foo(double); |
| # typedef char (*F)(float); |
| # F foo<F>(double) |
| |
| CHECK-PARAMS: char (*foo<char (*)(float)>(double))(float) |
| CHECK-NO-PARAMS: foo<char (*)(float)> |
| |
| # Use an invalid mangled name broken in the function parameters to check how -p |
| # or --no-params flag works. If the option is given we should be able to |
| # demangle the function name just fine. If it is not given, demangling will fail |
| # because of the invalid params. |
| |
| CHECK-PARAMS: _ZN1f2baC2ERKNS_2baIT_EE |
| CHECK-NO-PARAMS: f::ba::ba |
| |
| # Check that a vendor specific suffix is also omitted when --no-params is |
| # specified. This matches c++filt's behaviour. |
| |
| CHECK-PARAMS: foo() (.123) |
| CHECK-NO-PARAMS: foo |