From 60d722ec53f1a763b8a6e6c2d92f0974cc2b2693 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Luca=20Pep=C3=A8=20Sciarria?= Date: Mon, 9 Jun 2025 10:09:28 +0200 Subject: [PATCH] fix cmake --- samples/advanced/fileread/CMakeLists.txt | 47 +++++++++++++++--------- 1 file changed, 30 insertions(+), 17 deletions(-) diff --git a/samples/advanced/fileread/CMakeLists.txt b/samples/advanced/fileread/CMakeLists.txt index 5521416f..1ab7286b 100644 --- a/samples/advanced/fileread/CMakeLists.txt +++ b/samples/advanced/fileread/CMakeLists.txt @@ -2,11 +2,11 @@ cmake_minimum_required(VERSION 3.15) project(AMGExamples Fortran) # Installation directories (passed as CMake variables) -set(AMG_INSTALL_DIR "" CACHE PATH "Path to AMG installation") +set(AMG4PSBLAS_INSTALL_DIR "" CACHE PATH "Path to AMG installation") set(PSBLAS_INSTALL_DIR "" CACHE PATH "Path to PSBLAS installation") # Check if installation directories are set -if(NOT AMG_INSTALL_DIR) +if(NOT AMG4PSBLAS_INSTALL_DIR) message(FATAL_ERROR "AMG_INSTALL_DIR must be set. Use -DAMG_INSTALL_DIR=/path/to/amg when running CMake.") endif() @@ -14,37 +14,46 @@ if(NOT PSBLAS_INSTALL_DIR) message(FATAL_ERROR "PSBLAS_INSTALL_DIR must be set. Use -DPSBLAS_INSTALL_DIR=/path/to/psblas when running CMake.") endif() + +find_package(psblas REQUIRED PATHS ${PSBLAS_INSTALL_DIR}) +find_package(amg4psblas REQUIRED PATHS ${AMG4PSBLAS_INSTALL_DIR}) + + # Include directories include_directories( "." - "${AMG_INSTALL_DIR}/include" - "${AMG_INSTALL_DIR}/modules" - "${PSBLAS_INSTALL_DIR}/include" # Assuming PSBLAS include directory is here + "${AMG4PSBLAS_INSTALL_DIR}/include" + "${AMG4PSBLAS_INSTALL_DIR}/modules" + "${PSBLAS_INSTALL_DIR}/include" ) # Fortran module directory set(CMAKE_Fortran_MODULE_DIRECTORY "${CMAKE_CURRENT_BINARY_DIR}/modules") -set(FMFLAG "-I") # Adjust if needed +set(FMFLAG "-I") # Library directories link_directories( - "${AMG_INSTALL_DIR}/lib" + "${AMG4PSBLAS_INSTALL_DIR}/lib" "${PSBLAS_INSTALL_DIR}/lib" ) # Libraries -set(AMG_LIBS psb_linsolve amg_prec psb_prec) -set(PSBLAS_LIBS psb_util psb_linsolve psb_prec psb_base) # Example, adjust as needed +set(AMG_LIBS amg4psblas::amgprec) +set(PSBLAS_LIBS psblas::util psblas::linsolve psblas::prec psblas::base) # Executable directory set(EXEDIR "${CMAKE_CURRENT_BINARY_DIR}/runs") file(MAKE_DIRECTORY "${EXEDIR}") +set(COMMON_SOURCE data_input.f90) + # Source files -set(DFSOBJS amg_df_sample.f90 data_input.f90) -set(SFSOBJS amg_sf_sample.f90 data_input.f90) -set(CFSOBJS amg_cf_sample.f90 data_input.f90) -set(ZFSOBJS amg_zf_sample.f90 data_input.f90) +set(DFSOBJS ${COMMON_SOURCE} amg_df_sample.f90) +set(SFSOBJS ${COMMON_SOURCE} amg_sf_sample.f90) +set(CFSOBJS ${COMMON_SOURCE} amg_cf_sample.f90) +set(ZFSOBJS ${COMMON_SOURCE} amg_zf_sample.f90) + + # Function to create executable macro(create_amg_executable target sources) @@ -52,15 +61,19 @@ macro(create_amg_executable target sources) target_link_libraries(${target} PUBLIC ${AMG_LIBS} ${PSBLAS_LIBS} - #${LDLIBS} # Assuming this variable is defined elsewhere if needed + ) # Move executable to EXEDIR (post-build) - add_custom_command(TARGET ${target} POST_BUILD - COMMAND ${CMAKE_COMMAND} -E move $ ${EXEDIR} - ) + #add_custom_command(TARGET ${target} POST_BUILD + # COMMAND ${CMAKE_COMMAND} -E move $ ${EXEDIR} + #) + set_target_properties(${target} PROPERTIES + RUNTIME_OUTPUT_DIRECTORY ${EXEDIR} + ) endmacro() + # Create executables create_amg_executable(amg_df_sample ${DFSOBJS}) create_amg_executable(amg_sf_sample ${SFSOBJS})