mirror of https://github.com/procxx/kepka.git
				
				
				
			Reorg cmake structure - remove duplication, reorder sections
This commit is contained in:
		
							parent
							
								
									53f5bed333
								
							
						
					
					
						commit
						ed3c14a172
					
				|  | @ -1,6 +1,17 @@ | ||||||
| cmake_minimum_required(VERSION 3.9) | cmake_minimum_required(VERSION 3.9) | ||||||
| project(telegram-desktop) | project(telegram-desktop) | ||||||
| 
 | 
 | ||||||
|  | set(CMAKE_MODULE_PATH "${CMAKE_SOURCE_DIR}/cotire/CMake;${PROJECT_SOURCE_DIR}/modules/") | ||||||
|  | include(cotire) | ||||||
|  | 
 | ||||||
|  | if (CMAKE_VERSION VERSION_GREATER 3.9) | ||||||
|  |     cmake_policy(SET CMP0071 NEW) | ||||||
|  | endif() | ||||||
|  | 
 | ||||||
|  | ##================================================ | ||||||
|  | ## Configure packages | ||||||
|  | ##================================================ | ||||||
|  | 
 | ||||||
| if (EXISTS ${CMAKE_BINARY_DIR}/conanbuildinfo.cmake) | if (EXISTS ${CMAKE_BINARY_DIR}/conanbuildinfo.cmake) | ||||||
|     include(${CMAKE_BINARY_DIR}/conanbuildinfo.cmake) |     include(${CMAKE_BINARY_DIR}/conanbuildinfo.cmake) | ||||||
|     conan_basic_setup() |     conan_basic_setup() | ||||||
|  | @ -8,9 +19,6 @@ else() | ||||||
|     find_package(OpenSSL REQUIRED) |     find_package(OpenSSL REQUIRED) | ||||||
| endif() | endif() | ||||||
| 
 | 
 | ||||||
| set(CMAKE_MODULE_PATH "${CMAKE_SOURCE_DIR}/cotire/CMake;${PROJECT_SOURCE_DIR}/modules/") |  | ||||||
| include(cotire) |  | ||||||
| 
 |  | ||||||
| set(CMAKE_CXX_STANDARD 14) | set(CMAKE_CXX_STANDARD 14) | ||||||
| set(CMAKE_CXX_STANDARD_REQUIRED YES) | set(CMAKE_CXX_STANDARD_REQUIRED YES) | ||||||
| set(CMAKE_CXX_EXTENSIONS OFF) | set(CMAKE_CXX_EXTENSIONS OFF) | ||||||
|  | @ -18,17 +26,11 @@ set(CMAKE_CXX_EXTENSIONS OFF) | ||||||
| set(CMAKE_AUTOMOC ON) | set(CMAKE_AUTOMOC ON) | ||||||
| set(CMAKE_INCLUDE_CURRENT_DIR ON) | set(CMAKE_INCLUDE_CURRENT_DIR ON) | ||||||
| 
 | 
 | ||||||
| if (CMAKE_VERSION VERSION_GREATER 3.9) |  | ||||||
|     cmake_policy(SET CMP0071 NEW) |  | ||||||
| endif() |  | ||||||
| 
 |  | ||||||
| # Needs OpenAL-SOFT | # Needs OpenAL-SOFT | ||||||
| # Install via `brew install openal-soft` and configure with cmake call from README.md | # Install via `brew install openal-soft` and configure with cmake call from README.md | ||||||
| find_package(OpenAL REQUIRED NO_MODULE) | find_package(OpenAL REQUIRED NO_MODULE) | ||||||
| find_package(ZLIB REQUIRED) | find_package(ZLIB REQUIRED) | ||||||
| find_package(OpenSSL REQUIRED) |  | ||||||
| find_package(FFmpeg REQUIRED) | find_package(FFmpeg REQUIRED) | ||||||
| find_package(ZLIB REQUIRED) |  | ||||||
| find_package(Opus REQUIRED) | find_package(Opus REQUIRED) | ||||||
| find_package(Qt5 COMPONENTS Core Gui Widgets Network REQUIRED) | find_package(Qt5 COMPONENTS Core Gui Widgets Network REQUIRED) | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -7,9 +7,9 @@ if(CMAKE_SYSTEM_NAME STREQUAL "Linux") | ||||||
|     endif() |     endif() | ||||||
| endif() | endif() | ||||||
| 
 | 
 | ||||||
