fix appveyor visual studio build
See #465 To compile the build tool `bin2c`, add a target with `add_executable()` on visual studio instead of using `HostCompile.cmake` because running `cl.exe` fails in the appveyor visual studio environment, see: https://developercommunity.visualstudio.com/content/problem/325122/c1356-unable-to-find-mspdbcoredll.html Also update the dependencies module to latest. appveyor build now tested to work. Signed-off-by: Rafael Kitover <rkitover@gmail.com>
This commit is contained in:
parent
a8b7b72dbd
commit
8ceef90fc4
|
@ -16,7 +16,7 @@
|
||||||
|
|
||||||
[![Join the chat at https://gitter.im/visualboyadvance-m/Lobby](https://badges.gitter.im/visualboyadvance-m/Lobby.svg)](https://gitter.im/visualboyadvance-m/Lobby)
|
[![Join the chat at https://gitter.im/visualboyadvance-m/Lobby](https://badges.gitter.im/visualboyadvance-m/Lobby.svg)](https://gitter.im/visualboyadvance-m/Lobby)
|
||||||
[![Build Status](https://travis-ci.org/visualboyadvance-m/visualboyadvance-m.svg?branch=master)](https://travis-ci.org/visualboyadvance-m/visualboyadvance-m)
|
[![Build Status](https://travis-ci.org/visualboyadvance-m/visualboyadvance-m.svg?branch=master)](https://travis-ci.org/visualboyadvance-m/visualboyadvance-m)
|
||||||
[![Coverity Scan Build Status](https://scan.coverity.com/projects/16096/badge.svg)](https://scan.coverity.com/projects/visualboyadvance-m-visualboyadvance-m)
|
[![Build status](https://ci.appveyor.com/api/projects/status/5ckx25vct1q1ovfc?svg=true)](https://ci.appveyor.com/project/ZachBacon65337/visualboyadvance-m-2ys5r)
|
||||||
|
|
||||||
# Visual Boy Advance - M
|
# Visual Boy Advance - M
|
||||||
|
|
||||||
|
|
12
appveyor.yml
12
appveyor.yml
|
@ -1,15 +1,10 @@
|
||||||
version: '{build}'
|
version: '{build}'
|
||||||
branches:
|
|
||||||
only:
|
|
||||||
- master
|
|
||||||
|
|
||||||
image:
|
image:
|
||||||
- Visual Studio 2017
|
- Visual Studio 2017
|
||||||
|
|
||||||
configuration:
|
configuration:
|
||||||
- Debug
|
- Release
|
||||||
|
|
||||||
#let's start with 64bit
|
|
||||||
|
|
||||||
platform:
|
platform:
|
||||||
- x64
|
- x64
|
||||||
|
@ -24,9 +19,8 @@ matrix:
|
||||||
before_build:
|
before_build:
|
||||||
- cmd: |-
|
- cmd: |-
|
||||||
mkdir build
|
mkdir build
|
||||||
git submodule update --init --recursive
|
|
||||||
cd build
|
cd build
|
||||||
cmake .. -G "Visual Studio 15 2017" -DVCPKG_TARGET_TRIPLET=x64-windows
|
cmake .. -DVCPKG_TARGET_TRIPLET=x64-windows
|
||||||
|
|
||||||
build_script:
|
build_script:
|
||||||
- cmake --build .
|
- msbuild /m ALL_BUILD.vcxproj -p:Configuration=Release
|
||||||
|
|
|
@ -18,12 +18,12 @@ function(host_compile src dst_cmd)
|
||||||
set(compile_command cc ${src} -o ${dst} ${link_flags})
|
set(compile_command cc ${src} -o ${dst} ${link_flags})
|
||||||
else()
|
else()
|
||||||
# special case for Visual Studio
|
# special case for Visual Studio
|
||||||
set(compile_command cl ${src} /link "/out:${dst}")
|
set(compile_command ${CMAKE_C_COMPILER} ${src} /link "/out:${dst}")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
execute_process(COMMAND ${compile_command} OUTPUT_VARIABLE compile_out ERROR_VARIABLE compile_out RESULT_VARIABLE compile_result)
|
execute_process(COMMAND ${compile_command} OUTPUT_VARIABLE compile_out ERROR_VARIABLE compile_err RESULT_VARIABLE compile_result)
|
||||||
|
|
||||||
if(NOT compile_result EQUAL 0)
|
if(NOT compile_result EQUAL 0)
|
||||||
message(FATAL_ERROR "Failed compiling ${src} for the host: ${compile_out}")
|
message(FATAL_ERROR "Failed compiling ${src} for the host: ${compile_err}")
|
||||||
endif()
|
endif()
|
||||||
endfunction()
|
endfunction()
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
Subproject commit 3e018956d57cf32278a3f3cdd67763b304732482
|
Subproject commit fe50718d0e642c2c9c32b63abec510ced9f1ae0a
|
|
@ -515,11 +515,19 @@ set(XRC_SOURCES
|
||||||
# wxrc does not support xrs files in -c output (> 10x compression)
|
# wxrc does not support xrs files in -c output (> 10x compression)
|
||||||
# we do it using the bin2c.c utility
|
# we do it using the bin2c.c utility
|
||||||
|
|
||||||
set(BIN2C ${CMAKE_BINARY_DIR}/bin2c)
|
set(BIN2C ${CMAKE_BINARY_DIR}/bin2c${CMAKE_EXECUTABLE_SUFFIX})
|
||||||
|
|
||||||
|
if(NOT MSVC)
|
||||||
include(HostCompile)
|
include(HostCompile)
|
||||||
|
|
||||||
host_compile(${CMAKE_CURRENT_SOURCE_DIR}/bin2c.c ${BIN2C})
|
host_compile(${CMAKE_CURRENT_SOURCE_DIR}/bin2c.c ${BIN2C})
|
||||||
|
set(BIN2C_DEP ${BIN2C})
|
||||||
|
else()
|
||||||
|
# on the appveyor visual studio environment, cl.exe cannot be run from
|
||||||
|
# cmake
|
||||||
|
add_executable(bin2c ${CMAKE_CURRENT_SOURCE_DIR}/bin2c.c)
|
||||||
|
set(BIN2C bin2c)
|
||||||
|
set(BIN2C_DEP bin2c)
|
||||||
|
endif()
|
||||||
|
|
||||||
if(WXRC)
|
if(WXRC)
|
||||||
separate_arguments(WXRC UNIX_COMMAND ${WXRC})
|
separate_arguments(WXRC UNIX_COMMAND ${WXRC})
|
||||||
|
@ -596,14 +604,14 @@ add_custom_command(
|
||||||
add_custom_command(
|
add_custom_command(
|
||||||
OUTPUT builtin-xrc.h
|
OUTPUT builtin-xrc.h
|
||||||
COMMAND ${BIN2C} wxvbam.xrs builtin-xrc.h builtin_xrs
|
COMMAND ${BIN2C} wxvbam.xrs builtin-xrc.h builtin_xrs
|
||||||
DEPENDS wxvbam.xrs
|
DEPENDS wxvbam.xrs ${BIN2C_DEP}
|
||||||
)
|
)
|
||||||
|
|
||||||
# use a built-in vba-over.ini if no config file present
|
# use a built-in vba-over.ini if no config file present
|
||||||
add_custom_command(
|
add_custom_command(
|
||||||
OUTPUT builtin-over.h
|
OUTPUT builtin-over.h
|
||||||
COMMAND ${BIN2C} ${CMAKE_CURRENT_SOURCE_DIR}/../vba-over.ini builtin-over.h builtin_over
|
COMMAND ${BIN2C} ${CMAKE_CURRENT_SOURCE_DIR}/../vba-over.ini builtin-over.h builtin_over
|
||||||
DEPENDS ../vba-over.ini
|
DEPENDS ../vba-over.ini ${BIN2C_DEP}
|
||||||
)
|
)
|
||||||
|
|
||||||
# I don't like duplicating/triplicating code, so I only declare
|
# I don't like duplicating/triplicating code, so I only declare
|
||||||
|
|
Loading…
Reference in New Issue