xmake.lua 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. package("sqlpp11")
  2. set_kind("library", {headeronly = true})
  3. set_homepage("https://github.com/rbock/sqlpp11")
  4. set_description("A type safe SQL template library for C++")
  5. add_urls("https://github.com/rbock/sqlpp11/archive/refs/tags/$(version).tar.gz",
  6. "https://github.com/rbock/sqlpp11.git")
  7. add_versions("0.61", "d5a95e28ae93930f7701f517b1342ac14bcf33a9b1c5b5f0dff6aea5e315bb50")
  8. add_deps("cmake")
  9. add_configs("sqlite3_connector", { description = "Enable SQlite3 connector.", default = false, type = "boolean"})
  10. add_configs("sqlcipher_connector", { description = "Enable SQlite3 connector with SQLCipher.", default = false, type = "boolean"})
  11. add_configs("mariadb_connector", { description = "Enable MariaDB connector.", default = false, type = "boolean"})
  12. add_configs("postgresql_connector", { description = "Enable PostgreSQL connector.", default = false, type = "boolean"})
  13. add_configs("mysql_connector", { description = "Enable MySQL connector.", default = false, type = "boolean"})
  14. on_load("windows", "linux", "macosx", function (package)
  15. if package:config("mysql_connector") then
  16. package:add("deps", "mysql")
  17. end
  18. end)
  19. on_install("windows", "linux", "macosx", function (package)
  20. local configs = {"-DBUILD_TESTING=OFF"}
  21. table.insert(configs, "-DCMAKE_BUILD_TYPE=" .. (package:debug() and "Debug" or "Release"))
  22. table.insert(configs, "-DBUILD_SHARED_LIBS=" .. (package:config("shared") and "ON" or "OFF"))
  23. if package:config("sqlite3_connector") then
  24. table.insert(configs, "-DBUILD_SQLITE3_CONNECTOR=ON")
  25. end
  26. if package:config("sqlcipher_connector") then
  27. table.insert(configs, "-DBUILD_SQLCIPHER_CONNECTOR=ON")
  28. end
  29. if package:config("mariadb_connector") then
  30. table.insert(configs, "-DBUILD_MARIADB_CONNECTOR=ON")
  31. end
  32. -- TODO we need add PostgreSQL deps
  33. if package:config("postgresql_connector") then
  34. table.insert(configs, "-DBUILD_POSTGRESQL_CONNECTOR=ON")
  35. end
  36. -- TODO we need add MySQL deps
  37. if package:config("mysql_connector") then
  38. table.insert(configs, "-DBUILD_MYSQL_CONNECTOR=ON")
  39. local libmysql = package:dep("mysql"):fetch()
  40. if libmysql then
  41. table.insert(configs, "-DMySQL_INCLUDE_DIR=" .. table.concat(libmysql.includedirs or libmysql.sysincludedirs, ";"))
  42. table.insert(configs, "-DMySQL_LIBRARY=" .. table.concat(libmysql.libfiles or {}, ";"))
  43. end
  44. end
  45. import("package.tools.cmake").install(package, configs)
  46. end)
  47. on_test(function (package)
  48. assert(package:check_cxxsnippets({test = [[
  49. void test() {
  50. select(sqlpp::value(false).as(sqlpp::alias::a));
  51. }
  52. ]]}, {configs = {languages = "c++14"}, includes = {"sqlpp11/sqlpp11.h"}}))
  53. end)