Allow cross build for windows using mingw32
authorPascal Bach <pascal.bach@siemens.com>
Tue, 10 Jun 2014 11:15:40 +0000 (13:15 +0200)
committerPascal Bach <pascal.bach@siemens.com>
Tue, 10 Jun 2014 11:44:02 +0000 (13:44 +0200)
- Build the compiler using CMake for:
  - Linux native gcc
  - Windows using mingw32

.travis.yml
compiler/cpp/CMakeLists.txt
contrib/mingw32-toolchain.cmake [new file with mode: 0644]

index 2ae6fcb..d40e81c 100644 (file)
@@ -72,5 +72,7 @@ script:
   - make -j$NUM_CPU && make dist
   - make cross -j$NUM_CPU
   - sh bootstrap.sh ; sh contrib/mingw-cross-compile.sh
+  - mkdir build_native && cd build_native && cmake ../compiler/cpp/ && make; cd ..
+  - mkdir build_mingw32 && cd build_mingw32 && cmake -DCMAKE_TOOLCHAIN_FILE=../contrib/mingw32-toolchain.cmake ../compiler/cpp/ && make; cd ..
 # TODO: add these steps
 #  - sh bootstrap.sh ; dpkg-buildpackage -tc
index 5e07178..152e5db 100644 (file)
@@ -37,7 +37,7 @@ string(REGEX REPLACE "[0-9]+\\.[0-9]+\\.([0-9]+)" "\\1" thrift_VERSION_PATCH ${t
 message(STATUS "Thrift version: ${thrift_VERSION} (${thrift_VERSION_MAJOR}.${thrift_VERSION_MINOR}.${thrift_VERSION_PATCH})")
 
 # Windows has a different header
-if(WIN32)
+if(MSVC)
     set(FLEX_FLAGS "--wincompat") # Don't use unistd.h on windows
     configure_file(${CMAKE_CURRENT_SOURCE_DIR}/src/windows/version.h.in ${CMAKE_CURRENT_BINARY_DIR}/version.h)
 else()
@@ -144,7 +144,6 @@ THRIFT_ADD_COMPILER(lua     "Enable compiler for Lua" ON)
 include_directories(${CMAKE_CURRENT_BINARY_DIR} src)
 
 add_executable(thrift ${thrift_SOURCES})
-set_target_properties(thrift PROPERTIES VERSION ${thrift_VERSION})
 
 target_link_libraries(thrift libparse)
 
diff --git a/contrib/mingw32-toolchain.cmake b/contrib/mingw32-toolchain.cmake
new file mode 100644 (file)
index 0000000..3dfb1a5
--- /dev/null
@@ -0,0 +1,19 @@
+# CMake mingw32 cross compile toolchain file\r
+\r
+# the name of the target operating system\r
+SET(CMAKE_SYSTEM_NAME Windows)\r
+\r
+# which compilers to use for C and C++\r
+SET(CMAKE_C_COMPILER i586-mingw32msvc-gcc)\r
+SET(CMAKE_CXX_COMPILER i586-mingw32msvc-g++)\r
+SET(CMAKE_RC_COMPILER i586-mingw32msvc-windres)\r
+\r
+# here is the target environment located\r
+SET(CMAKE_FIND_ROOT_PATH /usr/i586-mingw32msvc)\r
+\r
+# adjust the default behaviour of the FIND_XXX() commands:\r
+# search headers and libraries in the target environment, search \r
+# programs in the host environment\r
+set(CMAKE_FIND_ROOT_PATH_MODE_PROGRAM NEVER)\r
+set(CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY)\r
+set(CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY)\r