35 lines
1.5 KiB
Text
35 lines
1.5 KiB
Text
|
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
|