- 
                Notifications
    You must be signed in to change notification settings 
- Fork 157
Cmake #487
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Cmake #487
Conversation
c1f6922    to
    002bdab      
    Compare
  
    There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
@JeromeCCP9 Here's the re-implementation. I have left a few comments
| jobs: | ||
| tests: | ||
| name: Check on ${{ matrix.toolchain }} toolchain ${{ matrix.mpi }} | ||
| runs-on: ${{ matrix.os || 'ubuntu-latest' }} | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There is no macos and windows here, because we need to discuss what compilers to use there and where to get them
| LANGUAGES Fortran C | ||
| ) | ||
|  | ||
| set(CMAKE_C_STANDARD 11) | ||
| set(CMAKE_C_STANDARD_REQUIRED ON) | ||
| set(CMAKE_C_EXTENSIONS OFF) | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There are some new C sources, but header only? Probably we don't need to add C to the main project in that case.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Adding C is useful for compiling with MKL, without this cmake cannot detect MKL automatically
https://cmake.org/cmake/help/latest/module/FindBLAS.html#intel-mkl
It is a bit annoying since we are actually a fortran code, but without this users need to define a lot of cmake variables for MKL.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What about using find_package(MKL) by default if it's intel compiler, otherwise have an option WANNIER90_MKL option that uses either MKL or default BLAS/LAPACK? I am not sure if it works on a pure Fortran project, but we can try and see
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Did a test, we can add some if conditionals to find either MKL or BLAS/LAPACK, however, in the
target_link_libraries(Wannier90_lib PRIVATE
        BLAS::BLAS LAPACK::LAPACK)
I guess we need to add another if for MKL as well, not sure if there is a simpler solution.
On the other hand, by enabling C language everything works automatically.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Ok, I suggest we postpone the decision of using either implementation, because @giovannipizzi warned me that there is an issue between LAPACK and macos, which we need to think how to handle.
| It seems the only failing tests are with  | 
388e5e4    to
    7540c6f      
    Compare
  
    | @JeromeCCP9 There are a few issues with the  | 
d3eaa3d    to
    bf954ab      
    Compare
  
    | Yes, I'll attend to these, let me catch up this evening... 
 | 
| This last week I've made some changes to the library and provided a new test driver for the c++ interface in a branch "c-for-gc," and these will be merged shortly into develop. I think that the existent tests must be replaced (by me), so it would make more sense to remove the demo.F90 tests from this PR, if possible? If not, then I merge later, that's also ok. (Also, at the moment, the c++ interface relies on a f2018 support (for CFI_establish) and this needs to be tested for.) | 
| 
 I saw that, it's ok, just ping me and I will rebase and fix that. 
 It would be good to have a Fortran test. In #444 I am mocking up a packaging test that would at least do a smoke test. 
 Do we need specific flag to enable it? | 
| set(CMAKE_INSTALL_MODULEDIR ${_DEFAULT_CMAKE_INSTALL_MODULEDIR} | ||
| CACHE STRING | ||
| "Fortran module installation path (Not a cmake native variable)" | ||
| ) | ||
| cmake_path(IS_ABSOLUTE CMAKE_INSTALL_MODULEDIR _is_absolute) | ||
| if (_is_absolute) | ||
| set(CMAKE_INSTALL_FULL_MODULEDIR ${CMAKE_INSTALL_MODULEDIR}) | ||
| else () | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It's not a good idea to use CMAKE_ prefixed variables (To avoid a possible future conflict).
I think WANNIER90_INSTALL_MODULEDIR is better.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Fully aware of that. The issue is that CMake install support for Fortran has not been implemented and these are a bit tricky because these are ABI dependent and there is no discussion on how it should be designed. This path is also one that should be common among all dependencies, thus the preference of CMAKE_ variable.
Currently this is made compatible with fortran-stdlib in hopes that there can be convergence towards that.
        
          
                cmake/wannier90.pc.in
              
                Outdated
          
        
      | prefix: @CMAKE_INSTALL_PREFIX@ | ||
