2023-10-10 13:31:13 +02:00
|
|
|
// swift-tools-version:5.5
|
2023-03-28 18:39:01 +02:00
|
|
|
|
|
|
|
import PackageDescription
|
|
|
|
|
2024-04-15 12:14:46 +02:00
|
|
|
var sources = [
|
2024-06-26 17:33:02 +02:00
|
|
|
"src/llama.cpp",
|
2024-07-23 12:10:17 +02:00
|
|
|
"src/llama-vocab.cpp",
|
|
|
|
"src/llama-grammar.cpp",
|
|
|
|
"src/llama-sampling.cpp",
|
2024-06-26 17:33:02 +02:00
|
|
|
"src/unicode.cpp",
|
|
|
|
"src/unicode-data.cpp",
|
|
|
|
"ggml/src/ggml.c",
|
|
|
|
"ggml/src/ggml-alloc.c",
|
2024-10-03 01:49:47 +02:00
|
|
|
"ggml/src/ggml-backend.cpp",
|
2024-11-14 18:04:35 +01:00
|
|
|
"ggml/src/ggml-backend-reg.cpp",
|
|
|
|
"ggml/src/ggml-cpu/ggml-cpu.c",
|
|
|
|
"ggml/src/ggml-cpu/ggml-cpu.cpp",
|
2024-12-07 13:37:50 +01:00
|
|
|
"ggml/src/ggml-cpu/ggml-cpu-aarch64.cpp",
|
|
|
|
"ggml/src/ggml-cpu/ggml-cpu-hbm.cpp",
|
2024-11-14 18:04:35 +01:00
|
|
|
"ggml/src/ggml-cpu/ggml-cpu-quants.c",
|
2024-12-07 13:37:50 +01:00
|
|
|
"ggml/src/ggml-cpu/ggml-cpu-traits.cpp",
|
2024-11-14 18:04:35 +01:00
|
|
|
"ggml/src/ggml-threading.cpp",
|
2024-06-26 17:33:02 +02:00
|
|
|
"ggml/src/ggml-quants.c",
|
2024-04-15 12:14:46 +02:00
|
|
|
]
|
|
|
|
|
|
|
|
var resources: [Resource] = []
|
|
|
|
var linkerSettings: [LinkerSetting] = []
|
|
|
|
var cSettings: [CSetting] = [
|
|
|
|
.unsafeFlags(["-Wno-shorten-64-to-32", "-O3", "-DNDEBUG"]),
|
|
|
|
.unsafeFlags(["-fno-objc-arc"]),
|
2024-11-14 18:04:35 +01:00
|
|
|
.headerSearchPath("ggml/src"),
|
2024-11-29 21:54:58 +01:00
|
|
|
.headerSearchPath("ggml/src/ggml-cpu"),
|
2024-04-15 12:14:46 +02:00
|
|
|
// NOTE: NEW_LAPACK will required iOS version 16.4+
|
|
|
|
// We should consider add this in the future when we drop support for iOS 14
|
|
|
|
// (ref: ref: https://developer.apple.com/documentation/accelerate/1513264-cblas_sgemm?language=objc)
|
|
|
|
// .define("ACCELERATE_NEW_LAPACK"),
|
|
|
|
// .define("ACCELERATE_LAPACK_ILP64")
|
2024-11-29 21:54:58 +01:00
|
|
|
.define("GGML_USE_CPU"),
|
2024-04-15 12:14:46 +02:00
|
|
|
]
|
|
|
|
|
2024-11-29 21:54:58 +01:00
|
|
|
|
2024-04-15 12:14:46 +02:00
|
|
|
#if canImport(Darwin)
|
2024-11-14 18:04:35 +01:00
|
|
|
sources.append("ggml/src/ggml-common.h")
|
|
|
|
sources.append("ggml/src/ggml-metal/ggml-metal.m")
|
|
|
|
resources.append(.process("ggml/src/ggml-metal/ggml-metal.metal"))
|
2024-04-15 12:14:46 +02:00
|
|
|
linkerSettings.append(.linkedFramework("Accelerate"))
|
|
|
|
cSettings.append(
|
|
|
|
contentsOf: [
|
|
|
|
.define("GGML_USE_ACCELERATE"),
|
2024-11-25 15:13:39 +01:00
|
|
|
.define("GGML_USE_METAL"),
|
2024-04-15 12:14:46 +02:00
|
|
|
]
|
|
|
|
)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if os(Linux)
|
|
|
|
cSettings.append(.define("_GNU_SOURCE"))
|
|
|
|
#endif
|
|
|
|
|
2023-03-28 18:39:01 +02:00
|
|
|
let package = Package(
|
|
|
|
name: "llama",
|
2023-12-05 08:29:46 +01:00
|
|
|
platforms: [
|
|
|
|
.macOS(.v12),
|
|
|
|
.iOS(.v14),
|
|
|
|
.watchOS(.v4),
|
|
|
|
.tvOS(.v14)
|
|
|
|
],
|
2023-03-28 18:39:01 +02:00
|
|
|
products: [
|
|
|
|
.library(name: "llama", targets: ["llama"]),
|
|
|
|
],
|
|
|
|
targets: [
|
|
|
|
.target(
|
|
|
|
name: "llama",
|
|
|
|
path: ".",
|
2024-02-12 18:54:29 +01:00
|
|
|
exclude: [
|
2024-11-08 10:34:06 +01:00
|
|
|
"build",
|
2024-02-12 18:54:29 +01:00
|
|
|
"cmake",
|
|
|
|
"examples",
|
|
|
|
"scripts",
|
|
|
|
"models",
|
|
|
|
"tests",
|
|
|
|
"CMakeLists.txt",
|
2024-11-08 10:34:06 +01:00
|
|
|
"Makefile",
|
|
|
|
"ggml/src/ggml-metal-embed.metal"
|
2024-02-12 18:54:29 +01:00
|
|
|
],
|
2024-04-15 12:14:46 +02:00
|
|
|
sources: sources,
|
|
|
|
resources: resources,
|
2023-03-28 18:39:01 +02:00
|
|
|
publicHeadersPath: "spm-headers",
|
2024-04-15 12:14:46 +02:00
|
|
|
cSettings: cSettings,
|
|
|
|
linkerSettings: linkerSettings
|
2023-09-09 11:12:10 +02:00
|
|
|
)
|
2023-03-28 18:39:01 +02:00
|
|
|
],
|
2024-12-01 16:12:41 +01:00
|
|
|
cxxLanguageStandard: .cxx17
|
2023-03-28 18:39:01 +02:00
|
|
|
)
|