From: Dan Albert Date: Tue, 3 Mar 2015 18:28:38 +0000 (+0000) Subject: Support __attribute__((availability)) on Android. X-Git-Url: https://granicus.if.org/sourcecode?a=commitdiff_plain;h=83a7dd8f4d67e6ffbebfeae9c290268d81f35663;p=clang Support __attribute__((availability)) on Android. Reviewers: srhines Reviewed By: srhines Subscribers: cfe-commits Differential Revision: http://reviews.llvm.org/D7929 git-svn-id: https://llvm.org/svn/llvm-project/cfe/trunk@231092 91177308-0d34-0410-b5e6-96231b3b80d8 --- diff --git a/include/clang/Basic/Attr.td b/include/clang/Basic/Attr.td index fb49132b7e..05a399afda 100644 --- a/include/clang/Basic/Attr.td +++ b/include/clang/Basic/Attr.td @@ -440,6 +440,7 @@ def Availability : InheritableAttr { let AdditionalMembers = [{static llvm::StringRef getPrettyPlatformName(llvm::StringRef Platform) { return llvm::StringSwitch(Platform) + .Case("android", "Android") .Case("ios", "iOS") .Case("macosx", "OS X") .Case("ios_app_extension", "iOS (App Extension)") diff --git a/lib/Basic/Targets.cpp b/lib/Basic/Targets.cpp index 6173b7b11f..1d820d36a9 100644 --- a/lib/Basic/Targets.cpp +++ b/lib/Basic/Targets.cpp @@ -363,8 +363,13 @@ protected: DefineStd(Builder, "linux", Opts); Builder.defineMacro("__gnu_linux__"); Builder.defineMacro("__ELF__"); - if (Triple.getEnvironment() == llvm::Triple::Android) + if (Triple.getEnvironment() == llvm::Triple::Android) { Builder.defineMacro("__ANDROID__", "1"); + unsigned Maj, Min, Rev; + Triple.getOSVersion(Maj, Min, Rev); + this->PlatformName = "android"; + this->PlatformMinVersion = VersionTuple(Maj, Min, Rev); + } if (Opts.POSIXThreads) Builder.defineMacro("_REENTRANT"); if (Opts.CPlusPlus) diff --git a/test/Sema/attr-availability-android.c b/test/Sema/attr-availability-android.c new file mode 100644 index 0000000000..d4031b3b52 --- /dev/null +++ b/test/Sema/attr-availability-android.c @@ -0,0 +1,31 @@ +// RUN: %clang_cc1 "-triple" "arm-linux-androideabi16" -fsyntax-only -verify %s + +void f0(int) __attribute__((availability(android,introduced=14,deprecated=19))); +void f1(int) __attribute__((availability(android,introduced=16))); +void f2(int) __attribute__((availability(android,introduced=14,deprecated=16))); // expected-note {{'f2' has been explicitly marked deprecated here}} +void f3(int) __attribute__((availability(android,introduced=19))); +void f4(int) __attribute__((availability(android,introduced=9,deprecated=11,obsoleted=16), availability(ios,introduced=2.0,deprecated=3.0))); // expected-note{{explicitly marked unavailable}} +void f5(int) __attribute__((availability(ios,introduced=3.2), availability(android,unavailable))); // expected-note{{'f5' has been explicitly marked unavailable here}} + +void test() { + f0(0); + f1(0); + f2(0); // expected-warning{{'f2' is deprecated: first deprecated in Android 16}} + f3(0); + f4(0); // expected-error{{f4' is unavailable: obsoleted in Android 16}} + f5(0); // expected-error{{'f5' is unavailable: not available on Android}} +} + +// rdar://10535640 + +enum { + foo __attribute__((availability(android,introduced=8.0,deprecated=9.0))) +}; + +enum { + bar __attribute__((availability(android,introduced=8.0,deprecated=9.0))) = foo +}; + +enum __attribute__((availability(android,introduced=8.0,deprecated=9.0))) { + bar1 = foo +};