forked from OSchip/llvm-project
parent
2620c60545
commit
4908f9c0d0
|
@ -75,7 +75,7 @@ void check_free_no_error() {
|
|||
}
|
||||
|
||||
void check_free_use_after_free() {
|
||||
OSArray *arr = OSArray::withCapacity(10); // expected-note{{Call to function 'OSArray::withCapacity' returns an OSObject of type struct OSArray * with a +1 retain count}}
|
||||
OSArray *arr = OSArray::withCapacity(10); // expected-note{{Call to method 'OSArray::withCapacity' returns an OSObject of type OSArray with a +1 retain count}}
|
||||
arr->retain(); // expected-note{{Reference count incremented. The object now has a +2 retain count}}
|
||||
arr->free(); // expected-note{{Object released}}
|
||||
arr->retain(); // expected-warning{{Reference-counted object is used after it is released}}
|
||||
|
@ -83,13 +83,13 @@ void check_free_use_after_free() {
|
|||
}
|
||||
|
||||
unsigned int check_leak_explicit_new() {
|
||||
OSArray *arr = new OSArray; // expected-note{{Operator new returns an OSObject of type struct OSArray * with a +1 retain count}}
|
||||
return arr->getCount(); // expected-note{{Object leaked: allocated object of type struct OSArray * is not referenced later in this execution path and has a retain count of +1}}
|
||||
// expected-warning@-1{{Potential leak of an object of type struct OSArray *}}
|
||||
OSArray *arr = new OSArray; // expected-note{{Operator new returns an OSObject of type OSArray with a +1 retain count}}
|
||||
return arr->getCount(); // expected-note{{Object leaked: allocated object of type OSArray is not referenced later in this execution path and has a retain count of +1}}
|
||||
// expected-warning@-1{{Potential leak of an object of type OSArray}}
|
||||
}
|
||||
|
||||
unsigned int check_leak_factory() {
|
||||
OSArray *arr = OSArray::withCapacity(10); // expected-note{{Call to function 'OSArray::withCapacity' returns an OSObject of type struct OSArray * with a +1 retain count}}
|
||||
OSArray *arr = OSArray::withCapacity(10); // expected-note{{Call to method 'OSArray::withCapacity' returns an OSObject of type OSArray with a +1 retain count}}
|
||||
return arr->getCount(); // expected-note{{Object leaked: object allocated and stored into 'arr' is not referenced later in this execution path and has a retain count of +1}}
|
||||
// expected-warning@-1{{Potential leak of an object stored into 'arr'}}
|
||||
}
|
||||
|
|
|
@ -2,7 +2,7 @@
|
|||
|
||||
// The number of supported attributes should never go down!
|
||||
|
||||
// CHECK: #pragma clang attribute supports 132 attributes:
|
||||
// CHECK: #pragma clang attribute supports 133 attributes:
|
||||
// CHECK-NEXT: AMDGPUFlatWorkGroupSize (SubjectMatchRule_function)
|
||||
// CHECK-NEXT: AMDGPUNumSGPR (SubjectMatchRule_function)
|
||||
// CHECK-NEXT: AMDGPUNumVGPR (SubjectMatchRule_function)
|
||||
|
@ -86,8 +86,8 @@
|
|||
// CHECK-NEXT: NoThrow (SubjectMatchRule_function)
|
||||
// CHECK-NEXT: NotTailCalled (SubjectMatchRule_function)
|
||||
// CHECK-NEXT: OSConsumed (SubjectMatchRule_variable_is_parameter)
|
||||
// CHECK-NEXT: OSReturnsNotRetained (SubjectMatchRule_function, SubjectMatchRule_objc_method)
|
||||
// CHECK-NEXT: OSReturnsRetained (SubjectMatchRule_function, SubjectMatchRule_objc_method)
|
||||
// CHECK-NEXT: OSReturnsNotRetained (SubjectMatchRule_function, SubjectMatchRule_objc_method, SubjectMatchRule_objc_property)
|
||||
// CHECK-NEXT: OSReturnsRetained (SubjectMatchRule_function, SubjectMatchRule_objc_method, SubjectMatchRule_objc_property)
|
||||
// CHECK-NEXT: ObjCBoxable (SubjectMatchRule_record)
|
||||
// CHECK-NEXT: ObjCBridge (SubjectMatchRule_record, SubjectMatchRule_type_alias)
|
||||
// CHECK-NEXT: ObjCBridgeMutable (SubjectMatchRule_record)
|
||||
|
|
Loading…
Reference in New Issue