A package builder/manager for Android NDK to build projects written in C, C++, Rust, Golang, etc.
Please read these caveats carefully before starting to use this software.
- 
This software is being actively developed. It's in beta stage and may not be stable. Some features are subject to change without notice. 
- 
Please do NOT place your own files under ~/.ndk-pkgdirectory, asndk-pkgwill change files under~/.ndk-pkgdirectory without notice.
- 
Please do NOT run ndk-pkgcommand in parallel so as not to generate dirty data.
| HostOS | HostArch | SubSystem | recommended | fully tested | fully supported | 
|---|---|---|---|---|---|
| ✶ | x86_64 | Docker | ✔︎ | ✔︎ | ✔︎ | 
| GNU/Linux | x86_64 | ✔︎ | ✔︎ | ✔︎ | |
| Windows | x86_64 | WSL | |||
| macOS | x86_64arm64 | ✔︎ | |||
| Android | aarch64 | Termux | 
Notes :
- This software can NOT run on Cygwin and MSYS2 due to a cmake error: CMake: Builds hosted on 'CYGWIN' not supported., for the reason please refer to Android-Determine.cmake. If you really want to use this software on Windows, please use via Docker or WSL instead.
Generally, you don't need to download the Android NDK, because ndk-pkg will automatically download it when needed, unless you want to use your own Android NDK, you can specify your location of Android NDK via --ndk-home=<ANDROID-NDK-HOME> option. Please note that you can't specify your location of Android NDK via environment variable ANDROID_NDK_HOME and ANDROID_NDK_ROOT
ndk-pkg also allows you to use a specific revision of Android NDK via --ndk-revision=<ANDROID-NDK-REVISION> option. For example, if you want to use the Android NDK r28c, you can run ndk-pkg install <PKG> --ndk-revision=28c
At the moment, ndk-pkg use Android NDK r27d, it doesn't compile 16 KB-aligned by default. Due to Android NDK r28 and higher compile 16 KB-aligned by default, you can run ndk-pkg install <PKG> --ndk-revision=28c if you need 16 KB-aligned ELF files.
This is the recommended way of using this software.
In this way, you don't need a computer in hand, you could use GitHub mobile Apps.
In this way, you will be liberated from the rut of setting up the build environment.
In this way, you do NOT need to frequently update this software, you always use the latest version.
In this way, all you need to do is just clicking the buttons and waiting for finishing. After finishing, a url refers to a zip archive will be provided to download.
For more details please refer to https://github.com/leleliu008/ndk-pkg-package-manually-build
Using ndk-pkg via Docker
This is the recommended way of using this software if you want to use this software locally.
docker container is an isolated clean environment where the running process can not be affected by your host system's environemt variables.
step1. create the ndk-pkg docker container
mkdir -p ~/ndk-pkg-home
mkdir -p ~/.m2
docker create -it --name ndk-pkg -v ~/ndk-pkg-home:/root/.ndk-pkg -v ~/.m2:/root/.m2 ghcr.io/leleliu008/ndk-pkgstep2. start the ndk-pkg docker container
docker start ndk-pkgstep3. install essential tools
docker exec -it ndk-pkg ndk-pkg setupstep4. update formula repositories
docker exec -it ndk-pkg ndk-pkg updateIf all goes well, then next you can start to install packages whatever you want, for example, let's install curl package for target android-35-arm64-v8a:
docker exec -it ndk-pkg ndk-pkg install curl --target=android-35-arm64-v8a --staticNote: you can use podman instead of docker
This is the recommended way of using this software if you want to use this software locally and your host is linux-x86_64.
chroot, an isolated clean environment, is much like docker container, where the running process can not be affected by your host system's environment variables.
curl -LO https://cdimage.ubuntu.com/ubuntu-base/releases/24.04/release/ubuntu-base-24.04.3-base-amd64.tar.gz
install -d ubuntu-rootfs
tar xf ubuntu-base-24.04.3-base-amd64.tar.gz -C ubuntu-rootfs
cp -p /etc/resolv.conf ubuntu-rootfs/etc/
curl -LO https://raw.githubusercontent.com/leleliu008/ndk-pkg/master/ndk-pkg
chmod a+x ndk-pkg
mv ndk-pkg ubuntu-rootfs/bin/
sudo mount -o bind  /dev ubuntu-rootfs/dev
sudo mount -t proc  none ubuntu-rootfs/proc
sudo mount -t sysfs none ubuntu-rootfs/sys
sudo mount -t tmpfs none ubuntu-rootfs/tmp
sudo chroot ubuntu-rootfs ndk-pkg setup -y
sudo chroot ubuntu-rootfs ndk-pkg update
sudo chroot ubuntu-rootfs ndk-pkg install curl --target=android-35-arm64-v8a --staticThis is the recommended way of using this software if you want to use this software locally and your host is linux-x86_64.
chroot, an isolated clean environment, is much like docker container, where the running process can not be affected by your host system's environment variables.
curl -LO https://dl-cdn.alpinelinux.org/alpine/v3.22/releases/x86_64/alpine-minirootfs-3.22.0-x86_64.tar.gz
install -d alpine-rootfs
tar xf alpine-minirootfs-3.22.0-x86_64.tar.gz -C alpine-rootfs
cp -p /etc/resolv.conf alpine-rootfs/etc/
curl -LO https://raw.githubusercontent.com/leleliu008/ndk-pkg/master/ndk-pkg
chmod a+x ndk-pkg
mv ndk-pkg alpine-rootfs/bin/
sudo mount -o bind  /dev alpine-rootfs/dev
sudo mount -t proc  none alpine-rootfs/proc
sudo mount -t sysfs none alpine-rootfs/sys
sudo chroot alpine-rootfs ndk-pkg setup
sudo chroot alpine-rootfs ndk-pkg update
sudo chroot alpine-rootfs ndk-pkg install curl --target=android-35-arm64-v8a --staticUsing ndk-pkg via WSL
Note :
- As of Android NDK r25, Android NDK for Linux is incompatible with WSL1 due to the use of BOLT. For more details please refer to android/ndk#1755
/etc/wsl.conf :
[network]
hostname = ubuntu
generateHosts = false
[automount]
enabled = true
root = /mnt/
options = "metadata,umask=22,fmask=11"
mountFsTab = trueinstallation instructions :
# If you want to store ndk-pkg generated data to D:\ partition
export NDKPKG_HOME=/mnt/d/ndk-pkg
# If you use Ubuntu or Debian distribution
sudo apt -y update
sudo apt -y install curl
curl -LO https://raw.githubusercontent.com/leleliu008/ndk-pkg/master/ndk-pkg
chmod a+x ndk-pkg
./ndk-pkg setupCaveats:
- Running ndk-pkglocally directly on your local host is not recommended due to build tools(e.g. autotools, cmake, etc) are easy to be affected by environment variables. Runningndk-pkgin an isolated clean environment (docker,chroot) is highly recommended.
curl -LO https://raw.githubusercontent.com/leleliu008/ndk-pkg/master/ndk-pkg
chmod a+x ndk-pkg
./ndk-pkg setup中国大陆的用户亦可将上面的地址替换为下面的地址:
- https://ghfast.top/https://raw.githubusercontent.com/leleliu008/ndk-pkg/master/ndk-pkg
- https://cdn.jsdelivr.net/gh/leleliu008/ndk-pkg/ndk-pkg
- https://gitee.com/fpliu/ndk-pkg/raw/master/ndk-pkg
git clone --depth 1 https://github.com/leleliu008/ndk-pkg
ndk-pkg/ndk-pkg setupCaveats: Please do NOT place your own files under ~/.ndk-pkg directory, as ndk-pkg will change (remove, modify, override) files under ~/.ndk-pkg directory without notice.
A typical hierarchical structure under ~/.ndk-pkg directory looks like below:
~/.ndk-pkg
├── core
│   ├── SourceCodePro-Light.otf
│   ├── cacert.pem
│   ├── fonts.conf
│   ├── init.sh
│   ├── ndk-pkg-core-2024.05.15-linux-x86_64.tar.xz
│   ├── ndk-pkg-core-latest-release-version
│   ├── uppm
│   ├── wrapper-native-cc
│   ├── wrapper-native-c++
│   ├── wrapper-native-objc
│   ├── wrapper-target-cc
│   └── wrapper-target-c++
├── downloads
│   ├── 8f74213b56238c85a50a5329f77e06198771e70dd9a739779f4c02f65d971313.tgz
│   ├── b3a24de97a8fdbc835b9833169501030b8977031bcb54b3b3ac13740f846ab30.tgz
│   └── c642ae9b75fee120b2d96c712538bd2cf283228d2337df2cf2988e3c02678ef4.tgz
├── installed
│   ├── android-35-arm64-v8a
│   │   ├── f39a5f7836ac7ca1e04de14c8103e663d0b375a524a40e537258747e2deb3c0b
│   │   │   ├── include
│   │   │   ├── lib
│   │   │   └── share
│   │   └── zlib -> f39a5f7836ac7ca1e04de14c8103e663d0b375a524a40e537258747e2deb3c0b
│   ├── android-35-armeabi-v7a
│   │   ├── cc9b367d5068ef6b8aaaee38ec2a25691da35e02757c7e0d83aff3775aef3323
│   │   │   ├── include
│   │   │   ├── lib
│   │   │   └── share
│   │   └── zlib -> cc9b367d5068ef6b8aaaee38ec2a25691da35e02757c7e0d83aff3775aef3323
│   ├── android-35-x86
│   │   ├── a0718632fe829426c1d946e6658cc7586da0039e99d5a140d1e402a6b4a4e2f3
│   │   │   ├── include
│   │   │   ├── lib
│   │   │   └── share
│   │   └── zlib -> a0718632fe829426c1d946e6658cc7586da0039e99d5a140d1e402a6b4a4e2f3
│   └── android-35-x86_64
│       ├── c099047714d4ce1402d66346da88d14f25c313b0d4c879520198426ebc2f36fe
│       │   ├── include
│       │   ├── lib
│       │   └── share
│       └── zlib -> c099047714d4ce1402d66346da88d14f25c313b0d4c879520198426ebc2f36fe
├── native
│   └── linux-x86_64
│       ├── 30b5043e2c5513343152506e5b1e14436ddbb654f7edf69167df05f117fcdb16
│       │   ├── bin
│       │   │   ├── aclocal
│       │   │   ├── aclocal-1.16
│       │   │   ├── automake
│       │   │   └── automake-1.16
│       │   ├── share
│       │   └── receipt.txt
│       └── automake -> 30b5043e2c5513343152506e5b1e14436ddbb654f7edf69167df05f117fcdb16
├── uppm
│   ├── downloads
│   │   ├── fe6b6f7db67a20ccca0385ae38c4aafc7b2bfedc98f9d86880dfeb127a56c012.txz
│   │   └── ff66b70c830a38d331d44f6c25a37b582471def9a161c93902bac7bea3098319.tgz
│   ├── installed
│   │   ├── android-ndk-r26d
│   │   │   ├── CHANGELOG.md
│   │   │   ├── NOTICE
│   │   │   ├── NOTICE.toolchain
│   │   │   ├── README.md
│   │   │   ├── build
│   │   │   ├── meta
│   │   │   ├── ndk-build
│   │   │   ├── ndk-gdb
│   │   │   ├── ndk-lldb
│   │   │   ├── ndk-stack
│   │   │   ├── ndk-which
│   │   │   ├── prebuilt
│   │   │   ├── python-packages
│   │   │   ├── shader-tools
│   │   │   ├── simpleperf
│   │   │   ├── source.properties
│   │   │   ├── sources
│   │   │   ├── toolchains
│   │   │   └── wrap.sh
│   │   ├── bash
│   │   │   ├── bin
│   │   │   └── share
│   │   ├── bsdtar
│   │   │   ├── bin
│   │   │   └── share
│   │   ├── coreutils
│   │   │   ├── bin
│   │   │   ├── libexec
│   │   │   └── share
│   │   ├── curl
│   │   │   ├── bin
│   │   │   └── share
│   │   ├── d2
│   │   │   ├── bin
│   │   │   └── share
│   │   ├── dot_static
│   │   │   └── bin
│   │   ├── findutils
│   │   │   ├── bin
│   │   │   ├── libexec
│   │   │   ├── share
│   │   │   └── var
│   │   ├── gawk
│   │   │   ├── bin
│   │   │   ├── etc
│   │   │   ├── libexec
│   │   │   └── share
│   │   ├── git
│   │   │   ├── bin
│   │   │   ├── libexec
│   │   │   └── share
│   │   ├── grep
│   │   │   ├── bin
│   │   │   └── share
│   │   ├── gsed
│   │   │   ├── bin
│   │   │   └── share
│   │   ├── jq
│   │   │   ├── bin
│   │   │   └── share
│   │   ├── patchelf
│   │   │   ├── bin
│   │   │   └── share
│   │   ├── pkg-config
│   │   │   ├── bin
│   │   │   └── share
│   │   ├── tree
│   │   │   ├── bin
│   │   │   └── share
│   │   ├── xxd
│   │   │   └── bin
│   │   ├── yq
│   │   │   └── bin
│   │   └── zip
│   │       ├── bin
│   │       └── share
│   └── repos.d
│       └── official-core
│           ├── LICENSE
│           ├── README.md
│           └── formula
├── repos.d
│   └── official-core
│       ├── formula
│       │   ├── zlib.yml
│       │   ├── libbz2.yml
│       │   ├── liblzma.yml
│       │   └── libzstd.yml
│       └── README.md
└── run
    ├── 3409784
    ├── 3447656
    └── 3457395
