Skip to content

Commit 7d47f0a

Browse files
authored
Merge pull request #1978 from danielgindi/feature/msvc_cmake
Better support for MSVC/Windows in CMake (v0.3.x)
2 parents a529c71 + b56b34a commit 7d47f0a

File tree

3 files changed

+21
-13
lines changed

3 files changed

+21
-13
lines changed

CMakeLists.txt

Lines changed: 19 additions & 11 deletions
Original file line numberDiff line numberDiff line change
@@ -42,6 +42,19 @@ endif()
4242

4343
#######
4444

45+
if(MSVC AND MSVC_STATIC_CRT)
46+
set(CompilerFlags
47+
CMAKE_CXX_FLAGS
48+
CMAKE_CXX_FLAGS_DEBUG
49+
CMAKE_CXX_FLAGS_RELEASE
50+
CMAKE_C_FLAGS
51+
CMAKE_C_FLAGS_DEBUG
52+
CMAKE_C_FLAGS_RELEASE
53+
)
54+
foreach(CompilerFlag ${CompilerFlags})
55+
string(REPLACE "/MD" "/MT" ${CompilerFlag} "${${CompilerFlag}}")
56+
endforeach()
57+
endif()
4558

4659
message(WARNING "CMake support is experimental. It does not yet support all build options and may not produce the same Makefiles that OpenBLAS ships with.")
4760

@@ -134,7 +147,7 @@ endif ()
134147

135148
# Only generate .def for dll on MSVC and always produce pdb files for debug and release
136149
if(MSVC)
137-
if (${CMAKE_MAJOR_VERSION}.${CMAKE_MINOR_VERSION} LESS 3.4)
150+
if (${CMAKE_MAJOR_VERSION}.${CMAKE_MINOR_VERSION} VERSION_LESS 3.4)
138151
set(OpenBLAS_DEF_FILE "${PROJECT_BINARY_DIR}/openblas.def")
139152
endif()
140153
set(CMAKE_C_FLAGS_RELEASE "${CMAKE_C_FLAGS_RELEASE} /Zi")
@@ -149,12 +162,6 @@ if (${DYNAMIC_ARCH})
149162
endforeach()
150163
endif ()
151164

152-
# Only build shared libs for MSVC
153-
if (MSVC)
154-
set(BUILD_SHARED_LIBS ON)
155-
endif()
156-
157-
158165
# add objects to the openblas lib
159166
add_library(${OpenBLAS_LIBNAME} ${LA_SOURCES} ${LAPACKE_SOURCES} ${RELA_SOURCES} ${TARGET_OBJS} ${OpenBLAS_DEF_FILE})
160167
target_include_directories(${OpenBLAS_LIBNAME} INTERFACE $<INSTALL_INTERFACE:include>)
@@ -166,7 +173,7 @@ endif()
166173

167174
# Handle MSVC exports
168175
if(MSVC AND BUILD_SHARED_LIBS)
169-
if (${CMAKE_MAJOR_VERSION}.${CMAKE_MINOR_VERSION} LESS 3.4)
176+
if (${CMAKE_MAJOR_VERSION}.${CMAKE_MINOR_VERSION} VERSION_LESS 3.4)
170177
include("${PROJECT_SOURCE_DIR}/cmake/export.cmake")
171178
else()
172179
# Creates verbose .def file (51KB vs 18KB)
@@ -314,7 +321,7 @@ install (FILES ${OPENBLAS_CONFIG_H} DESTINATION ${CMAKE_INSTALL_INCLUDEDIR})
314321
if(NOT NOFORTRAN)
315322
message(STATUS "Generating f77blas.h in ${CMAKE_INSTALL_INCLUDEDIR}")
316323

317-
set(F77BLAS_H ${CMAKE_BINARY_DIR}/f77blas.h)
324+
set(F77BLAS_H ${CMAKE_BINARY_DIR}/generated/f77blas.h)
318325
file(WRITE ${F77BLAS_H} "#ifndef OPENBLAS_F77BLAS_H\n")
319326
file(APPEND ${F77BLAS_H} "#define OPENBLAS_F77BLAS_H\n")
320327
file(APPEND ${F77BLAS_H} "#include \"openblas_config.h\"\n")
@@ -327,10 +334,11 @@ endif()
327334
if(NOT NO_CBLAS)
328335
message (STATUS "Generating cblas.h in ${CMAKE_INSTALL_INCLUDEDIR}")
329336

337+
set(CBLAS_H ${CMAKE_BINARY_DIR}/generated/cblas.h)
330338
file(READ ${CMAKE_CURRENT_SOURCE_DIR}/cblas.h CBLAS_H_CONTENTS)
331339
string(REPLACE "common" "openblas_config" CBLAS_H_CONTENTS_NEW "${CBLAS_H_CONTENTS}")
332-
file(WRITE ${CMAKE_BINARY_DIR}/cblas.tmp "${CBLAS_H_CONTENTS_NEW}")
333-
install (FILES ${CMAKE_BINARY_DIR}/cblas.tmp DESTINATION ${CMAKE_INSTALL_INCLUDEDIR} RENAME cblas.h)
340+
file(WRITE ${CBLAS_H} "${CBLAS_H_CONTENTS_NEW}")
341+
install (FILES ${CBLAS_H} DESTINATION ${CMAKE_INSTALL_INCLUDEDIR})
334342
endif()
335343

336344
if(NOT NO_LAPACKE)

appveyor.yml

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -53,7 +53,7 @@ before_build:
5353
- ps: if (-Not (Test-Path .\build)) { mkdir build }
5454
- cd build
5555
- if [%COMPILER%]==[cl] cmake -G "Visual Studio 15 2017 Win64" ..
56-
- if [%WITH_FORTRAN%]==[no] cmake -G "Ninja" -DCMAKE_CXX_COMPILER=clang-cl -DCMAKE_C_COMPILER=clang-cl ..
56+
- if [%WITH_FORTRAN%]==[no] cmake -G "Ninja" -DCMAKE_CXX_COMPILER=clang-cl -DCMAKE_C_COMPILER=clang-cl -DMSVC_STATIC_CRT=ON ..
5757
- if [%WITH_FORTRAN%]==[yes] cmake -G "Ninja" -DCMAKE_CXX_COMPILER=clang-cl -DCMAKE_C_COMPILER=clang-cl -DCMAKE_Fortran_COMPILER=flang -DBUILD_WITHOUT_LAPACK=no -DNOFORTRAN=0 ..
5858
- if [%DYNAMIC_ARCH%]==[ON] cmake -DDYNAMIC_ARCH=ON ..
5959

utest/CMakeLists.txt

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -61,7 +61,7 @@ foreach (OUTPUTCONFIG ${CMAKE_CONFIGURATION_TYPES})
6161
set_target_properties( ${OpenBLAS_utest_bin} PROPERTIES RUNTIME_OUTPUT_DIRECTORY_${OUTPUTCONFIG} ${CMAKE_CURRENT_BINARY_DIR})
6262
endforeach()
6363

64-
if (MSVC)
64+
if (MSVC AND BUILD_SHARED_LIBS)
6565
add_custom_command(TARGET ${OpenBLAS_utest_bin}
6666
POST_BUILD
6767
COMMAND ${CMAKE_COMMAND} -E copy ${PROJECT_BINARY_DIR}/lib/${CMAKE_CFG_INTDIR}/${OpenBLAS_LIBNAME}.dll ${CMAKE_CURRENT_BINARY_DIR}/.

0 commit comments

Comments
 (0)