You've already forked qBittorrent
							
							
				mirror of
				https://github.com/qbittorrent/qBittorrent
				synced 2025-10-23 22:32:16 +02:00 
			
		
		
		
	Compare commits
	
		
			269 Commits
		
	
	
		
			release-4.
			...
			v4_0_x
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | d2f3d1ec2c | ||
|   | bc6e3ae40d | ||
|   | b02e239f7c | ||
|   | 397cd4bf60 | ||
|   | 409f972ad3 | ||
|   | 267961ffca | ||
|   | dff753c452 | ||
|   | ce3bafd30d | ||
|   | e5538d9f25 | ||
|   | 7a8a32b1c3 | ||
|   | cac5e0391b | ||
|   | 726790fa93 | ||
|   | c9c7a5be53 | ||
|   | 1495513cfc | ||
|   | 085afaac14 | ||
|   | d58a54c758 | ||
|   | 78d9bcb6a1 | ||
|   | 1a43cd329d | ||
|   | 2fe687eeca | ||
|   | 107bd8a54f | ||
|   | 865df3fcf1 | ||
|   | cbf9c52462 | ||
|   | 171e25e962 | ||
|   | 239d14fd10 | ||
|   | 0b7a175156 | ||
|   | b37dbb60b5 | ||
|   | d5acd1f210 | ||
|   | 65eda4a68e | ||
|   | 7209881025 | ||
|   | a5d0a4b619 | ||
|   | 79276a8786 | ||
|   | fa2b645a64 | ||
|   | 4d5d6df734 | ||
|   | 2c39b69c18 | ||
|   | 13c0077e95 | ||
|   | 9299e3f371 | ||
|   | b9ddc6ee86 | ||
|   | 276856a614 | ||
|   | fbd6a8a0da | ||
|   | 6fc18b4af6 | ||
|   | 44d633fb68 | ||
|   | eb4bf6cc68 | ||
|   | 6db6c850eb | ||
|   | 02ae1e3734 | ||
|   | eb887139fd | ||
|   | 84805f7fb8 | ||
|   | 2719131ed2 | ||
|   | 52401bd2b0 | ||
|   | 4834703bc4 | ||
|   | 3ed73244b1 | ||
|   | 97cd430125 | ||
|   | d202b85d51 | ||
|   | c51b79e9fc | ||
|   | 4449018207 | ||
|   | ced8e41473 | ||
|   | 2c66ed6708 | ||
|   | c7d3d6ac90 | ||
|   | 13210b3e9f | ||
|   | 6e622fc23b | ||
|   | ae35111b59 | ||
|   | e1c3d419a7 | ||
|   | 7396b8adba | ||
|   | c09001545d | ||
|   | f8d4315f7e | ||
|   | 1fa2957d27 | ||
|   | ade50d2b53 | ||
|   | 0fa1d35b87 | ||
|   | 6486fc5f4d | ||
|   | 1e059ab1a2 | ||
|   | 15b137211b | ||
|   | 6f8f1d7bad | ||
|   | a31f0c0a3d | ||
|   | f977d1293a | ||
|   | 1399be50cb | ||
|   | 52dcf32cc8 | ||
|   | 52b2b807ab | ||
|   | 5cf4f00824 | ||
|   | faa6fad025 | ||
|   | 9f94bbce3a | ||
|   | 5c49b2486c | ||
|   | 4f6e7f97c6 | ||
|   | 7751c5b75c | ||
|   | a1a9f3317b | ||
|   | fb20f59a96 | ||
|   | a15e3407b0 | ||
|   | e267c2d37a | ||
|   | ae32edeb26 | ||
|   | 34d38ef466 | ||
|   | 120ee6b836 | ||
|   | 7d25b6fce2 | ||
|   | 068eff9e9f | ||
|   | 31a55f79f1 | ||
|   | bac032e01c | ||
|   | b809941f02 | ||
|   | 77c3758090 | ||
|   | 5758817189 | ||
|   | acc9f08a05 | ||
|   | f3b7f17a7c | ||
|   | dfc3f047e2 | ||
|   | 223ab7de84 | ||
|   | d2a4027347 | ||
|   | 4594895082 | ||
|   | e457223fcd | ||
|   | 8fc25c4524 | ||
|   | 410e133592 | ||
|   | e114bc7ef6 | ||
|   | 6ac57cb24c | ||
|   | 2b7893adc8 | ||
|   | 84b8832d57 | ||
|   | 0e738b534c | ||
|   | 96ce8690b6 | ||
|   | a23698940c | ||
|   | 50bb733293 | ||
|   | 6420157b55 | ||
|   | 86bdfbf88c | ||
|   | 81e8f79164 | ||
|   | 64a0ad33c1 | ||
|   | 3cd0ffecaf | ||
|   | a2ddabaedb | ||
|   | 1fec1978aa | ||
|   | 8de67fd745 | ||
|   | 3b51582416 | ||
|   | ffa2fdce9d | ||
|   | 588f1c7592 | ||
|   | ab1ece2460 | ||
|   | 7a935d8a87 | ||
|   | 3926eba585 | ||
|   | 74bf420610 | ||
|   | 324f18a0b2 | ||
|   | c134e391e6 | ||
|   | 24504951b0 | ||
|   | f7f02ab16a | ||
|   | fe810fcd37 | ||
|   | 17167e79d2 | ||
|   | 7bd86048a8 | ||
|   | d399f024a7 | ||
|   | 21f06abef8 | ||
|   | fbe0e96fd5 | ||
|   | 94e00dd38d | ||
|   | c3f5432877 | ||
|   | 4dcc187a72 | ||
|   | 97c99dfaaf | ||
|   | da83041a3f | ||
|   | d40a4f14dd | ||
|   | de7b0278f4 | ||
|   | 17f5e10ffc | ||
|   | a0dbb6c97c | ||
|   | 4d330a6110 | ||
|   | 9fc2bf6353 | ||
|   | f9c7121847 | ||
|   | d3a0ac3b6e | ||
|   | a6c99844de | ||
|   | d51a957247 | ||
|   | a0c16cd461 | ||
|   | 8fe11dff91 | ||
|   | efcdcf5898 | ||
|   | da543cdae2 | ||
|   | 0374742e57 | ||
|   | 408052d1ec | ||
|   | b0ebbc3596 | ||
|   | e45e1166b2 | ||
|   | de64d5c3bc | ||
|   | 07130c4b26 | ||
|   | 8482464ad0 | ||
|   | d7ce6e39d4 | ||
|   | 97acbd5259 | ||
|   | 60937a1871 | ||
|   | ed43bc377d | ||
|   | 8d11929815 | ||
|   | 0e6f8c15c5 | ||
|   | 8107201a5b | ||
|   | 395ea4d1d0 | ||
|   | 7bf317929b | ||
|   | 3cacf876c9 | ||
|   | d6247dd4ec | ||
|   | 4f0c49f1c4 | ||
|   | 30455e8b01 | ||
|   | 60adb94463 | ||
|   | a02fd5b588 | ||
|   | 39ce080318 | ||
|   | f53abd2f07 | ||
|   | 5b0ae0271b | ||
|   | ec2efd8c62 | ||
|   | 146daea513 | ||
|   | 5ab67faacb | ||
|   | 4213d37857 | ||
|   | 0192922910 | ||
|   | d2b88e9f84 | ||
|   | a32c4aca92 | ||
|   | 91d41336a7 | ||
|   | d73d790612 | ||
|   | af0fed6669 | ||
|   | a24c13b902 | ||
|   | c44c6a8d88 | ||
|   | 5f62a68e71 | ||
|   | 5af90fee46 | ||
|   | b17566f113 | ||
|   | 29edea050b | ||
|   | 7ceb646e90 | ||
|   | 0ff39e4d10 | ||
|   | 1e146c94bd | ||
|   | 8a0da04807 | ||
|   | 9e7a847cce | ||
|   | 63d3f20e51 | ||
|   | 817e3fbb05 | ||
|   | 263e96aba2 | ||
|   | 0379376fd8 | ||
|   | de7efb50c2 | ||
|   | 400f8dc2d8 | ||
|   | b2b63be798 | ||
|   | c9aba893de | ||
|   | 1ac4cdcf4d | ||
|   | 08a0fef18a | ||
|   | 6f54c170ab | ||
|   | d3b4c7bec4 | ||
|   | f8dfe1ea57 | ||
|   | ce5f8bab44 | ||
|   | 59cf70f8f2 | ||
|   | 561975f435 | ||
|   | eae6fea830 | ||
|   | 2673c2b5b2 | ||
|   | 3c17f3a836 | ||
|   | 0890154e16 | ||
|   | 0877824875 | ||
|   | 60bd5999b0 | ||
|   | d0ec60fa01 | ||
|   | e7a70a4acc | ||
|   | 85cb49e8e1 | ||
|   | 3f00a6e5e3 | ||
|   | 35e18a2e09 | ||
|   | 8ae2ae3b5c | ||
|   | 27c5f2aede | ||
|   | 34a69aa0b2 | ||
|   | 72fc903f4a | ||
|   | 4f04992de8 | ||
|   | 1b147494d4 | ||
|   | b535a0b44e | ||
|   | 6c2271584c | ||
|   | 1002b28c95 | ||
|   | dfded7bc9d | ||
|   | 36fde9ede5 | ||
|   | 6b4ac1b960 | ||
|   | cc141ba02f | ||
|   | 8fc931a61b | ||
|   | 0b6cf54508 | ||
|   | ff12163176 | ||
|   | 6a8a0bbd6b | ||
|   | f8ebffac65 | ||
|   | e58f4c0bdf | ||
|   | f450ff278d | ||
|   | 566fd893f4 | ||
|   | 30ab46999c | ||
|   | 0320f9d5b5 | ||
|   | ad7c9ed123 | ||
|   | 25acdba344 | ||
|   | 786059802b | ||
|   | 0ae708114b | ||
|   | fbeaabb841 | ||
|   | 98bef605a7 | ||
|   | 37a0e48b46 | ||
|   | fea1a66aba | ||
|   | 0ffdb51f95 | ||
|   | 4e596629fd | ||
|   | 61281dd226 | ||
|   | 61d1f2180f | ||
|   | 3bcf941205 | ||
|   | 1746c9d331 | ||
|   | 58c31c5353 | ||
|   | e872719ef1 | 
| @@ -45,14 +45,13 @@ before_build: | ||||
|   - CALL "C:\Program Files (x86)\Microsoft Visual Studio\2017\Community\VC\Auxiliary\Build\vcvars32.bat" | ||||
|   - SET PATH=%PATH%;c:\qbt\qt5_32\bin;%CACHE_DIR%\jom; | ||||
|   # setup project | ||||
|   - COPY /Y "%CACHE_DIR%\conf.pri" "%REPO_DIR%" | ||||
|   - COPY /Y "%CACHE_DIR%\winconf.pri" "%REPO_DIR%" | ||||
|   - COPY /Y "%CACHE_DIR%\winconf-msvc.pri" "%REPO_DIR%" | ||||
|   # workarounds | ||||
|   - MKLINK /J "c:\qbt\base" "%CACHE_DIR%\base" | ||||
|  | ||||
| build_script: | ||||
|   - cd "%REPO_DIR%" | ||||
|   # scan only as lupdate is prone to hang | ||||
|   - lupdate -extensions c,cpp,h,hpp,ui . | ||||
|   - qmake qbittorrent.pro && cd src && qmake src.pro | ||||
|   - jom -j2 -f Makefile.Release | ||||
|  | ||||
|   | ||||
							
								
								
									
										2
									
								
								.github/ISSUE_TEMPLATE.md
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								.github/ISSUE_TEMPLATE.md
									
									
									
									
										vendored
									
									
								
							| @@ -3,7 +3,7 @@ | ||||
| ### qBittorrent version and Operating System | ||||
| (type here) | ||||
|  | ||||
| ### If on linux, libtorrent-rasterbar and Qt version | ||||
| ### If on linux, libtorrent and Qt version | ||||
| (type here) | ||||
|  | ||||
| ### What is the problem | ||||
|   | ||||
							
								
								
									
										6
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										6
									
								
								.gitignore
									
									
									
									
										vendored
									
									
								
							| @@ -4,7 +4,6 @@ src/qbittorrent | ||||