- 
show help of this command ndk-pkg -h ndk-pkg --help 
- 
show version of this command ndk-pkg -V ndk-pkg --version 
- 
show basic information about this software ndk-pkg about 
- 
show basic information about your current running operation system ndk-pkg sysinfo 
- 
show basic information about the specified location of Android NDK ndk-pkg ndkinfo /usr/local/share/android-ndk 
- 
generate url-transform sample ndk-pkg gen-url-transform-sample 
- 
install essential tools used by this shell script ndk-pkg setup ndk-pkg setup -y This command is mainly doing the following things: 
- 
integrate zsh-completionscriptndk-pkg integrate zsh ndk-pkg integrate zsh --output-dir=/usr/local/share/zsh/site-functions ndk-pkg integrate zsh -v This software provides a zsh-completion script for ndk-pkg. when you've typedndk-pkgthen typeTABkey, the rest of the arguments will be automatically complete for you.Note: to apply this feature, you may need to run the command autoload -U compinit && compinitin your terminal (your current running shell must be zsh).Caveat: to use this feature, you should put ndk-pkgcommand inPATH
- 
update all available formula repositories ndk-pkg update 
- 
search all available packages whose name matches the given regular expression pattern ndk-pkg search curl ndk-pkg search lib 
- 
show information of the given available package ndk-pkg info-available curl ndk-pkg info-available curl --yaml ndk-pkg info-available curl --json ndk-pkg info-available curl version ndk-pkg info-available curl license ndk-pkg info-available curl summary ndk-pkg info-available curl web-url ndk-pkg info-available curl git-url ndk-pkg info-available curl git-sha ndk-pkg info-available curl git-ref ndk-pkg info-available curl src-url ndk-pkg info-available curl src-sha ndk-pkg info-available curl src-ft ndk-pkg info-available curl src-fp 
- 
show information of the given installed package ndk-pkg info-installed android-35-arm64-v8a/curl --prefix ndk-pkg info-installed android-35-arm64-v8a/curl --files ndk-pkg info-installed android-35-arm64-v8a/curl builtat ndk-pkg info-installed android-35-arm64-v8a/curl builtat-iso-8601 ndk-pkg info-installed android-35-arm64-v8a/curl builtat-rfc-3339 ndk-pkg info-installed android-35-arm64-v8a/curl builtat-iso-8601-utc ndk-pkg info-installed android-35-arm64-v8a/curl builtat-rfc-3339-utc 
- 
show packages that are depended by the given package ndk-pkg depends curl ndk-pkg depends curl -t d2 ndk-pkg depends curl -t dot ndk-pkg depends curl -t box ndk-pkg depends curl -t png ndk-pkg depends curl -t svg ndk-pkg depends curl -t d2 -o dependencies/ ndk-pkg depends curl -t dot -o dependencies/ ndk-pkg depends curl -t box -o dependencies/ ndk-pkg depends curl -t png -o dependencies/ ndk-pkg depends curl -t svg -o dependencies/ ndk-pkg depends curl -o curl-dependencies.d2 ndk-pkg depends curl -o curl-dependencies.dot ndk-pkg depends curl -o curl-dependencies.box ndk-pkg depends curl -o curl-dependencies.png ndk-pkg depends curl -o curl-dependencies.svg ndk-pkg depends curl -t svg -o . --engine=d2 ndk-pkg depends curl -t svg -o . --engine=dot 
- 
download resources of the given package to the local cache ndk-pkg fetch curl ndk-pkg fetch curl -v 
- 
install packages ndk-pkg install curl ndk-pkg install android-35-arm64-v8a/curl ndk-pkg install android-35-arm64-v8a/curl --static 
- 
reinstall packages ndk-pkg reinstall curl ndk-pkg reinstall android-35-arm64-v8a/curl --static 
- 
uninstall packages ndk-pkg uninstall curl ndk-pkg uninstall android-35-arm64-v8a/curl 
- 
upgrade the outdated packages ndk-pkg upgrade curl ndk-pkg upgrade android-35-arm64-v8a/curl --static 
- 
upgrade this software ndk-pkg upgrade-self ndk-pkg upgrade-self -v 
- 
list all available formula repositories ndk-pkg formula-repo-list 
- 
add a new formula repository ndk-pkg formula-repo-add my_repo https://github.com/leleliu008/ndk-pkg-formula-repository-my_repo ndk-pkg formula-repo-add my_repo https://github.com/leleliu008/ndk-pkg-formula-repository-my_repo --branch=master ndk-pkg formula-repo-add my_repo https://github.com/leleliu008/ndk-pkg-formula-repository-my_repo --branch=main ndk-pkg formula-repo-add my_repo https://github.com/leleliu008/ndk-pkg-formula-repository-my_repo --sync ndk-pkg formula-repo-add my_repo https://github.com/leleliu008/ndk-pkg-formula-repository-my_repo --sync --branch=master ndk-pkg formula-repo-add my_repo https://github.com/leleliu008/ndk-pkg-formula-repository-my_repo --sync --branch=main 
- 
delete a existing formula repository ndk-pkg formula-repo-del my_repo 
- 
list all available packages ndk-pkg ls-available 
- 
list all installed packages ndk-pkg ls-installed 
- 
list all outdated packages ndk-pkg ls-outdated 
- 
check if the given package is available ndk-pkg is-available curl 
- 
check if the given package is installed ndk-pkg is-installed curl ndk-pkg is-installed android-35-arm64-v8a/curl 
- 
check if the given package is outdated ndk-pkg is-outdated curl ndk-pkg is-outdated android-35-arm64-v8a/curl 
- 
list installed files of the given installed package in a tree-like format ndk-pkg tree curl ndk-pkg tree android-35-arm64-v8a/curl -L 3 
- 
show logs of the given installed package ndk-pkg logs curl ndk-pkg logs android-35-arm64-v8a/curl 
- 
bundle the given installed package into a single archive file ndk-pkg bundle android-35-arm64-v8a/curl .tar.gz ndk-pkg bundle android-35-arm64-v8a/curl .tar.xz ndk-pkg bundle android-35-arm64-v8a/curl .tar.lz ndk-pkg bundle android-35-arm64-v8a/curl .tar.bz2 ndk-pkg bundle android-35-arm64-v8a/curl .zip ndk-pkg bundle android-35-arm64-v8a/curl xx.zip ndk-pkg bundle android-35-arm64-v8a/curl a/.zip ndk-pkg bundle android-35-arm64-v8a/curl a/xx.zip 
- 
export the given installed package as the google prefab aar ndk-pkg export android-35-arm64-v8a,x86_64/curl -o . ndk-pkg export android-35-arm64-v8a,x86_64/curl -o curl-8.1.2.aar 
- 
export the given installed package as the google prefab aar then deploy it to Maven Local Repository ndk-pkg depoly android-35-arm64-v8a,x86_64/curl ndk-pkg depoly android-35-arm64-v8a,x86_64/curl --debug ndk-pkg depoly android-35-arm64-v8a,x86_64/curl --local=/somewhere 
- 
export the given installed package as the google prefab aar then deploy it to Sonatype OSSRH ndk-pkg depoly android-35-arm64-v8a,x86_64/curl --remote < ~/OSSRH-config ndk-pkg depoly android-35-arm64-v8a,x86_64/curl --remote <<EOF SERVER_ID=OSSRH SERVER_URL=https://s01.oss.sonatype.org/service/local/staging/deploy/maven2/ SERVER_USERNAME=your-sonatype-account-username SERVER_PASSWORD=your-sonatype-account-password GPG_PASSPHRASE=your-gpg-store-passphase EOF 
- 
delete the unused cached files ndk-pkg cleanup 
- 
HOME This environment variable already have been set on the most operating systems, if not set or set a empty string, you may receive an error message. 
- 
PATH This environment variable already have been set on the most operating systems, if not set or set a empty string, you may receive an error message. 
- 
SSL_CERT_FILE curl -LO https://curl.se/ca/cacert.pem export SSL_CERT_FILE="$PWD/cacert.pem" In general, you don't need to set this environment variable, but, if you encounter the reporting the SSL certificate is invalid, trying to run above commands in your terminal will do the trick.
- 
GOPROXY export GOPROXY='https://goproxy.cn' 
- 
NDKPKG_URL_TRANSFORM export NDKPKG_URL_TRANSFORM=/path/of/url-transform/path/of/url-transformcommand would be invoked as/path/of/url-transform <URL>/path/of/url-transformcommand must output a<URL>you can generate a url-transform sample via ndk-pkg gen-url-transform-sampleIf you want to change the request url, you can set this environment variable. It is very useful for chinese users. 
- 
NDKPKG_DNS_SERVERS DNS servers to be used instead of the system default. export NDKPKG_DNS_SERVERS='1.1.1.1,8.8.8.8' 
- 
NDKPKG_XTRACE For debugging purposes. enable set -x:export NDKPKG_XTRACE=1
- 
NDKPKG_HOME If this environment variable is not set or set a empty string, ~/.ndk-pkgwill be used as the default value.export NDKPKG_HOME=/path/of/ndk-pkg-home
- 
NDKPKG_DEFAULT_TARGET Some ACTIONs of ndk-pkg are associated with an installed package which need PACKAGE-SPECto be specified.PACKAGE-SPEC : a formatted string that has form: <TARGET>/<PACKAGE-NAME>, represents an installed package.PACKAGE-NAME : should match the regular expression pattern ^[A-Za-z0-9+-_.@]{1,50}$TARGET : a formatted string that has form: android-<ANDROID-API>-<ANDROID-ABI>ANDROID-API : indicates which minimum Android SDK API Level was built with. ANDROID-ABI : indicates which Android ABI was built for. To simplify the usage, you are allowed to omit <TARGET>/. If<TARGET>/is omitted, environment variableNDKPKG_DEFAULT_TARGETwould be checked, if this environment variable is not set, thenandroid-21-arm64-v8awill be used as the default.Example: export NDKPKG_DEFAULT_TARGET='android-35-arm64-v8a' 
- 
NDKPKG_FORMULA_SEARCH_DIRS colon-seperated list of directories to search formulas. 
Note: some commonly used environment variables are overridden by this software, these are CC, CXX, CPP, AS, AR, LD, CFLAGS, CPPFLAGS, LDFLAGS, PKG_CONFIG_LIBDIR, PKG_CONFIG_PATH, ACLOCAL_PATH
A ndk-pkg formula is a YAML format file, which is used to config a ndk-pkg package's meta-information such as one sentence description, package version, installation instructions, etc.
A ndk-pkg formula's filename suffix must be .yml
A ndk-pkg formula'a filename prefix would be treated as the package name.
A ndk-pkg formula'a filename prefix must match regular expression pattern ^[A-Za-z0-9+-._@]{1,50}$
A ndk-pkg formula's file content only has one level mapping and shall/might have the following KEYs:
| KEY | TYPE | overview | 
|---|---|---|
| pkgtype | ENUM | the type of this package. value shall be any one of exe,lib,exe+lib.If this mapping is not present, ndk-pkgwill determine the package type by package name, if the package name starts/ends withlibor ends with-dev, it would be recognized as typelib, otherwise, it would be recognized as typeexe | 
| linkage | ENUM | This mapping is only for exetype package to specify the executable's link method.value shall be any one of static,static/pie,shared,shared/most.staticindicates this package only support creating fully statically linked executables.sharedindicates this package only support creating dynamically linked executables andndk-pkgwill try to link as many static libraries as possible.shared/mostindicates this package only support creating dynamically linked executables andndk-pkgwill try to link as many shared libraries as possible.sharedas default if this mapping is not present. | 
| summary | TEXT | one sentence description of this package. | 
| license | LIST | A space-separated list of SPDX license short identifiers | 
| version | TEXT | the version of this package. If this mapping is not present, it will be calculated from src-url, ifsrc-urlis also not present, it will be calculated from running time as formatdate +%Y.%m.%d | 
| web-url | URL | the home webpage of this package. If this mapping is not present, if git-urlmapping is present, use it asweb-url, ifgit-urlmapping is not present, extract fromsrc-url. | 
| git-url | URL | the source code git repository url. If src-urlis not present, this mapping must be present. | 
| git-ref | TEXT | reference: https://git-scm.com/book/en/v2/Git-Internals-Git-References example values: HEADrefs/heads/masterrefs/heads/mainrefs/tags/v1, default value isHEAD | 
| git-sha | SHA1SUM | the full git commit id, 40-byte hexadecimal string, if git-refandgit-shaboth are present,git-shatakes precedence overgit-ref | 
| git-nth | INT | tell ndk-pkgthat how many depth commits would you like to fetch. default is1, this would save your time and storage. If you have to fetch all commits, set this to0 | 
| src-url | URI | the source code download url of this package. If value of this mapping ends with one of .zip.tar.xz.tar.gz.tar.lz.tar.bz2.tgz.txz.tlz.tbz2.crate, it will be uncompressed to$PACKAGE_WORKING_DIR/srcwhile this package is installing, otherwise, it will be copied to$PACKAGE_WORKING_DIR/srcalso support format like dir://DIR | 
| src-uri | URL | the mirror of src-url. | 
| src-sha | SHA256SUM | the sha256sumof source code.src-shaandsrc-urlmust appear together. | 
| fix-url | URL | the patch file download url of this package. If value of this mapping ends with one of .zip.tar.xz.tar.gz.tar.lz.tar.bz2.tgz.txz.tlz.tbz2.crate, it will be uncompressed to$PACKAGE_WORKING_DIR/fixwhile this package is installing, otherwise, it will be copied to$PACKAGE_WORKING_DIR/fix. | 
| fix-uri | URL | the mirror of fix-url. | 
| fix-sha | SHA256SUM | the sha256sumof patch file.fix-shaandfix-urlmust appear together. | 
| fix-opt | LIST | A space-separated list of arguments to be passed to patchcommand. default value is-p1. | 
| patches | LIST | A LF-delimited list of formatted TEXTs. each TEXT has format: <fix-sha>|<fix-url>[|fix-uri][|fix-opt] | 
| res-url | URL | other resource download url of this package. If value of this mapping ends with one of .zip.tar.xz.tar.gz.tar.lz.tar.bz2.tgz.txz.tlz.tbz2.crate, it will be uncompressed to$PACKAGE_WORKING_DIR/reswhile this package is installing, otherwise, it will be copied to$PACKAGE_WORKING_DIR/res. | 
| res-uri | URL | the mirror of res-url. | 
| res-sha | SHA256SUM | the sha256sumof resource file.res-shaandres-urlmust appear together. | 
| reslist | LIST | A LF-delimited list of formatted TEXTs. each TEXT has format: <res-sha>|<res-url>[|res-uri][|unpack-dir][|N].unpack-diris relative to$PACKAGE_WORKING_DIR/res, default value is empty.Nis--strip-components=N | 
| dep-lib | LIST | A space-separated list of pkg-configpackages needed by this package when installing.each of them will be calculated via pkg-config --libs-only-l then passed to the linker. | 
| dep-pkg | LIST | A space-separated list of ndk-pkg packagesdepended by this package when installing, which will be installed via ndk-pkg. | 
| dep-upp | LIST | A space-separated list of uppm packagesdepended by this package when installing, which will be installed via uppm. | 
| dep-plm | LIST | A space-separated list of perl modulesdepended by this package when installing, which will be installed via cpan. | 
| dep-pip | LIST | A space-separated list of python packagesdepended by this package when installing, which will be installed via pip. | 
| dep-gem | LIST | A space-separated list of ruby packagesdepended by this package when installing, which will be installed via gem. | 
| dep-npm | LIST | A space-separated list of nodejs packagesdepended by this package when installing, which will be installed via npm. | 
| ccflags | LIST | A space-separated list of arguments to be passed to the C compiler. | 
| xxflags | LIST | A space-separated list of arguments to be passed to the C++ compiler. | 
| ppflags | LIST | A space-separated list of arguments to be passed to the PreProcessor. | 
| ldflags | LIST | A space-separated list of arguments to be passed to the linker. ndk-pkgsupports a custom option-p<PKG-CONFIG-PACKAGE-NAME>. It will be substituted by the result ofpkg-config --libs-only-l <PKG-CONFIG-PACKAGE-NAME> | 
| bsystem | LIST | A space-separated list of build system names (e.g. autogenautotoolsconfigurecmakecmake+gmakecmake+ninjamesonxmakegmakeninjacargocabalgorakendk-build) | 
| bscript | PATH | the directory where the build script is located, relative to $PACKAGE_WORKING_DIR/src. build script such asconfigure,Makefile,CMakeLists.txt,meson.build,Cargo.toml, etc. | 
| binbstd | BOOL | whether to build in the directory where the build script is located, otherwise build in other directory. value shall be 0or1. default value is0. | 
| ltoable | BOOL | whether support LTO. value shall be 0or1. default value is1. | 
| movable | BOOL | whether the installed files can be moved/copied to other locations. value shall be 0or1. default value is1. | 
| parallel | BOOL | whether to allow build system to run jobs in parallel. value shall be 0or1. default value is1. | 
| dofetch | CODE | POSIX shell code to be run to take over the fetching process. It would be run in a separate process. PWDis$PACKAGE_WORKING_DIR | 
| do12345 | CODE | POSIX shell code to be run for native build. It is running in a separated process. | 
| dopatch | CODE | POSIX shell code to be run to apply patches manually. PWDis$PACKAGE_BSCRIPT_DIR | 
| prepare | CODE | POSIX shell code to be run to do some additional preparation before installing. PWDis$PACKAGE_BSCRIPT_DIR | 
| install | CODE | POSIX shell code to be run when user run ndk-pkg install <PKG>.If this mapping is not present, ndk-pkgwill run default install code according tobsystem.PWDis$PACKAGE_BSCRIPT_DIRifbinbstdis0, otherwise it is$PACKAGE_BCACHED_DIR | 
| dotweak | CODE | POSIX shell code to be run to do some tweaks immediately after installing. PWDis$PACKAGE_INSTALL_DIR | 
| bindenv | LIST | A LF-delimited list of formatted TEXTs. each TEXT has format: <ENV>=<VALUE>.%sin<VALUE>represents the install directory.ndk-pkgwill bind these environment variables to executables while you are runningndk-pkg bundle. | 
| wrapper | LIST | A LF-delimited list of formatted TEXTs. each TEXT has format: <SRC>|<DST>. e.g.bear.c|bin/means thatndk-pkgwill fetchbear.cfrom https://raw.githubusercontent.com/leleliu008/ndk-pkg-formula-repository-official-core/refs/heads/master/wrappers/bear.c then install it to$PACKAGE_INSTALL_DIR/bin/directory.ndk-pkgwill use these C source files to build the corresponding wrappers rather than a generic one while you are runningndk-pkg bundle. | 
| caveats | TEXT | plain text to be displayed after installing. | 
| api-min | INT | indicates which minimum Android SDK API Level is supported for this package. | 
Notes:
- All mappings except summaryare optional.
- At least one of web-urlgit-urlsrc-urlmappings should be present.
- Mappings not listed in the table above will be ignored.
phases of a package's installation:
 process-0      process-1      process-2      process-3     process-0
