mirror of
https://github.com/apple/swift.git
synced 2025-12-14 20:36:38 +01:00
PrintAsClang is supposed to emit declarations in the same order regardless of the compiler’s internal state, but we have repeatedly found that our current criteria are inadequate, resulting in non-functionality-affecting changes to generated header content. Add a diagnostic that’s emitted when this happens soliciting a bug report. Since there *should* be no cases where the compiler fails to order declarations, this diagnostic is never actually emitted. Instead, we test this change by enabling `-verify` on nearly all PrintAsClang tests to make sure they are unaffected. This did demonstrate a missing criterion that only mattered in C++ mode: extensions that varied only in their generic signature were not sorted stably. Add a sort criterion for this.
28 lines
1001 B
Objective-C
28 lines
1001 B
Objective-C
// RUN: %empty-directory(%t)
|
|
// RUN: %target-swift-frontend(mock-sdk: %clang-importer-sdk) %S/../Inputs/empty.swift -typecheck -verify -emit-objc-header-path %t/empty.h
|
|
// RUN: %clang -F %clang-importer-sdk-path/frameworks -E -fobjc-arc -fmodules -isysroot %clang-importer-sdk-path -I %t %s | %FileCheck %s
|
|
|
|
// REQUIRES: objc_interop
|
|
|
|
#import "empty.h"
|
|
|
|
@class ABC; // CHECK-LABEL: @class ABC;
|
|
SWIFT_CLASS(abc) // CHECK-NEXT: __attribute__((objc_runtime_name(abc)))
|
|
@interface ABC // CHECK-NEXT: @interface
|
|
@end
|
|
|
|
@class DEF; // CHECK-LABEL: @class DEF;
|
|
SWIFT_CLASS_NAMED(def) // CHECK-NEXT: __attribute__((swift_name(def)))
|
|
@interface DEF // CHECK-NEXT: @interface
|
|
@end
|
|
|
|
@protocol AAA; // CHECK-LABEL: @protocol AAA;
|
|
SWIFT_PROTOCOL(aaa) // CHECK-NEXT: __attribute__((objc_runtime_name(aaa)))
|
|
@protocol AAA // CHECK-NEXT: @protocol
|
|
@end
|
|
|
|
@protocol BBB; // CHECK-LABEL: @protocol BBB;
|
|
SWIFT_PROTOCOL_NAMED(bbb) // CHECK-NEXT: __attribute__((swift_name(bbb)))
|
|
@protocol BBB // CHECK-NEXT: @protocol
|
|
@end
|