xmake.lua 2.9 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  1. package("amgcl")
  2. set_homepage("https://github.com/ddemidov/amgcl/")
  3. set_description("C++ library for solving large sparse linear systems with algebraic multigrid method")
  4. set_license("MIT")
  5. add_urls("https://github.com/ddemidov/amgcl/archive/refs/tags/$(version).tar.gz",
  6. "https://github.com/ddemidov/amgcl.git", {submodules = false})
  7. add_versions("1.4.5", "611b7e46b60640abab055d815e2b28af3cb92e71fa609c514465f94b51c1f886")
  8. add_versions("1.4.0", "018b824396494c8958faa6337cebcaba48a2584d828f279eef0bbf9e05f900a7")
  9. add_versions("1.4.2", "db0de6b75e6c205f44542c3ac8d9935c8357a58072963228d0bb11a54181aea8")
  10. add_versions("1.4.3", "e920d5767814ce697d707d1f359a16c9b9eb79eba28fe19e14c18c2a505fe0ad")
  11. add_versions("1.4.4", "02fd5418e14d669422f65fc739ce72bf9516ced2d8942574d4b8caa05dda9d8c")
  12. add_deps("cmake")
  13. add_deps("boost", {configs = {cmake = false, serialization = true, program_options = true}})
  14. on_install("windows", "mingw", "macosx", "linux", function (package)
  15. io.replace("CMakeLists.txt", "cmake_policy(SET CMP0058 OLD)", "", {plain = true})
  16. io.replace("CMakeLists.txt", "unit_test_framework", "", {plain = true})
  17. local configs = {"-DBoost_USE_STATIC_LIBS=ON"}
  18. table.insert(configs, "-DCMAKE_BUILD_TYPE=" .. (package:is_debug() and "Debug" or "Release"))
  19. table.insert(configs, "-DBUILD_SHARED_LIBS=" .. (package:config("shared") and "ON" or "OFF"))
  20. if package:is_plat("windows") then
  21. table.insert(configs, "-DBoost_USE_STATIC_RUNTIME=" .. (package:has_runtime("MT", "MTd") and "ON" or "OFF"))
  22. else
  23. table.insert(configs, "-DBoost_USE_STATIC_RUNTIME=OFF")
  24. end
  25. import("package.tools.cmake").install(package, configs)
  26. end)
  27. on_test(function (package)
  28. assert(package:check_cxxsnippets({test = [[
  29. #include <vector>
  30. #include <amgcl/backend/builtin.hpp>
  31. #include <amgcl/adapter/crs_tuple.hpp>
  32. #include <amgcl/make_solver.hpp>
  33. #include <amgcl/amg.hpp>
  34. #include <amgcl/coarsening/smoothed_aggregation.hpp>
  35. #include <amgcl/relaxation/spai0.hpp>
  36. #include <amgcl/solver/bicgstab.hpp>
  37. void test() {
  38. typedef amgcl::backend::builtin<double> Backend;
  39. typedef amgcl::make_solver<
  40. amgcl::amg<
  41. Backend,
  42. amgcl::coarsening::smoothed_aggregation,
  43. amgcl::relaxation::spai0
  44. >,
  45. amgcl::solver::bicgstab<Backend>
  46. > Solver;
  47. ptrdiff_t rows, cols;
  48. std::vector<int> ptr, col;
  49. std::vector<double> val;
  50. Solver solve(std::tie(rows, ptr, col, val));
  51. }
  52. ]]}, {configs = {languages = "c++17"}}))
  53. end)