2
0

xmake.lua 5.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109
  1. package("sqlite3")
  2. set_homepage("https://sqlite.org/")
  3. set_description("The most used database engine in the world")
  4. set_license("Public Domain")
  5. set_urls("https://sqlite.org/$(version)", {version = function (version)
  6. local year = "2024"
  7. if version:le("3.24") then
  8. year = "2018"
  9. elseif version:le("3.36") then
  10. year = "2021"
  11. elseif version:le("3.42") then
  12. year = "2022"
  13. elseif version:le("3.44") then
  14. year = "2023"
  15. end
  16. local version_str = version:gsub("[.+]", "")
  17. if #version_str < 7 then
  18. version_str = version_str .. "00"
  19. end
  20. return year .. "/sqlite-autoconf-" .. version_str .. ".tar.gz"
  21. end})
  22. add_versions("3.23.0+0", "b7711a1800a071674c2bf76898ae8584fc6c9643cfe933cfc1bc54361e3a6e49")
  23. add_versions("3.24.0+0", "d9d14e88c6fb6d68de9ca0d1f9797477d82fc3aed613558f87ffbdbbc5ceb74a")
  24. add_versions("3.34.0+100", "2a3bca581117b3b88e5361d0ef3803ba6d8da604b1c1a47d902ef785c1b53e89")
  25. add_versions("3.35.0+300", "ecbccdd440bdf32c0e1bb3611d635239e3b5af268248d130d0445a32daf0274b")
  26. add_versions("3.35.0+400", "7771525dff0185bfe9638ccce23faa0e1451757ddbda5a6c853bb80b923a512d")
  27. add_versions("3.36.0+0", "bd90c3eb96bee996206b83be7065c9ce19aef38c3f4fb53073ada0d0b69bbce3")
  28. add_versions("3.37.0+200", "4089a8d9b467537b3f246f217b84cd76e00b1d1a971fe5aca1e30e230e46b2d8")
  29. add_versions("3.39.0+200", "852be8a6183a17ba47cee0bbff7400b7aa5affd283bf3beefc34fcd088a239de")
  30. add_versions("3.43.0+200", "6d422b6f62c4de2ca80d61860e3a3fb693554d2f75bb1aaca743ccc4d6f609f0")
  31. add_versions("3.45.0+100", "cd9c27841b7a5932c9897651e20b86c701dd740556989b01ca596fcfa3d49a0a")
  32. add_versions("3.45.0+200", "bc9067442eedf3dd39989b5c5cfbfff37ae66cc9c99274e0c3052dc4d4a8f6ae")
  33. add_versions("3.45.0+300", "b2809ca53124c19c60f42bf627736eae011afdcc205bb48270a5ee9a38191531")
  34. add_versions("3.46.0+0", "6f8e6a7b335273748816f9b3b62bbdc372a889de8782d7f048c653a447417a7d")
  35. add_versions("3.46.0+100", "67d3fe6d268e6eaddcae3727fce58fcc8e9c53869bdd07a0c61e38ddf2965071")
  36. add_versions("3.47.0+0", "83eb21a6f6a649f506df8bd3aab85a08f7556ceed5dbd8dea743ea003fc3a957")
  37. add_versions("3.47.0+100", "416a6f45bf2cacd494b208fdee1beda509abda951d5f47bc4f2792126f01b452")
  38. add_versions("3.47.0+200", "f1b2ee412c28d7472bc95ba996368d6f0cdcf00362affdadb27ed286c179540b")
  39. add_configs("explain_comments", { description = "Inserts comment text into the output of EXPLAIN.", default = true, type = "boolean"})
  40. add_configs("dbpage_vtab", { description = "Enable the SQLITE_DBPAGE virtual table.", default = true, type = "boolean"})
  41. add_configs("stmt_vtab", { description = "Enable the SQLITE_STMT virtual table logic.", default = true, type = "boolean"})
  42. add_configs("dbstat_vtab", { description = "Enable the dbstat virtual table.", default = true, type = "boolean"})
  43. add_configs("math_functions", { description = "Enable the built-in SQL math functions.", default = true, type = "boolean"})
  44. add_configs("rtree", { description = "Enable R-Tree.", default = false, type = "boolean"})
  45. add_configs("safe_mode", { description = "Use thread safe mode in 0 (single thread) | 1 (serialize) | 2 (mutli thread).", default = "1", type = "string", values = {"0", "1", "2"}})
  46. if is_plat("macosx", "linux", "bsd") then
  47. add_syslinks("pthread", "dl")
  48. end
  49. on_install(function (package)
  50. local xmake_lua = [[
  51. add_rules("mode.debug", "mode.release")
  52. set_encodings("utf-8")
  53. option("explain_comments", {default = false, defines = "SQLITE_ENABLE_EXPLAIN_COMMENTS"})
  54. option("dbpage_vtab", {default = false, defines = "SQLITE_ENABLE_DBPAGE_VTAB"})
  55. option("stmt_vtab", {default = false, defines = "SQLITE_ENABLE_STMTVTAB"})
  56. option("dbstat_vtab", {default = false, defines = "SQLITE_ENABLE_DBSTAT_VTAB"})
  57. option("math_functions", {default = false, defines = "SQLITE_ENABLE_MATH_FUNCTIONS"})
  58. option("rtree", {default = false, defines = "SQLITE_ENABLE_RTREE"})
  59. option("safe_mode", {default = "1"})
  60. target("sqlite3")
  61. set_kind("$(kind)")
  62. add_files("sqlite3.c")
  63. add_headerfiles("sqlite3.h", "sqlite3ext.h")
  64. add_options("explain_comments", "dbpage_vtab", "stmt_vtab", "dbstat_vtab", "math_functions", "rtree")
  65. if has_config("safe_mode") then
  66. add_defines("SQLITE_THREADSAFE=" .. get_config("safe_mode"))
  67. end
  68. if is_kind("shared") and is_plat("windows") then
  69. add_defines("SQLITE_API=__declspec(dllexport)")
  70. end
  71. if is_plat("macosx", "linux", "bsd") then
  72. add_syslinks("pthread", "dl")
  73. end
  74. ]]
  75. if package:is_plat(os.host()) and (package:is_arch(os.arch()) or package:is_plat("windows")) then
  76. xmake_lua = xmake_lua .. [[
  77. target("sqlite3_shell")
  78. set_kind("binary")
  79. set_basename("sqlite3")
  80. add_files("shell.c")
  81. add_deps("sqlite3")
  82. ]]
  83. end
  84. io.writefile("xmake.lua", xmake_lua)
  85. local configs = {}
  86. for opt, value in pairs(package:configs()) do
  87. if not package:extraconf("configs", opt, "builtin") then
  88. configs[opt] = value
  89. end
  90. end
  91. import("package.tools.xmake").install(package, configs)
  92. package:addenv("PATH", "bin")
  93. end)
  94. on_test(function (package)
  95. assert(package:has_cfuncs("sqlite3_open_v2", {includes = "sqlite3.h"}))
  96. end)