🐛 Fixed ogre 1.11 build with conan V2
This commit is contained in:
parent
48367f6c6b
commit
da749af80e
@ -4,14 +4,7 @@ sources:
|
|||||||
sha256: "31c84051ffe9a3710c553cfa27ebda7b176c9dfe3b4d2a113d4f02caf48ecd5b"
|
sha256: "31c84051ffe9a3710c553cfa27ebda7b176c9dfe3b4d2a113d4f02caf48ecd5b"
|
||||||
patches:
|
patches:
|
||||||
"1.11.6.1":
|
"1.11.6.1":
|
||||||
- patch_file: "patches/1.11.6.1/CMakeLists.txt.patch"
|
- patch_file: "patches/1.11.6.1/FixFreeImage.patch"
|
||||||
- patch_file: "patches/1.11.6.1/Samples-CMakeList.txt.patch"
|
- patch_file: "patches/1.11.6.1/FixSamples.patch"
|
||||||
- patch_file: "patches/1.11.6.1/FixOverlayCMakeLists.txt.patch"
|
- patch_file: "patches/1.11.6.1/FixOverlay.patch"
|
||||||
- patch_file: "patches/1.11.6.1/scriptlexer.patch"
|
- patch_file: "patches/1.11.6.1/scriptlexer.patch"
|
||||||
requirements:
|
|
||||||
- "zlib/[1.x]"
|
|
||||||
- "zziplib/[0.13.x]"
|
|
||||||
- "freetype/[2.x]"
|
|
||||||
- "freeimage/[3.x]"
|
|
||||||
- "cg-toolkit/3.1@anotherfoxguy/stable"
|
|
||||||
- "pugixml/[1.x]"
|
|
@ -1,7 +1,8 @@
|
|||||||
import shutil
|
from conan import ConanFile
|
||||||
from conans import ConanFile, CMake, tools
|
from conan.tools.files import get, collect_libs, rmdir, replace_in_file, apply_conandata_patches, export_conandata_patches
|
||||||
from conans.tools import os_info, SystemPackageTool
|
from conan.tools.cmake import CMakeToolchain, CMake, CMakeDeps, cmake_layout
|
||||||
|
from conan.tools.system.package_manager import Apt
|
||||||
|
import os
|
||||||
|
|
||||||
class OGREConan(ConanFile):
|
class OGREConan(ConanFile):
|
||||||
name = "ogre3d"
|
name = "ogre3d"
|
||||||
@ -9,88 +10,94 @@ class OGREConan(ConanFile):
|
|||||||
url = "https://github.com/AnotherFoxGuy/conan-OGRE"
|
url = "https://github.com/AnotherFoxGuy/conan-OGRE"
|
||||||
description = "scene-oriented, flexible 3D engine written in C++"
|
description = "scene-oriented, flexible 3D engine written in C++"
|
||||||
settings = "os", "compiler", "build_type", "arch"
|
settings = "os", "compiler", "build_type", "arch"
|
||||||
generators = "cmake_paths", "cmake_find_package"
|
|
||||||
exports_sources = "patches/**"
|
def export_sources(self):
|
||||||
|
export_conandata_patches(self)
|
||||||
|
|
||||||
|
def layout(self):
|
||||||
|
cmake_layout(self)
|
||||||
|
|
||||||
def requirements(self):
|
def requirements(self):
|
||||||
for req in self.conan_data["requirements"]:
|
self.requires("zlib/[1.x]")
|
||||||
self.requires(req)
|
self.requires("zziplib/[0.13.x]")
|
||||||
|
self.requires("freetype/[2.x]")
|
||||||
if os_info.is_windows:
|
self.requires("freeimage/[3.x]")
|
||||||
|
self.requires("cg-toolkit/3.1@anotherfoxguy/stable")
|
||||||
|
self.requires("pugixml/[1.x]")
|
||||||
|
self.requires("libpng/1.6.38")
|
||||||
|
if self.settings.os == "Windows":
|
||||||
self.requires("directx-sdk/9.0@anotherfoxguy/stable")
|
self.requires("directx-sdk/9.0@anotherfoxguy/stable")
|
||||||
|
|
||||||
def system_requirements(self):
|
def system_requirements(self):
|
||||||
if os_info.is_linux:
|
Apt(self).install([
|
||||||
if os_info.with_apt:
|
"libx11-dev",
|
||||||
installer = SystemPackageTool()
|
"libxaw7-dev",
|
||||||
installer.install("libgles2-mesa-dev")
|
"libxrandr-dev",
|
||||||
installer.install("libglu1-mesa-dev")
|
"libgles2-mesa-dev",
|
||||||
installer.install("libx11-dev")
|
"libvulkan-dev",
|
||||||
installer.install("libxaw7-dev")
|
"glslang-dev"
|
||||||
installer.install("libxrandr-dev")
|
], check=True)
|
||||||
installer.install("libxt-dev")
|
|
||||||
|
|
||||||
def source(self):
|
def source(self):
|
||||||
tools.get(**self.conan_data["sources"][self.version], strip_root=True)
|
get(self, **self.conan_data["sources"][self.version], strip_root=True)
|
||||||
tools.replace_in_file(
|
|
||||||
"CMake/Dependencies.cmake",
|
def generate(self):
|
||||||
|
tc = CMakeToolchain(self)
|
||||||
|
tc.variables["OGRE_BUILD_COMPONENT_BITES"] = "ON"
|
||||||
|
tc.variables["OGRE_BUILD_COMPONENT_CSHARP"] = "OFF"
|
||||||
|
tc.variables["OGRE_BUILD_COMPONENT_JAVA"] = "OFF"
|
||||||
|
tc.variables["OGRE_BUILD_COMPONENT_OVERLAY_IMGUI"] = "ON"
|
||||||
|
tc.variables["OGRE_BUILD_COMPONENT_PYTHON"] = "OFF"
|
||||||
|
tc.variables["OGRE_BUILD_DEPENDENCIES"] = "OFF"
|
||||||
|
tc.variables["OGRE_BUILD_PLUGIN_STBI"] = "ON"
|
||||||
|
tc.variables["OGRE_BUILD_PLUGIN_EXRCODEC"] = "OFF"
|
||||||
|
tc.variables["OGRE_BUILD_RENDERSYSTEM_D3D11"] = "ON"
|
||||||
|
tc.variables["OGRE_BUILD_RENDERSYSTEM_D3D9"] = "ON"
|
||||||
|
tc.variables["OGRE_BUILD_RENDERSYSTEM_GL3PLUS"] = "OFF"
|
||||||
|
tc.variables["OGRE_BUILD_SAMPLES"] = "OFF"
|
||||||
|
tc.variables["OGRE_INSTALL_SAMPLES"] = "OFF"
|
||||||
|
tc.variables["OGRE_RESOURCEMANAGER_STRICT"] = 0
|
||||||
|
|
||||||
|
if self.settings.os == "Windows":
|
||||||
|
tc.variables["CMAKE_CXX_FLAGS"] = "-D_OGRE_FILESYSTEM_ARCHIVE_UNICODE"
|
||||||
|
tc.generate()
|
||||||
|
deps = CMakeDeps(self)
|
||||||
|
deps.generate()
|
||||||
|
|
||||||
|
def _patch_sources(self):
|
||||||
|
apply_conandata_patches(self)
|
||||||
|
replace_in_file(self,
|
||||||
|
os.path.join(self.source_folder, "CMake/Dependencies.cmake"),
|
||||||
"find_package(DirectX)",
|
"find_package(DirectX)",
|
||||||
"find_package(DirectX9)",
|
"find_package(DirectX9)",
|
||||||
)
|
)
|
||||||
tools.replace_in_file(
|
replace_in_file(self,
|
||||||
"CMake/Dependencies.cmake",
|
os.path.join(self.source_folder, "CMake/Packages/FindDirectX11.cmake"),
|
||||||
"find_package(FreeImage)",
|
|
||||||
"find_package(ConanFreeImage)",
|
|
||||||
)
|
|
||||||
tools.replace_in_file(
|
|
||||||
"CMake/Dependencies.cmake",
|
|
||||||
"find_package(ZZip)",
|
|
||||||
"find_package(ConanZZip)",
|
|
||||||
)
|
|
||||||
tools.replace_in_file(
|
|
||||||
"CMake/Packages/FindDirectX11.cmake",
|
|
||||||
'find_path(DirectX11_INCLUDE_DIR NAMES d3d11.h HINTS "',
|
'find_path(DirectX11_INCLUDE_DIR NAMES d3d11.h HINTS "',
|
||||||
'find_path(DirectX11_INCLUDE_DIR NO_CMAKE_PATH NO_CMAKE_ENVIRONMENT_PATH NAMES d3d11.h HINTS "',
|
'find_path(DirectX11_INCLUDE_DIR NO_CMAKE_PATH NO_CMAKE_ENVIRONMENT_PATH NAMES d3d11.h HINTS "',
|
||||||
)
|
)
|
||||||
shutil.copyfile(
|
|
||||||
"patches/FindFreeImage.cmake", "CMake/Packages/FindConanFreeImage.cmake"
|
|
||||||
)
|
|
||||||
shutil.copyfile("patches/FindZZip.cmake", "CMake/Packages/FindConanZZip.cmake")
|
|
||||||
for patch in self.conan_data["patches"][self.version]:
|
|
||||||
tools.patch(**patch)
|
|
||||||
|
|
||||||
def build(self):
|
def build(self):
|
||||||
|
self._patch_sources()
|
||||||
cmake = CMake(self)
|
cmake = CMake(self)
|
||||||
cmake.definitions["OGRE_BUILD_COMPONENT_BITES"] = "ON"
|
|
||||||
cmake.definitions["OGRE_BUILD_COMPONENT_CSHARP"] = "OFF"
|
|
||||||
cmake.definitions["OGRE_BUILD_COMPONENT_JAVA"] = "OFF"
|
|
||||||
cmake.definitions["OGRE_BUILD_COMPONENT_OVERLAY_IMGUI"] = "ON"
|
|
||||||
cmake.definitions["OGRE_BUILD_COMPONENT_PYTHON"] = "OFF"
|
|
||||||
cmake.definitions["OGRE_BUILD_DEPENDENCIES"] = "OFF"
|
|
||||||
cmake.definitions["OGRE_BUILD_PLUGIN_STBI"] = "ON"
|
|
||||||
cmake.definitions["OGRE_BUILD_PLUGIN_EXRCODEC"] = "OFF"
|
|
||||||
cmake.definitions["OGRE_BUILD_RENDERSYSTEM_D3D11"] = "ON"
|
|
||||||
cmake.definitions["OGRE_BUILD_RENDERSYSTEM_D3D9"] = "ON"
|
|
||||||
cmake.definitions["OGRE_BUILD_RENDERSYSTEM_GL3PLUS"] = "OFF"
|
|
||||||
cmake.definitions["OGRE_BUILD_SAMPLES"] = "OFF"
|
|
||||||
cmake.definitions["OGRE_INSTALL_SAMPLES"] = "OFF"
|
|
||||||
cmake.definitions["OGRE_RESOURCEMANAGER_STRICT"] = 0
|
|
||||||
if os_info.is_windows:
|
|
||||||
cmake.definitions["CMAKE_CXX_FLAGS"] = "-D_OGRE_FILESYSTEM_ARCHIVE_UNICODE"
|
|
||||||
cmake.configure()
|
cmake.configure()
|
||||||
cmake.build()
|
cmake.build()
|
||||||
|
|
||||||
def package(self):
|
def package(self):
|
||||||
cmake = CMake(self)
|
cmake = CMake(self)
|
||||||
cmake.install()
|
cmake.install()
|
||||||
|
rmdir(self, os.path.join(self.package_folder, "CMake"))
|
||||||
|
rmdir(self, os.path.join(self.package_folder, "Docs"))
|
||||||
|
|
||||||
def package_info(self):
|
def package_info(self):
|
||||||
self.cpp_info.name = "OGRE"
|
self.cpp_info.set_property("cmake_module_file_name", "OGRE")
|
||||||
|
self.cpp_info.set_property("cmake_module_target_name", "OGRE::OGRE")
|
||||||
|
self.cpp_info.set_property("cmake_file_name", "OGRE")
|
||||||
|
self.cpp_info.set_property("cmake_target_name", "OGRE::OGRE")
|
||||||
self.cpp_info.includedirs = [
|
self.cpp_info.includedirs = [
|
||||||
"include",
|
"include",
|
||||||
"include/OGRE",
|
"include/OGRE",
|
||||||
"include/OGRE/Bites",
|
"include/OGRE/Bites",
|
||||||
"include/OGRE/HLMS",
|
|
||||||
"include/OGRE/MeshLodGenerator",
|
"include/OGRE/MeshLodGenerator",
|
||||||
"include/OGRE/Overlay",
|
"include/OGRE/Overlay",
|
||||||
"include/OGRE/Paging",
|
"include/OGRE/Paging",
|
||||||
@ -102,4 +109,4 @@ class OGREConan(ConanFile):
|
|||||||
"include/OGRE/Threading",
|
"include/OGRE/Threading",
|
||||||
"include/OGRE/Volume",
|
"include/OGRE/Volume",
|
||||||
]
|
]
|
||||||
self.cpp_info.libs = tools.collect_libs(self)
|
self.cpp_info.libs = collect_libs(self)
|
||||||
|
@ -1,20 +0,0 @@
|
|||||||
--- CMakeLists.txt
|
|
||||||
+++ CMakeLists.txt
|
|
||||||
@@ -16,6 +16,8 @@
|
|
||||||
|
|
||||||
cmake_minimum_required(VERSION 3.3.0)
|
|
||||||
|
|
||||||
+include(${CMAKE_BINARY_DIR}/conan_paths.cmake)
|
|
||||||
+
|
|
||||||
set(CMAKE_CXX_STANDARD 11)
|
|
||||||
set(CMAKE_CXX_STANDARD_REQUIRED ON)
|
|
||||||
set(CMAKE_CXX_EXTENSIONS OFF)
|
|
||||||
@@ -63,6 +65,7 @@
|
|
||||||
|
|
||||||
# Include necessary submodules
|
|
||||||
set(CMAKE_MODULE_PATH
|
|
||||||
+ "${CMAKE_BINARY_DIR}"
|
|
||||||
"${PROJECT_SOURCE_DIR}/CMake"
|
|
||||||
"${PROJECT_SOURCE_DIR}/CMake/Utils"
|
|
||||||
"${PROJECT_SOURCE_DIR}/CMake/Packages"
|
|
||||||
|
|
11
ogre/1.11/patches/1.11.6.1/FixFreeImage.patch
Normal file
11
ogre/1.11/patches/1.11.6.1/FixFreeImage.patch
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
--- a/PlugIns/FreeImageCodec/CMakeLists.txt
|
||||||
|
+++ b/PlugIns/FreeImageCodec/CMakeLists.txt
|
||||||
|
@@ -13,7 +13,7 @@ set(SOURCES "${CMAKE_CURRENT_SOURCE_DIR}/src/OgreFreeImageCodec.cpp")
|
||||||
|
|
||||||
|
add_definitions(-DFREEIMAGE_LIB)
|
||||||
|
add_library(Codec_FreeImage ${OGRE_LIB_TYPE} ${HEADER_FILES} ${SOURCES})
|
||||||
|
-target_link_libraries(Codec_FreeImage PUBLIC OgreMain ${FreeImage_LIBRARIES})
|
||||||
|
+target_link_libraries(Codec_FreeImage PUBLIC OgreMain freeimage::FreeImage)
|
||||||
|
target_include_directories(Codec_FreeImage PUBLIC
|
||||||
|
"$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include>"
|
||||||
|
$<INSTALL_INTERFACE:include/OGRE/Plugins/FreeImageCodec>
|
@ -1,11 +1,13 @@
|
|||||||
--- Components/Overlay/CMakeLists.txt
|
diff --git a/Components/Overlay/CMakeLists.txt b/Components/Overlay/CMakeLists.txt
|
||||||
+++ Components/Overlay/CMakeLists.txt
|
index 1ed646080..3f0b75c33 100644
|
||||||
@@ -21,7 +21,7 @@
|
--- a/Components/Overlay/CMakeLists.txt
|
||||||
|
+++ b/Components/Overlay/CMakeLists.txt
|
||||||
|
@@ -21,7 +21,7 @@ file(GLOB SOURCE_FILES "${CMAKE_CURRENT_SOURCE_DIR}/src/*.cpp")
|
||||||
# setup target
|
# setup target
|
||||||
add_library(OgreOverlay ${OGRE_COMP_LIB_TYPE} ${HEADER_FILES} ${SOURCE_FILES} ${PLATFORM_HEADER_FILES} ${PLATFORM_SOURCE_FILES})
|
add_library(OgreOverlay ${OGRE_COMP_LIB_TYPE} ${HEADER_FILES} ${SOURCE_FILES} ${PLATFORM_HEADER_FILES} ${PLATFORM_SOURCE_FILES})
|
||||||
set_target_properties(OgreOverlay PROPERTIES VERSION ${OGRE_SOVERSION} SOVERSION ${OGRE_SOVERSION})
|
set_target_properties(OgreOverlay PROPERTIES VERSION ${OGRE_SOVERSION} SOVERSION ${OGRE_SOVERSION})
|
||||||
-target_link_libraries(OgreOverlay PUBLIC OgreMain PRIVATE "${FREETYPE_LIBRARIES}" ZLIB::ZLIB)
|
-target_link_libraries(OgreOverlay PUBLIC OgreMain PRIVATE "${FREETYPE_LIBRARIES}" ZLIB::ZLIB)
|
||||||
+target_link_libraries(OgreOverlay PUBLIC OgreMain PRIVATE Freetype::Freetype ZLIB::ZLIB)
|
+target_link_libraries(OgreOverlay PUBLIC OgreMain PRIVATE freetype ZLIB::ZLIB)
|
||||||
target_include_directories(OgreOverlay PUBLIC
|
target_include_directories(OgreOverlay PUBLIC
|
||||||
"$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include>"
|
"$<BUILD_INTERFACE:${CMAKE_CURRENT_SOURCE_DIR}/include>"
|
||||||
$<INSTALL_INTERFACE:include/OGRE/Overlay>
|
$<INSTALL_INTERFACE:include/OGRE/Overlay>
|
Loading…
x
Reference in New Issue
Block a user