mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-25 15:56:37 +00:00 
			
		
		
		
	Merge branch 'master' of https://github.com/zinnschlag/openmw
This commit is contained in:
		
						commit
						058f0b665c
					
				
					 12 changed files with 200 additions and 20 deletions
				
			
		|  | @ -31,6 +31,8 @@ option(OGRE_STATIC "Link static build of Ogre and Ogre Plugins into the binaries | ||||||
| option(BUILD_ESMTOOL "build ESM inspector" ON) | option(BUILD_ESMTOOL "build ESM inspector" ON) | ||||||
| option(BUILD_LAUNCHER "build Launcher" ON) | option(BUILD_LAUNCHER "build Launcher" ON) | ||||||
| option(BUILD_MWINIIMPORTER "build MWiniImporter" ON) | option(BUILD_MWINIIMPORTER "build MWiniImporter" ON) | ||||||
|  | option(BUILD_WITH_CODE_COVERAGE "Enable code coverage with gconv" OFF) | ||||||
|  | option(BUILD_UNITTESTS "Enable Unittests with Google C++ Unittest ang GMock frameworks" OFF) | ||||||
| 
 | 
 | ||||||
| # Sound source selection | # Sound source selection | ||||||
| option(USE_FFMPEG "use ffmpeg for sound" OFF) | option(USE_FFMPEG "use ffmpeg for sound" OFF) | ||||||
|  | @ -459,6 +461,11 @@ if (BUILD_MWINIIMPORTER) | ||||||
|    add_subdirectory( apps/mwiniimporter ) |    add_subdirectory( apps/mwiniimporter ) | ||||||
| endif() | endif() | ||||||
| 
 | 
 | ||||||
|  | # UnitTests | ||||||
|  | if (BUILD_UNITTESTS) | ||||||
|  |   add_subdirectory( apps/openmw_test_suite ) | ||||||
|  | endif() | ||||||
|  | 
 | ||||||
| if (WIN32) | if (WIN32) | ||||||
|   if (MSVC) |   if (MSVC) | ||||||
|     if (USE_DEBUG_CONSOLE) |     if (USE_DEBUG_CONSOLE) | ||||||
|  | @ -622,3 +629,34 @@ if (APPLE) | ||||||
|         " COMPONENT Runtime) |         " COMPONENT Runtime) | ||||||
|         include(CPack) |         include(CPack) | ||||||
| endif (APPLE) | endif (APPLE) | ||||||
|  | 
 | ||||||
|  | ## Linux building | ||||||
|  | # paths | ||||||
|  | set(BINDIR "${CMAKE_INSTALL_PREFIX}/usr/bin" CACHE PATH "Where to install binaries") | ||||||
|  | set(DATAROOTDIR "${CMAKE_INSTALL_PREFIX}/share" CACHE PATH "Sets the root of data directories to a non-default location") | ||||||
|  | set(DATADIR "${DATAROOTDIR}/openmw" CACHE PATH "Sets the openmw data directories to a non-default location") | ||||||
|  | set(DOCDIR "${DATAROOTDIR}/doc/openmw" CACHE PATH "Sets the doc directory to a non-default location.") | ||||||
|  | set(MANDIR "${DATAROOTDIR}/man" CACHE PATH "Where to install manpages") | ||||||
|  | set(SYSCONFDIR "${CMAKE_INSTALL_PREFIX}/etc/openmw" CACHE PATH "Set config dir") | ||||||
|  | set(ICONDIR "${DATAROOTDIR}/pixmaps" CACHE PATH "Set icon dir") | ||||||
|  | 
 | ||||||
|  | # Install binaries | ||||||
|  | INSTALL(PROGRAMS "${OpenMW_BINARY_DIR}/openmw" DESTINATION "${BINDIR}" ) | ||||||
|  | INSTALL(PROGRAMS "${OpenMW_BINARY_DIR}/omwlauncher" DESTINATION "${BINDIR}" ) | ||||||
|  | INSTALL(PROGRAMS "${OpenMW_BINARY_DIR}/esmtool" DESTINATION "${BINDIR}" ) | ||||||
|  | INSTALL(PROGRAMS "${OpenMW_BINARY_DIR}/mwiniimport" DESTINATION "${BINDIR}" ) | ||||||
|  | 
 | ||||||
