aboutsummaryrefslogtreecommitdiff
path: root/llvm/test/tools/llvm-cxxfilt/no-params.test
blob: cf1eac27aa02d1cd4bcd200999cd4c7af48efad8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
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