mirror of
				https://github.com/OpenMW/openmw.git
				synced 2025-10-26 16: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_LAUNCHER "build Launcher" 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 | ||||
| option(USE_FFMPEG "use ffmpeg for sound" OFF) | ||||
|  | @ -459,6 +461,11 @@ if (BUILD_MWINIIMPORTER) | |||
|    add_subdirectory( apps/mwiniimporter ) | ||||
| endif() | ||||
| 
 | ||||
| # UnitTests | ||||
| if (BUILD_UNITTESTS) | ||||
|   add_subdirectory( apps/openmw_test_suite ) | ||||
| endif() | ||||
| 
 | ||||
| if (WIN32) | ||||
|   if (MSVC) | ||||
|     if (USE_DEBUG_CONSOLE) | ||||
|  | @ -622,3 +629,34 @@ if (APPLE) | |||
|         " COMPONENT Runtime) | ||||
|         include(CPack) | ||||
| 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) | ||||
| #    target_link_libraries(openmw ${CARBON_FRAMEWORK}) | ||||
| #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 | ||||
|         "${CMAKE_RUNTIME_OUTPUT_DIRECTORY}/launcher.cfg") | ||||
| endif() | ||||
| 
 | ||||
| if (BUILD_WITH_CODE_COVERAGE) | ||||
|   add_definitions (--coverage) | ||||
|   target_link_libraries(omwlauncher gcov) | ||||
| endif() | ||||
|  |  | |||
|  | @ -18,3 +18,7 @@ target_link_libraries(mwiniimport | |||
|     components | ||||
| ) | ||||
| 
 | ||||
| if (BUILD_WITH_CODE_COVERAGE) | ||||
|   add_definitions (--coverage) | ||||
|   target_link_libraries(mwiniimport gcov) | ||||
| endif() | ||||
|  |  | |||
|  | @ -123,3 +123,8 @@ endif(APPLE) | |||
| if(DPKG_PROGRAM) | ||||
|     INSTALL(TARGETS openmw RUNTIME DESTINATION games COMPONENT openmw) | ||||
| 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 userPath("."); | ||||
|     boost::filesystem::path suffix(mName); | ||||
| 
 | ||||
|     const char* theDir = getenv("HOME"); | ||||
|     if (theDir == NULL) | ||||
|  | @ -58,19 +57,15 @@ boost::filesystem::path LinuxPath::getUserPath() const | |||
| 
 | ||||
|     if (theDir != NULL) | ||||
|     { | ||||
|         suffix = boost::filesystem::path("/.config/"); | ||||
|         userPath = boost::filesystem::path(theDir); | ||||
|     } | ||||
| 
 | ||||
|     userPath /= suffix; | ||||
| 
 | ||||
|     return userPath; | ||||
|     return userPath / ".config" / mName; | ||||
| } | ||||
| 
 | ||||
| boost::filesystem::path LinuxPath::getCachePath() const | ||||
| { | ||||
|     boost::filesystem::path userPath("."); | ||||
|     boost::filesystem::path suffix(mName); | ||||
| 
 | ||||
|     const char* theDir = getenv("HOME"); | ||||
|     if (theDir == NULL) | ||||
|  | @ -86,9 +81,8 @@ boost::filesystem::path LinuxPath::getCachePath() const | |||
|     { | ||||
|         userPath = boost::filesystem::path(theDir); | ||||
|     } | ||||
|     userPath /= ".cache" / suffix; | ||||
| 
 | ||||
|     return userPath; | ||||
|     return userPath / ".cache" / mName; | ||||
| } | ||||
| 
 | ||||
| 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 userPath("."); | ||||
|     boost::filesystem::path suffix(mName); | ||||
| 
 | ||||
|     const char* theDir = getenv("HOME"); | ||||
|     if (theDir == NULL) | ||||
|  | @ -63,9 +62,7 @@ boost::filesystem::path MacOsPath::getUserPath() const | |||
|         userPath = boost::filesystem::path(theDir) / "Library/Preferences/"; | ||||
|     } | ||||
| 
 | ||||
|     userPath /= suffix; | ||||
| 
 | ||||
|     return userPath; | ||||
|     return userPath / mName; | ||||
| } | ||||
| 
 | ||||
| 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 userPath("."); | ||||
|     boost::filesystem::path suffix(mName); | ||||
| 
 | ||||
|     TCHAR path[MAX_PATH]; | ||||
|     memset(path, 0, sizeof(path)); | ||||
|  | @ -39,15 +38,12 @@ boost::filesystem::path WindowsPath::getUserPath() const | |||
|         userPath = boost::filesystem::path(path); | ||||
|     } | ||||
| 
 | ||||
|     userPath /= suffix; | ||||
| 
 | ||||
|     return userPath; | ||||
|     return userPath / mName; | ||||
| } | ||||
| 
 | ||||
| boost::filesystem::path WindowsPath::getGlobalPath() const | ||||
| { | ||||
|     boost::filesystem::path globalPath("."); | ||||
|     boost::filesystem::path suffix(mName); | ||||
| 
 | ||||
|     TCHAR path[MAX_PATH]; | ||||
|     memset(path, 0, sizeof(path)); | ||||
|  | @ -57,9 +53,7 @@ boost::filesystem::path WindowsPath::getGlobalPath() const | |||
|         globalPath = boost::filesystem::path(path); | ||||
|     } | ||||
| 
 | ||||
|     globalPath /= suffix; | ||||
| 
 | ||||
|     return globalPath; | ||||
|     return globalPath / mName; | ||||
| } | ||||
| 
 | ||||
| boost::filesystem::path WindowsPath::getLocalPath() const | ||||
|  |  | |||
		Loading…
	
		Reference in a new issue