mirror of
https://github.com/vcmi/vcmi.git
synced 2025-01-24 03:47:18 +02:00
Merge branch 'develop' of https://github.com/vcmi/vcmi into windows_mingw_cmake_presets
This commit is contained in:
commit
30b851da7c
2
.github/workflows/github.yml
vendored
2
.github/workflows/github.yml
vendored
@ -244,7 +244,7 @@ jobs:
|
|||||||
|
|
||||||
- name: CMake Preset with ccache
|
- name: CMake Preset with ccache
|
||||||
run: |
|
run: |
|
||||||
cmake -DCMAKE_CXX_COMPILER_LAUNCHER=ccache --preset ${{ matrix.preset }}
|
cmake -DENABLE_CCACHE:BOOL=ON --preset ${{ matrix.preset }}
|
||||||
|
|
||||||
- name: Build Preset
|
- name: Build Preset
|
||||||
run: |
|
run: |
|
||||||
|
@ -265,7 +265,8 @@ uint64_t DangerHitMapAnalyzer::enemyCanKillOurHeroesAlongThePath(const AIPath &
|
|||||||
{
|
{
|
||||||
int3 tile = path.targetTile();
|
int3 tile = path.targetTile();
|
||||||
int turn = path.turn();
|
int turn = path.turn();
|
||||||
const HitMapNode & info = hitMap[tile.x][tile.y][tile.z];
|
|
||||||
|
const auto& info = getTileThreat(tile);
|
||||||
|
|
||||||
return (info.fastestDanger.turn <= turn && !isSafeToVisit(path.targetHero, path.heroArmy, info.fastestDanger.danger))
|
return (info.fastestDanger.turn <= turn && !isSafeToVisit(path.targetHero, path.heroArmy, info.fastestDanger.danger))
|
||||||
|| (info.maximumDanger.turn <= turn && !isSafeToVisit(path.targetHero, path.heroArmy, info.maximumDanger.danger));
|
|| (info.maximumDanger.turn <= turn && !isSafeToVisit(path.targetHero, path.heroArmy, info.maximumDanger.danger));
|
||||||
@ -280,9 +281,7 @@ const HitMapNode & DangerHitMapAnalyzer::getObjectThreat(const CGObjectInstance
|
|||||||
|
|
||||||
const HitMapNode & DangerHitMapAnalyzer::getTileThreat(const int3 & tile) const
|
const HitMapNode & DangerHitMapAnalyzer::getTileThreat(const int3 & tile) const
|
||||||
{
|
{
|
||||||
const HitMapNode & info = hitMap[tile.x][tile.y][tile.z];
|
return hitMap[tile.x][tile.y][tile.z];
|
||||||
|
|
||||||
return info;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
const std::set<const CGObjectInstance *> empty = {};
|
const std::set<const CGObjectInstance *> empty = {};
|
||||||
|
@ -321,9 +321,7 @@ bool AINodeStorage::hasBetterChain(const PathNodeInfo & source, CDestinationNode
|
|||||||
|
|
||||||
bool AINodeStorage::isTileAccessible(const int3 & pos, const EPathfindingLayer layer) const
|
bool AINodeStorage::isTileAccessible(const int3 & pos, const EPathfindingLayer layer) const
|
||||||
{
|
{
|
||||||
const AIPathNode & node = nodes[layer][pos.z][pos.x][pos.y][0];
|
return nodes[layer][pos.z][pos.x][pos.y][0].action != EPathNodeAction::UNKNOWN;
|
||||||
|
|
||||||
return node.action != EPathNodeAction::UNKNOWN;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
std::vector<AIPath> AINodeStorage::getChainInfo(const int3 & pos, bool isOnLand) const
|
std::vector<AIPath> AINodeStorage::getChainInfo(const int3 & pos, bool isOnLand) const
|
||||||
|
@ -79,15 +79,19 @@ if(NOT APPLE_IOS AND NOT ANDROID)
|
|||||||
option(ENABLE_MONOLITHIC_INSTALL "Install everything in single directory on Linux and Mac" OFF)
|
option(ENABLE_MONOLITHIC_INSTALL "Install everything in single directory on Linux and Mac" OFF)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# On Linux, use -DCMAKE_CXX_COMPILER_LAUNCHER=ccache instead.
|
option(ENABLE_CCACHE "Speed up recompilation by caching previous compilations" OFF)
|
||||||
# The XCode and MSVC builds each require some more configuration, which is enabled by the following option:
|
if(ENABLE_CCACHE)
|
||||||
if(MSVC OR (CMAKE_GENERATOR STREQUAL "Xcode"))
|
find_program(CCACHE ccache REQUIRED)
|
||||||
option(ENABLE_CCACHE "Speed up recompilation by caching previous compilations" OFF)
|
endif()
|
||||||
|
|
||||||
|
# On Linux, use ccache via CMAKE_CXX_COMPILER_LAUNCHER.
|
||||||
|
# The XCode and MSVC builds each require some more configuration further down.
|
||||||
|
if(ENABLE_CCACHE AND LINUX)
|
||||||
|
set(CMAKE_C_COMPILER_LAUNCHER "ccache")
|
||||||
|
set(CMAKE_CXX_COMPILER_LAUNCHER "ccache")
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
if(ENABLE_CCACHE AND (CMAKE_GENERATOR STREQUAL "Xcode"))
|
if(ENABLE_CCACHE AND (CMAKE_GENERATOR STREQUAL "Xcode"))
|
||||||
find_program(CCACHE ccache REQUIRED)
|
|
||||||
if(CCACHE)
|
|
||||||
# https://stackoverflow.com/a/36515503/2278742
|
# https://stackoverflow.com/a/36515503/2278742
|
||||||
# Set up wrapper scripts
|
# Set up wrapper scripts
|
||||||
configure_file(xcode/launch-c.in xcode/launch-c)
|
configure_file(xcode/launch-c.in xcode/launch-c)
|
||||||
@ -100,7 +104,6 @@ if(ENABLE_CCACHE AND (CMAKE_GENERATOR STREQUAL "Xcode"))
|
|||||||
set(CMAKE_XCODE_ATTRIBUTE_CXX "${CMAKE_BINARY_DIR}/xcode/launch-cxx")
|
set(CMAKE_XCODE_ATTRIBUTE_CXX "${CMAKE_BINARY_DIR}/xcode/launch-cxx")
|
||||||
set(CMAKE_XCODE_ATTRIBUTE_LD "${CMAKE_BINARY_DIR}/xcode/launch-c")
|
set(CMAKE_XCODE_ATTRIBUTE_LD "${CMAKE_BINARY_DIR}/xcode/launch-c")
|
||||||
set(CMAKE_XCODE_ATTRIBUTE_LDPLUSPLUS "${CMAKE_BINARY_DIR}/xcode/launch-cxx")
|
set(CMAKE_XCODE_ATTRIBUTE_LDPLUSPLUS "${CMAKE_BINARY_DIR}/xcode/launch-cxx")
|
||||||
endif()
|
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
# Allow to pass package name from Travis CI
|
# Allow to pass package name from Travis CI
|
||||||
@ -266,8 +269,6 @@ if(MINGW OR MSVC)
|
|||||||
if(MSVC)
|
if(MSVC)
|
||||||
if(ENABLE_CCACHE)
|
if(ENABLE_CCACHE)
|
||||||
# https://github.com/ccache/ccache/discussions/1154#discussioncomment-3611387
|
# https://github.com/ccache/ccache/discussions/1154#discussioncomment-3611387
|
||||||
find_program(CCACHE ccache REQUIRED)
|
|
||||||
if (CCACHE)
|
|
||||||
file(COPY_FILE
|
file(COPY_FILE
|
||||||
${CCACHE} ${CMAKE_BINARY_DIR}/cl.exe
|
${CCACHE} ${CMAKE_BINARY_DIR}/cl.exe
|
||||||
ONLY_IF_DIFFERENT)
|
ONLY_IF_DIFFERENT)
|
||||||
@ -279,7 +280,6 @@ if(MINGW OR MSVC)
|
|||||||
"UseMultiToolTask=true"
|
"UseMultiToolTask=true"
|
||||||
)
|
)
|
||||||
endif()
|
endif()
|
||||||
endif()
|
|
||||||
|
|
||||||
add_definitions(-DBOOST_ALL_NO_LIB)
|
add_definitions(-DBOOST_ALL_NO_LIB)
|
||||||
add_definitions(-DBOOST_ALL_DYN_LINK)
|
add_definitions(-DBOOST_ALL_DYN_LINK)
|
||||||
|
@ -65,6 +65,15 @@
|
|||||||
"CMAKE_CXX_COMPILER": "/usr/bin/clang++"
|
"CMAKE_CXX_COMPILER": "/usr/bin/clang++"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "linux-clang-release-ccache",
|
||||||
|
"displayName": "Clang x86_64-pc-linux-gnu with ccache",
|
||||||
|
"description": "VCMI Linux Clang with ccache",
|
||||||
|
"inherits": "linux-release",
|
||||||
|
"cacheVariables": {
|
||||||
|
"ENABLE_CCACHE": "ON"
|
||||||
|
}
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "linux-gcc-release",
|
"name": "linux-gcc-release",
|
||||||
"displayName": "GCC x86_64-pc-linux-gnu",
|
"displayName": "GCC x86_64-pc-linux-gnu",
|
||||||
@ -76,6 +85,15 @@
|
|||||||
"CMAKE_CXX_COMPILER": "/usr/bin/g++"
|
"CMAKE_CXX_COMPILER": "/usr/bin/g++"
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "linux-gcc-release-ccache",
|
||||||
|
"displayName": "GCC x86_64-pc-linux-gnu with ccache",
|
||||||
|
"description": "VCMI Linux GCC with ccache",
|
||||||
|
"inherits": "linux-release",
|
||||||
|
"cacheVariables": {
|
||||||
|
"ENABLE_CCACHE": "ON"
|
||||||
|
}
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "linux-gcc-debug",
|
"name": "linux-gcc-debug",
|
||||||
"displayName": "GCC x86_64-pc-linux-gnu (debug)",
|
"displayName": "GCC x86_64-pc-linux-gnu (debug)",
|
||||||
@ -293,6 +311,11 @@
|
|||||||
"configurePreset": "linux-clang-release",
|
"configurePreset": "linux-clang-release",
|
||||||
"inherits": "default-release"
|
"inherits": "default-release"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "linux-clang-release-ccache",
|
||||||
|
"configurePreset": "linux-clang-release-ccache",
|
||||||
|
"inherits": "linux-clang-release"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "linux-clang-test",
|
"name": "linux-clang-test",
|
||||||
"configurePreset": "linux-clang-test",
|
"configurePreset": "linux-clang-test",
|
||||||
@ -308,6 +331,11 @@
|
|||||||
"configurePreset": "linux-gcc-release",
|
"configurePreset": "linux-gcc-release",
|
||||||
"inherits": "default-release"
|
"inherits": "default-release"
|
||||||
},
|
},
|
||||||
|
{
|
||||||
|
"name": "linux-gcc-release-ccache",
|
||||||
|
"configurePreset": "linux-gcc-release-ccache",
|
||||||
|
"inherits": "linux-gcc-release"
|
||||||
|
},
|
||||||
{
|
{
|
||||||
"name": "linux-gcc-debug",
|
"name": "linux-gcc-debug",
|
||||||
"configurePreset": "linux-gcc-debug",
|
"configurePreset": "linux-gcc-debug",
|
||||||
|
@ -54,6 +54,8 @@
|
|||||||
"vcmi.radialWheel.moveDown" : "下移",
|
"vcmi.radialWheel.moveDown" : "下移",
|
||||||
"vcmi.radialWheel.moveBottom" : "移到底端",
|
"vcmi.radialWheel.moveBottom" : "移到底端",
|
||||||
|
|
||||||
|
"vcmi.spellBook.search" : "搜索中...",
|
||||||
|
|
||||||
"vcmi.mainMenu.serverConnecting" : "连接中...",
|
"vcmi.mainMenu.serverConnecting" : "连接中...",
|
||||||
"vcmi.mainMenu.serverAddressEnter" : "使用地址:",
|
"vcmi.mainMenu.serverAddressEnter" : "使用地址:",
|
||||||
"vcmi.mainMenu.serverConnectionFailed" : "连接失败",
|
"vcmi.mainMenu.serverConnectionFailed" : "连接失败",
|
||||||
@ -69,6 +71,7 @@
|
|||||||
"vcmi.lobby.noPreview" : "无地上部分",
|
"vcmi.lobby.noPreview" : "无地上部分",
|
||||||
"vcmi.lobby.noUnderground" : "无地下部分",
|
"vcmi.lobby.noUnderground" : "无地下部分",
|
||||||
|
|
||||||
|
"vcmi.client.errors.missingCampaigns" : "{找不到数据文件}\n\n没有找到战役数据文件!你可能使用了不完整或损坏的英雄无敌3数据文件,请重新安装数据文件。",
|
||||||
"vcmi.server.errors.existingProcess" : "一个VCMI进程已经在运行,启动新进程前请结束它。",
|
"vcmi.server.errors.existingProcess" : "一个VCMI进程已经在运行,启动新进程前请结束它。",
|
||||||
"vcmi.server.errors.modsToEnable" : "{需要启用的mod列表}",
|
"vcmi.server.errors.modsToEnable" : "{需要启用的mod列表}",
|
||||||
"vcmi.server.errors.modsToDisable" : "{需要禁用的mod列表}",
|
"vcmi.server.errors.modsToDisable" : "{需要禁用的mod列表}",
|
||||||
@ -302,7 +305,6 @@
|
|||||||
"vcmi.optionsTab.simturns.months.1" : " %d 月",
|
"vcmi.optionsTab.simturns.months.1" : " %d 月",
|
||||||
"vcmi.optionsTab.simturns.months.2" : " %d 月",
|
"vcmi.optionsTab.simturns.months.2" : " %d 月",
|
||||||
|
|
||||||
|
|
||||||
// Custom victory conditions for H3 campaigns and HotA maps
|
// Custom victory conditions for H3 campaigns and HotA maps
|
||||||
"vcmi.map.victoryCondition.daysPassed.toOthers" : "敌人依然存活至今,你失败了!",
|
"vcmi.map.victoryCondition.daysPassed.toOthers" : "敌人依然存活至今,你失败了!",
|
||||||
"vcmi.map.victoryCondition.daysPassed.toSelf" : "祝贺你,你依然存活,取得了胜利!",
|
"vcmi.map.victoryCondition.daysPassed.toSelf" : "祝贺你,你依然存活,取得了胜利!",
|
||||||
|
@ -62,7 +62,7 @@ Building for Android is a 2-step process. First, native C++ code is compiled to
|
|||||||
This is a traditional CMake project, you can build it from command line or some IDE. You're not required to pass any custom options (except Conan toolchain file), defaults are already good. If you wish to use your own CMake presets, inherit them from our `build-with-conan` preset. Example:
|
This is a traditional CMake project, you can build it from command line or some IDE. You're not required to pass any custom options (except Conan toolchain file), defaults are already good. If you wish to use your own CMake presets, inherit them from our `build-with-conan` preset. Example:
|
||||||
|
|
||||||
```
|
```
|
||||||
cmake -S . -B ../build -G Ninja -D CMAKE_BUILD_TYPE=Debug -D CMAKE_CXX_COMPILER_LAUNCHER=ccache -D CMAKE_C_COMPILER_LAUNCHER=ccache --toolchain ...
|
cmake -S . -B ../build -G Ninja -D CMAKE_BUILD_TYPE=Debug -D ENABLE_CCACHE:BOOL=ON --toolchain ...
|
||||||
cmake --build ../build
|
cmake --build ../build
|
||||||
```
|
```
|
||||||
|
|
||||||
|
@ -76,7 +76,7 @@ cmake ../vcmi
|
|||||||
**Notice**: The ../vcmi/ is not a typo, it will place makefile scripts into the build dir as the build dir is your working dir when calling CMake.
|
**Notice**: The ../vcmi/ is not a typo, it will place makefile scripts into the build dir as the build dir is your working dir when calling CMake.
|
||||||
|
|
||||||
## To use ccache:
|
## To use ccache:
|
||||||
`cmake ../vcmi -D CMAKE_CXX_COMPILER_LAUNCHER=ccache -D CMAKE_C_COMPILER_LAUNCHER=ccache`
|
`cmake ../vcmi -D ENABLE_CCACHE:BOOL=ON`
|
||||||
|
|
||||||
## Trigger build
|
## Trigger build
|
||||||
|
|
||||||
|
@ -226,7 +226,7 @@ void CGPandoraBox::serializeJsonOptions(JsonSerializeFormat & handler)
|
|||||||
handler.serializeInt("experience", vinfo.reward.heroExperience, 0);
|
handler.serializeInt("experience", vinfo.reward.heroExperience, 0);
|
||||||
handler.serializeInt("mana", vinfo.reward.manaDiff, 0);
|
handler.serializeInt("mana", vinfo.reward.manaDiff, 0);
|
||||||
|
|
||||||
int val;
|
int val = 0;
|
||||||
handler.serializeInt("morale", val, 0);
|
handler.serializeInt("morale", val, 0);
|
||||||
if(val)
|
if(val)
|
||||||
vinfo.reward.bonuses.emplace_back(BonusDuration::ONE_BATTLE, BonusType::MORALE, BonusSource::OBJECT_INSTANCE, val, BonusSourceID(id));
|
vinfo.reward.bonuses.emplace_back(BonusDuration::ONE_BATTLE, BonusType::MORALE, BonusSource::OBJECT_INSTANCE, val, BonusSourceID(id));
|
||||||
|
Loading…
x
Reference in New Issue
Block a user