| ##====================== | ##================================================ | ||||||
| ## Codegen Tools | ## Codegen Tools | ||||||
| ##====================== | ##================================================ | ||||||
| 
 | 
 | ||||||
| include_directories(SourceFiles) | include_directories(SourceFiles) | ||||||
| add_subdirectory(SourceFiles/codegen) | add_subdirectory(SourceFiles/codegen) | ||||||
|  | @ -113,7 +113,7 @@ add_custom_command( | ||||||
| add_custom_target(scheme_output | add_custom_target(scheme_output | ||||||
|     DEPENDS scheme.h scheme.cpp) |     DEPENDS scheme.h scheme.cpp) | ||||||
| 
 | 
 | ||||||
| ##======== | ##================================================ | ||||||
| 
 | 
 | ||||||
| list(APPEND style_files | list(APPEND style_files | ||||||
|     Resources/basic |     Resources/basic | ||||||
|  | @ -162,15 +162,17 @@ foreach (src ${style_files}) | ||||||
| 
 | 
 | ||||||
| endforeach() | endforeach() | ||||||
| 
 | 
 | ||||||
| ##====================== | ##================================================ | ||||||
| ## Main app | ## Telegram app | ||||||
| ##====================== | ##================================================ | ||||||
| 
 | 
 | ||||||
| #add_subdirectory(SourceFiles/boxes) | #add_subdirectory(SourceFiles/boxes) | ||||||
| # ^ Unused: cotire PCH needs more rigid structure with targets defined from the same | # ^ Unused: cotire PCH needs more rigid structure with targets defined from the same | ||||||
| # cmakelists file. To do: get rid of the PCH requirement for more flexible build structure. | # cmakelists file. To do: get rid of the PCH requirement for more flexible build structure. | ||||||
| 
 | 
 | ||||||
| set(APP_SRC | add_executable(Telegram WIN32 MACOSX_BUNDLE | ||||||
|  |     SourceFiles/stdafx.cpp | ||||||
|  | 
 | ||||||
|     ${CMAKE_CURRENT_BINARY_DIR}/styles/palette.cpp |     ${CMAKE_CURRENT_BINARY_DIR}/styles/palette.cpp | ||||||
|     ${CMAKE_CURRENT_BINARY_DIR}/numbers.cpp |     ${CMAKE_CURRENT_BINARY_DIR}/numbers.cpp | ||||||
|     ${CMAKE_CURRENT_BINARY_DIR}/lang_auto.cpp |     ${CMAKE_CURRENT_BINARY_DIR}/lang_auto.cpp | ||||||
|  | @ -463,10 +465,8 @@ set(APP_SRC | ||||||
|     SourceFiles/structs.cpp |     SourceFiles/structs.cpp | ||||||
| ) | ) | ||||||
| 
 | 
 | ||||||
| set(PLAT_SRC) |  | ||||||
| 
 |  | ||||||
| if (APPLE) | if (APPLE) | ||||||
|     list(APPEND PLAT_SRC |     target_sources(Telegram PRIVATE | ||||||
|         SourceFiles/platform/mac/file_utilities_mac.mm |         SourceFiles/platform/mac/file_utilities_mac.mm | ||||||
|         SourceFiles/platform/mac/mac_utilities.mm |         SourceFiles/platform/mac/mac_utilities.mm | ||||||
|         SourceFiles/platform/mac/main_window_mac.mm |         SourceFiles/platform/mac/main_window_mac.mm | ||||||
|  | @ -477,8 +477,9 @@ if (APPLE) | ||||||
|     ) |     ) | ||||||
|     set(tg_RESOURCES Resources/qrc/telegram_mac.qrc) |     set(tg_RESOURCES Resources/qrc/telegram_mac.qrc) | ||||||
| endif() | endif() | ||||||
|  | 
 | ||||||
| if (WIN32) | if (WIN32) | ||||||
|     list(APPEND PLAT_SRC |     target_sources(Telegram PRIVATE | ||||||
|         SourceFiles/platform/win/audio_win.cpp |         SourceFiles/platform/win/audio_win.cpp | ||||||
|         SourceFiles/platform/win/file_utilities_win.cpp |         SourceFiles/platform/win/file_utilities_win.cpp | ||||||
|         SourceFiles/platform/win/main_window_win.cpp |         SourceFiles/platform/win/main_window_win.cpp | ||||||
|  | @ -488,16 +489,20 @@ if (WIN32) | ||||||
|         SourceFiles/platform/win/windows_app_user_model_id.cpp |         SourceFiles/platform/win/windows_app_user_model_id.cpp | ||||||
|         SourceFiles/platform/win/windows_dlls.cpp |         SourceFiles/platform/win/windows_dlls.cpp | ||||||
|         SourceFiles/platform/win/windows_event_filter.cpp |         SourceFiles/platform/win/windows_event_filter.cpp | ||||||
|  | 
 | ||||||
|  |         Resources/winrc/Telegram.rc | ||||||
|     ) |     ) | ||||||
|     set(tg_RESOURCES Resources/qrc/telegram_wnd.qrc) |     set(tg_RESOURCES Resources/qrc/telegram_wnd.qrc) | ||||||
| endif() | endif() | ||||||
|  | 
 | ||||||
| if (WINRT) | if (WINRT) | ||||||
|     list(APPEND PLAT_SRC |     target_sources(Telegram PRIVATE | ||||||
|         SourceFiles/platform/winrt/main_window_winrt.cpp |         SourceFiles/platform/winrt/main_window_winrt.cpp | ||||||
|     ) |     ) | ||||||
| endif() | endif() | ||||||
|  | 
 | ||||||
| if (LINUX) | if (LINUX) | ||||||
|     set(PLAT_SRC ${PLAT_SRC} |     target_sources(Telegram PRIVATE | ||||||
|         SourceFiles/platform/linux/file_utilities_linux.cpp |         SourceFiles/platform/linux/file_utilities_linux.cpp | ||||||
|         SourceFiles/platform/linux/linux_desktop_environment.cpp |         SourceFiles/platform/linux/linux_desktop_environment.cpp | ||||||
|         SourceFiles/platform/linux/linux_gdk_helper.cpp |         SourceFiles/platform/linux/linux_gdk_helper.cpp | ||||||
|  | @ -519,17 +524,20 @@ list(APPEND tg_RESOURCES | ||||||
| 
 | 
 | ||||||
| qt5_add_resources(tg_RESOURCES_RCC ${tg_RESOURCES}) | qt5_add_resources(tg_RESOURCES_RCC ${tg_RESOURCES}) | ||||||
| 
 | 
 | ||||||
| set(THIRD_PARTY_SRC) | target_sources(Telegram PRIVATE | ||||||
|  |     ${tg_RESOURCES} | ||||||
|  |     ${tg_RESOURCES_RCC} | ||||||
|  | ) | ||||||
| 
 | 
 | ||||||
| if (APPLE) | if (APPLE) | ||||||
|     list(APPEND THIRD_PARTY_SRC |     target_sources(Telegram PRIVATE | ||||||
|         ThirdParty/SPMediaKeyTap/SPMediaKeyTap.m |         ThirdParty/SPMediaKeyTap/SPMediaKeyTap.m | ||||||
|         ThirdParty/SPMediaKeyTap/SPInvocationGrabbing/NSObject+SPInvocationGrabbing.m |         ThirdParty/SPMediaKeyTap/SPInvocationGrabbing/NSObject+SPInvocationGrabbing.m | ||||||
|     ) |     ) | ||||||
|     include_directories(ThirdParty/SPMediaKeyTap) |     include_directories(ThirdParty/SPMediaKeyTap) | ||||||
| endif() | endif() | ||||||
| 
 | 
 | ||||||
| list(APPEND THIRD_PARTY_SRC | target_sources(Telegram PRIVATE | ||||||
|     ThirdParty/minizip/ioapi.c |     ThirdParty/minizip/ioapi.c | ||||||
|     ThirdParty/minizip/zip.c |     ThirdParty/minizip/zip.c | ||||||
|     ThirdParty/minizip/unzip.c |     ThirdParty/minizip/unzip.c | ||||||
|  | @ -543,13 +551,9 @@ include_directories(ThirdParty) # For minizip/ but we use fully-qualified | ||||||
| include_directories(ThirdParty/GSL/include ThirdParty/variant/include | include_directories(ThirdParty/GSL/include ThirdParty/variant/include | ||||||
|     ThirdParty/emoji_suggestions ThirdParty/libtgvoip) |     ThirdParty/emoji_suggestions ThirdParty/libtgvoip) | ||||||
| 
 | 
 | ||||||
| ##====================== |  | ||||||
| ## Telegram |  | ||||||
| ##====================== |  | ||||||
| 
 |  | ||||||
| include_directories(SourceFiles SourceFiles/core) | include_directories(SourceFiles SourceFiles/core) | ||||||
| 
 | 
 | ||||||
| include_directories(${ZLIB_INCLUDE_DIRS} ${OPENSSL_INCLUDE_DIR} | include_directories(${OPENAL_INCLUDE_DIRS} ${ZLIB_INCLUDE_DIRS} ${OPENSSL_INCLUDE_DIR} | ||||||
|     ${OPUS_INCLUDE_DIR} ${FFMPEG_INCLUDE_DIRS}) |     ${OPUS_INCLUDE_DIR} ${FFMPEG_INCLUDE_DIRS}) | ||||||
| 
 | 
 | ||||||
| add_subdirectory(ThirdParty/libtgvoip) | add_subdirectory(ThirdParty/libtgvoip) | ||||||
|  | @ -561,7 +565,6 @@ endif() | ||||||
| if (WIN32) | if (WIN32) | ||||||
|     add_definitions(-D_CRT_SECURE_NO_WARNINGS -DWIN32 -D_WINDOWS -DUNICODE -DWIN64 |     add_definitions(-D_CRT_SECURE_NO_WARNINGS -DWIN32 -D_WINDOWS -DUNICODE -DWIN64 | ||||||
|         -DWINAPI_FAMILY=WINAPI_FAMILY_DESKTOP_APP) |         -DWINAPI_FAMILY=WINAPI_FAMILY_DESKTOP_APP) | ||||||
|     list(APPEND tg_RESOURCES Resources/winrc/Telegram.rc) |  | ||||||
| endif() | endif() | ||||||
| 
 | 
 | ||||||
| add_definitions(-DTDESKTOP_DISABLE_CRASH_REPORTS) | add_definitions(-DTDESKTOP_DISABLE_CRASH_REPORTS) | ||||||
|  | @ -586,25 +589,18 @@ if (APPLE) | ||||||
|     set_source_files_properties(${CMAKE_CURRENT_BINARY_DIR}/${MACOSX_BUNDLE_ICON_FILE} |     set_source_files_properties(${CMAKE_CURRENT_BINARY_DIR}/${MACOSX_BUNDLE_ICON_FILE} | ||||||
|         PROPERTIES |         PROPERTIES | ||||||
|             MACOSX_PACKAGE_LOCATION Resources) |             MACOSX_PACKAGE_LOCATION Resources) | ||||||
|     set(APPLE_BUNDLE_SRC ${CMAKE_CURRENT_BINARY_DIR}/${MACOSX_BUNDLE_ICON_FILE}) |  | ||||||
| endif() |  | ||||||
| 
 | 
 | ||||||
| add_executable(Telegram WIN32 MACOSX_BUNDLE |     target_sources(Telegram PRIVATE | ||||||
|     SourceFiles/stdafx.cpp |         ${CMAKE_CURRENT_BINARY_DIR}/${MACOSX_BUNDLE_ICON_FILE} | ||||||
|     ${APP_SRC} |     ) | ||||||
|     ${PLAT_SRC} | endif() | ||||||
|     ${THIRD_PARTY_SRC} |  | ||||||
|     ${tg_RESOURCES} |  | ||||||
|     ${tg_RESOURCES_RCC} |  | ||||||
|     ${APPLE_BUNDLE_SRC} |  | ||||||
| ) |  | ||||||
| 
 | 
 | ||||||
| # Disable a single annoying warning about c++17 | # Disable a single annoying warning about c++17 | ||||||
| if(NOT WIN32) | if(NOT WIN32) | ||||||
|     target_compile_options(Telegram PRIVATE -Wno-c++1z-extensions) |     target_compile_options(Telegram PRIVATE -Wno-c++1z-extensions) | ||||||
| endif() | endif() | ||||||
| 
 | 
 | ||||||
| # Enable C++14 support for msvc (@todo this should be done in cmake) | # Enable C++14 support for msvc (@todo this should be done in cmake - see ver 3.10 or above) | ||||||
| if(WIN32) | if(WIN32) | ||||||
|     target_compile_options(Telegram PRIVATE /std:c++14) |     target_compile_options(Telegram PRIVATE /std:c++14) | ||||||
| endif() | endif() | ||||||
|  | @ -627,8 +623,6 @@ target_link_libraries(Telegram | ||||||
|     ${CONAN_LIBS} |     ${CONAN_LIBS} | ||||||
| ) # crashpad::crashpad_client) | ) # crashpad::crashpad_client) | ||||||
| 
 | 
 | ||||||
| add_dependencies(Telegram boxes_styles_output) |  | ||||||
| 
 |  | ||||||
| if (APPLE) | if (APPLE) | ||||||
|     add_dependencies(Telegram iconset_output) |     add_dependencies(Telegram iconset_output) | ||||||
| 
 | 
 | ||||||
|  | @ -655,9 +649,9 @@ if (APPLE) | ||||||
| endif() | endif() | ||||||
| 
 | 
 | ||||||
| if(WIN32) | if(WIN32) | ||||||
|     target_link_libraries(Telegram winmm imm32 ws2_32 kernel32 user32 gdi32 winspool |     target_link_libraries(Telegram | ||||||
|         comdlg32 advapi32 shell32 ole32 oleaut32 uuid odbc32 odbccp32 Shlwapi Iphlpapi |         winmm imm32 ws2_32 kernel32 user32 gdi32 winspool comdlg32 advapi32 shell32 ole32 | ||||||
|         Gdiplus Strmiids |         oleaut32 uuid odbc32 odbccp32 Shlwapi Iphlpapi Gdiplus Strmiids | ||||||
|     ) |     ) | ||||||
| endif() | endif() | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -87,6 +87,7 @@ add_library(tgvoip STATIC | ||||||
|     webrtc_dsp/webrtc/modules/audio_processing/utility/ooura_fft_sse2.cc |     webrtc_dsp/webrtc/modules/audio_processing/utility/ooura_fft_sse2.cc | ||||||
|     webrtc_dsp/webrtc/system_wrappers/source/cpu_features.cc |     webrtc_dsp/webrtc/system_wrappers/source/cpu_features.cc | ||||||
| ) | ) | ||||||
|  | 
 | ||||||
| if (WIN32) | if (WIN32) | ||||||
|     target_compile_definitions(tgvoip PRIVATE -DNOMINMAX -D_USING_V110_SDK71_ -DTGVOIP_WINXP_COMPAT) |     target_compile_definitions(tgvoip PRIVATE -DNOMINMAX -D_USING_V110_SDK71_ -DTGVOIP_WINXP_COMPAT) | ||||||
|     target_sources(tgvoip PRIVATE |     target_sources(tgvoip PRIVATE | ||||||
|  |  | ||||||
		Loading…
	
		Reference in New Issue