|
| 1 | +// swift-tools-version:5.9 |
| 2 | +import PackageDescription |
| 3 | + |
| 4 | +let package = Package( |
| 5 | + name: "swift-sqlcipher", |
| 6 | + platforms: [ |
| 7 | + .iOS(.v13), |
| 8 | + .macOS(.v10_13), |
| 9 | + .watchOS(.v4), |
| 10 | + .tvOS(.v12), |
| 11 | + .visionOS(.v1) |
| 12 | + ], |
| 13 | + products: [ |
| 14 | + .library( |
| 15 | + name: "SQLiteDB", |
| 16 | + targets: ["SQLiteDB"] |
| 17 | + ), |
| 18 | + .library( |
| 19 | + name: "SQLCipher", |
| 20 | + targets: ["SQLCipher"] |
| 21 | + ) |
| 22 | + ], |
| 23 | + targets: [ |
| 24 | + .target( |
| 25 | + name: "SQLiteDB", |
| 26 | + dependencies: [.target(name: "SQLCipher")], |
| 27 | + cSettings: [.define("SQLITE_HAS_CODEC")] |
| 28 | + ), |
| 29 | + .target( |
| 30 | + name: "SQLCipher", |
| 31 | + sources: ["sqlite", "libtomcrypt"], |
| 32 | + publicHeadersPath: "sqlite", |
| 33 | + cSettings: [ |
| 34 | + .headerSearchPath("libtomcrypt/headers"), |
| 35 | + .define("SQLITE_DQS", to: "0"), |
| 36 | + .define("SQLITE_ENABLE_API_ARMOR"), |
| 37 | + .define("SQLITE_ENABLE_COLUMN_METADATA"), |
| 38 | + .define("SQLITE_ENABLE_DBSTAT_VTAB"), |
| 39 | + .define("SQLITE_ENABLE_FTS3"), |
| 40 | + .define("SQLITE_ENABLE_FTS3_PARENTHESIS"), |
| 41 | + .define("SQLITE_ENABLE_FTS3_TOKENIZER"), |
| 42 | + .define("SQLITE_ENABLE_FTS4"), |
| 43 | + .define("SQLITE_ENABLE_FTS5"), |
| 44 | + .define("SQLITE_ENABLE_MEMORY_MANAGEMENT"), |
| 45 | + .define("SQLITE_ENABLE_PREUPDATE_HOOK"), |
| 46 | + .define("SQLITE_ENABLE_RTREE"), |
| 47 | + .define("SQLITE_ENABLE_SESSION"), |
| 48 | + .define("SQLITE_ENABLE_STMTVTAB"), |
| 49 | + .define("SQLITE_ENABLE_UNKNOWN_SQL_FUNCTION"), |
| 50 | + .define("SQLITE_ENABLE_UNLOCK_NOTIFY"), |
| 51 | + .define("SQLITE_MAX_VARIABLE_NUMBER", to: "250000"), |
| 52 | + .define("SQLITE_LIKE_DOESNT_MATCH_BLOBS"), |
| 53 | + .define("SQLITE_OMIT_DEPRECATED"), |
| 54 | + .define("SQLITE_OMIT_SHARED_CACHE"), |
| 55 | + .define("SQLITE_SECURE_DELETE"), |
| 56 | + .define("SQLITE_THREADSAFE", to: "2"), |
| 57 | + .define("SQLITE_USE_URI"), |
| 58 | + .define("SQLITE_ENABLE_SNAPSHOT"), |
| 59 | + .define("SQLITE_HAS_CODEC"), |
| 60 | + .define("SQLITE_HOMEGROWN_RECURSIVE_MUTEX"), // needed or we see hangs in test cases |
| 61 | + .define("SQLITE_TEMP_STORE", to: "2"), |
| 62 | + .define("SQLITE_EXTRA_INIT", to: "sqlcipher_extra_init"), |
| 63 | + .define("SQLITE_EXTRA_SHUTDOWN", to: "sqlcipher_extra_shutdown"), |
| 64 | + .define("HAVE_GETHOSTUUID", to: "0"), |
| 65 | + .define("HAVE_STDINT_H"), |
| 66 | + .define("SQLCIPHER_CRYPTO_LIBTOMCRYPT"), |
| 67 | + .define("SQLCIPHER_CRYPTO_CUSTOM", to: "sqlcipher_ltc_setup"), |
| 68 | + ], |
| 69 | + linkerSettings: [.linkedLibrary("log", .when(platforms: [.android]))]), |
| 70 | + .testTarget( |
| 71 | + name: "SQLiteDBTests", |
| 72 | + dependencies: ["SQLiteDB"], |
| 73 | + resources: [.process("Resources")] |
| 74 | + ) |
| 75 | + ] |
| 76 | +) |
0 commit comments