Skip to content

Commit 5aa63fc

Browse files
authored
Merge pull request #72634 from hyp/eng/android/ndk-overlay
[android] add an Android NDK Swift overlay
2 parents 46502f9 + 743a501 commit 5aa63fc

File tree

72 files changed

+305
-31
lines changed

Some content is hidden

Large Commits have some content hidden by default. Use the searchbox below for content that may be hidden.

72 files changed

+305
-31
lines changed

lib/ClangImporter/ClangIncludePaths.cpp

+20-13
Original file line numberDiff line numberDiff line change
@@ -180,7 +180,7 @@ createClangArgs(const ASTContext &ctx, clang::driver::Driver &clangDriver) {
180180

181181
static SmallVector<std::pair<std::string, std::string>, 2>
182182
getLibcFileMapping(ASTContext &ctx, StringRef modulemapFileName,
183-
std::optional<StringRef> maybeHeaderFileName,
183+
std::optional<ArrayRef<StringRef>> maybeHeaderFileNames,
184184
const llvm::IntrusiveRefCntPtr<llvm::vfs::FileSystem> &vfs) {
185185
const llvm::Triple &triple = ctx.LangOpts.Target;
186186

@@ -220,18 +220,20 @@ getLibcFileMapping(ASTContext &ctx, StringRef modulemapFileName,
220220
SmallVector<std::pair<std::string, std::string>, 2> vfsMappings{
221221
{std::string(injectedModuleMapPath), std::string(actualModuleMapPath)}};
222222

223-
if (maybeHeaderFileName) {
224-
// TODO: remove the SwiftGlibc.h header and reference all Glibc headers
225-
// directly from the modulemap.
226-
Path actualHeaderPath = actualModuleMapPath;
227-
llvm::sys::path::remove_filename(actualHeaderPath);
228-
llvm::sys::path::append(actualHeaderPath, maybeHeaderFileName.value());
223+
if (maybeHeaderFileNames) {
224+
for (const auto &filename : *maybeHeaderFileNames) {
225+
// TODO: remove the SwiftGlibc.h header and reference all Glibc headers
226+
// directly from the modulemap.
227+
Path actualHeaderPath = actualModuleMapPath;
228+
llvm::sys::path::remove_filename(actualHeaderPath);
229+
llvm::sys::path::append(actualHeaderPath, filename);
229230

230-
Path injectedHeaderPath(libcDir);
231-
llvm::sys::path::append(injectedHeaderPath, maybeHeaderFileName.value());
231+
Path injectedHeaderPath(libcDir);
232+
llvm::sys::path::append(injectedHeaderPath, filename);
232233

233-
vfsMappings.push_back(
234-
{std::string(injectedHeaderPath), std::string(actualHeaderPath)});
234+
vfsMappings.push_back(
235+
{std::string(injectedHeaderPath), std::string(actualHeaderPath)});
236+
}
235237
}
236238

237239
return vfsMappings;
@@ -552,9 +554,14 @@ ClangInvocationFileMapping swift::getClangInvocationFileMapping(
552554
} else if (triple.isMusl()) {
553555
libcFileMapping =
554556
getLibcFileMapping(ctx, "musl.modulemap", StringRef("SwiftMusl.h"), vfs);
557+
} else if (triple.isAndroid()) {
558+
// Android uses the android-specific module map that overlays the NDK.
559+
StringRef headerFiles[] = {"SwiftAndroidNDK.h", "SwiftBionic.h"};
560+
libcFileMapping =
561+
getLibcFileMapping(ctx, "android.modulemap", headerFiles, vfs);
555562
} else if (triple.isOSGlibc() || triple.isOSOpenBSD() ||
556-
triple.isOSFreeBSD() || triple.isAndroid()) {
557-
// Android/BSD/Linux Mappings
563+
triple.isOSFreeBSD()) {
564+
// BSD/Linux Mappings
558565
libcFileMapping = getLibcFileMapping(ctx, "glibc.modulemap",
559566
StringRef("SwiftGlibc.h"), vfs);
560567

stdlib/cmake/modules/AddSwiftStdlib.cmake

+13-2
Original file line numberDiff line numberDiff line change
@@ -1757,6 +1757,9 @@ endfunction()
17571757
# SWIFT_MODULE_DEPENDS_WASI
17581758
# Swift modules this library depends on when built for WASI.
17591759
#
1760+
# SWIFT_MODULE_DEPENDS_ANDROID
1761+
# Swift modules this library depends on when built for Android.
1762+
#
17601763
# FRAMEWORK_DEPENDS
17611764
# System frameworks this library depends on.
17621765
#
@@ -1919,6 +1922,7 @@ function(add_swift_target_library name)
19191922
SWIFT_COMPILE_FLAGS_XROS
19201923
SWIFT_COMPILE_FLAGS_LINUX
19211924
SWIFT_MODULE_DEPENDS
1925+
SWIFT_MODULE_DEPENDS_ANDROID
19221926
SWIFT_MODULE_DEPENDS_CYGWIN
19231927
SWIFT_MODULE_DEPENDS_FREEBSD
19241928
SWIFT_MODULE_DEPENDS_FREESTANDING
@@ -2146,12 +2150,15 @@ function(add_swift_target_library name)
21462150
elseif(sdk STREQUAL "OPENBSD")
21472151
list(APPEND swiftlib_module_depends_flattened
21482152
${SWIFTLIB_SWIFT_MODULE_DEPENDS_OPENBSD})
2149-
elseif(sdk STREQUAL "LINUX" OR sdk STREQUAL "ANDROID")
2153+
elseif(sdk STREQUAL "LINUX")
21502154
list(APPEND swiftlib_module_depends_flattened
21512155
${SWIFTLIB_SWIFT_MODULE_DEPENDS_LINUX})
21522156
elseif(sdk STREQUAL "LINUX_STATIC")
21532157
list(APPEND swiftlib_module_depends_flattened
21542158
${SWIFTLIB_SWIFT_MODULE_DEPENDS_LINUX_STATIC})
2159+
elseif(sdk STREQUAL "ANDROID")
2160+
list(APPEND swiftlib_module_depends_flattened
2161+
${SWIFTLIB_SWIFT_MODULE_DEPENDS_ANDROID})
21552162
elseif(sdk STREQUAL "CYGWIN")
21562163
list(APPEND swiftlib_module_depends_flattened
21572164
${SWIFTLIB_SWIFT_MODULE_DEPENDS_CYGWIN})
@@ -3005,6 +3012,7 @@ function(add_swift_target_executable name)
30053012
DEPENDS
30063013
LINK_LIBRARIES
30073014
SWIFT_MODULE_DEPENDS
3015+
SWIFT_MODULE_DEPENDS_ANDROID
30083016
SWIFT_MODULE_DEPENDS_CYGWIN
30093017
SWIFT_MODULE_DEPENDS_FREEBSD
30103018
SWIFT_MODULE_DEPENDS_FREESTANDING
@@ -3118,12 +3126,15 @@ function(add_swift_target_executable name)
31183126
elseif(sdk STREQUAL "OPENBSD")
31193127
list(APPEND swiftexe_module_depends_flattened
31203128
${SWIFTEXE_TARGET_SWIFT_MODULE_DEPENDS_OPENBSD})
3121-
elseif(sdk STREQUAL "LINUX" OR sdk STREQUAL "ANDROID")
3129+
elseif(sdk STREQUAL "LINUX")
31223130
list(APPEND swiftexe_module_depends_flattened
31233131
${SWIFTEXE_TARGET_SWIFT_MODULE_DEPENDS_LINUX})
31243132
elseif(sdk STREQUAL "LINUX_STATIC")
31253133
list(APPEND swiftexe_module_depends_flattened
31263134
${SWIFTEXE_TARGET_SWIFT_MODULE_DEPENDS_LINUX_STATIC})
3135+
elseif(sdk STREQUAL "ANDROID")
3136+
list(APPEND swiftexe_module_depends_flattened
3137+
${SWIFTEXE_TARGET_SWIFT_MODULE_DEPENDS_ANDROID})
31273138
elseif(sdk STREQUAL "CYGWIN")
31283139
list(APPEND swiftexe_module_depends_flattened
31293140
${SWIFTEXE_TARGET_SWIFT_MODULE_DEPENDS_CYGWIN})

stdlib/private/RuntimeUnittest/CMakeLists.txt

+1
Original file line numberDiff line numberDiff line change
@@ -8,6 +8,7 @@ add_swift_target_library(swiftRuntimeUnittest ${SWIFT_STDLIB_LIBRARY_BUILD_TYPES
88
ExclusivityTests.cpp
99

1010
SWIFT_MODULE_DEPENDS StdlibUnittest
11+
SWIFT_MODULE_DEPENDS_ANDROID Android
1112
SWIFT_MODULE_DEPENDS_LINUX Glibc
1213
SWIFT_MODULE_DEPENDS_FREEBSD Glibc
1314
SWIFT_MODULE_DEPENDS_OPENBSD Glibc

stdlib/private/StdlibCollectionUnittest/CMakeLists.txt

+1
Original file line numberDiff line numberDiff line change
@@ -19,6 +19,7 @@ add_swift_target_library(swiftStdlibCollectionUnittest ${SWIFT_STDLIB_LIBRARY_BU
1919
WriteBackMutableSlice.swift
2020

2121
SWIFT_MODULE_DEPENDS StdlibUnittest
22+
SWIFT_MODULE_DEPENDS_ANDROID Android
2223
SWIFT_MODULE_DEPENDS_LINUX Glibc
2324
SWIFT_MODULE_DEPENDS_FREEBSD Glibc
2425
SWIFT_MODULE_DEPENDS_OPENBSD Glibc

stdlib/private/StdlibUnicodeUnittest/CMakeLists.txt

+1
Original file line numberDiff line numberDiff line change
@@ -10,6 +10,7 @@ add_swift_target_library(swiftStdlibUnicodeUnittest ${SWIFT_STDLIB_LIBRARY_BUILD
1010
WordBreaking.swift
1111

1212
SWIFT_MODULE_DEPENDS StdlibUnittest
13+
SWIFT_MODULE_DEPENDS_ANDROID Android
1314
SWIFT_MODULE_DEPENDS_LINUX Glibc
1415
SWIFT_MODULE_DEPENDS_FREEBSD Glibc
1516
SWIFT_MODULE_DEPENDS_OPENBSD Glibc

stdlib/private/StdlibUnittest/CMakeLists.txt

+1
Original file line numberDiff line numberDiff line change
@@ -62,6 +62,7 @@ add_swift_target_library(swiftStdlibUnittest ${SWIFT_STDLIB_LIBRARY_BUILD_TYPES}
6262
SWIFT_MODULE_DEPENDS_XROS ${swift_stdlib_unittest_darwin_dependencies}
6363
SWIFT_MODULE_DEPENDS_MACCATALYST ${swift_stdlib_unittest_darwin_dependencies}
6464
SWIFT_MODULE_DEPENDS_FREESTANDING "${SWIFT_FREESTANDING_TEST_DEPENDENCIES}"
65+
SWIFT_MODULE_DEPENDS_ANDROID Android
6566
SWIFT_MODULE_DEPENDS_LINUX Glibc
6667
SWIFT_MODULE_DEPENDS_FREEBSD Glibc
6768
SWIFT_MODULE_DEPENDS_OPENBSD Glibc

stdlib/private/StdlibUnittest/RaceTest.swift

+2
Original file line numberDiff line numberDiff line change
@@ -45,6 +45,8 @@ import Darwin
4545
import Glibc
4646
#elseif canImport(Musl)
4747
import Musl
48+
#elseif canImport(Android)
49+
import Android
4850
#elseif os(WASI)
4951
import WASILibc
5052
#elseif os(Windows)

stdlib/private/StdlibUnittest/StdlibCoreExtras.swift

+2
Original file line numberDiff line numberDiff line change
@@ -18,6 +18,8 @@ import Darwin
1818
import Glibc
1919
#elseif canImport(Musl)
2020
import Musl
21+
#elseif canImport(Android)
22+
import Android
2123
#elseif os(WASI)
2224
import WASILibc
2325
#elseif os(Windows)

stdlib/private/StdlibUnittest/StdlibUnittest.swift

+2
Original file line numberDiff line numberDiff line change
@@ -24,6 +24,8 @@ import Darwin
2424
import Glibc
2525
#elseif canImport(Musl)
2626
import Musl
27+
#elseif canImport(Android)
28+
import Android
2729
#elseif os(WASI)
2830
import WASILibc
2931
#elseif os(Windows)

stdlib/private/SwiftPrivate/CMakeLists.txt

+1
Original file line numberDiff line numberDiff line change
@@ -27,6 +27,7 @@ add_swift_target_library(swiftSwiftPrivate ${SWIFT_STDLIB_LIBRARY_BUILD_TYPES} I
2727
SWIFT_MODULE_DEPENDS_WATCHOS ${swift_swiftprivate_darwin_depencencies}
2828
SWIFT_MODULE_DEPENDS_MACCATALYST ${swift_swiftprivate_darwin_depencencies}
2929
SWIFT_MODULE_DEPENDS_FREESTANDING "${SWIFT_FREESTANDING_TEST_DEPENDENCIES}"
30+
SWIFT_MODULE_DEPENDS_ANDROID Android
3031
SWIFT_MODULE_DEPENDS_LINUX Glibc
3132
SWIFT_MODULE_DEPENDS_LINUX_STATIC Musl
3233
SWIFT_MODULE_DEPENDS_FREEBSD Glibc

stdlib/private/SwiftPrivate/IO.swift

+2
Original file line numberDiff line numberDiff line change
@@ -23,6 +23,8 @@ import Darwin
2323
import Glibc
2424
#elseif canImport(Musl)
2525
import Musl
26+
#elseif canImport(Android)
27+
import Android
2628
#elseif canImport(WASILibc)
2729
import WASILibc
2830
#endif

stdlib/private/SwiftPrivateLibcExtras/CMakeLists.txt

+1
Original file line numberDiff line numberDiff line change
@@ -38,6 +38,7 @@ add_swift_target_library(swiftSwiftPrivateLibcExtras ${SWIFT_STDLIB_LIBRARY_BUIL
3838
SWIFT_MODULE_DEPENDS_XROS ${swift_private_libc_extras_darwin_depencencies}
3939
SWIFT_MODULE_DEPENDS_MACCATALYST ${swift_private_libc_extras_darwin_depencencies}
4040
SWIFT_MODULE_DEPENDS_FREESTANDING "${SWIFT_FREESTANDING_TEST_DEPENDENCIES}"
41+
SWIFT_MODULE_DEPENDS_ANDROID Android
4142
SWIFT_MODULE_DEPENDS_LINUX Glibc
4243
SWIFT_MODULE_DEPENDS_LINUX_STATIC Musl
4344
SWIFT_MODULE_DEPENDS_FREEBSD Glibc

stdlib/private/SwiftPrivateLibcExtras/Subprocess.swift

+2
Original file line numberDiff line numberDiff line change
@@ -17,6 +17,8 @@ import Darwin
1717
import Glibc
1818
#elseif canImport(Musl)
1919
import Musl
20+
#elseif canImport(Android)
21+
import Android
2022
#elseif os(WASI)
2123
import WASILibc
2224
#elseif os(Windows)

stdlib/private/SwiftPrivateLibcExtras/SwiftPrivateLibcExtras.swift

+2
Original file line numberDiff line numberDiff line change
@@ -17,6 +17,8 @@ import Darwin
1717
import Glibc
1818
#elseif canImport(Musl)
1919
import Musl
20+
#elseif canImport(Android)
21+
import Android
2022
#elseif os(WASI)
2123
import WASILibc
2224
#elseif os(Windows)

stdlib/private/SwiftPrivateThreadExtras/CMakeLists.txt

+1
Original file line numberDiff line numberDiff line change
@@ -19,6 +19,7 @@ add_swift_target_library(swiftSwiftPrivateThreadExtras ${SWIFT_STDLIB_LIBRARY_BU
1919
SWIFT_MODULE_DEPENDS_XROS ${swift_private_thread_extras_darwin_depencencies}
2020
SWIFT_MODULE_DEPENDS_MACCATALYST ${swift_private_thread_extras_darwin_depencencies}
2121
SWIFT_MODULE_DEPENDS_FREESTANDING "${SWIFT_FREESTANDING_TEST_DEPENDENCIES}"
22+
SWIFT_MODULE_DEPENDS_ANDROID Android
2223
SWIFT_MODULE_DEPENDS_LINUX Glibc
2324
SWIFT_MODULE_DEPENDS_LINUX_STATIC Musl
2425
SWIFT_MODULE_DEPENDS_FREEBSD Glibc

stdlib/private/SwiftPrivateThreadExtras/SwiftPrivateThreadExtras.swift

+2
Original file line numberDiff line numberDiff line change
@@ -21,6 +21,8 @@ import Darwin
2121
import Glibc
2222
#elseif canImport(Musl)
2323
import Musl
24+
#elseif canImport(Android)
25+
import Android
2426
#elseif os(WASI)
2527
import WASILibc
2628
#elseif os(Windows)

stdlib/private/SwiftPrivateThreadExtras/ThreadBarriers.swift

+2
Original file line numberDiff line numberDiff line change
@@ -16,6 +16,8 @@ import Darwin
1616
import Glibc
1717
#elseif canImport(Musl)
1818
import Musl
19+
#elseif canImport(Android)
20+
import Android
1921
#elseif os(WASI)
2022
import WASILibc
2123
#elseif os(Windows)

stdlib/private/SwiftReflectionTest/CMakeLists.txt

+1
Original file line numberDiff line numberDiff line change
@@ -14,6 +14,7 @@ if (SWIFT_INCLUDE_TESTS AND SWIFT_BUILD_DYNAMIC_STDLIB)
1414
SWIFT_MODULE_DEPENDS_TVOS ${swift_reflection_test_darwin_depencencies}
1515
SWIFT_MODULE_DEPENDS_WATCHOS ${swift_reflection_test_darwin_depencencies}
1616
SWIFT_MODULE_DEPENDS_XROS ${swift_reflection_test_darwin_depencencies}
17+
SWIFT_MODULE_DEPENDS_ANDROID Android
1718
SWIFT_MODULE_DEPENDS_LINUX Glibc
1819
SWIFT_MODULE_DEPENDS_LINUX_STATIC Musl
1920
SWIFT_MODULE_DEPENDS_FREEBSD Glibc

stdlib/private/SwiftReflectionTest/SwiftReflectionTest.swift

+2
Original file line numberDiff line numberDiff line change
@@ -131,6 +131,8 @@ import SwiftShims
131131
import Glibc
132132
#elseif canImport(Musl)
133133
import Musl
134+
#elseif canImport(Android)
135+
import Android
134136
#endif
135137

136138
let rtldDefault: UnsafeMutableRawPointer? = nil

stdlib/public/Concurrency/CMakeLists.txt

+1
Original file line numberDiff line numberDiff line change
@@ -156,6 +156,7 @@ add_swift_target_library(swift_Concurrency ${SWIFT_STDLIB_LIBRARY_BUILD_TYPES} I
156156
${SWIFT_RUNTIME_CONCURRENCY_C_SOURCES}
157157
${SWIFT_RUNTIME_CONCURRENCY_SWIFT_SOURCES}
158158

159+
SWIFT_MODULE_DEPENDS_ANDROID Android
159160
SWIFT_MODULE_DEPENDS_LINUX Glibc
160161
SWIFT_MODULE_DEPENDS_FREEBSD Glibc
161162
SWIFT_MODULE_DEPENDS_OPENBSD Glibc

stdlib/public/Cxx/std/CMakeLists.txt

+2-1
Original file line numberDiff line numberDiff line change
@@ -45,6 +45,7 @@ add_swift_target_library(swiftCxxStdlib STATIC NO_LINK_NAME IS_STDLIB IS_SWIFT_O
4545
SWIFT_MODULE_DEPENDS_WATCHOS ${swift_cxxstdlib_darwin_dependencies}
4646
SWIFT_MODULE_DEPENDS_XROS ${swift_cxxstdlib_darwin_dependencies}
4747
SWIFT_MODULE_DEPENDS_MACCATALYST ${swift_cxxstdlib_darwin_dependencies}
48+
SWIFT_MODULE_DEPENDS_ANDROID Android
4849

4950
SWIFT_COMPILE_FLAGS ${SWIFT_RUNTIME_SWIFT_COMPILE_FLAGS} ${SWIFT_STANDARD_LIBRARY_SWIFT_FLAGS}
5051
-cxx-interoperability-mode=default
@@ -56,7 +57,7 @@ add_swift_target_library(swiftCxxStdlib STATIC NO_LINK_NAME IS_STDLIB IS_SWIFT_O
5657
DEPLOYMENT_VERSION_OSX ${COMPATIBILITY_MINIMUM_DEPLOYMENT_VERSION_OSX}
5758

5859
LINK_FLAGS "${SWIFT_RUNTIME_SWIFT_LINK_FLAGS}"
59-
TARGET_SDKS ALL_APPLE_PLATFORMS LINUX WINDOWS
60+
TARGET_SDKS ALL_APPLE_PLATFORMS LINUX WINDOWS ANDROID
6061
INSTALL_IN_COMPONENT compiler
6162
INSTALL_WITH_SHARED
6263
DEPENDS libstdcxx-modulemap libcxxshim_modulemap CxxStdlib-apinotes)

stdlib/public/Differentiation/CMakeLists.txt

+1
Original file line numberDiff line numberDiff line change
@@ -42,6 +42,7 @@ add_swift_target_library(swift_Differentiation ${SWIFT_STDLIB_LIBRARY_BUILD_TYPE
4242
SWIFT_MODULE_DEPENDS_TVOS ${swiftDifferentiationDarwinDependencies}
4343
SWIFT_MODULE_DEPENDS_WATCHOS ${swiftDifferentiationDarwinDependencies}
4444
SWIFT_MODULE_DEPENDS_XROS ${swiftDifferentiationDarwinDependencies}
45+
SWIFT_MODULE_DEPENDS_ANDROID Android
4546
SWIFT_MODULE_DEPENDS_LINUX Glibc
4647
SWIFT_MODULE_DEPENDS_LINUX_STATIC Musl
4748
SWIFT_MODULE_DEPENDS_FREEBSD Glibc

stdlib/public/Differentiation/TgmathDerivatives.swift.gyb

+3-1
Original file line numberDiff line numberDiff line change
@@ -18,12 +18,14 @@ import Swift
1818
import Darwin.C.tgmath
1919
#elseif canImport(Musl)
2020
import Musl
21-
#elseif os(Linux) || os(FreeBSD) || os(OpenBSD) || os(PS4) || os(Android) || os(Cygwin) || os(Haiku)
21+
#elseif os(Linux) || os(FreeBSD) || os(OpenBSD) || os(PS4) || os(Cygwin) || os(Haiku)
2222
import Glibc
2323
#elseif os(WASI)
2424
import WASILibc
2525
#elseif os(Windows)
2626
import CRT
27+
#elseif canImport(Android)
28+
import Android
2729
#else
2830
#error("Unsupported platform")
2931
#endif

stdlib/public/Distributed/CMakeLists.txt

+1
Original file line numberDiff line numberDiff line change
@@ -34,6 +34,7 @@ add_swift_target_library(swiftDistributed ${SWIFT_STDLIB_LIBRARY_BUILD_TYPES} IS
3434
SWIFT_MODULE_DEPENDS_OSX ${swift_distributed_darwin_depencencies}
3535
SWIFT_MODULE_DEPENDS_TVOS ${swift_distributed_darwin_depencencies}
3636
SWIFT_MODULE_DEPENDS_WATCHOS ${swift_distributed_darwin_depencencies}
37+
SWIFT_MODULE_DEPENDS_ANDROID Android
3738
SWIFT_MODULE_DEPENDS_LINUX Glibc
3839
SWIFT_MODULE_DEPENDS_FREEBSD Glibc
3940
SWIFT_MODULE_DEPENDS_OPENBSD Glibc

stdlib/public/Distributed/LocalTestingDistributedActorSystem.swift

+2
Original file line numberDiff line numberDiff line change
@@ -18,6 +18,8 @@ import Darwin
1818
import Glibc
1919
#elseif canImport(Musl)
2020
import Musl
21+
#elseif canImport(Android)
22+
import Android
2123
#elseif os(Windows)
2224
import WinSDK
2325
#endif

stdlib/public/Platform/Android.swift

+13
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,13 @@
1+
//===----------------------------------------------------------------------===//
2+
//
3+
// This source file is part of the Swift.org open source project
4+
//
5+
// Copyright (c) 2014 - 2017 Apple Inc. and the Swift project authors
6+
// Licensed under Apache License v2.0 with Runtime Library Exception
7+
//
8+
// See https://swift.org/LICENSE.txt for license information
9+
// See https://swift.org/CONTRIBUTORS.txt for the list of Swift project authors
10+
//
11+
//===----------------------------------------------------------------------===//
12+
13+
@_exported import SwiftAndroid // Clang module

0 commit comments

Comments
 (0)