xmake.lua 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253
  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")
  7. add_versions("1.4.0", "018b824396494c8958faa6337cebcaba48a2584d828f279eef0bbf9e05f900a7")
  8. add_versions("1.4.2", "db0de6b75e6c205f44542c3ac8d9935c8357a58072963228d0bb11a54181aea8")
  9. add_deps("cmake")
  10. add_deps("boost", {configs = {serialization = true, program_options = true}})
  11. on_install("windows", "macosx", "linux", function (package)
  12. io.replace("CMakeLists.txt", "unit_test_framework", "", {plain = true})
  13. local configs = {"-DBoost_USE_STATIC_LIBS=ON"}
  14. table.insert(configs, "-DCMAKE_BUILD_TYPE=" .. (package:debug() and "Debug" or "Release"))
  15. table.insert(configs, "-DBUILD_SHARED_LIBS=" .. (package:config("shared") and "ON" or "OFF"))
  16. if package:is_plat("windows") then
  17. table.insert(configs, "-DBoost_USE_STATIC_RUNTIME=" .. (package:config("vs_runtime"):startswith("MT") and "ON" or "OFF"))
  18. else
  19. table.insert(configs, "-DBoost_USE_STATIC_RUNTIME=OFF")
  20. end
  21. import("package.tools.cmake").install(package, configs)
  22. end)
  23. on_test(function (package)
  24. assert(package:check_cxxsnippets({test = [[
  25. #include <vector>
  26. #include <amgcl/backend/builtin.hpp>
  27. #include <amgcl/adapter/crs_tuple.hpp>
  28. #include <amgcl/make_solver.hpp>
  29. #include <amgcl/amg.hpp>
  30. #include <amgcl/coarsening/smoothed_aggregation.hpp>
  31. #include <amgcl/relaxation/spai0.hpp>
  32. #include <amgcl/solver/bicgstab.hpp>
  33. void test() {
  34. typedef amgcl::backend::builtin<double> Backend;
  35. typedef amgcl::make_solver<
  36. amgcl::amg<
  37. Backend,
  38. amgcl::coarsening::smoothed_aggregation,
  39. amgcl::relaxation::spai0
  40. >,
  41. amgcl::solver::bicgstab<Backend>
  42. > Solver;
  43. ptrdiff_t rows, cols;
  44. std::vector<int> ptr, col;
  45. std::vector<double> val;
  46. Solver solve(std::tie(rows, ptr, col, val));
  47. }
  48. ]]}, {configs = {languages = "c++17"}}))
  49. end)