|  | # Install icon and .desktop | ||||||
|  | INSTALL(FILES "${OpenMW_SOURCE_DIR}/apps/launcher/resources/images/openmw.png" DESTINATION "${ICONDIR}") | ||||||
|  | INSTALL(FILES "${OpenMW_BINARY_DIR}/openmw.desktop" DESTINATION "${DATAROOTDIR}/applications") | ||||||
|  | 
 | ||||||
|  | # Install global configuration files | ||||||
|  | INSTALL(FILES "${OpenMW_BINARY_DIR}/openmw.cfg.install" DESTINATION "${SYSCONFDIR}" RENAME "openmw.cfg" ) | ||||||
|  | #INSTALL(FILES "${OpenMW_BINARY_DIR}/plugins.cfg" DESTINATION "${SYSCONFDIR}" ) | ||||||
|  | INSTALL(FILES "${OpenMW_BINARY_DIR}/settings-default.cfg" DESTINATION "${SYSCONFDIR}" ) | ||||||
|  | INSTALL(FILES "${OpenMW_BINARY_DIR}/transparency-overrides.cfg" DESTINATION "${SYSCONFDIR}" ) | ||||||
|  | INSTALL(FILES "${OpenMW_BINARY_DIR}/launcher.cfg" DESTINATION "${SYSCONFDIR}" ) | ||||||
|  | 
 | ||||||
