2
0

xmake.lua 5.2 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687
  1. package("sqlitecpp")
  2. set_homepage("http://srombauts.github.io/SQLiteCpp")
  3. set_description("SQLiteC++ (SQLiteCpp) is a smart and easy to use C++ SQLite3 wrapper.")
  4. set_license("MIT")
  5. set_urls("https://github.com/SRombauts/SQLiteCpp/archive/refs/tags/$(version).tar.gz",
  6. "https://github.com/SRombauts/SQLiteCpp.git")
  7. add_versions("3.3.3", "33bd4372d83bc43117928ee842be64d05e7807f511b5195f85d30015cad9cac6")
  8. add_versions("3.3.2", "5aa8eda130d0689bd5ed9b2074714c2dbc610f710483c61ba6cf944cebfe03af")
  9. add_versions("3.3.1", "71f990f9fb4b004533b6859ce40729af823b87fe691dd99ca084a7fd40db54b9")
  10. add_versions("3.2.1", "70c67d5680c47460f82a7abf8e6b0329bf2fb10795a982a6d8abc06adb42d693")
  11. if is_plat("android", "wasm") then
  12. add_configs("sqlite3_external", { description = "Use external sqlite3 library instead of bundled.", default = false, type = "boolean", readonly = true})
  13. elseif is_plat("linux", "macosx", "mingw", "msys", "bsd", "cross") then
  14. add_configs("sqlite3_external", { description = "Use external sqlite3 library instead of bundled.", default = true, type = "boolean", readonly = true})
  15. else
  16. add_configs("sqlite3_external", { description = "Use external sqlite3 library instead of bundled.", default = false, type = "boolean"})
  17. end
  18. add_configs("column_metadata", { description = "Enable Column::getColumnOriginName(). Require support from sqlite3 library.", default = false, type = "boolean"})
  19. add_configs("assert_handled", { description = "Enable the user definition of a assertion_failed() handler.", default = false, type = "boolean"})
  20. add_configs("has_codec", { description = "Enable database encryption API. Not available in the public release of SQLite.", default = false, type = "boolean"})
  21. add_configs("legacy_struct", { description = "EFallback to forward declaration of legacy struct sqlite3_value (pre SQLite 3.19)", default = false, type = "boolean"})
  22. add_configs("ommit_load_extension", { description = "Enable ommit load extension.", default = false, type = "boolean"})
  23. add_configs("filesystem", { description = "Disable the support for std::filesystem (C++17)", default = false, type = "boolean"})
  24. if is_plat("mingw") then
  25. add_configs("stack_protection", { description = "Enable stack protection for MySQL.", default = true, type = "boolean", readonly = true})
  26. else
  27. add_configs("stack_protection", { description = "Enable stack protection for MySQL.", default = true, type = "boolean"})
  28. end
  29. add_deps("cmake")
  30. on_load(function (package)
  31. if package:config("sqlite3_external") then
  32. package:add("deps", "sqlite3")
  33. end
  34. end)
  35. on_install(function (package)
  36. local configs =
  37. {
  38. "-DSQLITECPP_BUILD_EXAMPLES=OFF",
  39. "-DSQLITECPP_BUILD_TESTS=OFF",
  40. "-DSQLITECPP_RUN_CPPLINT=OFF",
  41. "-DSQLITECPP_RUN_CPPCHECK=OFF",
  42. }
  43. table.insert(configs, "-DSQLITECPP_INTERNAL_SQLITE=" .. (package:config("sqlite3_external") and "OFF" or "ON"))
  44. table.insert(configs, "-DSQLITE_ENABLE_COLUMN_METADATA=" .. (package:config("column_metadata") and "ON" or "OFF"))
  45. table.insert(configs, "-DSQLITE_ENABLE_ASSERT_HANDLER=" .. (package:config("assert_handled") and "ON" or "OFF"))
  46. table.insert(configs, "-DSQLITE_HAS_CODEC=" .. (package:config("has_codec") and "ON" or "OFF"))
  47. table.insert(configs, "-DSQLITE_USE_LEGACY_STRUCT=" .. (package:config("legacy_struct") and "ON" or "OFF"))
  48. table.insert(configs, "-DSQLITE_OMMIT_LOAD_EXTENSION=" .. (package:config("ommit_load_extension") and "ON" or "OFF"))
  49. table.insert(configs, "-DSQLITECPP_DISABLE_STD_FILESYSTEM=" .. (package:config("filesystem") and "ON" or "OFF"))
  50. table.insert(configs, "-DSQLITECPP_USE_STACK_PROTECTION=" .. (package:config("stack_protection") and "ON" or "OFF"))
  51. table.insert(configs, "-DCMAKE_BUILD_TYPE=" .. (package:is_debug() and "Debug" or "Release"))
  52. table.insert(configs, "-DBUILD_SHARED_LIBS=" .. (package:config("shared") and "ON" or "OFF"))
  53. if package:is_plat("windows") then
  54. if package:config("shared") then
  55. if package:version():gt("3.2.1") then
  56. package:add("defines", "SQLITECPP_COMPILE_DLL")
  57. else
  58. table.remove(configs, #configs) -- BUILD_SHARED_LIBS
  59. table.insert(configs, "-DCMAKE_WINDOWS_EXPORT_ALL_SYMBOLS=ON")
  60. end
  61. end
  62. table.insert(configs, "-DSQLITECPP_USE_STATIC_RUNTIME=" .. (package:config("vs_runtime"):startswith("MT") and "ON" or "OFF"))
  63. end
  64. import("package.tools.cmake").install(package, configs)
  65. os.trycp("**.dll", package:installdir("bin"))
  66. os.trycp("**.so", package:installdir("lib"))
  67. if package:config("sqlite3_external") then
  68. os.tryrm(package:installdir("bin/sqlite3*"))
  69. os.tryrm(package:installdir("lib/sqlite3*"))
  70. end
  71. end)
  72. on_test(function (package)
  73. assert(package:check_cxxsnippets({test = [[
  74. void test() {
  75. SQLite::Database db("example.db3");
  76. }
  77. ]]}, {configs = {languages = "c++11"}, includes = {"SQLiteCpp/Database.h"}}))
  78. end)