| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455 |
- # For more information about using CMake with Android Studio, read the
- # documentation: https://d.android.com/studio/projects/add-native-code.html.
- # For more examples on how to use CMake, see https://github.com/android/ndk-samples.
- # Sets the minimum CMake version required for this project.
- cmake_minimum_required(VERSION 3.22.1)
- # Declares the project name. The project name can be accessed via ${ PROJECT_NAME},
- # Since this is the top level CMakeLists.txt, the project name is also accessible
- # with ${CMAKE_PROJECT_NAME} (both CMake variables are in-sync within the top level
- # build script scope).
- project("llama-android")
- ## Fetch latest llama.cpp from GitHub
- #include(FetchContent)
- #FetchContent_Declare(
- # llama
- # GIT_REPOSITORY https://github.com/ggerganov/llama.cpp
- # GIT_TAG master
- #)
- #
- ## Also provides "common"
- #FetchContent_MakeAvailable(llama)
- # llama.cpp CI uses the code from the current branch
- # ref: https://github.com/ggerganov/llama.cpp/pull/7341#issuecomment-2117617700
- add_subdirectory(../../../../../../ build-llama)
- # Creates and names a library, sets it as either STATIC
- # or SHARED, and provides the relative paths to its source code.
- # You can define multiple libraries, and CMake builds them for you.
- # Gradle automatically packages shared libraries with your APK.
- #
- # In this top level CMakeLists.txt, ${CMAKE_PROJECT_NAME} is used to define
- # the target library name; in the sub-module's CMakeLists.txt, ${PROJECT_NAME}
- # is preferred for the same purpose.
- #
- # In order to load a library into your app from Java/Kotlin, you must call
- # System.loadLibrary() and pass the name of the library defined here;
- # for GameActivity/NativeActivity derived applications, the same library name must be
- # used in the AndroidManifest.xml file.
- add_library(${CMAKE_PROJECT_NAME} SHARED
- # List C/C++ source files with relative paths to this CMakeLists.txt.
- llama-android.cpp)
- # Specifies libraries CMake should link to your target library. You
- # can link libraries from various origins, such as libraries defined in this
- # build script, prebuilt third-party libraries, or Android system libraries.
- target_link_libraries(${CMAKE_PROJECT_NAME}
- # List libraries link to the target library
- llama
- common
- android
- log)
|