Skip to content
Snippets Groups Projects
Commit dfe79870 authored by Adrian Prantl's avatar Adrian Prantl
Browse files

Test-case golfing.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@312175 91177308-0d34-0410-b5e6-96231b3b80d8
parent 57fd59f6
No related branches found
No related tags found
No related merge requests found
// RUN: %clang_cc1 -emit-llvm -triple i686-pc-windows-msvc19.0.24213 -gcodeview -debug-info-kind=limited -std=c++14 %s -o - | FileCheck %s // RUN: %clang_cc1 -emit-llvm -triple i686-pc-windows-msvc19.0.24213 -gcodeview -debug-info-kind=limited -std=c++14 %s -o - | FileCheck %s
// PR33997. // PR33997.
struct already_AddRefed { struct WithDtor {
~already_AddRefed(); ~WithDtor();
}; };
struct RefPtr { struct Base {
operator int *(); Base(WithDtor);
}; };
struct ServoCssRulesStrong { class Forward : Base {
already_AddRefed Consume(); using Base::Base;
}; };
struct GroupRule { class A : Forward {
GroupRule(already_AddRefed); A();
}; };
class ConditionRule : GroupRule { class B : Forward {
using GroupRule::GroupRule; B();
}; };
class CSSMediaRule : ConditionRule { A::A() : Forward(WithDtor()) {}
using ConditionRule::ConditionRule;
};
class CSSMozDocumentRule : ConditionRule {
using ConditionRule::ConditionRule;
};
class ServoDocumentRule : CSSMozDocumentRule {
ServoDocumentRule(RefPtr);
};
class ServoMediaRule : CSSMediaRule {
ServoMediaRule(RefPtr);
};
ServoCssRulesStrong Servo_MediaRule_GetRules(int *);
ServoCssRulesStrong Servo_DocumentRule_GetRules(int *);
ServoDocumentRule::ServoDocumentRule(RefPtr aRawRule)
: CSSMozDocumentRule(Servo_DocumentRule_GetRules(aRawRule).Consume()) {}
ServoMediaRule::ServoMediaRule(RefPtr aRawRule) B::B() : Forward(WithDtor()) {}
: CSSMediaRule(Servo_MediaRule_GetRules(aRawRule).Consume()) {}
// CHECK: define{{.*}}ServoMediaRule // CHECK: define{{.*}}A
// CHECK-NOT: {{ ret }} // CHECK-NOT: {{ ret }}
// CHECK: store %class.ConditionRule* % // CHECK: store %class.Forward* %
// CHECK-SAME: %class.ConditionRule** % // CHECK-SAME: %class.Forward** %
// CHECK-SAME: !dbg ![[INL:[0-9]+]] // CHECK-SAME: !dbg ![[INL:[0-9]+]]
// CHECK: ![[INL]] = !DILocation(line: 16, scope: ![[SP:[0-9]+]], inlinedAt: // CHECK: ![[INL]] = !DILocation(line: 10, scope: ![[SP:[0-9]+]], inlinedAt:
// CHECK: ![[SP]] = distinct !DISubprogram(name: "GroupRule", {{.*}}isDefinition: true // CHECK: ![[SP]] = distinct !DISubprogram(name: "Base", {{.*}}isDefinition: true
0% Loading or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment