mirror of
				https://github.com/ggml-org/llama.cpp.git
				synced 2025-11-03 09:22:01 +00:00 
			
		
		
		
	
		
			
				
	
	
		
			56 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			CMake
		
	
	
	
	
	
			
		
		
	
	
			56 lines
		
	
	
		
			2.2 KiB
		
	
	
	
		
			CMake
		
	
	
	
	
	
 | 
						|
# 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)
 |