Introduce DESKTOP_APP_USE_PACKAGED.
This commit is contained in:
		
							parent
							
								
									3182d2d4a7
								
							
						
					
					
						commit
						632ed315b2
					
				
					 7 changed files with 90 additions and 23 deletions
				
			
		|  | @ -5,4 +5,6 @@ | |||
| # https://github.com/desktop-app/legal/blob/master/LEGAL | ||||
| 
 | ||||
| add_subdirectory(external) | ||||
| add_subdirectory(linux_glibc_wraps) | ||||
| if (DESKTOP_APP_USE_GLIBC_WRAPS) | ||||
|     add_subdirectory(linux_glibc_wraps) | ||||
| endif() | ||||
|  |  | |||
							
								
								
									
										5
									
								
								external/auto_updates/xz/CMakeLists.txt
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										5
									
								
								external/auto_updates/xz/CMakeLists.txt
									
										
									
									
										vendored
									
									
								
							|  | @ -7,7 +7,10 @@ | |||
| add_library(external_xz INTERFACE IMPORTED GLOBAL) | ||||
| add_library(desktop-app::external_xz ALIAS external_xz) | ||||
| 
 | ||||
| if (APPLE AND NOT build_osx) | ||||
| if (DESKTOP_APP_USE_PACKAGED) | ||||
|     find_package(LibLZMA REQUIRED) | ||||
|     target_link_libraries(external_xz LibLZMA::LibLZMA) | ||||
| elseif (APPLE AND NOT build_osx) | ||||
|     target_link_libraries(external_xz | ||||
|     INTERFACE | ||||
|         /usr/local/macos/lib/liblzma.a | ||||
|  |  | |||
							
								
								
									
										9
									
								
								external/openssl/CMakeLists.txt
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										9
									
								
								external/openssl/CMakeLists.txt
									
										
									
									
										vendored
									
									
								
							|  | @ -47,9 +47,8 @@ INTERFACE | |||
| ) | ||||
| 
 | ||||
| if (LINUX) | ||||
|     target_link_libraries(external_openssl | ||||
|     INTERFACE | ||||
|         desktop-app::linux_glibc_wraps | ||||
|         pthread | ||||
|     ) | ||||
|     if (DESKTOP_APP_USE_GLIBC_WRAPS) | ||||
|         target_link_libraries(external_openssl INTERFACE desktop-app::linux_glibc_wraps) | ||||
|     endif() | ||||
|     target_link_libraries(external_openssl INTERFACE pthread) | ||||
| endif() | ||||
|  |  | |||
							
								
								
									
										4
									
								
								external/qt/CMakeLists.txt
									
										
									
									
										vendored
									
									
								
							
							
						
						
									
										4
									
								
								external/qt/CMakeLists.txt
									
										
									
									
										vendored
									
									
								
							|  | @ -191,9 +191,11 @@ if (LINUX) | |||
