mirror of
https://github.com/Gericom/teak-llvm.git
synced 2025-06-27 15:28:53 -04:00

target Objective-C runtime down to the frontend: break this down into a single target runtime kind and version, and compute all the relevant information from that. This makes it relatively painless to add support for new runtimes to the compiler. Make the new -cc1 flag, -fobjc-runtime=blah-x.y.z, available at the driver level as a better and more general alternative to -fgnu-runtime and -fnext-runtime. This new concept of an Objective-C runtime also encompasses what we were previously separating out as the "Objective-C ABI", so fragile vs. non-fragile runtimes are now really modelled as different kinds of runtime, paving the way for better overall differentiation. As a sort of special case, continue to accept the -cc1 flag -fobjc-runtime-has-weak, as a sop to PLCompatibilityWeak. I won't go so far as to say "no functionality change", even ignoring the new driver flag, but subtle changes in driver semantics are almost certainly not intended. llvm-svn: 158793
44 lines
1.1 KiB
Objective-C
44 lines
1.1 KiB
Objective-C
// RUN: %clang_cc1 %s -emit-llvm -triple x86_64-apple-darwin -fobjc-runtime=macosx-fragile-10.5 -o - | FileCheck %s
|
|
// Bitfield references must not touch memory outside of the enclosing
|
|
// struct. Radar 7639995
|
|
typedef signed char BOOL;
|
|
@protocol NSObject
|
|
- (id)init;
|
|
@end
|
|
@interface NSObject <NSObject> {}
|
|
@end
|
|
@interface IMAVChatParticipant : NSObject {
|
|
int _ardRole;
|
|
int _state;
|
|
int _avRelayStatus;
|
|
int _chatEndedReason;
|
|
int _chatError;
|
|
unsigned _sendingAudio:1;
|
|
unsigned _sendingVideo:1;
|
|
unsigned _sendingAuxVideo:1;
|
|
unsigned _audioMuted:1;
|
|
unsigned _videoPaused:1;
|
|
unsigned _networkStalled:1;
|
|
unsigned _isInitiator:1;
|
|
unsigned _isAOLInterop:1;
|
|
unsigned _isRecording:1;
|
|
unsigned _isUsingICE:1;
|
|
}
|
|
@end
|
|
@implementation IMAVChatParticipant
|
|
- (id) init {
|
|
self = [super init];
|
|
if ( self ) {
|
|
BOOL blah = (BOOL)1;
|
|
// We're expecting these three bitfield assignments will generate i8 stores.
|
|
_sendingAudio = (BOOL)1;
|
|
_isUsingICE = (BOOL)1;
|
|
_isUsingICE = blah;
|
|
// CHECK: store i8
|
|
// CHECK: store i8
|
|
// CHECK: store i8
|
|
}
|
|
return self;
|
|
}
|
|
@end
|