|  | # Install resources | ||||||
|  | INSTALL(DIRECTORY "${OpenMW_BINARY_DIR}/resources" DESTINATION "${DATADIR}" ) | ||||||
|  | INSTALL(FILES "${OpenMW_BINARY_DIR}/launcher.qss" DESTINATION "${DATADIR}/resources" ) | ||||||
|  |  | ||||||
|  | @ -17,3 +17,8 @@ target_link_libraries(esmtool | ||||||
| #    find_library(CARBON_FRAMEWORK Carbon) | #    find_library(CARBON_FRAMEWORK Carbon) | ||||||
| #    target_link_libraries(openmw ${CARBON_FRAMEWORK}) | #    target_link_libraries(openmw ${CARBON_FRAMEWORK}) | ||||||
| #endif (APPLE) | #endif (APPLE) | ||||||
|  | 
 | ||||||
|  | if (BUILD_WITH_CODE_COVERAGE) | ||||||
|  |   add_definitions (--coverage) | ||||||
|  |   target_link_libraries(esmtool gcov) | ||||||
|  | endif() | ||||||
|  |  | ||||||
|  | @ -100,3 +100,8 @@ else() | ||||||
|     configure_file(${CMAKE_SOURCE_DIR}/files/launcher.cfg |     configure_file(${CMAKE_SOURCE_DIR}/files/launcher.cfg | ||||||
|         "${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/launcher.cfg") |         "${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/launcher.cfg") | ||||||
| endif() | endif() | ||||||
|  | 
 | ||||||
|  | if (BUILD_WITH_CODE_COVERAGE) | ||||||
|  |   add_definitions (--coverage) | ||||||
|  |   target_link_libraries(omwlauncher gcov) | ||||||
|  | endif() | ||||||
|  |  | ||||||
|  | @ -18,3 +18,7 @@ target_link_libraries(mwiniimport | ||||||
|     components |     components | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
|  | if (BUILD_WITH_CODE_COVERAGE) | ||||||
|  |   add_definitions (--coverage) | ||||||
|  |   target_link_libraries(mwiniimport gcov) | ||||||
|  | endif() | ||||||
|  |  | ||||||
|  | @ -123,3 +123,8 @@ endif(APPLE) | ||||||
| if(DPKG_PROGRAM) | if(DPKG_PROGRAM) | ||||||
|     INSTALL(TARGETS openmw RUNTIME DESTINATION games COMPONENT openmw) |     INSTALL(TARGETS openmw RUNTIME DESTINATION games COMPONENT openmw) | ||||||
| endif(DPKG_PROGRAM) | endif(DPKG_PROGRAM) | ||||||
|  | 
 | ||||||
|  | if (BUILD_WITH_CODE_COVERAGE) | ||||||
|  |   add_definitions (--coverage) | ||||||
|  |   target_link_libraries(openmw gcov) | ||||||
|  | endif() | ||||||
|  |  | ||||||
							
								
								
									
										28
									
								
								apps/openmw_test_suite/CMakeLists.txt
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										28
									
								
								apps/openmw_test_suite/CMakeLists.txt
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,28 @@ | ||||||
|  | # TODO: This should not be needed, check how it was done in FindGTEST | ||||||
|  | set(GMOCK_ROOT "/usr/include") | ||||||
|  | set(GMOCK_BUILD "/usr/lib") | ||||||
|  | 
 | ||||||
|  | find_package(GTest REQUIRED) | ||||||
|  | find_package(GMock REQUIRED) | ||||||
|  | 
 | ||||||
|  | if (GTEST_FOUND AND GMOCK_FOUND) | ||||||
|  | 
 | ||||||
|  |     include_directories(${GTEST_INCLUDE_DIRS}) | ||||||
|  |     include_directories(${GMOCK_INCLUDE_DIRS}) | ||||||
|  | 
 | ||||||
|  |     file(GLOB UNITTEST_SRC_FILES | ||||||
|  |         components/misc/*.cpp | ||||||
|  |     ) | ||||||
|  | 
 | ||||||
|  |     source_group(apps\\openmw_test_suite FILES openmw_test_suite.cpp ${UNITTEST_SRC_FILES}) | ||||||
|  | 
 | ||||||
|  |     add_executable(openmw_test_suite openmw_test_suite.cpp ${UNITTEST_SRC_FILES}) | ||||||
|  | 
 | ||||||
|  |     target_link_libraries(openmw_test_suite ${GMOCK_BOTH_LIBRARIES} ${GTEST_BOTH_LIBRARIES}) | ||||||
|  |     # Fix for not visible pthreads functions for linker with glibc 2.15 | ||||||
|  |     if (UNIX AND NOT APPLE) | ||||||
|  |         target_link_libraries(openmw_test_suite ${CMAKE_THREAD_LIBS_INIT}) | ||||||
|  |     endif() | ||||||
|  | endif() | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | @ -0,0 +1,7 @@ | ||||||
|  | #include <gtest/gtest.h> | ||||||
|  | 
 | ||||||
|  | TEST(simple_test, dummy) | ||||||
|  | { | ||||||
|  |   EXPECT_EQ(true, true); | ||||||
|  | } | ||||||
|  | 
 | ||||||
							
								
								
									
										12
									
								
								apps/openmw_test_suite/openmw_test_suite.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								apps/openmw_test_suite/openmw_test_suite.cpp
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,12 @@ | ||||||
|  | #include <gmock/gmock.h> | ||||||
|  | #include <gtest/gtest.h> | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | int main(int argc, char** argv) { | ||||||
|  |   // The following line causes Google Mock to throw an exception on failure,
 | ||||||
|  |   // which will be interpreted by your testing framework as a test failure.
 | ||||||
|  |   ::testing::GTEST_FLAG(throw_on_failure) = true; | ||||||
|  |   ::testing::InitGoogleMock(&argc, argv); | ||||||
|  | 
 | ||||||
|  |   return RUN_ALL_TESTS(); | ||||||
|  | } | ||||||
							
								
								
									
										91
									
								
								cmake/FindGMock.cmake
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										91
									
								
								cmake/FindGMock.cmake
									
									
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,91 @@ | ||||||
|  | # Locate the Google C++ Mocking Framework. | ||||||
|  | # | ||||||
|  | # Defines the following variables: | ||||||
|  | # | ||||||
|  | #   GMOCK_FOUND - Found the Google Mocking framework | ||||||
|  | #   GMOCK_INCLUDE_DIRS - Include directories | ||||||
|  | # | ||||||
|  | # Also defines the library variables below as normal | ||||||
|  | # variables.  These contain debug/optimized keywords when | ||||||
|  | # a debugging library is found. | ||||||
|  | # | ||||||
|  | #   GMOCK_BOTH_LIBRARIES - Both libgmock & libgmock-main | ||||||
|  | #   GMOCK_LIBRARIES - libgmock | ||||||
|  | #   GMOCK_MAIN_LIBRARIES - libgmock-main | ||||||
|  | # | ||||||
|  | # Accepts the following variables as input: | ||||||
|  | # | ||||||
|  | #   GMOCK_ROOT - (as CMake or env. variable) | ||||||
|  | #                The root directory of the gmock install prefix | ||||||
|  | # | ||||||
|  | #----------------------- | ||||||
|  | # Example Usage: | ||||||
|  | # | ||||||
|  | #    enable_testing(true) | ||||||
|  | #    find_package(GMock REQUIRED) | ||||||
|  | #    include_directories(${GMOCK_INCLUDE_DIRS}) | ||||||
|  | # | ||||||
|  | #    add_executable(foo foo.cc) | ||||||
|  | #    target_link_libraries(foo ${GMOCK_BOTH_LIBRARIES}) | ||||||
|  | # | ||||||
|  | #    add_test(AllTestsInFoo foo) | ||||||
|  | # | ||||||
|  | 
 | ||||||
|  | #set (GMOCK_FOUND FALSE) | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | #set (GMOCK_ROOT $ENV{GMOCK_ROOT} CACHE PATH "Path to the gmock root directory.") | ||||||
|  | if (NOT EXISTS ${GMOCK_ROOT}) | ||||||
|  |     message (FATAL_ERROR "GMOCK_ROOT does not exist.") | ||||||
|  | endif () | ||||||
|  | 
 | ||||||
|  | #set (GMOCK_BUILD ${GMOCK_ROOT}/build CACHE PATH "Path to the gmock build directory.") | ||||||
|  | if (NOT EXISTS ${GMOCK_BUILD}) | ||||||
|  |     message (FATAL_ERROR "GMOCK_BUILD does not exist.") | ||||||
|  | endif () | ||||||
|  | 
 | ||||||
|  | # Find the include directory | ||||||
|  | find_path(GMOCK_INCLUDE_DIRS gmock/gmock.h | ||||||
|  |     HINTS | ||||||
|  |         $ENV{GMOCK_ROOT}/include | ||||||
|  |         ${GMOCK_ROOT}/include | ||||||
|  | ) | ||||||
|  | mark_as_advanced(GMOCK_INCLUDE_DIRS) | ||||||
|  | 
 | ||||||
|  | function(_gmock_find_library _name) | ||||||
|  |     find_library(${_name} | ||||||
|  |         NAMES ${ARGN} | ||||||
|  |         HINTS | ||||||
|  |             $ENV{GMOCK_BUILD} | ||||||
|  |             ${GMOCK_BUILD} | ||||||
|  |     ) | ||||||
|  |     mark_as_advanced(${_name}) | ||||||
|  | endfunction() | ||||||
|  | 
 | ||||||
|  | # Find the gmock libraries | ||||||
|  | if (MSVC) | ||||||
|  |     _gmock_find_library (GMOCK_LIBRARIES_DEBUG   gmock ${GMOCK_BUILD}/Debug) | ||||||
|  |     _gmock_find_library (GMOCK_LIBRARIES_RELEASE gmock ${GMOCK_BUILD}/Release) | ||||||
|  |     _gmock_find_library (GMOCK_MAIN_LIBRARIES_DEBUG   gmock_main ${GMOCK_BUILD}/Debug) | ||||||
|  |     _gmock_find_library (GMOCK_MAIN_LIBRARIES_RELEASE gmock_main ${GMOCK_BUILD}/Release) | ||||||
|  |     set (GMOCK_LIBRARIES | ||||||
|  |         debug ${GMOCK_LIBRARIES_DEBUG} | ||||||
|  |         optimized ${GMOCK_LIBRARIES_RELEASE} | ||||||
|  |     ) | ||||||
|  |     set (GMOCK_MAIN_LIBRARIES | ||||||
|  |         debug ${GMOCK_MAIN_LIBRARIES_DEBUG} | ||||||
|  |         optimized ${GMOCK_MAIN_LIBRARIES_RELEASE} | ||||||
|  |     ) | ||||||
|  | else () | ||||||
|  |     _gmock_find_library (GMOCK_LIBRARIES      gmock      ${GMOCK_BUILD}) | ||||||
|  |     _gmock_find_library (GMOCK_MAIN_LIBRARIES gmock_main ${GMOCK_BUILD} ${GMOCK_BUILD}/Debug) | ||||||
|  | endif () | ||||||
|  | 
 | ||||||
|  | FIND_PACKAGE_HANDLE_STANDARD_ARGS(GMock DEFAULT_MSG GMOCK_LIBRARIES GMOCK_INCLUDE_DIRS GMOCK_MAIN_LIBRARIES) | ||||||
|  | 
 | ||||||
|  | if(GMOCK_FOUND) | ||||||
|  |     set(GMOCK_INCLUDE_DIRS ${GMOCK_INCLUDE_DIR}) | ||||||
|  |     set(GMOCK_BOTH_LIBRARIES ${GMOCK_LIBRARIES} ${GMOCK_MAIN_LIBRARIES}) | ||||||
|  | endif() | ||||||
|  | 
 | ||||||
|  | 
 | ||||||
|  | @ -44,7 +44,6 @@ LinuxPath::LinuxPath(const std::string& application_name) | ||||||
| boost::filesystem::path LinuxPath::getUserPath() const | boost::filesystem::path LinuxPath::getUserPath() const | ||||||
| { | { | ||||||
|     boost::filesystem::path userPath("."); |     boost::filesystem::path userPath("."); | ||||||
|     boost::filesystem::path suffix(mName); |  | ||||||
| 
 | 
 | ||||||
|     const char* theDir = getenv("HOME"); |     const char* theDir = getenv("HOME"); | ||||||
|     if (theDir == NULL) |     if (theDir == NULL) | ||||||
|  | @ -58,19 +57,15 @@ boost::filesystem::path LinuxPath::getUserPath() const | ||||||
| 
 | 
 | ||||||
|     if (theDir != NULL) |     if (theDir != NULL) | ||||||
|     { |     { | ||||||
|         suffix = boost::filesystem::path("/.config/"); |  | ||||||
|         userPath = boost::filesystem::path(theDir); |         userPath = boost::filesystem::path(theDir); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     userPath /= suffix; |     return userPath / ".config" / mName; | ||||||
| 
 |  | ||||||
|     return userPath; |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| boost::filesystem::path LinuxPath::getCachePath() const | boost::filesystem::path LinuxPath::getCachePath() const | ||||||
| { | { | ||||||
|     boost::filesystem::path userPath("."); |     boost::filesystem::path userPath("."); | ||||||
|     boost::filesystem::path suffix(mName); |  | ||||||
| 
 | 
 | ||||||
|     const char* theDir = getenv("HOME"); |     const char* theDir = getenv("HOME"); | ||||||
|     if (theDir == NULL) |     if (theDir == NULL) | ||||||
|  | @ -86,9 +81,8 @@ boost::filesystem::path LinuxPath::getCachePath() const | ||||||
|     { |     { | ||||||
|         userPath = boost::filesystem::path(theDir); |         userPath = boost::filesystem::path(theDir); | ||||||
|     } |     } | ||||||
|     userPath /= ".cache" / suffix; |  | ||||||
| 
 | 
 | ||||||
|     return userPath; |     return userPath / ".cache" / mName; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| boost::filesystem::path LinuxPath::getGlobalPath() const | boost::filesystem::path LinuxPath::getGlobalPath() const | ||||||
|  |  | ||||||
|  | @ -47,7 +47,6 @@ MacOsPath::MacOsPath(const std::string& application_name) | ||||||
| boost::filesystem::path MacOsPath::getUserPath() const | boost::filesystem::path MacOsPath::getUserPath() const | ||||||
| { | { | ||||||
|     boost::filesystem::path userPath("."); |     boost::filesystem::path userPath("."); | ||||||
|     boost::filesystem::path suffix(mName); |  | ||||||
| 
 | 
 | ||||||
|     const char* theDir = getenv("HOME"); |     const char* theDir = getenv("HOME"); | ||||||
|     if (theDir == NULL) |     if (theDir == NULL) | ||||||
|  | @ -63,9 +62,7 @@ boost::filesystem::path MacOsPath::getUserPath() const | ||||||
|         userPath = boost::filesystem::path(theDir) / "Library/Preferences/"; |         userPath = boost::filesystem::path(theDir) / "Library/Preferences/"; | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     userPath /= suffix; |     return userPath / mName; | ||||||
| 
 |  | ||||||
|     return userPath; |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| boost::filesystem::path MacOsPath::getGlobalPath() const | boost::filesystem::path MacOsPath::getGlobalPath() const | ||||||
|  |  | ||||||
|  | @ -28,7 +28,6 @@ WindowsPath::WindowsPath(const std::string& application_name) | ||||||
| boost::filesystem::path WindowsPath::getUserPath() const | boost::filesystem::path WindowsPath::getUserPath() const | ||||||
| { | { | ||||||
|     boost::filesystem::path userPath("."); |     boost::filesystem::path userPath("."); | ||||||
|     boost::filesystem::path suffix(mName); |  | ||||||
| 
 | 
 | ||||||
|     TCHAR path[MAX_PATH]; |     TCHAR path[MAX_PATH]; | ||||||
|     memset(path, 0, sizeof(path)); |     memset(path, 0, sizeof(path)); | ||||||
|  | @ -39,15 +38,12 @@ boost::filesystem::path WindowsPath::getUserPath() const | ||||||
|         userPath = boost::filesystem::path(path); |         userPath = boost::filesystem::path(path); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     userPath /= suffix; |     return userPath / mName; | ||||||
| 
 |  | ||||||
|     return userPath; |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| boost::filesystem::path WindowsPath::getGlobalPath() const | boost::filesystem::path WindowsPath::getGlobalPath() const | ||||||
| { | { | ||||||
|     boost::filesystem::path globalPath("."); |     boost::filesystem::path globalPath("."); | ||||||
|     boost::filesystem::path suffix(mName); |  | ||||||
| 
 | 
 | ||||||
|     TCHAR path[MAX_PATH]; |     TCHAR path[MAX_PATH]; | ||||||
|     memset(path, 0, sizeof(path)); |     memset(path, 0, sizeof(path)); | ||||||
|  | @ -57,9 +53,7 @@ boost::filesystem::path WindowsPath::getGlobalPath() const | ||||||
|         globalPath = boost::filesystem::path(path); |         globalPath = boost::filesystem::path(path); | ||||||
|     } |     } | ||||||
| 
 | 
 | ||||||
|     globalPath /= suffix; |     return globalPath / mName; | ||||||
| 
 |  | ||||||
|     return globalPath; |  | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| boost::filesystem::path WindowsPath::getLocalPath() const | boost::filesystem::path WindowsPath::getLocalPath() const | ||||||
|  |  | ||||||
		Loading…
	
		Reference in a new issue