|         icuuc | ||||
|         icudata | ||||
|     ) | ||||
|     if (DESKTOP_APP_USE_GLIBC_WRAPS) | ||||
|         target_link_libraries(external_qt INTERFACE desktop-app::linux_glibc_wraps) | ||||
|     endif() | ||||
|     target_link_libraries(external_qt | ||||
|     INTERFACE | ||||
|         desktop-app::linux_glibc_wraps | ||||
|         xcb | ||||
|         X11 | ||||
|         X11-xcb | ||||
|  |  | |||
|  | @ -4,21 +4,19 @@ | |||
| # For license and copyright information please follow this link: | ||||
| # https://github.com/desktop-app/legal/blob/master/LEGAL | ||||
| 
 | ||||
| if (LINUX) | ||||
|     add_library(linux_glibc_wraps STATIC) | ||||
|     add_library(desktop-app::linux_glibc_wraps ALIAS linux_glibc_wraps) | ||||
| add_library(linux_glibc_wraps STATIC) | ||||
| add_library(desktop-app::linux_glibc_wraps ALIAS linux_glibc_wraps) | ||||
| 
 | ||||
|     get_filename_component(src_loc . REALPATH) | ||||
| get_filename_component(src_loc . REALPATH) | ||||
| 
 | ||||
|     nice_target_sources(linux_glibc_wraps ${src_loc} | ||||
|     PRIVATE | ||||
| nice_target_sources(linux_glibc_wraps ${src_loc} | ||||
| PRIVATE | ||||
|     platform/linux/linux_glibc_wraps.c | ||||
|     platform/linux/linux_glibc_wraps_32.c | ||||
|     platform/linux/linux_glibc_wraps_64.c | ||||
|     ) | ||||
|     if (NOT build_linux32) | ||||
| ) | ||||
| if (NOT build_linux32) | ||||
|     set_source_files_properties(${src_loc}/platform/linux/linux_glibc_wraps_32.c PROPERTIES HEADER_FILE_ONLY TRUE) | ||||
|     else() | ||||
| else() | ||||
|     set_source_files_properties(${src_loc}/platform/linux/linux_glibc_wraps_64.c PROPERTIES HEADER_FILE_ONLY TRUE) | ||||
|     endif() | ||||
| endif() | ||||
|  |  | |||
							
								
								
									
										54
									
								
								run_cmake.py
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										54
									
								
								run_cmake.py
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,54 @@ | |||
| ''' | ||||
| This file is part of Telegram Desktop, | ||||
| the official desktop application for the Telegram messaging service. | ||||
| 
 | ||||
| For license and copyright information please follow this link: | ||||
| https://github.com/telegramdesktop/tdesktop/blob/master/LEGAL | ||||
| ''' | ||||
| import sys, os, shutil, subprocess | ||||
| 
 | ||||
| def run(project, arguments): | ||||
|     scriptPath = os.path.dirname(os.path.realpath(__file__)) | ||||
|     basePath = scriptPath + '/../out' | ||||
|      | ||||
|     cmake = ['cmake'] | ||||
|     for arg in arguments: | ||||
|         if arg == 'debug': | ||||
|             cmake.append('-DCMAKE_BUILD_TYPE=Debug') | ||||
|         elif arg != 'fresh': | ||||
|             cmake.append(arg) | ||||
|      | ||||
|     if sys.platform == 'win32': | ||||
|         cmake.append('-AWin32') | ||||
|     elif sys.platform != 'darwin': | ||||
|         if not '-DCMAKE_BUILD_TYPE=Debug' in cmake: | ||||
|             cmake.append('-DCMAKE_BUILD_TYPE=Release') | ||||
| 
 | ||||
|     specialTarget = '' | ||||
|     specialTargetFile = scriptPath + '/../' + project + '/build/target' | ||||
|     if os.path.isfile(specialTargetFile): | ||||
|         with open(specialTargetFile, 'r') as f: | ||||
|             for line in f: | ||||
|                 target = line.strip() | ||||
|                 if len(target) > 0: | ||||
|                     cmake.append('-DDESKTOP_APP_SPECIAL_TARGET=' + target) | ||||
| 
 | ||||
|     cmake.extend(['-Werror=dev', '-Werror=deprecated', '--warn-uninitialized', '..']) | ||||
|     command = ' '.join(cmake) | ||||
| 
 | ||||
|     if not os.path.exists(basePath): | ||||
|         os.mkdir(basePath) | ||||
|     elif 'fresh' in arguments: | ||||
|         paths = os.listdir(basePath) | ||||
|         for path in paths: | ||||
|             if path.lower().startswith('cmake'): | ||||
|                 full = basePath + '/' + path | ||||
|                 if os.path.isdir(full): | ||||
|                     shutil.rmtree(full, ignore_errors=False) | ||||
|                 else: | ||||
|                     os.remove(full) | ||||
|         print('Cleared previous.') | ||||
|     os.chdir(basePath) | ||||
|     subprocess.call(command, shell=True) | ||||
| 
 | ||||
|     return 0 | ||||
|  | @ -8,6 +8,8 @@ set(DESKTOP_APP_SPECIAL_TARGET "" CACHE STRING "Use special platform target, lik | |||
| option(DESKTOP_APP_DISABLE_CRASH_REPORTS "Disable crash report generation." OFF) | ||||
| option(DESKTOP_APP_DISABLE_SPELLCHECK "Disable spellcheck library." OFF) | ||||
| option(DESKTOP_APP_LOTTIE_USE_CACHE "Use caching in lottie animations." ON) | ||||
| option(DESKTOP_APP_USE_GLIBC_WRAPS "Use wraps for new GLIBC features." OFF) | ||||
| option(DESKTOP_APP_USE_PACKAGED "Find libraries using CMake instead of exact paths." ON) | ||||
| 
 | ||||
| function(report_bad_special_target) | ||||
|     message(FATAL_ERROR "Bad special target '${DESKTOP_APP_SPECIAL_TARGET}'") | ||||
|  | @ -19,6 +21,11 @@ if (DESKTOP_APP_SPECIAL_TARGET STREQUAL "" | |||
|     set(disable_autoupdate 1) | ||||
| endif() | ||||
| 
 | ||||
| if (NOT DESKTOP_APP_SPECIAL_TARGET STREQUAL "") | ||||
|     set(DESKTOP_APP_USE_GLIBC_WRAPS ON) | ||||
|     set(DESKTOP_APP_USE_PACKAGED OFF) | ||||
| endif() | ||||
| 
 | ||||
| if (NOT DESKTOP_APP_SPECIAL_TARGET STREQUAL "osx") | ||||
|     set(CMAKE_OSX_DEPLOYMENT_TARGET 10.12 CACHE STRING "Minimum OS X deployment version" FORCE) | ||||
| else() | ||||
|  | @ -38,6 +45,7 @@ if (WIN32) | |||
|         AND NOT DESKTOP_APP_SPECIAL_TARGET STREQUAL "win") | ||||
|         report_bad_special_target() | ||||
|     endif() | ||||
|     set(DESKTOP_APP_USE_GLIBC_WRAPS OFF) | ||||
| elseif (APPLE) | ||||
|     if (DESKTOP_APP_SPECIAL_TARGET STREQUAL "osx") | ||||
|         set(build_osx 1) | ||||
|  | @ -48,6 +56,7 @@ elseif (APPLE) | |||
|         AND NOT DESKTOP_APP_SPECIAL_TARGET STREQUAL "mac") | ||||
|         report_bad_special_target() | ||||
|     endif() | ||||
|     set(DESKTOP_APP_USE_GLIBC_WRAPS OFF) | ||||
| else() | ||||
|     set(LINUX 1) | ||||
|     execute_process(COMMAND uname -m OUTPUT_VARIABLE machine_uname) | ||||
|  |  | |||
		Loading…
	
	Add table
		
		Reference in a new issue
	
	 John Preston
						John Preston