| src/qbittorrent-nox | ||||
| src/release | ||||
| src/debug | ||||
| CMakeLists.txt.user* | ||||
| qbittorrent.pro.user* | ||||
| conf.pri | ||||
| Makefile* | ||||
| @@ -23,7 +22,6 @@ qrc_*.cpp | ||||
| ui_*.h | ||||
| *.moc | ||||
| src/lang/qbittorrent_*.qm | ||||
| src/webui/www/translations/webui_*.qm | ||||
| .DS_Store | ||||
| .qmake.stash | ||||
| src/qbittorrent.app | ||||
| @@ -36,7 +34,3 @@ config.status | ||||
| src/icons/qbt-theme/build-icons/node_modules/ | ||||
| src/icons/skin/build-icons/node_modules/ | ||||
| src/icons/skin/build-icons/icons/*.png | ||||
|  | ||||
| # Web UI tools | ||||
| node_modules | ||||
| package-lock.json | ||||
|   | ||||
							
								
								
									
										240
									
								
								.travis.yml
									
									
									
									
									
								
							
							
						
						
									
										240
									
								
								.travis.yml
									
									
									
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										12
									
								
								.tx/config
									
									
									
									
									
								
							
							
						
						
									
										12
									
								
								.tx/config
									
									
									
									
									
								
							| @@ -10,18 +10,10 @@ type = QT | ||||
| minimum_perc = 23 | ||||
| mode = developer | ||||
|  | ||||
|  | ||||
| [qbittorrent.qbittorrentdesktop_master] | ||||
| source_file = dist/unix/org.qbittorrent.qBittorrent.desktop | ||||
| source_file = src/icons/qBittorrent.desktop | ||||
| source_lang = en | ||||
| type = DESKTOP | ||||
| minimum_perc = 23 | ||||
| mode = developer | ||||
|  | ||||
| [qbittorrent.qbittorrent_webui] | ||||
| file_filter = src/webui/www/translations/webui_<lang>.ts | ||||
| lang_map = pt: pt_PT | ||||
| source_file = src/webui/www/translations/webui_en.ts | ||||
| source_lang = en | ||||
| type = QT | ||||
| minimum_perc = 23 | ||||
| mode = developer | ||||
|   | ||||
| @@ -1,10 +1,5 @@ | ||||
| cmake_minimum_required(VERSION 3.9 FATAL_ERROR) | ||||
|  | ||||
| message(AUTHOR_WARNING "If the build fails, please try the autotools/qmake method.") | ||||
|  | ||||
| if(POLICY CMP0074) | ||||
|     cmake_policy(SET CMP0074 NEW) | ||||
| endif() | ||||
| cmake_minimum_required(VERSION 3.5) | ||||
| cmake_policy(VERSION 3.5) | ||||
|  | ||||
| list(APPEND CMAKE_MODULE_PATH ${CMAKE_CURRENT_SOURCE_DIR}/cmake/Modules) | ||||
| include(FunctionReadVersion) | ||||
| @@ -30,31 +25,32 @@ add_definitions(-DQBT_VERSION_BUILD=${VER_BUILD}) | ||||
| add_definitions(-DQBT_VERSION="v${PROJECT_VERSION}") | ||||
| add_definitions(-DQBT_VERSION_2="${PROJECT_VERSION}") | ||||
|  | ||||
| include(GNUInstallDirs) | ||||
| include(FeatureSummary) | ||||
|  | ||||
| # version requirements | ||||
| set(requiredBoostVersion 1.40) | ||||
| set(requiredQtVersion 5.9.0) | ||||
| set(requiredOpensslVersion 1.0) | ||||
| set(requiredLibtorrentVersion 1.1.10) | ||||
| if (UNIX AND NOT APPLE) | ||||
|     include(GNUInstallDirs) | ||||
| endif (UNIX AND NOT APPLE) | ||||
|  | ||||
| if(WIN32) | ||||
|     include(winconf) | ||||
| endif(WIN32) | ||||
|  | ||||
| # we need options here, because they are used not only in "src" subdir, but in the "dist" dir too | ||||
| include(CMakeDependentOption) | ||||
|  | ||||
| # we need options here, at the top level, because they are used not only in "src" subdir, but in the "dist" dir too | ||||
| include(CompileFeature) | ||||
| option(SYSTEM_QTSINGLEAPPLICATION | ||||
|     "Use the system qtsingleapplication library or shipped one otherwise") | ||||
|  | ||||
| option(GUI "Allows to disable GUI for headless running. Disables QtDBus and the GeoIP Database" ON) | ||||
|  | ||||
| option(WEBUI "Allows to disable the WebUI." ON) | ||||
|  | ||||
| if (WIN32) | ||||
|     option(STACKTRACE_WIN "") | ||||
| else (WIN32) | ||||
|     cmake_dependent_option(SYSTEMD "Install the systemd service file (headless only)" OFF | ||||
|         "NOT GUI" OFF) | ||||
|     cmake_dependent_option(DBUS "Enable use of QtDBus (GUI only)" ON "GUI" OFF) | ||||
| endif(WIN32) | ||||
|  | ||||
| optional_compile_definitions(COUNTRIES_RESOLUTION FEATURE DESCRIPTION "Enable resolving peers IP addresses to countries" | ||||
|     DEFAULT ON DISABLED DISABLE_COUNTRIES_RESOLUTION) | ||||
| optional_compile_definitions(STACKTRACE FEATURE DESCRIPTION "Enable stacktraces" | ||||
|     DEFAULT ON ENABLED STACKTRACE) | ||||
| optional_compile_definitions(WEBUI FEATURE DESCRIPTION "Enables built-in HTTP server for headless use" | ||||
|     DEFAULT ON DISABLED DISABLE_WEBUI) | ||||
|  | ||||
| add_subdirectory(src) | ||||
| add_subdirectory(dist) | ||||
|  | ||||
| feature_summary(DESCRIPTION "\nConfiguration results:" WHAT ALL) | ||||
|   | ||||
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										242
									
								
								CONTRIBUTING.md
									
									
									
									
									
								
							
							
						
						
									
										242
									
								
								CONTRIBUTING.md
									
									
									
									
									
								
							| @@ -1,221 +1,35 @@ | ||||
| # How to contribute to qBittorrent | ||||
| # Filing an issue | ||||
|  | ||||
| ### Must read | ||||
| * If you aren't sure, you can ask on the [**forum**](http://forum.qbittorrent.org) or read our [**wiki**](http://wiki.qbittorrent.org) first. | ||||
| * Do a quick **search**. Others might already reported the issue. | ||||
| * Write in **English**! | ||||
| * Provide **version** information: (You can find version numbers at menu `Help -> About -> Libraries`) | ||||
|   ``` | ||||
|   qBittorrent: | ||||
|   Qt: | ||||
|   libtorrent: | ||||
|   boost: | ||||
|   OS version: | ||||
|   ``` | ||||
| * Provide **steps** to reproduce the problem, it will be easier to pinpoint the fault. | ||||
| * **Screenshots**! A screenshot is worth a thousand words. just upload it. [(How?)](https://help.github.com/articles/file-attachments-on-issues-and-pull-requests) | ||||
|  | ||||
| ### Good to know | ||||
| * **Be patient**. The dev team is small and resource limited. Devs finding their free time, analyzing the problem and fixing the issue, it all takes time. :clock3: | ||||
| * If you can code, why not become a **contributor** by fixing the issue and open a pull request? :wink: | ||||
| * Harsh words or threats won't help your situation. What's worse, your complain will (very likely) to be **ignored**. :fearful: | ||||
|  | ||||
| There are three main ways to contribute to the project. | ||||
| Read the respective section to find out more. | ||||
|  | ||||
| ### Table Of Contents | ||||
|  | ||||
| *   **[Bug reporting etiquette](#bug-reporting-etiquette)** | ||||
|  | ||||
|  | ||||
| *   **[Submitting an issue/bug report](#submitting-an-issuebug-report)** | ||||
|     *   [What is an actual bug report?](#what-is-an-actual-bug-report) | ||||
|     *   [Before submitting a bug report](#before-submitting-a-bug-report) | ||||
|     *   [Steps to ensure a good bug report](#steps-to-ensure-a-good-bug-report) | ||||
|  | ||||
|  | ||||
| *   **[Suggesting enhancements/feature requests](#suggesting-enhancementsfeature-requests)** | ||||
|     *   [Before submitting an enhancement/feature request](#before-submitting-an-enhancementfeature-request) | ||||
|     *   [Steps to ensure a good enhancement/feature suggestion](#steps-to-ensure-a-good-enhancementfeature-suggestion) | ||||
|  | ||||
|  | ||||
| *   **[Opening a pull request](#opening-a-pull-request)** | ||||
|     *   [Must read](#must-read) | ||||
|     *   [Good to know](#good-to-know) | ||||
|  | ||||
| # Bug reporting etiquette | ||||
|  | ||||
| *   Issues, pull requests, and comments must always be in **English.** | ||||
|  | ||||
| *   This project is supported by volunteers, do not expect "customer support"-style interaction. | ||||
|  | ||||
| *   **Be patient.** The development team is small and resource limited. Developers and contributors take from their free time to analyze the problem and fix the issue. :clock3: | ||||
|  | ||||
| *   Harsh words or threats won't help your situation. What's worse, your complain will (very likely) be **ignored.** :fearful: | ||||
|  | ||||
| # Submitting an issue/bug report | ||||
|  | ||||
| This section guides you through submitting an issue/bug report for qBittorrent. | ||||
|  | ||||
| Following these guidelines helps maintainers and the community understand your report, reproduce the behavior, and find related reports. | ||||
|  | ||||
| Make sure to follow these rules carefully when submitting a bug report. Failure to do so will result in the issue being closed. | ||||
|  | ||||
| ## What is an actual bug report? | ||||
|  | ||||
| Developers and contributors are not supposed to deal with issues for which little to no investigation to find the actual cause of a purported issue was made by the reporter. | ||||
|  | ||||
| Positive contributions are those which are reported with efforts to find the actual cause of an issue, or at the very least efforts were made to narrow it as much as possible. | ||||
|  | ||||
| Requiring people to investigate as much as possible before opening an issue will more than likely avoid burdening the project with invalid issues or issues unrelated to qBittorrent. | ||||
|  | ||||
| The following are _not_ bug reports. **Check the [wiki][wiki-url], [forum][forum-url] or other places for help and support for issues like these**: | ||||
|  | ||||
| -   Explanation of qBittorrent options (see [wiki][wiki-url]). | ||||
| -   Help with WebUI setup. | ||||
| -   Help with embedded tracker setup. | ||||
| -   Help about BitTorrent in general. | ||||
| -   Issues with specific search plugins. | ||||
| -   Asking for specific builds of qBittorrent other than the current one. You can install older releases at your own risk or for regression testing purposes. Previous Windows and macOS builds are available [here][builds-url]. | ||||
|     -   If you want older Linux builds, you will have to compile them yourself from the corresponding commits, or ask someone on the [forum][forum-url] to do it for you. | ||||
| -   Possibly others. Read on and use common sense. | ||||
|  | ||||
| The issue tracker is for provable issues only: You will have to make the case that the issue is really with qBittorrent and not something else on your side. | ||||
|  | ||||
| To make a case means to provide detailed steps so that anybody can reproduce the issue. | ||||
| Be sure to rule out that the issue is not caused by something specific on your side. | ||||
|  | ||||
| Issue reports for bugs that apparently aren't easily reproducible or that you can't figure out what triggers it even though you tried are OK. | ||||
|  | ||||
| Any issue opened without effort to provide the required details for developers, contributors or anybody else to reproduce the problem will be closed as invalid. | ||||
| For example: | ||||
| -   Crash reports with just a stack trace. | ||||
| -   Speculated performance issues that do not come with actual profiling data + analysis supporting the claim. | ||||
|  | ||||
| ## Before submitting a bug report | ||||
|  | ||||
| -   **Do some basic troubleshooting (examples)**: | ||||
|     -   Restart qBittorrent. | ||||
|     -   Restart your PC. | ||||
|     -   Update your OS (e.g. Windows updates). | ||||
|     -   Update your network card drivers. | ||||
|     -   Fully reinstall qBittorrent. | ||||
|     -   etc... | ||||
| -   Make sure the problem is not caused by anti-virus or other program messing with your files. | ||||
| -   Check if you can reproduce the problem in the latest version of qBittorrent. | ||||
| -   **Check [forum][forum-url] and [wiki][wiki-url].** You might be able to find the cause of the problem and fix things yourself. | ||||
| -   **Check if the issue exists already in the issue tracker.** | ||||
|     -   If it does and the issue is still open, add a comment to the existing issue instead of opening a new one. | ||||
|     -   If you find a Closed issue that seems like it is the same thing that you're experiencing, open a new issue and include a link to the original issue in the body of your new one. | ||||
| -   If the issue is with the search functionality: | ||||
|     -   **Make sure you have [`python`][python-url] installed correctly (remember the search functionality requires a working python installation).** | ||||
|     -   Make sure it is in fact a problem with the search functionality itself, and not a problem with the plugins. If something does not work properly with the search functionality, the first step is to rule out search plugin-related issues. | ||||
|         -   For search plugin issues, report on the respective search plugin support page, or at [qbittorrent/search-plugins][search-plugins-url]. | ||||
|  | ||||
| ## Steps to ensure a good bug report | ||||
|  | ||||
| **Follow these guidelines** in order to provide as much useful information as possible right away. Not all of them are applicable to all issues, but you are expected to follow most of these steps (use common sense). | ||||
| Otherwise, we've noticed that a lot of your time (and the developers') gets thrown away on exchanging back and forth to get this information. | ||||
|  | ||||
| *   Use a **clear and descriptive title** for the issue to identify the problem. | ||||
|  | ||||
| *   Post only **one specific issue per submission.** | ||||
|  | ||||
| *   **Fill out the issue template properly.** | ||||
|  | ||||
| -   **Make sure you are using qBittorrent on a supported platform.** Do not submit issues which can only be reproduced on beta/unsupported releases of supported operating systems (e.g. Windows 10 Insider, Ubuntu 12.04 LTS, etc). | ||||
| These are unstable/unsupported platforms, and in all likelihood, whatever the issue is, it is not related to qBittorrent. | ||||
|  | ||||
| *   **Specify the OS you're using, its version and architecture.** | ||||
|     *   Examples: Windows 8.1 32-bit, Linux Mint 17.1 64-bit, Windows 10 Fall creators Update 64-bit, etc. | ||||
|  | ||||
|  | ||||
| *   **Report only if you run into the issue with an official stable release, a beta release, or with the most recent upstream changes (in this last case specify the specific commit you are on).** (beta testing is encouraged :smile:). We do not provide support for bugs on unofficial Windows builds. | ||||
|  | ||||
| *   **Specify the version of qBittorrent** you are using, as well as its **architecture** (x86 or x64) and its **libraries' versions** (Help -> About -> Libraries). | ||||
|  | ||||
| *   Specify **how you installed**: | ||||
|     -   Linux: either from the PPA, your distribution's repositories, or compiled from source, or even possibly third-party repositories. | ||||
|     -   Windows: either from the installer, or compiled from source, or even possibly third-party repositories. | ||||
|     -   macOS: either from the installer, or compiled from source, or even possibly third-party repositories. | ||||
|  | ||||
|  | ||||
| *   **Describe the exact steps which reproduce the problem in as many details as possible.** | ||||
|     -   For example, start by explaining how you started qBittorrent, e.g. was it via the terminal? Desktop icon? Did you start it as root or normal user? | ||||
|     -   **When listing steps, don't just say what you did, but explain how you did it.** | ||||
|         -   For example, if you added a torrent for download, did you do so via a `.torrent` file or via a magnet link? If it was with a torrent file did you do so by dragging the torrent file from the file manager to the transfer list, or did you use the "Add Torrent File" in the Top Bar? | ||||
|     -   Describe the behavior you observed after following the steps and point out what exactly is the problem with that behavior; this is what we'll be looking for after executing the steps. | ||||
|  | ||||
|  | ||||
| *   **Explain which behavior you expected to see instead** and why. | ||||
|  | ||||
| *   Use **screenshots/animated GIFs to help describe the issue** whenever appropriate [(How?)][attachments-howto-url]. | ||||
|  | ||||
| *   If the problem wasn't triggered by a specific action, describe what you were doing before the problem happened. | ||||
|  | ||||
| *   **If you are reporting that qBittorrent crashes**, include the stack trace in the report; include it in a code block, a file attachment, or put it in a gist and provide link to that gist. | ||||
|  | ||||
| *   **For performance-related issues**, include as much profiling data as you can (resource usage graphs, etc). | ||||
|  | ||||
| *   Paste the **qBittorrent log** (or put the contents of the log in a gist and provide a link to the gist). The log can be viewed in the GUI (View -> Log -> tick all boxes). If you can't do that, the file is at: | ||||
|     -   Linux: `~/.local/share/data/qBittorrent/logs/qBittorrent.log` | ||||
|     -   Windows: `%LocalAppData%\qBittorrent\logs` | ||||
|     -   macOS: `~/Library/Application Support/qBittorrent/qBittorrent.log` | ||||
|  | ||||
|  | ||||
| *   **Do NOT post comments like "+1" or "me too!"** without providing new relevant info on the issue. Using the built-in reactions is OK though. Remember that you can use the "subscribe" button to receive notifications of that report without having to comment first. | ||||
|  | ||||
| *   If there seems to be an **issue with specific torrent files/magnet links**: | ||||
|     -   Don't post private `.torrent` files/magnet links, or ones that point to copyrighted content. If you are willing, offer to email a link or the `.torrent` file itself to whoever developer is debugging it and requests it. | ||||
|     -   Make sure you can't reproduce the problem with another client, to rule out the possibility that the issue is with the `.torrent` file/magnet link itself. | ||||
|  | ||||
|  | ||||
| *   A screenshot, transcription or file upload of any of **qBittorrent's preferences that differ from the defaults.** Please include everything different from the defaults whether or not it seems relevant to your issue. | ||||
|  | ||||
| *   **Attachment rules**: | ||||
|     -   Short logs and error messages can be pasted as quotes/code whenever small enough; otherwise make a gist with the contents and post the link to the gist. | ||||
|     -   Avoid linking/attaching impractical file formats such as PDFs/Word documents with images. If you want to post an image, just post the image. | ||||
|  | ||||
| ### Provide more context by answering these questions (if applicable): | ||||
|  | ||||
| -   Can you **reliably reproduce the issue?** If not, provide details about how often the problem happens and under which conditions it normally happens (e.g. only happens with extremely large torrents/only happens after qBittorrent is open for more than 2 days/etc...) | ||||
|  | ||||
| -   Did the problem start happening recently (e.g. after updating to a new version of qBittorrent) or was this always a problem? | ||||
|  | ||||
| -   If the problem started happening recently, can you reproduce the problem in an older version of qBittorrent? | ||||
|  | ||||
| -   Are you saving files locally (in a disk in your machine), or are you saving them remotely (e.g. network drives)? | ||||
|  | ||||
| -   Are you using qBittorrent with multiple monitors? If so, can you reproduce the problem when you use a single monitor? | ||||
|  | ||||
| Good read: [How to Report Bugs Effectively][howto-report-bugs-url] | ||||
|  | ||||
| # Suggesting enhancements/feature requests | ||||
|  | ||||
| This section guides you through submitting an enhancement suggestion for qBittorrent, including completely new features and minor improvements to existing functionality. | ||||
|  | ||||
| Following these guidelines helps maintainers and the community understand your suggestion and find related suggestions. | ||||
|  | ||||
| ## Before submitting an enhancement/feature request | ||||
|  | ||||
| *   Check the [wiki][wiki-url] and [forum][forum-url] for tips — you might discover that the enhancement is already available. | ||||
| *   Most importantly, check if you're using the latest version of qBittorrent and if you can get the desired behavior by changing qBittorrent's settings. | ||||
| *   Check in the [releases][releases-url] page or on the [forum][forum-url], see if there's already a alpha/beta version with that enhancement. | ||||
| *   Perform a cursory search to see if the enhancement has already been suggested. If it has, add a comment to the existing issue instead of opening a new one. | ||||
|  | ||||
| ## Steps to ensure a good enhancement/feature suggestion | ||||
|  | ||||
| -   Specify which version of qBittorrent you're using. | ||||
| -   Specify the name and version of the OS you're using. | ||||
| -   Provide a step-by-step description of the suggested enhancement in as many details as possible. | ||||
| -   Describe the current behavior and explain which behavior you expected to see instead and why. | ||||
| -   Include screenshots and animated GIFs which help you demonstrate the steps or point out the part of qBittorrent which the suggestion is related to. | ||||
| -   If this enhancement exists in other BitTorrent clients, list those clients. | ||||
|  | ||||
| # Opening a pull request | ||||
|  | ||||
| ### Must read | ||||
| *   Read our [**coding guidelines**][coding-guidelines-url]. There are some scripts to help you: [uncrustify script][uncrustify-script-url], [astyle script][astyle-script-url], [(related thread)][coding-guidelines-thread-url]. | ||||
| *   Keep the title **short** and provide a **clear** description about what your pull request does. | ||||
| *   Provide **screenshots** for UI related changes. | ||||
| *   Keep your git commit history **clean** and **precise.** Refer to the section about "Git commit messages" in the [**coding guidelines**][coding-guidelines-url]. | ||||
| *   If your commit fixes a reported issue (for example #4134), add the following message to the commit `Closes #4134.`. Example [here][commit-message-fix-issue-example-url]. | ||||
| * Read our [**coding guidelines**](https://github.com/qbittorrent/qBittorrent/blob/master/CODING_GUIDELINES.md). There are some scripts to help you: [uncrustify script](https://raw.githubusercontent.com/qbittorrent/qBittorrent/master/uncrustify.cfg), [astyle script](https://gist.github.com/Chocobo1/539cee860d1eef0acfa6), [(related thread)](https://github.com/qbittorrent/qBittorrent/issues/2192). | ||||
| * Keep the title **short** and provide a **clear** description about what your pull request does. | ||||
| * Provide **screenshots** for UI related changes. | ||||
| * Keep your git commit history **clean** and **precise**. Commits like `xxx fixup` should not appear. | ||||
| * If your commit fix a reported issue (for example #4134), add the following message to the commit `Closes #4134.`. Example [here](https://github.com/qbittorrent/qBittorrent/commit/a74bac20c4e8de9776bf9bb77fdc7526135d1988). | ||||
|  | ||||
| ### Good to know | ||||
| *   **Search** pull request history! Others might have already implemented your idea and it is waiting to be merged (or got rejected already). Save your precious time by doing a search first. | ||||
| *   When resolving merge conflicts, do `git rebase <target_branch_name>`, don't do `git pull`. Then you can start fixing the conflicts. Here is a good explanation: [link][merging-vs-rebasing-url]. | ||||
|  | ||||
| [astyle-script-url]: https://gist.github.com/Chocobo1/539cee860d1eef0acfa6 | ||||
| [attachments-howto-url]: https://help.github.com/articles/file-attachments-on-issues-and-pull-requests | ||||
| [coding-guidelines-url]: https://github.com/qbittorrent/qBittorrent/blob/master/CODING_GUIDELINES.md | ||||
| [coding-guidelines-thread-url]: https://github.com/qbittorrent/qBittorrent/issues/2192 | ||||
| [commit-message-fix-issue-example-url]: https://github.com/qbittorrent/qBittorrent/commit/c07cd440cd46345297debb47cb260f8688975f50 | ||||
| [forum-url]: http://forum.qbittorrent.org/ | ||||
| [howto-report-bugs-url]: https://www.chiark.greenend.org.uk/~sgtatham/bugs.html | ||||
| [merging-vs-rebasing-url]: https://www.atlassian.com/git/tutorials/merging-vs-rebasing | ||||
| [python-url]: https://www.python.org/ | ||||
| [releases-url]: https://github.com/qbittorrent/qBittorrent/releases | ||||
| [search-plugins-url]: https://github.com/qbittorrent/search-plugins | ||||
| [uncrustify-script-url]: https://raw.githubusercontent.com/qbittorrent/qBittorrent/master/uncrustify.cfg | ||||
| [wiki-url]: https://github.com/qbittorrent/qBittorrent/wiki | ||||
| [builds-url]: https://sourceforge.net/projects/qbittorrent/files/ | ||||
| * **Search** pull request history! Others might already implemented your idea and is waiting to be merged (or got rejected already). Save your precious time by doing a search first. | ||||
| * When resolving merge conflicts, do `git rebase <target_branch_name>`, don't do `git pull`. Then you can start fixing the conflicts. Here is a good explanation: [link](https://www.atlassian.com/git/tutorials/merging-vs-rebasing). | ||||
|   | ||||
							
								
								
									
										65
									
								
								INSTALL
									
									
									
									
									
								
							
							
						
						
									
										65
									
								
								INSTALL
									
									
									
									
									
								
							| @@ -1,43 +1,54 @@ | ||||
| qBittorrent - A BitTorrent client in C++ / Qt | ||||
| qBittorrent - A BitTorrent client in C++ / Qt4 | ||||
| ------------------------------------------ | ||||
|  | ||||
| 1) Install these dependencies: | ||||
|  | ||||
|   - Boost >= 1.40 | ||||
|  | ||||
|   - libtorrent-rasterbar >= 1.1.10 (by Arvid Norberg) | ||||
|       * https://www.libtorrent.org/ | ||||
|       * Be careful: another library (the one used by rTorrent) uses a similar name | ||||
|  | ||||
|   - OpenSSL >= 1.0 | ||||
|  | ||||
|   - Qt >= 5.9.0 | ||||
|  | ||||
|   - zlib >= 1.2.5.2 | ||||
|  | ||||
|   - pkg-config (compile-time only) | ||||
|  | ||||
|   - Python >= 2.7.9 / 3.3.0 (optional, runtime only) | ||||
|       * Required by the internal search engine | ||||
|  | ||||
| 2a) Compile and install qBittorrent with Qt graphical interface | ||||
| 1) Compile and install qBittorrent with Qt4 Graphical Interface | ||||
|  | ||||
|   $ ./configure | ||||
|   $ make && make install | ||||
|   $ qbittorrent | ||||
|  | ||||
|   will install and execute qBittorrent. | ||||
|   will install and execute qBittorrent hopefully without any problems. | ||||
|  | ||||
| 2b) Compile and install qBittorrent without Qt graphical interface | ||||
|   Dependencies: | ||||
|     - Qt >= 4.6.0 (libqtgui, libqtcore, libqtnetwork, libqtxml, libqtdbus/optional) | ||||
|  | ||||
|     - pkg-config executable | ||||
|  | ||||
|     - libtorrent-rasterbar by Arvid Norberg (>= 1.0.6) | ||||
|         -> http://www.libtorrent.net | ||||
|         Be careful: another library (the one used by rTorrent) uses a similar name. | ||||
|  | ||||
|     - libboost >= 1.35.x (libboost-system) | ||||
|  | ||||
|     - python >= 2.3 (needed by search engine) | ||||
|         * Run time only dependency | ||||
|  | ||||
|     - geoip-database (optional) | ||||
|         * If qBittorrent cannot find this database, it will try to resolve countries using the Internet but it will be a lot slower. | ||||
|         * Run time only dependency | ||||
|  | ||||
| 2) Compile and install qBittorrent without Qt4 Graphical interface | ||||
|  | ||||
|   $ ./configure --disable-gui | ||||
|   $ make && make install | ||||
|   $ qbittorrent-nox | ||||
|   $ qbittorrent | ||||
|  | ||||
|   will install and execute qBittorrent hopefully without any problems. | ||||
|  | ||||
|   Dependencies: | ||||
|     - Qt >= 4.4.0 (libqt-devel, libqtcore, libqtnetwork) | ||||
|  | ||||
|     - pkg-config executable | ||||
|  | ||||
|     - libtorrent-rasterbar by Arvid Norberg (>= v1.0.6) | ||||
|         -> http://www.libtorrent.net | ||||
|         Be careful: another library (the one used by rTorrent) uses a similar name. | ||||
|  | ||||
|     - libboost: libboost-filesystem, libboost-date-time, libboost-thread, libboost-serialization | ||||
|  | ||||
|   will install and execute qBittorrent. | ||||
|  | ||||
| DOCUMENTATION: | ||||
| Please note that there is a "Compilation" section at http://wiki.qbittorrent.org. | ||||
| Please note that there is a documentation with a "compiling howto" at http://wiki.qbittorrent.org. | ||||
|  | ||||
| ------------------------------------------ | ||||
| sledgehammer999 <sledgehammer999@qbittorrent.org> | ||||
| Christophe Dumez <chris@qbittorrent.org> | ||||
|   | ||||
| @@ -1,9 +1,9 @@ | ||||
| #! /bin/sh | ||||
| # Wrapper for compilers which do not understand '-c -o'. | ||||
|  | ||||
| scriptversion=2018-03-07.03; # UTC | ||||
| scriptversion=2012-10-14.11; # UTC | ||||
|  | ||||
| # Copyright (C) 1999-2018 Free Software Foundation, Inc. | ||||
| # Copyright (C) 1999-2014 Free Software Foundation, Inc. | ||||
| # Written by Tom Tromey <tromey@cygnus.com>. | ||||
| # | ||||
| # This program is free software; you can redistribute it and/or modify | ||||
| @@ -17,7 +17,7 @@ scriptversion=2018-03-07.03; # UTC | ||||
| # GNU General Public License for more details. | ||||
| # | ||||
| # You should have received a copy of the GNU General Public License | ||||
| # along with this program.  If not, see <https://www.gnu.org/licenses/>. | ||||
| # along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
|  | ||||
| # As a special exception to the GNU General Public License, if you | ||||
| # distribute this file as part of a program that contains a | ||||
| @@ -255,8 +255,7 @@ EOF | ||||
|     echo "compile $scriptversion" | ||||
|     exit $? | ||||
|     ;; | ||||
|   cl | *[/\\]cl | cl.exe | *[/\\]cl.exe | \ | ||||
|   icl | *[/\\]icl | icl.exe | *[/\\]icl.exe ) | ||||
|   cl | *[/\\]cl | cl.exe | *[/\\]cl.exe ) | ||||
|     func_cl_wrapper "$@"      # Doesn't return... | ||||
|     ;; | ||||
| esac | ||||
| @@ -340,9 +339,9 @@ exit $ret | ||||
| # Local Variables: | ||||
| # mode: shell-script | ||||
| # sh-indentation: 2 | ||||
| # eval: (add-hook 'before-save-hook 'time-stamp) | ||||
| # eval: (add-hook 'write-file-hooks 'time-stamp) | ||||
| # time-stamp-start: "scriptversion=" | ||||
| # time-stamp-format: "%:y-%02m-%02d.%02H" | ||||
| # time-stamp-time-zone: "UTC0" | ||||
| # time-stamp-time-zone: "UTC" | ||||
| # time-stamp-end: "; # UTC" | ||||
| # End: | ||||
|   | ||||
							
								
								
									
										966
									
								
								build-aux/config.guess
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										966
									
								
								build-aux/config.guess
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										2702
									
								
								build-aux/config.sub
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2702
									
								
								build-aux/config.sub
									
									
									
									
										vendored
									
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							| @@ -1,7 +1,7 @@ | ||||
| #!/bin/sh | ||||
| # install - install a program, script, or datafile | ||||
|  | ||||
| scriptversion=2018-03-11.20; # UTC | ||||
| scriptversion=2013-12-25.23; # UTC | ||||
|  | ||||
| # This originates from X11R5 (mit/util/scripts/install.sh), which was | ||||
| # later released in X11R6 (xc/config/util/install.sh) with the | ||||
| @@ -271,18 +271,15 @@ do | ||||
|     fi | ||||
|     dst=$dst_arg | ||||
|  | ||||
|     # If destination is a directory, append the input filename. | ||||
|     # If destination is a directory, append the input filename; won't work | ||||
|     # if double slashes aren't ignored. | ||||
|     if test -d "$dst"; then | ||||
|       if test "$is_target_a_directory" = never; then | ||||
|         echo "$0: $dst_arg: Is a directory" >&2 | ||||
|         exit 1 | ||||
|       fi | ||||
|       dstdir=$dst | ||||
|       dstbase=`basename "$src"` | ||||
|       case $dst in | ||||
| 	*/) dst=$dst$dstbase;; | ||||
| 	*)  dst=$dst/$dstbase;; | ||||
|       esac | ||||
|       dst=$dstdir/`basename "$src"` | ||||
|       dstdir_status=0 | ||||
|     else | ||||
|       dstdir=`dirname "$dst"` | ||||
| @@ -291,11 +288,6 @@ do | ||||
|     fi | ||||
|   fi | ||||
|  | ||||
|   case $dstdir in | ||||
|     */) dstdirslash=$dstdir;; | ||||
|     *)  dstdirslash=$dstdir/;; | ||||
|   esac | ||||
|  | ||||
|   obsolete_mkdir_used=false | ||||
|  | ||||
|   if test $dstdir_status != 0; then | ||||
| @@ -332,43 +324,34 @@ do | ||||
|             # is incompatible with FreeBSD 'install' when (umask & 300) != 0. | ||||
|             ;; | ||||
|           *) | ||||
|             # Note that $RANDOM variable is not portable (e.g. dash);  Use it | ||||
|             # here however when possible just to lower collision chance. | ||||
|             tmpdir=${TMPDIR-/tmp}/ins$RANDOM-$$ | ||||
|             trap 'ret=$?; rmdir "$tmpdir/d" "$tmpdir" 2>/dev/null; exit $ret' 0 | ||||
|  | ||||
|             trap 'ret=$?; rmdir "$tmpdir/a/b" "$tmpdir/a" "$tmpdir" 2>/dev/null; exit $ret' 0 | ||||
|  | ||||
|             # Because "mkdir -p" follows existing symlinks and we likely work | ||||
|             # directly in world-writeable /tmp, make sure that the '$tmpdir' | ||||
|             # directory is successfully created first before we actually test | ||||
|             # 'mkdir -p' feature. | ||||
|             if (umask $mkdir_umask && | ||||
|                 $mkdirprog $mkdir_mode "$tmpdir" && | ||||
|                 exec $mkdirprog $mkdir_mode -p -- "$tmpdir/a/b") >/dev/null 2>&1 | ||||
|                 exec $mkdirprog $mkdir_mode -p -- "$tmpdir/d") >/dev/null 2>&1 | ||||
|             then | ||||
|               if test -z "$dir_arg" || { | ||||
|                    # Check for POSIX incompatibilities with -m. | ||||
|                    # HP-UX 11.23 and IRIX 6.5 mkdir -m -p sets group- or | ||||
|                    # other-writable bit of parent directory when it shouldn't. | ||||
|                    # FreeBSD 6.1 mkdir -m -p sets mode of existing directory. | ||||
|                    test_tmpdir="$tmpdir/a" | ||||
|                    ls_ld_tmpdir=`ls -ld "$test_tmpdir"` | ||||
|                    ls_ld_tmpdir=`ls -ld "$tmpdir"` | ||||
|                    case $ls_ld_tmpdir in | ||||
|                      d????-?r-*) different_mode=700;; | ||||
|                      d????-?--*) different_mode=755;; | ||||
|                      *) false;; | ||||
|                    esac && | ||||
|                    $mkdirprog -m$different_mode -p -- "$test_tmpdir" && { | ||||
|                      ls_ld_tmpdir_1=`ls -ld "$test_tmpdir"` | ||||
|                    $mkdirprog -m$different_mode -p -- "$tmpdir" && { | ||||
|                      ls_ld_tmpdir_1=`ls -ld "$tmpdir"` | ||||
|                      test "$ls_ld_tmpdir" = "$ls_ld_tmpdir_1" | ||||
|                    } | ||||
|                  } | ||||
|               then posix_mkdir=: | ||||
|               fi | ||||
|               rmdir "$tmpdir/a/b" "$tmpdir/a" "$tmpdir" | ||||
|               rmdir "$tmpdir/d" "$tmpdir" | ||||
|             else | ||||
|               # Remove any dirs left behind by ancient mkdir implementations. | ||||
|               rmdir ./$mkdir_mode ./-p ./-- "$tmpdir" 2>/dev/null | ||||
|               rmdir ./$mkdir_mode ./-p ./-- 2>/dev/null | ||||
|             fi | ||||
|             trap '' 0;; | ||||
|         esac;; | ||||
| @@ -444,8 +427,8 @@ do | ||||
|   else | ||||
|  | ||||
|     # Make a couple of temp file names in the proper directory. | ||||
|     dsttmp=${dstdirslash}_inst.$$_ | ||||
|     rmtmp=${dstdirslash}_rm.$$_ | ||||
|     dsttmp=$dstdir/_inst.$$_ | ||||
|     rmtmp=$dstdir/_rm.$$_ | ||||
|  | ||||
|     # Trap to clean up those temp files at exit. | ||||
|     trap 'ret=$?; rm -f "$dsttmp" "$rmtmp" && exit $ret' 0 | ||||
| @@ -510,9 +493,9 @@ do | ||||
| done | ||||
|  | ||||
| # Local variables: | ||||
| # eval: (add-hook 'before-save-hook 'time-stamp) | ||||
| # eval: (add-hook 'write-file-hooks 'time-stamp) | ||||
| # time-stamp-start: "scriptversion=" | ||||
| # time-stamp-format: "%:y-%02m-%02d.%02H" | ||||
| # time-stamp-time-zone: "UTC0" | ||||
| # time-stamp-time-zone: "UTC" | ||||
| # time-stamp-end: "; # UTC" | ||||
| # End: | ||||
|   | ||||
| @@ -1,9 +1,9 @@ | ||||
| #! /bin/sh | ||||
| # Common wrapper for a few potentially missing GNU programs. | ||||
|  | ||||
| scriptversion=2018-03-07.03; # UTC | ||||
| scriptversion=2013-10-28.13; # UTC | ||||
|  | ||||
| # Copyright (C) 1996-2018 Free Software Foundation, Inc. | ||||
| # Copyright (C) 1996-2014 Free Software Foundation, Inc. | ||||
| # Originally written by Fran,cois Pinard <pinard@iro.umontreal.ca>, 1996. | ||||
|  | ||||
| # This program is free software; you can redistribute it and/or modify | ||||
| @@ -17,7 +17,7 @@ scriptversion=2018-03-07.03; # UTC | ||||
| # GNU General Public License for more details. | ||||
|  | ||||
| # You should have received a copy of the GNU General Public License | ||||
| # along with this program.  If not, see <https://www.gnu.org/licenses/>. | ||||
| # along with this program.  If not, see <http://www.gnu.org/licenses/>. | ||||
|  | ||||
| # As a special exception to the GNU General Public License, if you | ||||
| # distribute this file as part of a program that contains a | ||||
| @@ -101,9 +101,9 @@ else | ||||
|   exit $st | ||||
| fi | ||||
|  | ||||
| perl_URL=https://www.perl.org/ | ||||
| flex_URL=https://github.com/westes/flex | ||||
| gnu_software_URL=https://www.gnu.org/software | ||||
| perl_URL=http://www.perl.org/ | ||||
| flex_URL=http://flex.sourceforge.net/ | ||||
| gnu_software_URL=http://www.gnu.org/software | ||||
|  | ||||
| program_details () | ||||
| { | ||||
| @@ -207,9 +207,9 @@ give_advice "$1" | sed -e '1s/^/WARNING: /' \ | ||||
| exit $st | ||||
|  | ||||
| # Local variables: | ||||
| # eval: (add-hook 'before-save-hook 'time-stamp) | ||||
| # eval: (add-hook 'write-file-hooks 'time-stamp) | ||||
| # time-stamp-start: "scriptversion=" | ||||
| # time-stamp-format: "%:y-%02m-%02d.%02H" | ||||
| # time-stamp-time-zone: "UTC0" | ||||
| # time-stamp-time-zone: "UTC" | ||||
| # time-stamp-end: "; # UTC" | ||||
| # End: | ||||
|   | ||||
| @@ -1,22 +0,0 @@ | ||||
| # Helper function for coupling add_feature_info(), option(), and add_definitions() | ||||
|  | ||||
| function(optional_compile_definitions _name) | ||||
|     set(options FEATURE) | ||||
|     set(oneValueArgs DESCRIPTION DEFAULT) | ||||
|     set(multiValueArgs ENABLED DISABLED) | ||||
|     cmake_parse_arguments(OCD "${options}" "${oneValueArgs}" "${multiValueArgs}" ${ARGN}) | ||||
|     option(${_name} "${OCD_DESCRIPTION}" ${OCD_DEFAULT}) | ||||
|     if (${${_name}}) | ||||
|         set_property(DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}" APPEND PROPERTY COMPILE_DEFINITIONS ${OCD_ENABLED}) | ||||
|     else() | ||||
|         set_property(DIRECTORY "${CMAKE_CURRENT_SOURCE_DIR}" APPEND PROPERTY COMPILE_DEFINITIONS ${OCD_DISABLED}) | ||||
|     endif() | ||||
|     if(${OCD_FEATURE}) | ||||
|         add_feature_info(${_name} ${_name} "${OCD_DESCRIPTION}") | ||||
|     endif() | ||||
| endfunction() | ||||
|  | ||||
| macro(feature_option _name _description _default) | ||||
|     option(${_name} "${_description}" ${_default}) | ||||
|     add_feature_info(${_name} ${_name} "${_description}") | ||||
| endmacro() | ||||
| @@ -38,9 +38,8 @@ else() | ||||
|         # libtorrent is very picky about those. Let's take a set of defaults and | ||||
|         # hope that they apply. If not, you the user are on your own. | ||||
|         set(LibtorrentRasterbar_DEFINITIONS | ||||
|             -DTORRENT_USE_LIBCRYPTO | ||||
|             # TODO: remove the following define as it is not used since OpenSSL >= 1.1 | ||||
|             -DTORRENT_USE_OPENSSL | ||||
|             -DTORRENT_DISABLE_GEO_IP | ||||
|             -DBOOST_ASIO_ENABLE_CANCELIO | ||||
|             -DUNICODE -D_UNICODE -D_FILE_OFFSET_BITS=64) | ||||
|     endif() | ||||
| @@ -48,7 +47,7 @@ else() | ||||
|     if(NOT LibtorrentRasterbar_USE_STATIC_LIBS) | ||||
|         list(APPEND LibtorrentRasterbar_DEFINITIONS | ||||
|             -DTORRENT_LINKING_SHARED | ||||
|             -DBOOST_SYSTEM_DYN_LINK) | ||||
|             -DBOOST_SYSTEM_DYN_LINK -DBOOST_CHRONO_DYN_LINK) | ||||
|     endif() | ||||
| endif() | ||||
|  | ||||
| @@ -100,7 +99,6 @@ list(FIND LibtorrentRasterbar_DEFINITIONS -DTORRENT_USE_OPENSSL LibtorrentRaster | ||||
| if(LibtorrentRasterbar_ENCRYPTION_INDEX GREATER -1) | ||||
|     find_package(OpenSSL REQUIRED) | ||||
|     set(LibtorrentRasterbar_LIBRARIES ${LibtorrentRasterbar_LIBRARIES} OpenSSL::SSL OpenSSL::Crypto) | ||||
|     list(APPEND LibtorrentRasterbar_INCLUDE_DIRS "${OPENSSL_INCLUDE_DIR}") | ||||
|     set(LibtorrentRasterbar_OPENSSL_ENABLED ON) | ||||
| endif() | ||||
|  | ||||
| @@ -115,10 +113,10 @@ mark_as_advanced(LibtorrentRasterbar_INCLUDE_DIR LibtorrentRasterbar_LIBRARY | ||||
|     LibtorrentRasterbar_ORIG_CMAKE_FIND_LIBRARY_SUFFIXES | ||||
|     LibtorrentRasterbar_ENCRYPTION_INDEX) | ||||
|  | ||||
| if (LibtorrentRasterbar_FOUND AND NOT TARGET LibtorrentRasterbar::torrent-rasterbar) | ||||
|     add_library(LibtorrentRasterbar::torrent-rasterbar UNKNOWN IMPORTED) | ||||
| if (LibtorrentRasterbar_FOUND AND NOT TARGET LibtorrentRasterbar::LibTorrent) | ||||
|     add_library(LibtorrentRasterbar::LibTorrent UNKNOWN IMPORTED) | ||||
|  | ||||
|     set_target_properties(LibtorrentRasterbar::torrent-rasterbar PROPERTIES | ||||
|     set_target_properties(LibtorrentRasterbar::LibTorrent PROPERTIES | ||||
|         IMPORTED_LINK_INTERFACE_LANGUAGES "CXX" | ||||
|         IMPORTED_LOCATION "${LibtorrentRasterbar_LIBRARY}" | ||||
|         INTERFACE_INCLUDE_DIRECTORIES "${LibtorrentRasterbar_INCLUDE_DIRS}" | ||||
|   | ||||
							
								
								
									
										94
									
								
								cmake/Modules/FindQtSingleApplication.cmake
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										94
									
								
								cmake/Modules/FindQtSingleApplication.cmake
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,94 @@ | ||||
| # - Try to find the QtSingleApplication includes and library | ||||
| # which defines | ||||
| # | ||||
| # QTSINGLEAPPLICATION_FOUND - system has QtSingleApplication | ||||
| # QTSINGLEAPPLICATION_INCLUDE_DIR - where to find header QtSingleApplication | ||||
| # QTSINGLEAPPLICATION_LIBRARIES - the libraries to link against to use QtSingleApplication | ||||
| # QTSINGLEAPPLICATION_LIBRARY - where to find the QtSingleApplication library (not for general use) | ||||
|  | ||||
| # copyright (c) 2013 TI_Eugene ti.eugene@gmail.com | ||||
| # | ||||
| # Redistribution and use is allowed according to the terms of the FreeBSD license. | ||||
|  | ||||
| SET(QTSINGLEAPPLICATION_FOUND FALSE) | ||||
|  | ||||
| IF(QT4_FOUND) | ||||
|     message(STATUS "Looking for Qt4 single application library") | ||||
|     FIND_PATH(QTSINGLEAPPLICATION_INCLUDE_DIR QtSingleApplication | ||||
|                 # standard locations | ||||
|                 /usr/include | ||||
|                 /usr/include/QtSolutions | ||||
|                 # qt4 location except mac's frameworks | ||||
|                 "${QT_INCLUDE_DIR}/QtSolutions" | ||||
|                 # mac's frameworks | ||||
|                 ${FRAMEWORK_INCLUDE_DIR}/QtSolutions | ||||
|     ) | ||||
|  | ||||
|     SET(QTSINGLEAPPLICATION_NAMES ${QTSINGLEAPPLICATION_NAMES} | ||||
|         QtSolutions_SingleApplication-2.6 libQtSolutions_SingleApplication-2.6) | ||||
|     FIND_LIBRARY(QTSINGLEAPPLICATION_LIBRARY | ||||
|         NAMES ${QTSINGLEAPPLICATION_NAMES} | ||||
|         PATHS ${QT_LIBRARY_DIR} | ||||
|     ) | ||||
| ELSEIF(Qt5Core_FOUND) | ||||
|     message(STATUS "Looking for Qt5 single application library") | ||||
|     FOREACH(TOP_INCLUDE_PATH in ${Qt5Core_INCLUDE_DIRS} ${FRAMEWORK_INCLUDE_DIR}) | ||||
|         FIND_PATH(QTSINGLEAPPLICATION_INCLUDE_DIR QtSingleApplication ${TOP_INCLUDE_PATH}/QtSolutions) | ||||
|  | ||||
|         IF(QTSINGLEAPPLICATION_INCLUDE_DIR) | ||||
|             BREAK() | ||||
|         ENDIF() | ||||
|     ENDFOREACH() | ||||
|  | ||||
|     SET(QTSINGLEAPPLICATION_NAMES ${QTSINGLEAPPLICATION_NAMES} | ||||
|         Qt5Solutions_SingleApplication-2.6 libQt5Solutions_SingleApplication-2.6 | ||||
|         QtSolutions_SingleApplication-2.6 libQtSolutions_SingleApplication-2.6) | ||||
|     GET_TARGET_PROPERTY(_QT5_CORELIBRARY Qt5::Core LOCATION) | ||||
|     GET_FILENAME_COMPONENT(_QT5_CORELIBRARYPATH ${_QT5_CORELIBRARY} PATH) | ||||
|  | ||||
|     FIND_LIBRARY(QTSINGLEAPPLICATION_LIBRARY | ||||
|         NAMES ${QTSINGLEAPPLICATION_NAMES} | ||||
|         PATHS ${_QT5_CORELIBRARYPATH} | ||||
|     ) | ||||
| ENDIF() | ||||
|  | ||||
| IF (QTSINGLEAPPLICATION_LIBRARY AND QTSINGLEAPPLICATION_INCLUDE_DIR) | ||||
|  | ||||
|     SET(QTSINGLEAPPLICATION_LIBRARIES ${QTSINGLEAPPLICATION_LIBRARY}) | ||||
|     SET(QTSINGLEAPPLICATION_FOUND TRUE) | ||||
|  | ||||
|     IF (CYGWIN) | ||||
|         IF(BUILD_SHARED_LIBS) | ||||
|         # No need to define QTSINGLEAPPLICATION_USE_DLL here, because it's default for Cygwin. | ||||
|         ELSE(BUILD_SHARED_LIBS) | ||||
|         SET (QTSINGLEAPPLICATION_DEFINITIONS -DQTSINGLEAPPLICATION_STATIC) | ||||
|         ENDIF(BUILD_SHARED_LIBS) | ||||
|     ENDIF (CYGWIN) | ||||
|  | ||||
| ENDIF (QTSINGLEAPPLICATION_LIBRARY AND QTSINGLEAPPLICATION_INCLUDE_DIR) | ||||
|  | ||||
| IF (QTSINGLEAPPLICATION_FOUND) | ||||
|   IF (NOT QtSingleApplication_FIND_QUIETLY) | ||||
|     MESSAGE(STATUS "Found QtSingleApplication: ${QTSINGLEAPPLICATION_LIBRARY}") | ||||
|     MESSAGE(STATUS "         includes: ${QTSINGLEAPPLICATION_INCLUDE_DIR}") | ||||
|   ENDIF (NOT QtSingleApplication_FIND_QUIETLY) | ||||
| ELSE (QTSINGLEAPPLICATION_FOUND) | ||||
|   IF (QtSingleApplication_FIND_REQUIRED) | ||||
|     MESSAGE(FATAL_ERROR "Could not find QtSingleApplication library") | ||||
|   ENDIF (QtSingleApplication_FIND_REQUIRED) | ||||
| ENDIF (QTSINGLEAPPLICATION_FOUND) | ||||
|  | ||||
| MARK_AS_ADVANCED(QTSINGLEAPPLICATION_INCLUDE_DIR QTSINGLEAPPLICATION_LIBRARY) | ||||
|  | ||||
| if(NOT TARGET QtSingleApplication::QtSingleApplication) | ||||
|     add_library(QtSingleApplication::QtSingleApplication UNKNOWN IMPORTED) | ||||
|     set_target_properties(QtSingleApplication::QtSingleApplication PROPERTIES | ||||
|         INTERFACE_INCLUDE_DIRECTORIES "${QTSINGLEAPPLICATION_INCLUDE_DIR}" | ||||
|         INTERFACE_SYSTEM_INCLUDE_DIRECTORIES "${QTSINGLEAPPLICATION_INCLUDE_DIR}" | ||||
|     ) | ||||
|     if(EXISTS "${QTSINGLEAPPLICATION_LIBRARY}") | ||||
|     set_target_properties(QtSingleApplication::QtSingleApplication PROPERTIES | ||||
|         IMPORTED_LINK_INTERFACE_LANGUAGES "CXX" | ||||
|         IMPORTED_LOCATION "${QTSINGLEAPPLICATION_LIBRARY}") | ||||
|     endif() | ||||
| endif(NOT TARGET QtSingleApplication::QtSingleApplication) | ||||
| @@ -1,5 +1,5 @@ | ||||
| # - macro similar to target_link_libraries, which links Qt components | ||||
| # names of the components are passed in Qt4/Qt5 agnostic way (Core, DBus, Xml...) | ||||
| # names of the components are pased in Qt4/Qt5 agnostic way (Core, DBus, Xml...) | ||||
| # and the macro links Qt4 ones if QT4_FOUND is set or Qt5 ones if not | ||||
|  | ||||
| macro (target_link_qt_components target) | ||||
|   | ||||
| @@ -10,18 +10,19 @@ macro(qbt_set_compiler_options) | ||||
|     if("${CMAKE_CXX_COMPILER_ID}" STREQUAL "GNU" OR "${CMAKE_CXX_COMPILER_ID}" STREQUAL "Clang") | ||||
|         #-Wshadow -Wconversion ? | ||||
|         set(_GCC_COMMON_C_AND_CXX_FLAGS "-Wall -Wextra" | ||||
|             "-Wcast-qual -Wcast-align" | ||||
|             "-Winvalid-pch -Wno-long-long" | ||||
|             #"-fstack-protector-all" | ||||
|             #"-Werror -Wno-error=deprecated-declarations" | ||||
|             "-Wfloat-equal -Wcast-qual -Wcast-align" | ||||
|             "-Wsign-conversion -Winvalid-pch -Werror=return-type -Wno-long-long" | ||||
| #			-fstack-protector-all | ||||
|             "-Werror -Wno-error=deprecated-declarations" | ||||
|         ) | ||||
|         set(_GCC_COMMON_CXX_FLAGS "-fexceptions -frtti" | ||||
|             "-Woverloaded-virtual -Wold-style-cast" | ||||
|             "-Wnon-virtual-dtor" | ||||
|             #"-Weffc++" | ||||
|             #"-Werror -Wno-error=cpp" | ||||
|         set (_GCC_COMMON_CXX_FLAGS  "-fexceptions -frtti" | ||||
|             "-Woverloaded-virtual -Wold-style-cast -Wstrict-null-sentinel" | ||||
|             "-Wnon-virtual-dtor -Wfloat-equal -Wcast-qual -Wcast-align" | ||||
|             "-Werror=overloaded-virtual" | ||||
|     # 		"-Weffc++" | ||||
|             "-Werror -Wno-error=cpp" | ||||
|             # we should modify code to make these ones obsolete | ||||
|             #"-Wno-error=sign-conversion -Wno-error=float-equal" | ||||
|             "-Wno-error=sign-conversion -Wno-error=float-equal" | ||||
|         ) | ||||
|  | ||||
|         if ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "GNU" AND CMAKE_CXX_COMPILER_VERSION VERSION_LESS 4.9) | ||||
| @@ -53,50 +54,36 @@ macro(qbt_set_compiler_options) | ||||
|             endif(${GLIBC_VERSION}) | ||||
|         endif (CMAKE_SYSTEM_NAME MATCHES Linux) | ||||
|  | ||||
|         if ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "Clang") | ||||
|             # Clang 5.0 still doesn't support -Wstrict-null-sentinel | ||||
|             check_cxx_compiler_flag(-Wstrict-null-sentinel _STRICT_NULL_SENTINEL_IS_SUPPORTED) | ||||
|             if (_STRICT_NULL_SENTINEL_IS_SUPPORTED) | ||||
|                 list(APPEND _GCC_COMMON_CXX_FLAGS "-Wstrict-null-sentinel") | ||||
|             endif (_STRICT_NULL_SENTINEL_IS_SUPPORTED) | ||||
|  | ||||
|             # Code should be improved to render this not needed | ||||
|             list(APPEND _GCC_COMMON_CXX_FLAGS "-Wno-error=unused-function") | ||||
|         else ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "Clang") | ||||
|             # GCC supports it | ||||
|             list(APPEND _GCC_COMMON_CXX_FLAGS "-Wstrict-null-sentinel") | ||||
|         endif ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "Clang") | ||||
|  | ||||
|         string(REPLACE ";" " " _GCC_COMMON_C_AND_CXX_FLAGS_STRING "${_GCC_COMMON_C_AND_CXX_FLAGS}") | ||||
|         string(REPLACE ";" " " _GCC_COMMON_CXX_FLAGS_STRING "${_GCC_COMMON_CXX_FLAGS}") | ||||
|  | ||||
|         string(APPEND CMAKE_C_FLAGS " ${_GCC_COMMON_C_AND_CXX_FLAGS_STRING}") | ||||
|         string(APPEND CMAKE_CXX_FLAGS " ${_GCC_COMMON_C_AND_CXX_FLAGS_STRING} ${_GCC_COMMON_CXX_FLAGS_STRING}") | ||||
|  | ||||
|         set(QBT_ADDITONAL_FLAGS "${_GCC_COMMON_C_AND_CXX_FLAGS_STRING}" CACHE STRING | ||||
|             "Additional qBittorent compile flags" FORCE) | ||||
|         set(QBT_ADDITONAL_CXX_FLAGS "${_GCC_COMMON_CXX_FLAGS_STRING}" CACHE STRING | ||||
|             "Additional qBittorent C++ compile flags" FORCE) | ||||
|  | ||||
|         # check whether we can enable -Og optimization for debug build | ||||
|         # also let's enable -march=native for debug builds | ||||
|         check_cxx_compiler_flag(-Og _DEBUG_OPTIMIZATION_LEVEL_IS_SUPPORTED) | ||||
|  | ||||
|         if (_DEBUG_OPTIMIZATION_LEVEL_IS_SUPPORTED) | ||||
|             set(QBT_ADDITONAL_FLAGS "-Og -g3 -march=native -pipe" CACHE STRING | ||||
|                 "Additional qBittorent compile flags") | ||||
|             set(QBT_ADDITONAL_CXX_FLAGS "-Og -g3 -march=native -pipe" CACHE STRING | ||||
|                 "Additional qBittorent C++ compile flags") | ||||
|             string(APPEND CMAKE_C_FLAGS_DEBUG " -Og -g3 -march=native -pipe" ) | ||||
|             string(APPEND CMAKE_CXX_FLAGS_DEBUG " -Og -g3 -march=native -pipe" ) | ||||
|         else(_DEBUG_OPTIMIZATION_LEVEL_IS_SUPPORTED) | ||||
|             set(QBT_ADDITONAL_FLAGS "-O0 -g3 -march=native -pipe" CACHE STRING | ||||
|                 "Additional qBittorent compile flags") | ||||
|             set(QBT_ADDITONAL_CXX_FLAGS "-O0 -g3 -march=native -pipe" CACHE STRING | ||||
|                 "Additional qBittorent C++ compile flags") | ||||
|             string(APPEND CMAKE_C_FLAGS_DEBUG " -O0 -g3 -march=native -pipe" ) | ||||
|             string(APPEND CMAKE_CXX_FLAGS_DEBUG " -O0 -g3 -march=native -pipe" ) | ||||
|         endif (_DEBUG_OPTIMIZATION_LEVEL_IS_SUPPORTED) | ||||
|     endif ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "GNU" OR "${CMAKE_CXX_COMPILER_ID}" STREQUAL "Clang") | ||||
|  | ||||
|     if ("${CMAKE_CXX_COMPILER_ID}" STREQUAL "MSVC") | ||||
|         set(QBT_ADDITONAL_FLAGS "-wd4290 -wd4275 -wd4251 /W4" CACHE STRING "Additional qBittorent compile flags") | ||||
|         string(APPEND CMAKE_C_FLAGS " ${QBT_ADDITONAL_FLAGS}") | ||||
|         string(APPEND CMAKE_CXX_FLAGS " ${QBT_ADDITONAL_FLAGS}") | ||||
|     endif () | ||||
|  | ||||
|     string(APPEND CMAKE_C_FLAGS " ${QBT_ADDITONAL_FLAGS}") | ||||
|     string(APPEND CMAKE_CXX_FLAGS " ${QBT_ADDITONAL_FLAGS}") | ||||
|  | ||||
| # endif (NOT QBT_ADDITONAL_FLAGS) | ||||
| endmacro(qbt_set_compiler_options) | ||||
|  | ||||
|   | ||||
| @@ -1,17 +1,16 @@ | ||||
| # a helper function which appends source to the target | ||||
| # sources file names are relative to the the target source dir | ||||
| # a helper function which appends source to the main qBt target | ||||
| # sources file names are relative to the the ${qBittorrent_SOURCE_DIR} | ||||
|  | ||||
| function (qbt_target_sources _target _scope) | ||||
|     get_target_property(targetSourceDir ${_target} SOURCE_DIR) | ||||
|     set(sourcesRelative "") | ||||
|     foreach(source IN ITEMS ${ARGN}) | ||||
|         if(IS_ABSOLUTE "${source}") | ||||
|             set(sourceAbsolutePath "${source}") | ||||
| function (qbt_target_sources) | ||||
|     set (_sources_rel "") | ||||
|     foreach (_source IN ITEMS ${ARGN}) | ||||
|         if (IS_ABSOLUTE "${_source}") | ||||
|             set(source_abs "${_source}") | ||||
|         else() | ||||
|             get_filename_component(sourceAbsolutePath "${source}" ABSOLUTE) | ||||
|             get_filename_component(_source_abs "${_source}" ABSOLUTE) | ||||
|         endif() | ||||
|         file(RELATIVE_PATH sourceRelativePath "${targetSourceDir}" "${sourceAbsolutePath}") | ||||
|         list(APPEND sourcesRelative "${sourceRelativePath}") | ||||
|         file (RELATIVE_PATH _source_rel "${qbt_executable_SOURCE_DIR}" "${_source_abs}") | ||||
|         list (APPEND _sources_rel "${_source_rel}") | ||||
|     endforeach() | ||||
|     target_sources(${_target} ${_scope} "${sourcesRelative}") | ||||
| endfunction(qbt_target_sources) | ||||
|     target_sources (qBittorrent PRIVATE "${_sources_rel}") | ||||
| endfunction (qbt_target_sources) | ||||
|   | ||||
| @@ -1,48 +0,0 @@ | ||||
| # macros to handle translation files | ||||
|  | ||||
| # qbt_add_translations(<target> QRC_FILE <filename> TS_FILES <filenames>) | ||||
| # handles out of source builds for Qt resource files that include translations | ||||
| # The function generates translations out of the supplied list of .ts files in the build directory, | ||||
| # copies the .qrc file there, calls qt5_add_resources() adds its output to the target sources list. | ||||
| function(qbt_add_translations _target) | ||||
|     set(oneValueArgs QRC_FILE) | ||||
|     set(multiValueArgs TS_FILES) | ||||
|     cmake_parse_arguments(QBT_TR "" "${oneValueArgs}" "${multiValueArgs}" ${ARGN}) | ||||
|  | ||||
|     get_target_property(_binaryDir ${_target} BINARY_DIR) | ||||
|  | ||||
|     if (NOT QBT_TR_QRC_FILE) | ||||
|         message(FATAL_ERROR "QRC file is empty") | ||||
|     endif() | ||||
|     if (NOT QBT_TR_TS_FILES) | ||||
|         message(FATAL_ERROR "TS_FILES files are empty") | ||||
|     endif() | ||||
|  | ||||
|     if(IS_ABSOLUTE "${QBT_TR_QRC_FILE}") | ||||
|         file(RELATIVE_PATH _qrcToTs "${CMAKE_CURRENT_SOURCE_DIR}" "${QBT_TR_QRC_FILE}") | ||||
|     else() | ||||
|         set(_qrcToTs "${QBT_TR_QRC_FILE}") | ||||
|     endif() | ||||
|  | ||||
|     get_filename_component(_qrcToTsDir "${_qrcToTs}" DIRECTORY) | ||||
|  | ||||
|     get_filename_component(_qmFilesBinaryDir "${CMAKE_CURRENT_BINARY_DIR}/${_qrcToTsDir}" ABSOLUTE) | ||||
|     # to make qt5_add_translation() work as we need | ||||
|     set_source_files_properties(${QBT_TR_TS_FILES} PROPERTIES OUTPUT_LOCATION "${_qmFilesBinaryDir}") | ||||
|     qt5_add_translation(_qmFiles ${QBT_TR_TS_FILES}) | ||||
|  | ||||
|     set(_qrc_dest_dir "${_binaryDir}/${_qrcToTsDir}") | ||||
|     set(_qrc_dest_file "${_binaryDir}/${QBT_TR_QRC_FILE}") | ||||
|  | ||||
|     message(STATUS "copying ${QBT_TR_QRC_FILE} to ${_qrc_dest_dir}") | ||||
|     file(COPY ${QBT_TR_QRC_FILE} DESTINATION ${_qrc_dest_dir}) | ||||
|  | ||||
|     set_source_files_properties("${_qrc_dest_file}" PROPERTIES | ||||
|         GENERATED True | ||||
|         OBJECT_DEPENDS "${_qmFiles}") | ||||
|  | ||||
|     # With AUTORCC enabled rcc is ran by cmake before language files are generated, | ||||
|     # and thus we call rcc explicitly | ||||
|     qt5_add_resources(_resources "${_qrc_dest_file}") | ||||
|     target_sources(${_target} PRIVATE "${_resources}") | ||||
| endfunction() | ||||
| @@ -1,11 +1,14 @@ | ||||
| if (STACKTRACE_WIN) | ||||
|     if ("${WINXXBITS}" NOT STREQUAL "Win64") | ||||
|         add_compile_options(-fno-omit-frame-pointer) | ||||
|     endif ("${WINXXBITS}" NOT STREQUAL "Win64") | ||||
|     link_libraries(libdbghelp  -Wl,--export-all-symbols) | ||||
| endif (STACKTRACE_WIN) | ||||
|  | ||||
| if (("${CMAKE_BUILD_TYPE}" STREQUAL "Debug") OR ("${CMAKE_BUILD_TYPE}" STREQUAL "RelWithDebInfo")) | ||||
|     link_libraries(-Wl,--dynamicbase) | ||||
| endif () | ||||
|  | ||||
| list(APPEND LibtorrentRasterbar_CUSTOM_DEFINITIONS | ||||
|     -D_FILE_OFFSET_BITS=64 | ||||
|     -D__USE_W32_SOCKETS) | ||||
|  | ||||
| # libraries from winconf.pri | ||||
| link_libraries(advapi32 iphlpapi ole32 shell32 user32 wsock32 ws2_32) | ||||
| endif() | ||||
|  | ||||
| # LIBS += libadvapi32 libshell32 libuser32 | ||||
| # LIBS += libcrypto.dll libssl.dll libwsock32 libws2_32 libz libiconv.dll | ||||
| # LIBS += libpowrprof | ||||
|   | ||||
| @@ -1,7 +1,21 @@ | ||||
| if (STACKTRACE_WIN) | ||||
|     if ("${WINXXBITS}" STREQUAL "Win64") | ||||
|         add_compile_options(-Zi) | ||||
|     else ("${WINXXBITS}" STREQUAL "Win64") | ||||
|         # i686 arch requires frame pointer preservation | ||||
|         add_compile_options(-Oy-) | ||||
|     endif ("${WINXXBITS}" STREQUAL "Win64") | ||||
|     link_libraries(dbghelp.lib) | ||||
| endif (STACKTRACE_WIN) | ||||
|  | ||||
| # Enable Wide characters | ||||
| add_definitions(-DTORRENT_USE_WPATH) | ||||
|  | ||||
| if (NOT QT5) | ||||
|     # Qt4 does not detect it itself | ||||
|     add_definitions(-DQ_COMPILER_INITIALIZER_LISTS) | ||||
| endif (NOT QT5) | ||||
|  | ||||
| include(MacroConfigureMSVCRuntime) | ||||
| set(MSVC_RUNTIME "dynamic") | ||||
| configure_msvc_runtime() | ||||
|  | ||||
| # libraries from winconf.pri | ||||
| link_libraries(advapi32 crypt32 Iphlpapi ole32 shell32 User32) | ||||
|  | ||||
|   | ||||
| @@ -2,51 +2,33 @@ | ||||
|  | ||||
| list(APPEND CMAKE_LIBRARY_PATH "$ENV{LIB}") | ||||
|  | ||||
| # We want to link with static version of | ||||
| # libtorrent | ||||
| set(LibtorrentRasterbar_USE_STATIC_LIBS True) | ||||
| set(LibtorrentRasterbar_CUSTOM_DEFINITIONS | ||||
|     -DBOOST_ASIO_DISABLE_CONNECTEX | ||||
|     -DBOOST_ALL_NO_LIB -DBOOST_ASIO_HASH_MAP_BUCKETS=1021 | ||||
|     -DBOOST_ASIO_SEPARATE_COMPILATION | ||||
|     -DBOOST_EXCEPTION_DISABLE | ||||
|     -DTORRENT_USE_LIBCRYPTO | ||||
|     # TODO: remove the following define as it is not used since OpenSSL >= 1.1 | ||||
|     -DBOOST_SYSTEM_STATIC_LINK=1 | ||||
|     -DTORRENT_USE_OPENSSL | ||||
|     # TODO: remove the following define as it is not used since libtorrent >= 1.2 | ||||
|     -DTORRENT_DISABLE_RESOLVE_COUNTRIES | ||||
| ) | ||||
|     -D__USE_W32_SOCKETS | ||||
|     -D_FILE_OFFSET_BITS=64) | ||||
|  | ||||
| set(LibtorrentRasterbar_CUSTOM_BOOST_DEPENDENCIES system) | ||||
|  | ||||
| # If you want to link with static version of libtorrent | ||||
| #set(LibtorrentRasterbar_USE_STATIC_LIBS True) | ||||
| #list(APPEND LibtorrentRasterbar_CUSTOM_DEFINITIONS | ||||
| #    -DBOOST_SYSTEM_STATIC_LINK=1) | ||||
|  | ||||
| # and boost | ||||
| #set(Boost_USE_STATIC_LIBS True) | ||||
| #set(Boost_USE_STATIC_RUNTIME True) | ||||
|  | ||||
| add_definitions( | ||||
|     -DNTDDI_VERSION=0x06010000 | ||||
|     -D_WIN32_WINNT=0x0601 | ||||
|     -D_WIN32_IE=0x0601 | ||||
|     -DUNICODE | ||||
| add_definitions(-DUNICODE | ||||
|     -D_UNICODE | ||||
|     -DWIN32 | ||||
|     -D_WIN32 | ||||
|     -DWIN32_LEAN_AND_MEAN | ||||
|     -DNTDDI_VERSION=0x05010000 | ||||
|     -D_WIN32_WINNT=0x0501 | ||||
|     -D_WIN32_IE=0x0501 | ||||
|     -D_CRT_SECURE_NO_DEPRECATE | ||||
|     -D_SCL_SECURE_NO_DEPRECATE | ||||
|     -DNOMINMAX | ||||
|     -DBOOST_ALL_NO_LIB | ||||
| ) | ||||
|  | ||||
| # Enable if libtorrent was built with this flag defined | ||||
| #list(APPEND LibtorrentRasterbar_CUSTOM_DEFINITIONS -DTORRENT_NO_DEPRECATE) | ||||
|  | ||||
| if (("${CMAKE_BUILD_TYPE}" STREQUAL "Debug") OR ("${CMAKE_BUILD_TYPE}" STREQUAL "RelWithDebInfo")) | ||||
|     list(APPEND LibtorrentRasterbar_CUSTOM_DEFINITIONS | ||||
|     -DTORRENT_DEBUG) | ||||
| else () | ||||
|     add_definitions(-DNDEBUG) | ||||
| endif () | ||||
| # and boost | ||||
| set(Boost_USE_STATIC_LIBS  True) | ||||
| # set(Boost_USE_STATIC_RUNTIME True) | ||||
|  | ||||
| # Here we assume that all required libraries are installed into the same prefix | ||||
| # with usual unix subdirectories (bin, lib, include) | ||||
| @@ -56,9 +38,17 @@ set(COMMON_INSTALL_PREFIX "c:/usr" CACHE PATH "Prefix used to install all the re | ||||
| list(APPEND CMAKE_SYSTEM_PREFIX_PATH "${COMMON_INSTALL_PREFIX}") | ||||
|  | ||||
| # If two version of Qt are installed, separate prefixes are needed most likely | ||||
| set(QT4_INSTALL_PREFIX "${COMMON_INSTALL_PREFIX}/lib/qt4" CACHE PATH "Prefix where Qt4 is installed") | ||||
| set(QT5_INSTALL_PREFIX "${COMMON_INSTALL_PREFIX}/lib/qt5" CACHE PATH "Prefix where Qt5 is installed") | ||||
|  | ||||
| # it is safe to set Qt dirs even if their files are directly in the prefix | ||||
| # Qt4 | ||||
| if(NOT QT5) | ||||
|     # for qt 4 we need qmake, Qt5 provides cmake config files | ||||
|     LIST(APPEND CMAKE_PROGRAM_PATH  "${QT4_INSTALL_PREFIX}/bin/") | ||||
| endif(NOT QT5) | ||||
|  | ||||
| # Qt5 | ||||
| set(Qt5_DIR "${QT5_INSTALL_PREFIX}/lib/cmake/Qt5") | ||||
|  | ||||
| # And now we can set specific values for the Boost and libtorrent libraries. | ||||
|   | ||||
| @@ -5,8 +5,6 @@ BINDIR = @EXPAND_BINDIR@ | ||||
| DATADIR = @EXPAND_DATADIR@ | ||||
| MANPREFIX = @EXPAND_MANDIR@ | ||||
|  | ||||
| QMAKE_CC = @QBT_CC@ | ||||
| QMAKE_CXX = @QBT_CXX@ | ||||
| QMAKE_CXXFLAGS += @QBT_CONF_EXTRA_CFLAGS@ | ||||
|  | ||||
| EXTERNAL_INCLUDES = @QBT_CONF_INCLUDES@ | ||||
|   | ||||
| @@ -35,24 +35,27 @@ LIBS += zlib.lib | ||||
| #LIBS += libcrypto libssl | ||||
| #LIBS += libz | ||||
|  | ||||
| DEFINES += NTDDI_VERSION=0x05010000 | ||||
| DEFINES += _WIN32_WINNT=0x0501 | ||||
| DEFINES += _WIN32_IE=0x0501 | ||||
|  | ||||
| # Disable to use Boost auto-linking | ||||
| DEFINES += BOOST_ALL_NO_LIB | ||||
| # Use one of the following options | ||||
| DEFINES += BOOST_SYSTEM_STATIC_LINK | ||||
| #DEFINES += BOOST_SYSTEM_DYN_LINK | ||||
| # Enable if encountered build error with boost version <= 1.59 | ||||
| #DEFINES += BOOST_NO_CXX11_RVALUE_REFERENCES | ||||
| # Boost 1.60+ defaults to Vista+ support. The define below enables XP support again. | ||||
| DEFINES += BOOST_USE_WINAPI_VERSION=0x0501 | ||||
| # Enable if building against libtorrent 1.0.x (RC_1_0) (static linking) | ||||
| #DEFINES += BOOST_ASIO_SEPARATE_COMPILATION | ||||
| # Enable if building against libtorrent 1.0.x (RC_1_0) (dynamic linking) | ||||
| #DEFINES += BOOST_ASIO_DYN_LINK | ||||
|  | ||||
| # Enable if libtorrent was built with this flag defined | ||||
| # Enable if building against libtorrent 1.1.x (RC_1_1) | ||||
| # built with this flag defined | ||||
| #DEFINES += TORRENT_NO_DEPRECATE | ||||
| # Enable if linking dynamically against libtorrent | ||||
| #DEFINES += TORRENT_LINKING_SHARED | ||||
|  | ||||
| # Enable stack trace support | ||||
| CONFIG += stacktrace | ||||
|  | ||||
| win32-msvc* { | ||||
|     QMAKE_CXXFLAGS += "/guard:cf" | ||||
|     QMAKE_LFLAGS += "/guard:cf" | ||||
|     QMAKE_LFLAGS_RELEASE += "/OPT:REF /OPT:ICF" | ||||
| } | ||||
| CONFIG += strace_win | ||||
|   | ||||
							
								
								
									
										134
									
								
								configure.ac
									
									
									
									
									
								
							
							
						
						
									
										134
									
								
								configure.ac
									
									
									
									
									
								
							| @@ -1,4 +1,4 @@ | ||||
| AC_INIT([qbittorrent], [v4.2.0], [bugs.qbittorrent.org], [], [https://www.qbittorrent.org/]) | ||||
| AC_INIT([qbittorrent], [v4.0.4], [bugs.qbittorrent.org], [], [https://www.qbittorrent.org/]) | ||||
| AC_CONFIG_AUX_DIR([build-aux]) | ||||
| AC_CONFIG_MACRO_DIR([m4]) | ||||
| AC_PROG_CC | ||||
| @@ -8,24 +8,22 @@ AC_LANG(C++) | ||||
| AC_CANONICAL_HOST | ||||
| AM_INIT_AUTOMAKE | ||||
|  | ||||
| # use compiler from env variables if available | ||||
| QBT_CC="$CC" | ||||
| QBT_CXX="$CXX" | ||||
|  | ||||
|  | ||||
| # Define --wth-* and --enable-* arguments | ||||
|  | ||||
| AC_ARG_WITH(qtsingleapplication, | ||||
|             [AS_HELP_STRING([--with-qtsingleapplication=@<:@system|shipped@:>@], | ||||
|                             [Use the shipped qtsingleapplication library or the system one (default=shipped)])], | ||||
|             [], | ||||
|             [with_qtsingleapplication=shipped]) | ||||
|  | ||||
| AC_ARG_ENABLE(debug, | ||||
|               [AS_HELP_STRING([--enable-debug], | ||||
|                               [Enable debug build])], | ||||
|               [], | ||||
|               [enable_debug=no]) | ||||
|  | ||||
| AC_ARG_ENABLE(stacktrace, | ||||
|               [AS_HELP_STRING([--enable-stacktrace], | ||||
|                               [Enable stacktrace feature (default=auto)])], | ||||
|               [], | ||||
|               [enable_stacktrace=auto]) | ||||
|  | ||||
| AC_ARG_ENABLE(gui, | ||||
|               [AS_HELP_STRING([--disable-gui], | ||||
|                               [Disable the GUI for headless running. Disables QtDBus and the GeoIP Database.])], | ||||
| @@ -82,23 +80,6 @@ AS_CASE(["x$enable_debug"], | ||||
|         [AC_MSG_RESULT([$enable_debug]) | ||||
|         AC_MSG_ERROR([Unknown option "$enable_debug". Use either "yes" or "no".])]) | ||||
|  | ||||
| AC_MSG_CHECKING([whether to enable the stacktrace feature]) | ||||
| AS_CASE(["x$enable_stacktrace"], | ||||
|         ["xno"], | ||||
|               [AC_MSG_RESULT([no]) | ||||
|               QBT_REMOVE_CONFIG="$QBT_REMOVE_CONFIG stacktrace"], | ||||
|         ["xyes"], | ||||
|                [AC_MSG_RESULT([yes]) | ||||
|                QBT_ADD_CONFIG="$QBT_ADD_CONFIG stacktrace"], | ||||
|         ["xauto"], | ||||
|                 [AC_COMPILE_IFELSE([AC_LANG_SOURCE([[#include <execinfo.h>]])], | ||||
|                 [AC_MSG_RESULT([yes]) | ||||
|                 QBT_ADD_CONFIG="$QBT_ADD_CONFIG stacktrace"], | ||||
|                 [AC_MSG_RESULT([no]) | ||||
|                 QBT_REMOVE_CONFIG="$QBT_REMOVE_CONFIG stacktrace"])], | ||||
|         [AC_MSG_RESULT([$enable_stacktrace]) | ||||
|         AC_MSG_ERROR([Unknown option "$enable_stacktrace". Use either "yes" or "no".])]) | ||||
|  | ||||
| AC_MSG_CHECKING([whether to enable the GUI]) | ||||
| AS_CASE(["x$enable_gui"], | ||||
|         ["xyes"], | ||||
| @@ -157,72 +138,38 @@ AS_CASE(["x$enable_qt_dbus"], | ||||
|         AC_MSG_ERROR([Unknown option "$enable_qt_dbus". Use either "yes" or "no".])]) | ||||
|  | ||||
|  | ||||
| AX_BOOST_BASE([1.40], | ||||
|               [AC_MSG_NOTICE([Boost CXXFLAGS: "$BOOST_CPPFLAGS"]) | ||||
|                AC_MSG_NOTICE([Boost LDFLAGS: "$BOOST_LDFLAGS"])], | ||||
| AX_BOOST_BASE([1.35], | ||||
|               [AC_MSG_NOTICE([Boost CPPFLAGS: "$BOOST_CPPFLAGS" | ||||
|                 Boost LDFLAGS: "$BOOST_LDFLAGS"])], | ||||
|               [AC_MSG_ERROR([Could not find Boost])]) | ||||
| CXXFLAGS="$BOOST_CPPFLAGS $CXXFLAGS" | ||||
| CPPFLAGS="$BOOST_CPPFLAGS $CPPFLAGS" | ||||
| LDFLAGS="$BOOST_LDFLAGS $LDFLAGS" | ||||
|  | ||||
| # add workaround for problematic boost version | ||||
| # taken from ax_boost_base.m4 | ||||
| m4_define([DETECT_BOOST_VERSION_PROGRAM], | ||||
|     [AC_LANG_PROGRAM([[#include <boost/version.hpp>]], | ||||
|                      [[(void) ((void)sizeof(char[1 - 2*!!((BOOST_VERSION) < ($1))]));]])]) | ||||
|  | ||||
| AC_COMPILE_IFELSE([DETECT_BOOST_VERSION_PROGRAM(106000)], [], | ||||
|     [QBT_ADD_DEFINES="$QBT_ADD_DEFINES BOOST_NO_CXX11_RVALUE_REFERENCES"]) | ||||
|  | ||||
| AX_BOOST_SYSTEM() | ||||
| AC_MSG_NOTICE([Boost.System LIB: "$BOOST_SYSTEM_LIB"]) | ||||
| LIBS="$BOOST_SYSTEM_LIB $LIBS" | ||||
|  | ||||
| PKG_CHECK_MODULES(libtorrent, | ||||
|                   [libtorrent-rasterbar >= 1.1.10], | ||||
|                   [CXXFLAGS="$libtorrent_CFLAGS $CXXFLAGS" | ||||
|                   LIBS="$libtorrent_LIBS $LIBS"]) | ||||
| AC_MSG_CHECKING([which qtsingleapplication to use]) | ||||
| AS_CASE(["x$with_qtsingleapplication"], | ||||
|         ["xshipped"], | ||||
|                    [AC_MSG_RESULT([shipped]) | ||||
|                    QBT_REMOVE_CONFIG="$QBT_REMOVE_CONFIG usesystemqtsingleapplication"], | ||||
|         ["xsystem"], | ||||
|                   [AC_MSG_RESULT([system]) | ||||
|                   QBT_ADD_CONFIG="$QBT_ADD_CONFIG usesystemqtsingleapplication"], | ||||
|         [AC_MSG_RESULT([$with_qtsingleapplication]) | ||||
|         AC_MSG_ERROR([Unknown option "$with_qtsingleapplication". Use either "system" or "shipped".])]) | ||||
|  | ||||
| PKG_CHECK_MODULES(openssl, | ||||
|                   [openssl >= 1.0], | ||||
|                   [CXXFLAGS="$openssl_CFLAGS $CXXFLAGS" | ||||
|                   LIBS="$openssl_LIBS $LIBS"]) | ||||
| PKG_CHECK_MODULES(libtorrent, | ||||
|                   [libtorrent-rasterbar >= 1.0.6], | ||||
|                   [CPPFLAGS="$libtorrent_CFLAGS $CPPFLAGS" | ||||
|                   LIBS="$libtorrent_LIBS $LIBS"]) | ||||
|  | ||||
| PKG_CHECK_MODULES(zlib, | ||||
|                  [zlib >= 1.2.5.2], | ||||
|                  [CXXFLAGS="$zlib_CFLAGS $CXXFLAGS" | ||||
|                  [CPPFLAGS="$zlib_CFLAGS $CPPFLAGS" | ||||
|                  LIBS="$zlib_LIBS $LIBS"]) | ||||
|  | ||||
| # Check if already in >= C++14 mode because of the flags returned by one of the above packages | ||||
| TMP_CXXFLAGS="$CXXFLAGS" | ||||
| CXXFLAGS="" | ||||
| AC_MSG_CHECKING([if compiler defaults to C++14 or later mode]) | ||||
| AC_COMPILE_IFELSE([DETECT_CPP14_PROGRAM()], | ||||
|                   [AC_MSG_RESULT([yes]) | ||||
|                    QBT_CXX14_FOUND="yes"], | ||||
|                   [AC_MSG_RESULT([no]) | ||||
|                    QBT_CXX14_FOUND="no"]) | ||||
|  | ||||
| # In case of no, check if the compiler can support at least C++14 | ||||
| # and if yes, enable it leaving a warning to the user | ||||
| AS_IF([test "x$QBT_CXX14_FOUND" = "xno"], | ||||
|       [AC_MSG_CHECKING([if compiler supports C++14]) | ||||
|        CXXFLAGS="-std=c++14" | ||||
|        AC_COMPILE_IFELSE([DETECT_CPP14_PROGRAM()], | ||||
|                         [AC_MSG_RESULT([yes]) | ||||
|                          AC_MSG_CHECKING([if C++14 is disabled by the set compiler flags]) | ||||
|                          # prepend the flag so it won't override conflicting user defined flags | ||||
|                          CXXFLAGS="-std=c++14 $TMP_CXXFLAGS" | ||||
|                          AC_COMPILE_IFELSE([DETECT_CPP14_PROGRAM()], | ||||
|                                            [AC_MSG_RESULT([no]) | ||||
|                                             QBT_ADD_CONFIG="$QBT_ADD_CONFIG c++14" | ||||
|                                             AC_MSG_WARN([C++14 mode is now force enabled. The C++ mode should match the mode that other libraries were built with, otherwise you'll likely get linking errors.])], | ||||
|                                            [AC_MSG_RESULT([yes]) | ||||
|                                             AC_MSG_ERROR([The compiler supports C++14 but the user or a dependency has explicitly enabled a lower mode.])])], | ||||
|                         [AC_MSG_RESULT([no]) | ||||
|                          AC_MSG_ERROR([A compiler supporting C++14 is required.])]) | ||||
|       ]) | ||||
| CXXFLAGS="$TMP_CXXFLAGS" | ||||
|  | ||||
| # These are required because autoconf doesn't expand these **particular** | ||||
| # vars automatically. And qmake cannot autoexpand them. | ||||
| AX_DEFINE_DIR([EXPAND_PREFIX], [prefix]) | ||||
| @@ -249,20 +196,18 @@ extract() { | ||||
|   for i in $string; do | ||||
|     case "$(echo "$i" | cut -c1)" in | ||||
|       '') ;; | ||||
|       D) QBT_CONF_DEFINES="$QBT_CONF_DEFINES $(echo $i | cut -c2-)";; | ||||
|       I) QBT_CONF_INCLUDES="$QBT_CONF_INCLUDES $(echo $i | cut -c2-)";; | ||||
|       *) QBT_CONF_EXTRA_CFLAGS="$QBT_CONF_EXTRA_CFLAGS -$i";; | ||||
|       D) QBT_CONF_DEFINES="$(echo $i | cut -c2-) $QBT_CONF_DEFINES";; | ||||
|       I) QBT_CONF_INCLUDES="$(echo $i | cut -c2-) $QBT_CONF_INCLUDES";; | ||||
|       *) QBT_CONF_EXTRA_CFLAGS="-$i $QBT_CONF_EXTRA_CFLAGS";; | ||||
|     esac | ||||
|   done | ||||
|   IFS=$SAVEIFS | ||||
| } | ||||
|  | ||||
| extract "$CFLAGS $CXXFLAGS" | ||||
| extract "$CFLAGS $CPPFLAGS $CXXFLAGS" | ||||
| QBT_ADD_DEFINES="$QBT_ADD_DEFINES $QBT_CONF_DEFINES" | ||||
|  | ||||
| # Substitute the values of these vars in conf.pri.in | ||||
| AC_SUBST(QBT_CC) | ||||
| AC_SUBST(QBT_CXX) | ||||
| AC_SUBST(QBT_CONF_INCLUDES) | ||||
| AC_SUBST(QBT_CONF_EXTRA_CFLAGS) | ||||
| AC_SUBST(QBT_ADD_CONFIG) | ||||
| @@ -274,14 +219,17 @@ AC_OUTPUT(conf.pri) | ||||
| AS_IF([test "x$enable_systemd" = "xyes"], | ||||
|       [AC_OUTPUT(dist/unix/systemd/qbittorrent-nox@.service)]) | ||||
|  | ||||
|  | ||||
|  | ||||
| AC_MSG_NOTICE([Running qmake to generate the makefile...]) | ||||
| TOPDIR="$(cd "$(dirname "$0")" && pwd)" | ||||
| $QT_QMAKE -r "$TOPDIR/qbittorrent.pro" "QMAKE_LRELEASE=$QMAKE_LRELEASE" | ||||
| qmake_ret="$?" | ||||
| CONFDIR="$( cd "$( dirname "$0" )" && pwd )" | ||||
|  | ||||
| $QT_QMAKE -r [$CONFDIR]/qbittorrent.pro "QMAKE_LRELEASE=$QMAKE_LRELEASE" | ||||
|  | ||||
| ret="$?" | ||||
|  | ||||
| AS_ECHO() | ||||
| AS_IF([test "x$qmake_ret" != "x0"], | ||||
|       [AC_MSG_ERROR([$QT_QMAKE failed to generate the makefile])]) | ||||
|  | ||||
| AC_MSG_NOTICE([Good, the configure finished.]) | ||||
| AS_IF([test "x$ret" = "x0"], | ||||
|       [AC_MSG_NOTICE([Good, your configure finished.])], | ||||
|       [AC_MSG_ERROR([Failed running $QT_QMAKE to generate the makefile])]) | ||||
| AS_ECHO() | ||||
|   | ||||
							
								
								
									
										2
									
								
								dist/CMakeLists.txt
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								dist/CMakeLists.txt
									
									
									
									
										vendored
									
									
								
							| @@ -1,5 +1,3 @@ | ||||
| find_package(Qt5Widgets ${requiredQtVersion}) # to conditionally install desktop-related files | ||||
|  | ||||
| if (APPLE) | ||||
|     add_subdirectory(mac) | ||||
| else (APPLE) | ||||
|   | ||||
							
								
								
									
										22
									
								
								dist/mac/Info.plist
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										22
									
								
								dist/mac/Info.plist
									
									
									
									
										vendored
									
									
								
							| @@ -2,10 +2,6 @@ | ||||
| <!DOCTYPE plist PUBLIC "-//Apple//DTD PLIST 1.0//EN" "http://www.apple.com/DTDs/PropertyList-1.0.dtd"> | ||||
| <plist version="1.0"> | ||||
| <dict> | ||||
| 	<key>CFBundleDevelopmentRegion</key> | ||||
| 	<string>en</string> | ||||
| 	<key>CFBundleDisplayName</key> | ||||
| 	<string>qBittorrent</string> | ||||
| 	<key>CFBundleDocumentTypes</key> | ||||
| 	<array> | ||||
| 		<dict> | ||||
| @@ -25,10 +21,6 @@ | ||||
| 			<array> | ||||
| 				<string>org.bittorrent.torrent</string> | ||||
| 			</array> | ||||
| 			<key>NSExportableTypes</key> | ||||
| 			<array> | ||||
| 				<string>org.bittorrent.torrent</string> | ||||
| 			</array> | ||||
| 			<key>LSIsAppleDefaultForType</key> | ||||
| 			<true/> | ||||
| 		</dict> | ||||
| @@ -36,8 +28,6 @@ | ||||
| 	<key>CFBundleURLTypes</key> | ||||
| 	<array> | ||||
| 		<dict> | ||||
| 			<key>CFBundleTypeRole</key> | ||||
| 			<string>Viewer</string> | ||||
| 			<key>CFBundleURLSchemes</key> | ||||
| 			<array> | ||||
| 				<string>magnet</string> | ||||
| @@ -55,19 +45,21 @@ | ||||
| 	<key>CFBundlePackageType</key> | ||||
| 	<string>APPL</string> | ||||
| 	<key>CFBundleShortVersionString</key> | ||||
| 	<string>4.2.0</string> | ||||
| 	<string>4.0.4</string> | ||||
| 	<key>CFBundleSignature</key> | ||||
| 	<string>qBit</string> | ||||
| 	<key>CFBundleExecutable</key> | ||||
| 	<string>@EXECUTABLE@</string> | ||||
| 	<key>CFBundleIdentifier</key> | ||||
| 	<string>org.qbittorrent.qBittorrent</string> | ||||
| 	<key>LSMinimumSystemVersion</key> | ||||
| 	<string>${MACOSX_DEPLOYMENT_TARGET}.0</string> | ||||
| 	<string>org.qbittorrent</string> | ||||
| 	<key>NSPrincipalClass</key> | ||||
| 	<string>NSApplication</string> | ||||
| 	<key>NSHighResolutionCapable</key> | ||||
| 	<string>True</string> | ||||
| 	<key>NSAppleScriptEnabled</key> | ||||
| 	<string>YES</string> | ||||
| 	<key>NSHumanReadableCopyright</key> | ||||
| 	<string>Copyright © 2006-2019 The qBittorrent project</string> | ||||
| 	<string>Copyright © 2006-2018 The qBittorrent project</string> | ||||
| 	<key>UTExportedTypeDeclarations</key> | ||||
| 	<array> | ||||
| 		<dict> | ||||
|   | ||||
							
								
								
									
										
											BIN
										
									
								
								dist/mac/qBitTorrentDocument.icns
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										
											BIN
										
									
								
								dist/mac/qBitTorrentDocument.icns
									
									
									
									
										vendored
									
									
								
							
										
											Binary file not shown.
										
									
								
							Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user