|  | ||
| Name: wannier | ||
| Version: @PROJECT_VERSION@ | ||
| Description: @PROJECT_DESCRIPTION@ | ||
| URL: @PROJECT_HOMEPAGE_URL@ | ||
|  | ||
| Cflags: -I@CMAKE_INSTALL_FULL_MODULEDIR@ -I@CMAKE_INSTALL_FULL_INCLUDEDIR@ | ||
| Libs: -L@CMAKE_INSTALL_FULL_LIBDIR@ -lwannier90 | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
| prefix: @CMAKE_INSTALL_PREFIX@ | |
| Name: wannier | |
| Version: @PROJECT_VERSION@ | |
| Description: @PROJECT_DESCRIPTION@ | |
| URL: @PROJECT_HOMEPAGE_URL@ | |
| Cflags: -I@CMAKE_INSTALL_FULL_MODULEDIR@ -I@CMAKE_INSTALL_FULL_INCLUDEDIR@ | |
| Libs: -L@CMAKE_INSTALL_FULL_LIBDIR@ -lwannier90 | |
| prefix: @CMAKE_INSTALL_PREFIX@ | |
| libdir: ${prefix}/@CMAKE_INSTALL_LIBDIR@ | |
| includedir: ${prefix}/@CMAKE_INSTALL_INCLUDEDIR@ | |
| moduledirL: ${prefix}/@WANNIER90_INSTALL_MODULEDIR@ | |
| Name: wannier | |
| Version: @PROJECT_VERSION@ | |
| Description: @PROJECT_DESCRIPTION@ | |
| URL: @PROJECT_HOMEPAGE_URL@ | |
| Cflags: -I${moduledir} -I${includedir} | |
| Libs: -L${libdir} -lwannier90 | 
Using full paths make it unrelocatable.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Indeed, there was some context for this, but I completely lost it. Maybe it was related to testing the pkg-config file in the integration tests since the file in the build directory is not usable. Really don't remember why I made it like that.
There are more issues there though because PUBLIC linked libraries are not included. In principle this should be written as:
file(GENERATE OUTPUT wannier.pc.in INPUT wannier.pc.in.in)
configure_file(${CMAKE_CURRENT_BINARY_DIR}/wannier.pc.in wannier.pc)
And use a gen-ex depending on the target property to get the -l/-L/-I flags needed there. Didn't get the time to investigate what are appropriate flags for it though, would appreciate some help/discussion on this.
This is necessary because of the use mpi_f08 that is conditionally used in the Fortran module api.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
You could add a new string variable WANNIER_LINK_LIBRARIES and add any library wannier is linked to. then add Requires: @WANNIER_LINK_LIBRARIES@ to wannier.pc.in file.
but WANNIER_LINK_LIBRARIES should contain the names of their .pc files.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The question is where do we get the values to construct it? If we figure out that, I can write a prototype to be more templatable.
These values are taken from targets like MPI::MPI_Fortran. We can investigate that is populate in there with things like: https://stackoverflow.com/a/34292622. It should be in an *_INTERFACE_* like property. But maybe target Wannier_lib should be used to check that instead
2393d90    to
    ef03aef      
    Compare
  
    13df820    to
    e26ac57      
    Compare
  
    92633c8    to
    74827e6      
    Compare
  
    | @JeromeCCP9 Can you check this PR again? I have disabled tests that fail, but you can work on it gradually in subsequent PRs. It would be great to get this in, because I plan to package this for Fedora soon because of quantum-espresso dependency | 
| Hi Christian! Yes, surely we'll work on this and include it in 4.0. For me the main concern was that the configuration files were a bit too complex and complicated, but let me go through it and we'll discuss later. Thank you for revisiting this! It is good timing. Jerome | 
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Provides rich cmake support for Wannier90!
ecf0969    to
    f0f72e7      
    Compare
  
    Signed-off-by: Cristian Le <[email protected]>
Signed-off-by: Cristian Le <[email protected]>
This PR contains both the CMake implementation and CI reorganization. We can split it up later, but lets keep them together until the CI pass