• Home
Name Date Size #Lines LOC

..--

.idea/03-May-2024-150150

buildSrc/03-May-2024-1,8591,378

curl/03-May-2024-117101

googletest/03-May-2024-143126

gradle/wrapper/03-May-2024-65

jsoncpp/03-May-2024-122102

openssl/03-May-2024-199168

scripts/03-May-2024-2521

.gitignoreD03-May-20241.8 KiB9069

DockerfileD03-May-2024548 1815

README.mdD03-May-20241.5 KiB4126

build.gradle.ktsD03-May-2024563 2720

gradle.propertiesD03-May-202426 11

gradlewD03-May-20245.6 KiB186125

gradlew.batD03-May-20242.6 KiB9068

settings.gradle.ktsD03-May-2024359 1714

README.md

1# ndkports
2
3A collection of Android build scripts for various third-party libraries and the
4tooling to build them.
5
6If you're an Android app developer looking to *consume* these libraries, this is
7probably not what you want. This project builds AARs to be published to Maven.
8You most likely want to use the AAR, not build it yourself.
9
10Note: Gradle support for consuming these artifacts from an AAR is a work in
11progress.
12
13## Ports
14
15Each third-party project is called a "port". Ports consist of a description of
16where to fetch the source, apply any patches needed, build, install, and package
17the library into an AAR.
18
19A port is a subclass of the abstract Kotlin class `com.android.ndkports.Port`.
20Projects define the name and version of the port, the URL to fetch source from,
21a list of modules (libraries) to build, and the build steps.
22
23See the [Port class] for documentation on the port API.
24
25Individual port files are kept in `ports/$name/port.kts`. For example, the cURL
26port is [ports/curl/port.kts](ports/curl/port.kts).
27
28[Port class]: src/main/kotlin/com/android/ndkports/Port.kt
29
30## Building a Port
31
32We recommend using the supplied scripts and Dockerfile for consistent builds.
33
34To build a release for distribution to a Maven repo, `scripts/build_release.sh`
35
36To build a snapshot, `scripts/build_snapshot.sh`
37
38You can also pass custom gradle targets: `scripts/build_snapshot.sh curl`
39
40The scripts use the standard `ANDROID_NDK_ROOT` environment variable to
41locate the NDK. For example, `ANDROID_NDK_ROOT=/path/to/ndk scripts/build_release.sh`