]> granicus.if.org Git - clang/commitdiff
[Sema] Fix for build on some iOS programs.
authorLeonard Chan <leonardchan@google.com>
Mon, 20 May 2019 22:42:19 +0000 (22:42 +0000)
committerLeonard Chan <leonardchan@google.com>
Mon, 20 May 2019 22:42:19 +0000 (22:42 +0000)
Nullability attributes weren't being stripped for AttributedTypes that
were wrapped in a MacroQualifiedType. This fix adds a check for this
type and a test.

git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@361205 91177308-0d34-0410-b5e6-96231b3b80d8

lib/AST/Type.cpp
test/SemaObjC/nullability_macro.m [new file with mode: 0644]

index 590e534fbdf44997e4b88d6f428aaadb7fe1c773..101c5184a5ac56fcf83b907c963e35433685495e 100644 (file)
@@ -3929,7 +3929,11 @@ AttributedType::getImmediateNullability() const {
 }
 
 Optional<NullabilityKind> AttributedType::stripOuterNullability(QualType &T) {
-  if (auto attributed = dyn_cast<AttributedType>(T.getTypePtr())) {
+  QualType AttrTy = T;
+  if (auto MacroTy = dyn_cast<MacroQualifiedType>(T))
+    AttrTy = MacroTy->getUnderlyingType();
+
+  if (auto attributed = dyn_cast<AttributedType>(AttrTy)) {
     if (auto nullability = attributed->getImmediateNullability()) {
       T = attributed->getModifiedType();
       return nullability;
diff --git a/test/SemaObjC/nullability_macro.m b/test/SemaObjC/nullability_macro.m
new file mode 100644 (file)
index 0000000..436bbea
--- /dev/null
@@ -0,0 +1,16 @@
+// Test that nullability attributes still get merged even though they are
+// wrapped with a MacroQualifiedType. This should just compile with no errors.
+// RUN: %clang_cc1 %s -Wno-objc-root-class -fsyntax-only -verify
+#define UI_APPEARANCE_SELECTOR __attribute__((annotate("ui_appearance_selector")))
+
+@class UIColor;
+
+@interface Test
+@property(null_resettable, nonatomic, strong) UIColor *onTintColor UI_APPEARANCE_SELECTOR; // expected-warning{{treating Unicode character as whitespace}}
+@end
+
+@implementation Test
+- (void)setOnTintColor:(nullable UIColor *)onTintColor {
+}
+
+@end