┌─────────┐    ┌─────────┐    ┌─────────┐    ┌─────────┐
│ dosetup │ -> │ dofetch │ -> │ do12345 │ -> │ dopatch │
└─────────┘    └─────────┘    └─────────┘    └─────────┘
                                                  ⬇
                                             ┌─────────┐
                                             │ prepare │
                                             └─────────┘
                                                  ⬇
                                             ┌─────────┐
                                             │ install │
                                             └─────────┘
                                                  ⬇
                                             ┌─────────┐
                                             │ dotweak │
                                             └─────────┘
                                                  ⬇
                                             ┌─────────┐    ┌─────────┐
                                             │ docheck │ -> │ caveats │
                                             └─────────┘    └─────────┘
commands that can be used out of the box:
| command | usage-example | 
|---|---|
| bash | Reference | 
| CoreUtils | Reference | 
| xargs | Reference | 
| find | Reference | 
| gawk | Reference | 
| gsed | Reference | 
| grep | Reference | 
| tree | Reference | 
| jq | Reference | 
| yq | Reference | 
| d2 | Reference | 
| dot_static | Reference | 
| bat | Reference | 
| xxd | Reference | 
| git | Reference | 
| curl | Reference | 
| bsdtar | Reference | 
| pkg-config | Reference | 
| patchelf | Reference | 
| echo | echo 'your message.' | 
| info | info 'your information.' | 
| warn | warn "no package manager found." | 
| error | error 'error message.' | 
| abort | abort 1 "please specify a package name." | 
| success | success "build success." | 
| isInteger | isInteger $x || abort 1 "should be an integer." | 
| isCrossBuild | isCrossBuild && abort 1 "This package is not supposed to be cross built." | 
| wfetch | wfetch <URL> [--uri=<URL-MIRROR>] [--sha256=<SHA256>] [-o <PATH> [-q] | 
| configure | configure --enable-pic | 
| mesonw | mesonw -Dneon=disabled -Darm-simd=disabled | 
| cmakew | cmakew -DBUILD_SHARED_LIBS=ON -DBUILD_STATIC_LIBS=ON | 
| gmakew | gmakew | 
| xmakew | xmakew | 
| cargow | cargow | 
| gow | gow | 
shell variables can be used directly:
| variable | overview | 
|---|---|
| NDKPKG_ARG0 | the 1st arguments of ndk-pkgthat you've supplied. | 
| NDKPKG_ARG1 | the 2nd arguments of ndk-pkgthat you've supplied. | 
| NDKPKG_ARGV | the all arguments of ndk-pkgthat you've supplied. | 
| NDKPKG_PATH | the full path of ndk-pkgthat you're running. | 
| NDKPKG_HOME | the home directory of ndk-pkgthat you're running. | 
| NDKPKG_VERSION | the version of ndk-pkgthat you're running. | 
| UPPM | the executable filepath of uppm | 
| TIMESTAMP_UNIX | the unix timestamp of this action. | 
| NATIVE_PLATFORM_KIND | current running os kind. value might be linuxordarwin | 
| NATIVE_PLATFORM_TYPE | current running os type. value might be linuxormacos | 
| NATIVE_PLATFORM_NAME | current running os name. value might be Ubuntu,macOS, etc | 
| NATIVE_PLATFORM_VERS | current running os version. | 
| NATIVE_PLATFORM_ARCH | current running os arch. value might be any one of x86_64,arm64, etc | 
| NATIVE_PLATFORM_NCPU | current running os's cpu core count. | 
| NATIVE_PLATFORM_EUID | current running os's effective user ID. | 
| NATIVE_PLATFORM_EGID | current running os's effective group ID. | 
| TARGET_PLATFORM_VERS | android sdk api-level table | 
| TARGET_PLATFORM_NBIT | value shall be any one of 3264 | 
| TARGET_PLATFORM_ARCH | value shall be any one of armv7aaarch64i686x86_64 | 
| TARGET_PLATFORM_ABI | value shall be any one of armeabi-v7aarm64-v8ax86x86_64 | 
| TARGET_TRIPLE | value shall be any one of armv7a-linux-androideabiaarch64-linux-androidi686-linux-androidx86_64-linux-android | 
| ANDROID_NDK_HOME | the home directory of Android NDK. | 
| ANDROID_NDK_ROOT | the home directory of Android NDK. | 
| ANDROID_NDK_VERSION | the version of Android NDK. | 
| ANDROID_NDK_VERSION_MAJOR | the major part of version of Android NDK. | 
| ANDROID_NDK_TOOLCHAIN_BIND | the bindirectory ofAndroid NDK. | 
| ANDROID_NDK_SYSROOT | the sysrootdirectory ofAndroid NDK. | 
| CC_FOR_BUILD | the C Compiler for native build. | 
| CFLAGS_FOR_BUILD | the flags of CC_FOR_BUILD. | 
| CXX_FOR_BUILD | the C++ Compiler for native build. | 
| CXXFLAGS_FOR_BUILD | the flags of CXX_FOR_BUILD. | 
| CPP_FOR_BUILD | the C/C++ PreProcessor for native build. | 
| CPPFLAGS_FOR_BUILD | the flags of CPP_FOR_BUILD. | 
| AS_FOR_BUILD | the assembler for native build. | 
| AR_FOR_BUILD | the archiver for native build. | 
| RANLIB_FOR_BUILD | the archiver extra tool for native build. | 
| LD_FOR_BUILD | the linker for native build. | 
| LDFLAGS_FOR_BUILD | the flags of LD_FOR_BUILD. | 
| NM_FOR_BUILD | a command line tool to list symbols from object files for native build. | 
| STRIP_FOR_BUILD | a command line tool to discard symbols and other data from object files for native build. | 
| CC | the C Compiler. | 
| CFLAGS | the flags of CC. | 
| CXX | the C++ Compiler. | 
| CXXFLAGS | the flags of CXX. | 
| CPP | the C/C++ PreProcessor. | 
| CPPFLAGS | the flags of CPP. | 
| AS | the assembler. | 
| AR | the archiver. | 
| RANLIB | the archiver extra tool. | 
| LD | the linker. | 
| LDFLAGS | the flags of LD. | 
| NM | a command line tool to list symbols from object files. | 
| STRIP | a command line tool to discard symbols and other data from object files. | 
| PACKAGE_WORKING_DIR | the working directory for installing. | 
| PACKAGE_BSCRIPT_DIR | the directory where the build script (e.g. Makefile,configure,CMakeLists.txt,meson.build,Cargo.toml, etc) is located. | 
| PACKAGE_BCACHED_DIR | the directory where the temporary files are stored in when building. | 
| PACKAGE_INSTALL_DIR | the directory where the final files will be installed to. | 
| x_INSTALL_DIR | the installation directory of x package. | 
| x_INCLUDE_DIR | $x_INSTALL_DIR/include | 
| x_LIBRARY_DIR | $x_INSTALL_DIR/lib | 
| build system name | build script file name | 
|---|---|
| meson | meson.build | 
| cmake | CMakeLists.txt | 
| gmake | GNUMakefileorMakefile | 
| ninja | build.ninja | 
| xmake | xmake.lua | 
| cargo | Cargo.toml | 
| go | go.mod | 
| gn | BUILD.gn | 
| rake | Rakefile | 
| autogen | autogen.sh | 
| autotools | configure.ac | 
| configure | configure | 
| ndk-build | Android.mk | 
A typical hierarchical structure of a ndk-pkg formula repository looks like below:
NDKPKGFormulaRepoName
├── formula
│   ├── packageA.yml
│   └── packageB.yml
├── LICENSE
└── README.md
${NDKPKG_HOME}/repos.d/${NDKPKGFormulaRepoName}
A ndk-pkg formula repository's config file is located at ${NDKPKG_HOME}/repos.d/${NDKPKGFormulaRepoName}/.ndk-pkg-formula-repo.yml
A typical ndk-pkg formula repository's config file content looks like below:
url: https://github.com/leleliu008/ndk-pkg-formula-repository-official-core
branch: master
pinned: 0
enabled: 1
created: 1673684639
updated: 1673684767If a ndk-pkg formula repository is pinned, it would not be updated.
If a ndk-pkg formula repository is disabled, it would not be searched.
run ndk-pkg formula-repo-add  command to create a new formula repository locally.
ndk-pkg official formula repository is hosted at https://github.com/leleliu008/ndk-pkg-formula-repository-official-core
It would be automatically fetched to your local repository as name official-core when you run ndk-pkg update command.
Note: If you find that a package is not in ndk-pkg official formula repository yet, PR is welcomed.
Using my prefab aars that have been published to GitHub-Hosted Maven Repository alongside with Android Gradle Plugin
I have published some commonly used packages as google prefab aar to https://github.com/leleliu008/ndk-pkg-prefab-aar-maven-repo
Using my prefab aars that have been published to Maven Central Repository alongside with Android Gradle Plugin
I have published some commonly used packages as google prefab aar to Maven Central Repository.
To get the full list of my published packages, please visit the following websites:
- https://repo1.maven.org/maven2/com/fpliu/ndk/pkg/prefab/android/21/
- https://search.maven.org/search?q=com.fpliu.ndk.pkg.prefab
In the next two sections, I will show you how to configure with Android Gradle Plugin in Kotlin DSL and Groovy DSL respectively.
step1. enable prefab feature for Android Gradle Plugin
android {
    buildFeatures {
        prefab = true
    }
}step2. enable Maven Central Repository for Gradle
allprojects {
    repositories {
        maven {
            mavenCentral()
        }
    }
}中国大陆的用户可使用如下配置:
allprojects {
    repositories {
        maven {
            maven { url = uri("https://maven.aliyun.com/repository/public") }
        }
    }
}step3. add dependencies in build.gradle.kts
Every package's coordinate for Gradle is com.fpliu.ndk.pkg.prefab.android.21:<PACKAGE-NAME>:<PACKAGE-VERSION>, for example, libpng package has a version 1.6.37, we could use it as follows:
dependencies {
    implementation ("com.fpliu.ndk.pkg.prefab.android.21:libpng:1.6.37")
}step4. invoke find_package(PACKAGE-NAME [REQUIRED] CONFIG) command in your Android project's CMakeLists.txt
Every package provides several cmake imported targets:
| TARGET-NAME | example | summary | 
|---|---|---|
| <PACKAGE-NAME>::headers | libpng::headers | C/C++ header files only | 
| <PACKAGE-NAME>::lib*.a | libpng::libpng16.a | static library | 
| <PACKAGE-NAME>::lib*.so | libpng::libpng16.so | shared library | 
| <PACKAGE-NAME>::* | libpng::libpng | base on .pc files | 
Following is a piece of codes show you how to link libpng.a which is provided by libpng package:
find_package(libpng REQUIRED CONFIG)
target_link_libraries(app libpng::libpng.a)or
find_package(libpng CONFIG)
if (libpng_FOUND)
    target_link_libraries(app libpng::libpng.a)
endif()step5. configure C++ standard and STL in build.gradle.kts
android {
    defaultConfig {
        externalNativeBuild {
            cmake {
                arguments += "-DANDROID_STL=c++_shared"
                cppFlags  += "-std=c++17"
            }
        }
    }
}Note:
- This step is only required for packages that use libc++.
- If you link a shared library that depends on libc++_shared.so, then your Android app should uselibc++_shared.sotoo.
step1. enable prefab feature for Android Gradle Plugin
android {
    buildFeatures {
        prefab true
    }
}step2. enable Maven Central Repository for Gradle
allprojects {
    repositories {
        maven {
            mavenCentral()
        }
    }
}中国大陆的用户可使用如下配置:
allprojects {
    repositories {
        maven {
            url 'https://maven.aliyun.com/repository/public'
        }
    }
}step3. add dependencies in build.gradle
Every package's coordinate for Gradle is com.fpliu.ndk.pkg.prefab.android.21:<PACKAGE-NAME>:<PACKAGE-VERSION>, for example, libpng package has a version 1.6.37, we could use it as follows:
dependencies {
    implementation 'com.fpliu.ndk.pkg.prefab.android.21:libpng:1.6.37'
}step4. invoke find_package(PACKAGE-NAME [REQUIRED] CONFIG) command in your Android project's CMakeLists.txt
Every package provides several cmake imported targets:
| TARGET-NAME | example | summary | 
|---|---|---|
| <PACKAGE-NAME>::headers | libpng::headers | C/C++ header files only | 
| <PACKAGE-NAME>::lib*.a | libpng::libpng16.a | static library | 
| <PACKAGE-NAME>::lib*.so | libpng::libpng16.so | shared library | 
| <PACKAGE-NAME>::* | libpng::libpng | base on .pc files | 
Following is a piece of codes show you how to link libpng.a which is provided by libpng package:
find_package(libpng REQUIRED CONFIG)
target_link_libraries(app libpng::libpng.a)or
find_package(libpng CONFIG)
if (libpng_FOUND)
    target_link_libraries(app libpng::libpng.a)
endif()step5. configure C++ standard and STL in build.gradle
android {
    defaultConfig {
        externalNativeBuild {
            cmake {
                arguments '-DANDROID_STL=c++_shared'
                cppFlags  '-std=c++17'
            }
        }
    }
}Note:
- This step is only required for packages that use libc++.
- If you link a shared library that depends on libc++_shared.so, then your Android app should uselibc++_shared.sotoo.
References:
- https://google.github.io/prefab/
- https://developer.android.com/studio/projects/android-library#aar-contents
- https://developer.android.com/studio/build/dependencies?agpversion=4.1#using-native-dependencies
Examples:
Create the google prefab aar then deploy it to Maven Local Repository and use it alongside with Android Gradle Plugin
If my published packages don't meet your needs, you can use this software to install packages then deploy them to Maven Local Repository.
In the next two sections, I will show you how to configure with Android Gradle Plugin in Kotlin DSL and Groovy DSL respectively.
step1. build and install libpng
Suppose you want to build and install libpng, the following command will build libpng with android-35 API and build for arm64-v8a and armeabi-v7a ABI respectively.
ndk-pkg install android-35-arm64-v8a,armeabi-v7a/libpngstep2. export the installed libpng package as the google prefab aar and deploy it to your Maven Local Repository
ndk-pkg deploy  android-35-arm64-v8a,armeabi-v7a/libpngstep3. enable prefab feature for Android Gradle Plugin
android {
    buildFeatures {
        prefab = true
    }
}step4. enable Maven Local Repository for Gradle
allprojects {
    repositories {
        maven {
            mavenLocal()
        }
    }
}step5. add dependencies in build.gradle.kts
Every package's coordinate for Gradle is com.fpliu.ndk.pkg.prefab.android.21:<PACKAGE-NAME>:<PACKAGE-VERSION>, for example, libpng package has a version 1.6.37, we could use it as follows:
dependencies {
    implementation ("com.fpliu.ndk.pkg.prefab.android.21:libpng:1.6.37")
}step6. invoke find_package(PACKAGE-NAME [REQUIRED] CONFIG) command in your Android project's CMakeLists.txt
Every package provides several cmake imported targets:
| TARGET-NAME | example | summary | 
|---|---|---|
| <PACKAGE-NAME>::headers | libpng::headers | C/C++ header files only | 
| <PACKAGE-NAME>::lib*.a | libpng::libpng16.a | static library | 
| <PACKAGE-NAME>::lib*.so | libpng::libpng16.so | shared library | 
| <PACKAGE-NAME>::* | libpng::libpng | base on .pc files | 
Following is a piece of codes show you how to link libpng.a which is provided by libpng package:
find_package(libpng REQUIRED CONFIG)
target_link_libraries(app libpng::libpng.a)or
find_package(libpng CONFIG)
if (libpng_FOUND)
    target_link_libraries(app libpng::libpng.a)
endif()step7. configure C++ standard and STL in build.gradle.kts
android {
    defaultConfig {
        externalNativeBuild {
            cmake {
                arguments += "-DANDROID_STL=c++_shared"
                cppFlags  += "-std=c++17"
            }
        }
    }
}Note:
- This step is only required for packages that use libc++.
- If you link a shared library that depends on libc++_shared.so, then your Android app should uselibc++_shared.sotoo.
step1. build and install libpng
Suppose you want to build and install libpng, the following command will build libpng with android-35 API and build for arm64-v8a and armeabi-v7a ABI respectively.
ndk-pkg install android-35-arm64-v8a,armeabi-v7a/libpngstep2. export the installed libpng package as the google prefab aar and deploy it to your Maven Local Repository
ndk-pkg deploy  android-35-arm64-v8a,armeabi-v7a/libpngstep3. enable prefab feature for Android Gradle Plugin
android {
    buildFeatures {
        prefab true
    }
}step4. enable Maven Local Repository for Gradle
allprojects {
    repositories {
        maven {
            mavenLocal()
        }
    }
}step5. add dependencies in build.gradle
Every package's coordinate for Gradle is com.fpliu.ndk.pkg.prefab.android.21:<PACKAGE-NAME>:<PACKAGE-VERSION>, for example, libpng package has a version 1.6.37, we could use it as follows:
dependencies {
    implementation 'com.fpliu.ndk.pkg.prefab.android.21:libpng:1.6.37'
}step6. invoke find_package(PACKAGE-NAME [REQUIRED] CONFIG) command in your Android project's CMakeLists.txt
Every package provides several cmake imported targets:
| TARGET-NAME | example | summary | 
|---|---|---|
| <PACKAGE-NAME>::headers | libpng::headers | C/C++ header files only | 
| <PACKAGE-NAME>::lib*.a | libpng::libpng16.a | static library | 
| <PACKAGE-NAME>::lib*.so | libpng::libpng16.so | shared library | 
| <PACKAGE-NAME>::* | libpng::libpng | base on .pc files | 
Following is a piece of codes show you how to link libpng.a which is provided by libpng package:
find_package(libpng REQUIRED CONFIG)
target_link_libraries(app libpng::libpng.a)or
find_package(libpng CONFIG)
if (libpng_FOUND)
    target_link_libraries(app libpng::libpng.a)
endif()step7. configure C++ standard and STL in build.gradle
android {
    defaultConfig {
        externalNativeBuild {
            cmake {
                arguments '-DANDROID_STL=c++_shared'
                cppFlags  '-std=c++17'
            }
        }
    }
}Note:
- This step is only required for packages that use libc++.
- If you link a shared library that depends on libc++_shared.so, then your Android app should uselibc++_shared.sotoo.
References:
- https://github.com/google/prefab
- https://developer.android.com/studio/projects/android-library#aar-contents
- https://developer.android.com/studio/build/dependencies?agpversion=4.1#using-native-dependencies
Examples: