You've already forked qBittorrent
							
							
				mirror of
				https://github.com/qbittorrent/qBittorrent
				synced 2025-10-23 22:32:16 +02:00 
			
		
		
		
	Compare commits
	
		
			186 Commits
		
	
	
		
			release-5.
			...
			release-4.
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
|   | d1ebbcb35d | ||
|   | 2743d998a8 | ||
|   | dbbfbaff9f | ||
|   | 0be8439cf6 | ||
|   | 66982c5524 | ||
|   | 85af8547f7 | ||
|   | e26977ab2c | ||
|   | ec1cc783a6 | ||
|   | 03b00ec045 | ||
|   | 5e90156e9e | ||
|   | 052206efa1 | ||
|   | 305d73180b | ||
|   | 80000bf0fd | ||
|   | 06ebe756e8 | ||
|   | 5fa3d9f19c | ||
|   | 5b4c6d3665 | ||
|   | 77bd0f17d1 | ||
|   | 03a702cfbd | ||
|   | a932cd2ec1 | ||
|   | 8e5743380a | ||
|   | 8001eb0368 | ||
|   | f214dc88fc | ||
|   | 5cff5ab135 | ||
|   | 82ba154b64 | ||
|   | 4ea44bbd2b | ||
|   | a5e68a8725 | ||
|   | 70291014d1 | ||
|   | 1aabcfc30c | ||
|   | aba80e2b1c | ||
|   | be683fbcd3 | ||
|   | 2bcf09cfa5 | ||
|   | 697325af63 | ||
|   | c21bd77be5 | ||
|   | d5430adaaa | ||
|   | 9e99a0d3f5 | ||
|   | d088ab6f43 | ||
|   | 820d510c12 | ||
|   | 676847fcd0 | ||
|   | 0204630ee6 | ||
|   | b515c7eda4 | ||
|   | 73fcecac76 | ||
|   | a7b82ebcb5 | ||
|   | f8598b010d | ||
|   | 93779bcc4b | ||
|   | 938f5b9dd9 | ||
|   | 3b4d9f49d5 | ||
|   | 171c93af50 | ||
|   | 6f81e40106 | ||
|   | e19b5cb2ce | ||
|   | 2c69faca58 | ||
|   | 9272151d0a | ||
|   | d45ebf5a43 | ||
|   | 8074be7644 | ||
|   | c99ac99a99 | ||
|   | 976e2450ec | ||
|   | 7e4db8fafd | ||
|   | 115a409d92 | ||
|   | c203ab3d16 | ||
|   | 5dff96496d | ||
|   | f813935011 | ||
|   | 2be719449f | ||
|   | 2094c870d5 | ||
|   | 4fe93ae8b8 | ||
|   | fff1103cf4 | ||
|   | 8cede43a45 | ||
|   | 9b1fa3a5af | ||
|   | 409e73c074 | ||
|   | c893729d62 | ||
|   | 945466968c | ||
|   | 54f080b755 | ||
|   | bfad14d552 | ||
|   | 2972e1596d | ||
|   | 987d2aae88 | ||
|   | 4707d34fad | ||
|   | 2ffc09d097 | ||
|   | afa8d6bb8f | ||
|   | a37ead98e8 | ||
|   | c73cd8d618 | ||
|   | 800a3aa61e | ||
|   | ebd815be75 | ||
|   | ef669acf89 | ||
|   | ac6426eab1 | ||
|   | b107b745f2 | ||
|   | 3d851a448f | ||
|   | ce133f01aa | ||
|   | 492d378537 | ||
|   | 7ece484423 | ||
|   | be5ad63e21 | ||
|   | bdac8f8db8 | ||
|   | bb893e70c5 | ||
|   | 57ec9db532 | ||
|   | 0287481001 | ||
|   | 0167496ecb | ||
|   | d86cf193a0 | ||
|   | 246cad1108 | ||
|   | 23bf86a8a8 | ||
|   | 6ce4c885b9 | ||
|   | faf84e483a | ||
|   | 576004c840 | ||
|   | c93b05c293 | ||
|   | 55c3813fac | ||
|   | 725c6857be | ||
|   | 86767c9ab4 | ||
|   | 46aa631d2b | ||
|   | 7c61a937c9 | ||
|   | b8d65dcc45 | ||
|   | b9ab83eaf2 | ||
|   | 8b7b563992 | ||
|   | b813a878d7 | ||
|   | 54e486c389 | ||
|   | 12d0a3acc1 | ||
|   | 6ad2a13386 | ||
|   | 2a9c401db9 | ||
|   | ea5a29018f | ||
|   | c8d0a715e8 | ||
|   | 2cfc6514ab | ||
|   | 1d78bc7206 | ||
|   | e5577e43f8 | ||
|   | 17c0463906 | ||
|   | 4168772904 | ||
|   | 44f2186749 | ||
|   | 0c918bcc3a | ||
|   | 0a8925dc75 | ||
|   | a446597597 | ||
|   | 54354a2732 | ||
|   | d94b8f08ab | ||
|   | 0d8189efeb | ||
|   | 00c886e426 | ||
|   | 551fc35439 | ||
|   | 9ff17c8d9d | ||
|   | ec37732e99 | ||
|   | 8a414f32a8 | ||
|   | bac06acb49 | ||
|   | ae1e3c2a81 | ||
|   | 67940eb0f9 | ||
|   | 007aa8480e | ||
|   | dedec10c58 | ||
|   | 75219e21be | ||
|   | 10f5964f8e | ||
|   | a4a64d51c0 | ||
|   | 1014313d88 | ||
|   | e486bb4c29 | ||
|   | 5c3d9ffb46 | ||
|   | 2e474fd8db | ||
|   | b2b110ae1f | ||
|   | 68a34e0738 | ||
|   | 38fa575958 | ||
|   | 6cfeefe054 | ||
|   | 8007971a53 | ||
|   | d66bd30fae | ||
|   | 3fa59b1b12 | ||
|   | 20e7aff393 | ||
|   | 4b7ce87f57 | ||
|   | 2075533468 | ||
|   | a4ad5c8d11 | ||
|   | 35f2f56757 | ||
|   | e6f4aa6a2f | ||
|   | 92fc62bb0d | ||
|   | 44b57a59f5 | ||
|   | 97b8e02bf5 | ||
|   | 5df42420cb | ||
|   | 0ede11a1b7 | ||
|   | 7d9c282db9 | ||
|   | bc0e0813a4 | ||
|   | f3aebb3001 | ||
|   | 800f966df9 | ||
|   | e33df4dd8c | ||
|   | 96d9d810fd | ||
|   | 8707a1bc86 | ||
|   | 0c988a5fd4 | ||
|   | b396ca771d | ||
|   | a37dfcf961 | ||
|   | 31989740cd | ||
|   | 501191289b | ||
|   | 8971e92d78 | ||
|   | 0c96e79d0d | ||
|   | 0704c0f5e6 | ||
|   | 9cb190ebe7 | ||
|   | 667f84995c | ||
|   | 7a93fae6e4 | ||
|   | 0d6deca15c | ||
|   | f54d7d46f2 | ||
|   | 8cf00ba5e1 | ||
|   | ecc9c6bbd9 | ||
|   | e11199f988 | ||
|   | e9ed621178 | 
| @@ -45,8 +45,7 @@ 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%\winconf.pri" "%REPO_DIR%" | ||||
|   - COPY /Y "%CACHE_DIR%\winconf-msvc.pri" "%REPO_DIR%" | ||||
|   - COPY /Y "%CACHE_DIR%\conf.pri" "%REPO_DIR%" | ||||
|   # workarounds | ||||
|   - MKLINK /J "c:\qbt\base" "%CACHE_DIR%\base" | ||||
|  | ||||
|   | ||||
| @@ -166,7 +166,10 @@ script: | ||||
|     if [ "$build_system" = "cmake" ]; then | ||||
|       mkdir build | ||||
|       cd build | ||||
|       cmake -DGUI=${gui} -DCMAKE_INSTALL_PREFIX="$qbt_path" "$MY_CMAKE_OPENSSL_HINT" \ | ||||
|       if [ "$gui" = "false" ]; then | ||||
|         DISABLE_GUI_OPTION="-DCMAKE_DISABLE_FIND_PACKAGE_Qt5Widgets=ON" | ||||
|       fi | ||||
|       cmake $DISABLE_GUI_OPTION -DCMAKE_INSTALL_PREFIX="$qbt_path" "$MY_CMAKE_OPENSSL_HINT" \ | ||||
|         -G "Ninja" -DCMAKE_INSTALL_RPATH_USE_LINK_PATH=TRUE .. | ||||
|       BUILD_TOOL="ninja" | ||||
|     fi | ||||
|   | ||||
| @@ -12,7 +12,7 @@ mode = developer | ||||
|  | ||||
|  | ||||
| [qbittorrent.qbittorrentdesktop_master] | ||||
| source_file = src/icons/qBittorrent.desktop | ||||
| source_file = dist/unix/qbittorrent.desktop | ||||
| source_lang = en | ||||
| type = DESKTOP | ||||
| minimum_perc = 23 | ||||
|   | ||||
| @@ -1,5 +1,6 @@ | ||||
| cmake_minimum_required(VERSION 3.5) | ||||
| cmake_policy(VERSION 3.5) | ||||
| cmake_minimum_required(VERSION 3.9 FATAL_ERROR) | ||||
|  | ||||
| message(WARNING "No official support for cmake build system. If it is broken, please submit patches!") | ||||
|  | ||||
| list(APPEND CMAKE_MODULE_PATH ${CMAKE_CURRENT_SOURCE_DIR}/cmake/Modules) | ||||
| include(FunctionReadVersion) | ||||
| @@ -25,32 +26,29 @@ add_definitions(-DQBT_VERSION_BUILD=${VER_BUILD}) | ||||
| add_definitions(-DQBT_VERSION="v${PROJECT_VERSION}") | ||||
| add_definitions(-DQBT_VERSION_2="${PROJECT_VERSION}") | ||||
|  | ||||
| if (UNIX AND NOT APPLE) | ||||
|     include(GNUInstallDirs) | ||||
| endif (UNIX AND NOT APPLE) | ||||
| include(GNUInstallDirs) | ||||
| include(FeatureSummary) | ||||
|  | ||||
| # version requirements | ||||
| set(requiredBoostVersion 1.35) | ||||
| set(requiredQtVersion 5.5.1) | ||||
|  | ||||
| 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) | ||||
|  | ||||
| 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) | ||||
|  | ||||
| option(STACKTRACE "Enable stacktrace feature" ON) | ||||
|  | ||||
| if (UNIX) | ||||
|     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(UNIX) | ||||
| # 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) | ||||
|  | ||||
| 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) | ||||
|   | ||||
| @@ -6,6 +6,31 @@ For programming languages other than C++ (e.g. JavaScript) used in this reposito | ||||
| **Note 2:** You can use the `uncrustify` program/tool to clean up any source file. Use it with the `uncrustify.cfg` configuration file found in the root folder.   | ||||
| **Note 3:** There is also a style for QtCreator but it doesn't cover all cases. In QtCreator `Tools->Options...->C++->Code Style->Import...` and choose the `codingStyleQtCreator.xml` file found in the root folder.   | ||||
|  | ||||
| ### Table Of Contents | ||||
|  | ||||
| * [1. New lines & curly braces](#1-new-lines--curly-braces) | ||||
|   * [a. Function blocks, class/struct definitions, namespaces](#a-function-blocks-classstruct-definitions-namespaces) | ||||
|   * [b. Other code blocks](#b-other-code-blocks) | ||||
|   * [c. Blocks in switch's case labels](#c-blocks-in-switchs-case-labels) | ||||
|   * [d. If-else statements](#d-if-else-statements) | ||||
|   * [e. Single statement if blocks](#e-single-statement-if-blocks) | ||||
|   * [f. Acceptable conditions to omit braces](#f-acceptable-conditions-to-omit-braces) | ||||
|   * [g. Brace enclosed initializers](#g-brace-enclosed-initializers) | ||||
| * [2. Indentation](#2-indentation) | ||||
| * [3. File encoding and line endings](#3-file-encoding-and-line-endings) | ||||
| * [4. Initialization lists](#4-initialization-lists) | ||||
| * [5. Enums](#5-enums) | ||||
| * [6. Names](#6-names) | ||||
|   * [a. Type names and namespaces](#a-type-names-and-namespaces) | ||||
|   * [b. Variable names](#b-variable-names) | ||||
|   * [c. Private member variable names](#c-private-member-variable-names) | ||||
| * [7. Header inclusion order](#7-header-inclusion-order) | ||||
| * [8. Include guard](#8-include-guard) | ||||
| * [9. Misc](#9-misc) | ||||
| * [10. Git commit message](#10-git-commit-message) | ||||
| * [11. Not covered above](#11-not-covered-above) | ||||
| --- | ||||
|  | ||||
| ### 1. New lines & curly braces ### | ||||
|  | ||||
| #### a. Function blocks, class/struct definitions, namespaces #### | ||||
| @@ -165,11 +190,11 @@ QVariantMap map {{"key1", 5}, {"key2", 10}}; | ||||
| ### 2. Indentation ### | ||||
| 4 spaces. | ||||
|  | ||||
| ### 3. File encoding and line endings. ### | ||||
| ### 3. File encoding and line endings ### | ||||
|  | ||||
| UTF-8 and Unix-like line ending (LF). Unless some platform specific files need other encodings/line endings. | ||||
|  | ||||
| ### 4. Initialization lists. ### | ||||
| ### 4. Initialization lists ### | ||||
| Initialization lists should be vertical. This will allow for more easily readable diffs. The initialization colon should be indented and in its own line along with first argument. The rest of the arguments should be indented too and have the comma prepended. | ||||
| ```c++ | ||||
| myClass::myClass(int a, int b, int c, int d) | ||||
| @@ -182,7 +207,7 @@ myClass::myClass(int a, int b, int c, int d) | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ### 5. Enums. ### | ||||
| ### 5. Enums ### | ||||
| Enums should be vertical. This will allow for more easily readable diffs. The members should be indented. | ||||
| ```c++ | ||||
| enum Days | ||||
| @@ -197,7 +222,7 @@ enum Days | ||||
| }; | ||||
| ``` | ||||
|  | ||||
| ### 6. Names. ### | ||||
| ### 6. Names ### | ||||
| All names should be camelCased. | ||||
|  | ||||
| #### a. Type names and namespaces #### | ||||
| @@ -231,7 +256,7 @@ class MyClass | ||||
| } | ||||
| ``` | ||||
|  | ||||
| ### 7. Header inclusion order. ### | ||||
| ### 7. Header inclusion order ### | ||||
| The headers should be placed in the following group order: | ||||
|   1. Module header (in .cpp) | ||||
|   2. C++ Standard Library headers | ||||
| @@ -239,11 +264,11 @@ The headers should be placed in the following group order: | ||||
|   4. Boost library headers | ||||
|   5. Libtorrent headers | ||||
|   6. Qt headers | ||||
|   7. qBittorrent own headers, starting from *base* headers. | ||||
|   7. qBittorrent's own headers, starting from the *base* headers. | ||||
|  | ||||
| The headers should be ordered alphabetically within each group.   | ||||
| If there are conditionals for the same header group, then put them at the bottom of the respective group.   | ||||
| If there are conditionals for the different header groups, then put them above of the "qBittorrent own headers" group. | ||||
| If there are conditionals that contain headers from several different header groups, then put them above the "qBittorrent's own headers" group. | ||||
|  | ||||
| One exception is the header containing the library version (for example, QtGlobal), this particular header isn't constrained by the aforementioned order. | ||||
|  | ||||
| @@ -285,19 +310,19 @@ Example: | ||||
| #include <QFont> | ||||
| #endif | ||||
|  | ||||
| // conditional for the different header groups | ||||
| // conditional that contains headers from several different header groups | ||||
| #if LIBTORRENT_VERSION_NUM >= 10100 | ||||
| #include <memory> | ||||
| #include <QElapsedTimer> | ||||
| #endif | ||||
|  | ||||
| // qBittorrent own headers | ||||
| // qBittorrent's own headers | ||||
| #include "base/bittorrent/infohash.h" | ||||
| #include "anothermodule.h" | ||||
| #include "ui_examplewidget.h" | ||||
| ``` | ||||
|  | ||||
| ### 8. Include guard. ### | ||||
| ### 8. Include guard ### | ||||
| `#pragma once` should be used instead of "include guard" in new code: | ||||
| ```c++ | ||||
| // examplewidget.h | ||||
| @@ -313,7 +338,7 @@ class ExampleWidget : public QWidget | ||||
|  | ||||
| ``` | ||||
|  | ||||
| ### 9. Misc. ### | ||||
| ### 9. Misc ### | ||||
|  | ||||
| * Line breaks for long lines with operation: | ||||
|  | ||||
|   | ||||
							
								
								
									
										83
									
								
								Changelog
									
									
									
									
									
								
							
							
						
						
									
										83
									
								
								Changelog
									
									
									
									
									
								
							| @@ -1,3 +1,86 @@ | ||||
| * Sun Aug 12 2018 - sledgehammer999 <sledgehammer999@qbittorrent.org> - v4.1.2 | ||||
|     - FEATURE: New options for "inhibit sleep" (Lukas Greib) | ||||
|     - FEATURE: Add option for regexps in the transferlist search filter's context menu (thalieht) | ||||
|     - FEATURE: Add async io threads option to AdvancedSettings (tjjh89017) | ||||
|     - FEATURE: Allow save resume interval to be disabled (Chocobo1) | ||||
|     - FEATURE: Add checkbox for recursive download dialog (Chocobo1) | ||||
|     - FEATURE: Add changelog link in program updater (Chocobo1) | ||||
|     - BUGFIX: Avoid allocating large memory when loading a .torrent file (Couchy) | ||||
|     - BUGFIX: Notify users on 1st time close/minimize to tray (sledgehammer999) | ||||
|     - BUGFIX: Fix I/O error after fetching magnet metadata (Chocobo1) | ||||
|     - BUGFIX: Never save resume data for already paused torrents (glassez) | ||||
|     - BUGFIX: Make ProgramUpdater upgrade to 64-bit qbt when running on 64-bit Windows (Chocobo1) | ||||
|     - BUGFIX: Put temporary files in qbt own temp folder (Chocobo1) | ||||
|     - BUGFIX: Avoid potentially setting the wrong piece priorities (Chocobo1) | ||||
|     - BUGFIX: Various code refactorings/improvements (Chocobo1, thalieht, glassez) | ||||
|     - BUGFIX: Add options "Download in sequential order" and "Download first and last pieces first" in AddNewTorrentDialog (Chocobo1) | ||||
|     - BUGFIX: Download favicon using appropriate protocol (glassez) | ||||
|     - BUGFIX: Apply proxy settings on DownloadManager creation (glassez) | ||||
|     - BUGFIX: Improve torrent initialization (glassez) | ||||
|     - BUGFIX: Save resume data on torrent change events (glassez) | ||||
|     - BUGFIX: Increase default resume data save interval (Chocobo1) | ||||
|     - BUGFIX: Work around crash when procesing recursive download. Closes #9086 (Chocobo1) | ||||
|     - BUGFIX: Reduce queries to python version (Chocobo1) | ||||
|     - BUGFIX: Disable certain mouse wheel events in Options dialog (Chocobo1) | ||||
|     - WEBUI: Send all rechecks in one request (Thomas Piccirello) | ||||
|     - WEBUI: Add WebUI Force Reannounce option (Thomas Piccirello) | ||||
|     - WEBUI: Create non-existing path in setLocationAction() (Goshik) | ||||
|     - WEBUI: Add WebUI support for Mac ⌘ (Command) key (Thomas Piccirello) | ||||
|     - WEBUI: Show current save path in 'Set location' window (Goshik) | ||||
|     - WEBUI: Fix WebUI cache behavior for css files (Chocobo1) | ||||
|     - WEBUI: Send Cache-Control header in WebUI responses (Chocobo1) | ||||
|     - WEBUI: Add form-action to CSP (Thomas Piccirello) | ||||
|     - WEBUI: Add upgrade-insecure-requests to CSP when HTTPS is enabled (Thomas Piccirello) | ||||
|     - WEBUI: Reset WebUI ban counter on login success (Chocobo1) | ||||
|     - WEBUI: Add logging messages in WebUI login action (Chocobo1) | ||||
|     - WEBUI: Add option to control CSRF protection (Chocobo1) | ||||
|     - WEBUI: Add option to control WebUI clickjacking protection (Chocobo1) | ||||
|     - RSS: Implement "Sequential downloading" feature. Closes #6835 (glassez) | ||||
|     - RSS: Don't use RSS feed URLs as base for file names. Closes #8399 (glassez) | ||||
|     - SEARCH: Add a name filter for search results (thalieht) | ||||
|     - SEARCH: Fix python version detection (Chocobo1) | ||||
|     - SEARCH: Clear python cache conditionally (Chocobo1) | ||||
|     - SEARCH: Properly normalize version string before parsing it (hannsen) | ||||
|     - WINDOWS: Turn on Control Flow Guard for MSVC builds (Chocobo1) | ||||
|     - MACOS: Replace deprecated function IOPMAssertionCreate() on macOS (Chocobo1) | ||||
|     - OTHER: Fix CMake build with QtSingleApplication. Fixes #9196 (Eugene Shalygin) | ||||
|  | ||||
| * Sun May 27 2018 - sledgehammer999 <sledgehammer999@qbittorrent.org> - v4.1.1 | ||||
|     - FEATURE: Add 'Moving' state for torrents being relocated/moved (sledgehammer999) | ||||
|     - FEATURE: Show rechecking progress (sledgehammer999) | ||||
|     - FEATURE: Add option to remember last used save path (glassez) | ||||
|     - FEATURE: Torrent name is also renamed if the content was renamed in the "Add New Torrent" dialog (glassez) | ||||
|     - FEATURE: Relax behavior of "Download first and last piece first". It applies to all files and not only to the previewable. (Chocobo1) | ||||
|     - BUGFIX: Fix issues with translatable strings (Chocobo1) | ||||
|     - BUGFIX: Fix displayed tracker messages (Chocobo1) | ||||
|     - BUGFIX: Make settings file recovery more robust (Chocobo1) | ||||
|     - BUGFIX: Retry saving settings when operation failed (Chocobo1) | ||||
|     - BUGFIX: Log successful torrent move (sledgehammer999) | ||||
|     - BUGFIX: Fix deletion of old logs (sledgehammer999) | ||||
|     - BUGFIX: Delete non-commited fastresume files (sledgehammer999) | ||||
|     - BUGFIX: Don't migrate torrents that have newer fastresumes (sledgehammer999) | ||||
|     - BUGFIX: Fix adding multiple torrents at once from WebUI (glassez) | ||||
|     - BUGFIX: Improve "Run External Program" behavior. On Windows, a backslash isn't appended to paths from path variables (Chocobo1) | ||||
|     - BUGFIX: Suppress multiple I/O errors for the same torrent (sledgehammer999) | ||||
|     - BUGFIX: Replace raster qbt logo with vector version (Chocobo1) | ||||
|     - WEBUI: Fix wrong API method names (glassez) | ||||
|     - WEBUI: Filter torrent info endpoint by hashes (Marcel Petersen) | ||||
|     - WEBUI: Fix invalid API calls in WebUI (glassez) | ||||
|     - WEBUI: Improve legacy API params handling (glassez) | ||||
|     - WEBUI: Fix params handling for some legacy API methods (glassez) | ||||
|     - WEBUI: Apply locale changes immediately in WebUI (Chocobo1) | ||||
|     - WEBUI: Use 32px icons for favicon (Chocobo1) | ||||
|     - WEBUI/RSS: Properly set RSS settings via API (glassez) | ||||
|     - RSS: Fix auto-downloading rule when Smart filter with regular Episode filter are used (glassez) | ||||
|     - RSS: Make "Ignoring days" to behave like other filters (glassez) | ||||
|     - RSS: Place "Use Smart Episode Filter" more correctly (glassez) | ||||
|     - RSS: Use RSS feed update time as a fallback (glassez) | ||||
|     - COSMETIC: Fix Stats dialog size (sledgehammer999) | ||||
|     - MACOS: Fix GUI scaling factor on macOS (Chocobo1) | ||||
|     - WINDOWS: Update icons (adem4ik) | ||||
|     - LINUX: Fix open destination folder with Nautilus > 3.28 (Evgeny Lensky) | ||||
|     - OTHER: Code improvements and refactoring (thalieht, Nick Korotysh, Chocobo1) | ||||
|  | ||||
| * Sat May 05 2018 - sledgehammer999 <sledgehammer999@qbittorrent.org> - v4.1.0 | ||||
|     - FEATURE: Add "Coalesce reads & writes" checkbox in advanced options (Chocobo1) | ||||
|     - FEATURE: Smart Filter for RSS (Stephen Dawkins) | ||||
|   | ||||
							
								
								
									
										22
									
								
								cmake/Modules/CompileFeature.cmake
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										22
									
								
								cmake/Modules/CompileFeature.cmake
									
									
									
									
									
										Normal file
									
								
							| @@ -0,0 +1,22 @@ | ||||
| # 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() | ||||
| @@ -99,6 +99,7 @@ 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() | ||||
|  | ||||
| @@ -113,10 +114,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::LibTorrent) | ||||
|     add_library(LibtorrentRasterbar::LibTorrent UNKNOWN IMPORTED) | ||||
| if (LibtorrentRasterbar_FOUND AND NOT TARGET LibtorrentRasterbar::torrent-rasterbar) | ||||
|     add_library(LibtorrentRasterbar::torrent-rasterbar UNKNOWN IMPORTED) | ||||
|  | ||||
|     set_target_properties(LibtorrentRasterbar::LibTorrent PROPERTIES | ||||
|     set_target_properties(LibtorrentRasterbar::torrent-rasterbar PROPERTIES | ||||
|         IMPORTED_LINK_INTERFACE_LANGUAGES "CXX" | ||||
|         IMPORTED_LOCATION "${LibtorrentRasterbar_LIBRARY}" | ||||
|         INTERFACE_INCLUDE_DIRECTORIES "${LibtorrentRasterbar_INCLUDE_DIRS}" | ||||
|   | ||||
| @@ -1,94 +1,79 @@ | ||||
| # - 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) | ||||
| # 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) | ||||
| 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 | ||||
|     ) | ||||
| if (Qt5Widgets_FOUND) | ||||
|     set(_includeFileName qtsingleapplication.h) | ||||
| else() | ||||
|     set(_includeFileName qtsinglecoreapplication.h) | ||||
| endif() | ||||
|  | ||||
|     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) | ||||
| FOREACH(TOP_INCLUDE_PATH in ${Qt5Core_INCLUDE_DIRS} ${FRAMEWORK_INCLUDE_DIR}) | ||||
|     FIND_PATH(QtSingleApplication_INCLUDE_DIR ${_includeFileName} ${TOP_INCLUDE_PATH}/QtSolutions) | ||||
|  | ||||
|         IF(QTSINGLEAPPLICATION_INCLUDE_DIR) | ||||
|             BREAK() | ||||
|         ENDIF() | ||||
|     ENDFOREACH() | ||||
|     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) | ||||
| 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() | ||||
| FIND_LIBRARY(QtSingleApplication_LIBRARY | ||||
|     NAMES ${QtSingleApplication_NAMES} | ||||
|     PATHS ${_QT5_CORELIBRARYPATH} | ||||
| ) | ||||
|  | ||||
| IF (QTSINGLEAPPLICATION_LIBRARY AND QTSINGLEAPPLICATION_INCLUDE_DIR) | ||||
| IF (QtSingleApplication_LIBRARY AND QtSingleApplication_INCLUDE_DIR) | ||||
|  | ||||
|     SET(QTSINGLEAPPLICATION_LIBRARIES ${QTSINGLEAPPLICATION_LIBRARY}) | ||||
|     SET(QTSINGLEAPPLICATION_FOUND TRUE) | ||||
|     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. | ||||
|         # No need to define QtSingleApplication_USE_DLL here, because it's default for Cygwin. | ||||
|         ELSE(BUILD_SHARED_LIBS) | ||||
|         SET (QTSINGLEAPPLICATION_DEFINITIONS -DQTSINGLEAPPLICATION_STATIC) | ||||
|         SET (QtSingleApplication_DEFINITIONS -DQTSINGLEAPPLICATION_STATIC) | ||||
|         ENDIF(BUILD_SHARED_LIBS) | ||||
|     ENDIF (CYGWIN) | ||||
|  | ||||
| ENDIF (QTSINGLEAPPLICATION_LIBRARY AND QTSINGLEAPPLICATION_INCLUDE_DIR) | ||||
| 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_FOUND) | ||||
|     IF (NOT QtSingleApplication_FIND_QUIETLY) | ||||
|         MESSAGE(STATUS "Found QtSingleApplication: ${QtSingleApplication_LIBRARY}") | ||||
|         MESSAGE(STATUS "         includes: ${QtSingleApplication_INCLUDE_DIR}") | ||||
|     ENDIF (NOT QtSingleApplication_FIND_QUIETLY) | ||||
|     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) | ||||
|  | ||||
| ELSE (QtSingleApplication_FOUND) | ||||
|   IF (QtSingleApplication_FIND_REQUIRED) | ||||
|     MESSAGE(FATAL_ERROR "Could not find QtSingleApplication library") | ||||
|   ENDIF (QtSingleApplication_FIND_REQUIRED) | ||||
| ENDIF (QTSINGLEAPPLICATION_FOUND) | ||||
| 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) | ||||
| MARK_AS_ADVANCED(QtSingleApplication_INCLUDE_DIR QtSingleApplication_LIBRARY) | ||||
|   | ||||
| @@ -11,18 +11,17 @@ macro(qbt_set_compiler_options) | ||||
|         #-Wshadow -Wconversion ? | ||||
|         set(_GCC_COMMON_C_AND_CXX_FLAGS "-Wall -Wextra" | ||||
|             "-Wfloat-equal -Wcast-qual -Wcast-align" | ||||
|             "-Wsign-conversion -Winvalid-pch -Werror=return-type -Wno-long-long" | ||||
| #			-fstack-protector-all | ||||
|             "-Werror -Wno-error=deprecated-declarations" | ||||
|             "-Wsign-conversion -Winvalid-pch -Wno-long-long" | ||||
|             #"-fstack-protector-all" | ||||
|             #"-Werror -Wno-error=deprecated-declarations" | ||||
|         ) | ||||
|         set (_GCC_COMMON_CXX_FLAGS  "-fexceptions -frtti" | ||||
|         set(_GCC_COMMON_CXX_FLAGS "-fexceptions -frtti" | ||||
|             "-Woverloaded-virtual -Wold-style-cast" | ||||
|             "-Wnon-virtual-dtor -Wfloat-equal -Wcast-qual -Wcast-align" | ||||
|             "-Werror=overloaded-virtual" | ||||
|     # 		"-Weffc++" | ||||
|             "-Werror -Wno-error=cpp" | ||||
|             #"-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) | ||||
|   | ||||
| @@ -1,16 +1,17 @@ | ||||
| # a helper function which appends source to the main qBt target | ||||
| # sources file names are relative to the the ${qBittorrent_SOURCE_DIR} | ||||
| # a helper function which appends source to the target | ||||
| # sources file names are relative to the the target source dir | ||||
|  | ||||
| function (qbt_target_sources) | ||||
|     set (_sources_rel "") | ||||
|     foreach (_source IN ITEMS ${ARGN}) | ||||
|         if (IS_ABSOLUTE "${_source}") | ||||
|             set(source_abs "${_source}") | ||||
| 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}") | ||||
|         else() | ||||
|             get_filename_component(_source_abs "${_source}" ABSOLUTE) | ||||
|             get_filename_component(sourceAbsolutePath "${source}" ABSOLUTE) | ||||
|         endif() | ||||
|         file (RELATIVE_PATH _source_rel "${qbt_executable_SOURCE_DIR}" "${_source_abs}") | ||||
|         list (APPEND _sources_rel "${_source_rel}") | ||||
|         file(RELATIVE_PATH sourceRelativePath "${targetSourceDir}" "${sourceAbsolutePath}") | ||||
|         list(APPEND sourcesRelative "${sourceRelativePath}") | ||||
|     endforeach() | ||||
|     target_sources (qBittorrent PRIVATE "${_sources_rel}") | ||||
| endfunction (qbt_target_sources) | ||||
|     target_sources(${_target} ${_scope} "${sourcesRelative}") | ||||
| endfunction(qbt_target_sources) | ||||
|   | ||||
| @@ -1,9 +1,9 @@ | ||||
| if (STACKTRACE_WIN) | ||||
| if (STACKTRACE) | ||||
|     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) | ||||
| endif (STACKTRACE) | ||||
|  | ||||
| if (("${CMAKE_BUILD_TYPE}" STREQUAL "Debug") OR ("${CMAKE_BUILD_TYPE}" STREQUAL "RelWithDebInfo")) | ||||
|     link_libraries(-Wl,--dynamicbase) | ||||
|   | ||||
| @@ -1,4 +1,4 @@ | ||||
| if (STACKTRACE_WIN) | ||||
| if (STACKTRACE) | ||||
|     if ("${WINXXBITS}" STREQUAL "Win64") | ||||
|         add_compile_options(-Zi) | ||||
|     else ("${WINXXBITS}" STREQUAL "Win64") | ||||
| @@ -6,7 +6,7 @@ if (STACKTRACE_WIN) | ||||
|         add_compile_options(-Oy-) | ||||
|     endif ("${WINXXBITS}" STREQUAL "Win64") | ||||
|     link_libraries(dbghelp.lib) | ||||
| endif (STACKTRACE_WIN) | ||||
| endif (STACKTRACE) | ||||
|  | ||||
| # Enable Wide characters | ||||
| add_definitions(-DTORRENT_USE_WPATH) | ||||
|   | ||||
| @@ -50,6 +50,8 @@ DEFINES += BOOST_USE_WINAPI_VERSION=0x0501 | ||||
| #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 encountered build error with boost version <= 1.59 | ||||
| #DEFINES += BOOST_NO_CXX11_RVALUE_REFERENCES | ||||
|  | ||||
| # Enable if building against libtorrent 1.1.x (RC_1_1) | ||||
| # built with this flag defined | ||||
| @@ -58,4 +60,10 @@ DEFINES += BOOST_USE_WINAPI_VERSION=0x0501 | ||||
| #DEFINES += TORRENT_LINKING_SHARED | ||||
|  | ||||
| # Enable stack trace support | ||||
| CONFIG += strace_win | ||||
| CONFIG += stacktrace | ||||
|  | ||||
| win32-msvc* { | ||||
|     QMAKE_CXXFLAGS += "/guard:cf" | ||||
|     QMAKE_LFLAGS += "/guard:cf" | ||||
|     QMAKE_LFLAGS_RELEASE += "/OPT:REF /OPT:ICF" | ||||
| } | ||||
|   | ||||
							
								
								
									
										58
									
								
								configure
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										58
									
								
								configure
									
									
									
									
										vendored
									
									
								
							| @@ -1,6 +1,6 @@ | ||||
| #! /bin/sh | ||||
| # Guess values for system-dependent variables and create Makefiles. | ||||
| # Generated by GNU Autoconf 2.69 for qbittorrent v4.1.0alpha. | ||||
| # Generated by GNU Autoconf 2.69 for qbittorrent v4.1.2. | ||||
| # | ||||
| # Report bugs to <bugs.qbittorrent.org>. | ||||
| # | ||||
| @@ -580,8 +580,8 @@ MAKEFLAGS= | ||||
| # Identity of this package. | ||||
| PACKAGE_NAME='qbittorrent' | ||||
| PACKAGE_TARNAME='qbittorrent' | ||||
| PACKAGE_VERSION='v4.1.0alpha' | ||||
| PACKAGE_STRING='qbittorrent v4.1.0alpha' | ||||
| PACKAGE_VERSION='v4.1.2' | ||||
| PACKAGE_STRING='qbittorrent v4.1.2' | ||||
| PACKAGE_BUGREPORT='bugs.qbittorrent.org' | ||||
| PACKAGE_URL='https://www.qbittorrent.org/' | ||||
|  | ||||
| @@ -1297,7 +1297,7 @@ if test "$ac_init_help" = "long"; then | ||||
|   # Omit some internal or obsolete options to make the list less imposing. | ||||
|   # This message is too long to be a string in the A/UX 3.1 sh. | ||||
|   cat <<_ACEOF | ||||
| \`configure' configures qbittorrent v4.1.0alpha to adapt to many kinds of systems. | ||||
| \`configure' configures qbittorrent v4.1.2 to adapt to many kinds of systems. | ||||
|  | ||||
| Usage: $0 [OPTION]... [VAR=VALUE]... | ||||
|  | ||||
| @@ -1368,7 +1368,7 @@ fi | ||||
|  | ||||
| if test -n "$ac_init_help"; then | ||||
|   case $ac_init_help in | ||||
|      short | recursive ) echo "Configuration of qbittorrent v4.1.0alpha:";; | ||||
|      short | recursive ) echo "Configuration of qbittorrent v4.1.2:";; | ||||
|    esac | ||||
|   cat <<\_ACEOF | ||||
|  | ||||
| @@ -1503,7 +1503,7 @@ fi | ||||
| test -n "$ac_init_help" && exit $ac_status | ||||
| if $ac_init_version; then | ||||
|   cat <<\_ACEOF | ||||
| qbittorrent configure v4.1.0alpha | ||||
| qbittorrent configure v4.1.2 | ||||
| generated by GNU Autoconf 2.69 | ||||
|  | ||||
| Copyright (C) 2012 Free Software Foundation, Inc. | ||||
| @@ -1642,7 +1642,7 @@ cat >config.log <<_ACEOF | ||||
| This file contains any messages produced by compilers while | ||||
| running configure, to aid debugging if configure makes a mistake. | ||||
|  | ||||
| It was created by qbittorrent $as_me v4.1.0alpha, which was | ||||
| It was created by qbittorrent $as_me v4.1.2, which was | ||||
| generated by GNU Autoconf 2.69.  Invocation command line was | ||||
|  | ||||
|   $ $0 $@ | ||||
| @@ -3820,7 +3820,7 @@ fi | ||||
|  | ||||
| # Define the identity of the package. | ||||
|  PACKAGE='qbittorrent' | ||||
|  VERSION='v4.1.0alpha' | ||||
|  VERSION='v4.1.2' | ||||
|  | ||||
|  | ||||
| cat >>confdefs.h <<_ACEOF | ||||
| @@ -5014,6 +5014,40 @@ fi | ||||
| CPPFLAGS="$BOOST_CPPFLAGS $CPPFLAGS" | ||||
| LDFLAGS="$BOOST_LDFLAGS $LDFLAGS" | ||||
|  | ||||
| # add workaround for problematic boost version | ||||
| ac_ext=cpp | ||||
| ac_cpp='$CXXCPP $CPPFLAGS' | ||||
| ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' | ||||
| ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' | ||||
| ac_compiler_gnu=$ac_cv_cxx_compiler_gnu | ||||
|  | ||||
| # taken from ax_boost_base.m4 | ||||
|  | ||||
|  | ||||
| cat confdefs.h - <<_ACEOF >conftest.$ac_ext | ||||
| /* end confdefs.h.  */ | ||||
| #include <boost/version.hpp> | ||||
| int | ||||
| main () | ||||
| { | ||||
| (void) ((void)sizeof(char[1 - 2*!!((BOOST_VERSION) < (106000))])); | ||||
|   ; | ||||
|   return 0; | ||||
| } | ||||
| _ACEOF | ||||
| if ac_fn_cxx_try_compile "$LINENO"; then : | ||||
|  | ||||
| else | ||||
|   QBT_ADD_DEFINES="$QBT_ADD_DEFINES BOOST_NO_CXX11_RVALUE_REFERENCES" | ||||
| fi | ||||
| rm -f core conftest.err conftest.$ac_objext conftest.$ac_ext | ||||
| ac_ext=cpp | ||||
| ac_cpp='$CXXCPP $CPPFLAGS' | ||||
| ac_compile='$CXX -c $CXXFLAGS $CPPFLAGS conftest.$ac_ext >&5' | ||||
| ac_link='$CXX -o conftest$ac_exeext $CXXFLAGS $CPPFLAGS $LDFLAGS conftest.$ac_ext $LIBS >&5' | ||||
| ac_compiler_gnu=$ac_cv_cxx_compiler_gnu | ||||
|  | ||||
|  | ||||
|  | ||||
|  | ||||
| # Check whether --with-boost-system was given. | ||||
| @@ -6140,7 +6174,7 @@ cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 | ||||
| # report actual input values of CONFIG_FILES etc. instead of their | ||||
| # values after options handling. | ||||
| ac_log=" | ||||
| This file was extended by qbittorrent $as_me v4.1.0alpha, which was | ||||
| This file was extended by qbittorrent $as_me v4.1.2, which was | ||||
| generated by GNU Autoconf 2.69.  Invocation command line was | ||||
|  | ||||
|   CONFIG_FILES    = $CONFIG_FILES | ||||
| @@ -6198,7 +6232,7 @@ _ACEOF | ||||
| cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 | ||||
| ac_cs_config="`$as_echo "$ac_configure_args" | sed 's/^ //; s/[\\""\`\$]/\\\\&/g'`" | ||||
| ac_cs_version="\\ | ||||
| qbittorrent config.status v4.1.0alpha | ||||
| qbittorrent config.status v4.1.2 | ||||
| configured by $0, generated by GNU Autoconf 2.69, | ||||
|   with options \\"\$ac_cs_config\\" | ||||
|  | ||||
| @@ -7455,7 +7489,7 @@ cat >>$CONFIG_STATUS <<\_ACEOF || ac_write_fail=1 | ||||
| # report actual input values of CONFIG_FILES etc. instead of their | ||||
| # values after options handling. | ||||
| ac_log=" | ||||
| This file was extended by qbittorrent $as_me v4.1.0alpha, which was | ||||
| This file was extended by qbittorrent $as_me v4.1.2, which was | ||||
| generated by GNU Autoconf 2.69.  Invocation command line was | ||||
|  | ||||
|   CONFIG_FILES    = $CONFIG_FILES | ||||
| @@ -7513,7 +7547,7 @@ _ACEOF | ||||
| cat >>$CONFIG_STATUS <<_ACEOF || ac_write_fail=1 | ||||
| ac_cs_config="`$as_echo "$ac_configure_args" | sed 's/^ //; s/[\\""\`\$]/\\\\&/g'`" | ||||
| ac_cs_version="\\ | ||||
| qbittorrent config.status v4.1.0alpha | ||||
| qbittorrent config.status v4.1.2 | ||||
| configured by $0, generated by GNU Autoconf 2.69, | ||||
|   with options \\"\$ac_cs_config\\" | ||||
|  | ||||
|   | ||||
							
								
								
									
										13
									
								
								configure.ac
									
									
									
									
									
								
							
							
						
						
									
										13
									
								
								configure.ac
									
									
									
									
									
								
							| @@ -1,4 +1,4 @@ | ||||
| AC_INIT([qbittorrent], [v4.1.0alpha], [bugs.qbittorrent.org], [], [https://www.qbittorrent.org/]) | ||||
| AC_INIT([qbittorrent], [v4.1.2], [bugs.qbittorrent.org], [], [https://www.qbittorrent.org/]) | ||||
| AC_CONFIG_AUX_DIR([build-aux]) | ||||
| AC_CONFIG_MACRO_DIR([m4]) | ||||
| AC_PROG_CC | ||||
| @@ -168,6 +168,17 @@ AX_BOOST_BASE([1.35], | ||||
| CPPFLAGS="$BOOST_CPPFLAGS $CPPFLAGS" | ||||
| LDFLAGS="$BOOST_LDFLAGS $LDFLAGS" | ||||
|  | ||||
| # add workaround for problematic boost version | ||||
| AC_LANG_PUSH(C++) | ||||
| # 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"]) | ||||
| AC_LANG_POP([C++]) | ||||
|  | ||||
| AX_BOOST_SYSTEM() | ||||
| AC_MSG_NOTICE([Boost.System LIB: "$BOOST_SYSTEM_LIB"]) | ||||
| LIBS="$BOOST_SYSTEM_LIB $LIBS" | ||||
|   | ||||
							
								
								
									
										2
									
								
								dist/CMakeLists.txt
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								dist/CMakeLists.txt
									
									
									
									
										vendored
									
									
								
							| @@ -1,3 +1,5 @@ | ||||
| find_package(Qt5Widgets ${requiredQtVersion}) # to conditionally install desktop-related files | ||||
|  | ||||
| if (APPLE) | ||||
|     add_subdirectory(mac) | ||||
| else (APPLE) | ||||
|   | ||||
							
								
								
									
										2
									
								
								dist/mac/Info.plist
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								dist/mac/Info.plist
									
									
									
									
										vendored
									
									
								
							| @@ -45,7 +45,7 @@ | ||||
| 	<key>CFBundlePackageType</key> | ||||
| 	<string>APPL</string> | ||||
| 	<key>CFBundleShortVersionString</key> | ||||
| 	<string>4.1.0</string> | ||||
| 	<string>4.1.2</string> | ||||
| 	<key>CFBundleSignature</key> | ||||
| 	<string>qBit</string> | ||||
| 	<key>CFBundleExecutable</key> | ||||
|   | ||||
							
								
								
									
										30
									
								
								dist/unix/CMakeLists.txt
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										30
									
								
								dist/unix/CMakeLists.txt
									
									
									
									
										vendored
									
									
								
							| @@ -1,31 +1,37 @@ | ||||
| if (SYSTEMD) | ||||
|     find_package(Systemd) | ||||
|     if (SYSTEMD_FOUND) | ||||
| if (NOT Qt5Widgets_FOUND) | ||||
|     feature_option(SYSTEMD "Install systemd service file (headless only)" OFF) | ||||
|     if (SYSTEMD) | ||||
|         if (NOT Systemd_SERVICES_INSTALL_DIR) | ||||
|             find_package(Systemd) | ||||
|             if (NOT Systemd_FOUND) | ||||
|                 message(FATAL_ERROR "Could not locate systemd services install dir." | ||||
|                 " Either pass -DSystemd_SERVICES_INSTALL_DIR=/path/to/systemd/services option or install systemd pkg-config") | ||||
|             endif(NOT Systemd_FOUND) | ||||
|         endif(NOT Systemd_SERVICES_INSTALL_DIR) | ||||
|         set(EXPAND_BINDIR ${CMAKE_INSTALL_FULL_BINDIR}) | ||||
|         configure_file(systemd/qbittorrent-nox@.service.in ${CMAKE_CURRENT_BINARY_DIR}/qbittorrent-nox@.service @ONLY) | ||||
|         install(FILES ${CMAKE_CURRENT_BINARY_DIR}/qbittorrent-nox@.service | ||||
|             DESTINATION ${SYSTEMD_SERVICES_INSTALL_DIR} | ||||
|             DESTINATION ${Systemd_SERVICES_INSTALL_DIR} | ||||
|             COMPONENT data) | ||||
|     endif(SYSTEMD_FOUND) | ||||
| endif(SYSTEMD) | ||||
|     endif(SYSTEMD) | ||||
| endif() | ||||
|  | ||||
|  | ||||
| if (GUI) | ||||
| if (Qt5Widgets_FOUND) | ||||
|     list(APPEND MAN_FILES ${qBittorrent_SOURCE_DIR}/doc/qbittorrent.1) | ||||
| else (GUI) | ||||
| else (Qt5Widgets_FOUND) | ||||
|     list(APPEND MAN_FILES ${qBittorrent_SOURCE_DIR}/doc/qbittorrent-nox.1) | ||||
| endif (GUI) | ||||
| endif (Qt5Widgets_FOUND) | ||||
|  | ||||
| install(FILES ${MAN_FILES} | ||||
|         DESTINATION ${CMAKE_INSTALL_MANDIR}/man1 | ||||
|         COMPONENT doc) | ||||
|  | ||||
| if (GUI) | ||||
| if (Qt5Widgets_FOUND) | ||||
|     install(DIRECTORY menuicons/ | ||||
|             DESTINATION ${CMAKE_INSTALL_DATAROOTDIR}/icons/hicolor | ||||
|             FILES_MATCHING PATTERN "*.png") | ||||
|  | ||||
|     install(FILES ${qBittorrent_SOURCE_DIR}/src/icons/qbittorrent.desktop | ||||
|     install(FILES qbittorrent.desktop | ||||
|             DESTINATION ${CMAKE_INSTALL_DATAROOTDIR}/applications/ | ||||
|             COMPONENT data) | ||||
|  | ||||
|   | ||||
							
								
								
									
										2
									
								
								dist/windows/options.nsi
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								dist/windows/options.nsi
									
									
									
									
										vendored
									
									
								
							| @@ -27,7 +27,7 @@ XPStyle on | ||||
| !define CSIDL_LOCALAPPDATA '0x1C' ;Local Application Data path | ||||
|  | ||||
| ; Program specific | ||||
| !define PROG_VERSION "4.1.0" | ||||
| !define PROG_VERSION "4.1.2" | ||||
|  | ||||
| !define MUI_FINISHPAGE_RUN | ||||
| !define MUI_FINISHPAGE_RUN_FUNCTION PageFinishRun | ||||
|   | ||||
| @@ -3,7 +3,6 @@ TEMPLATE = subdirs | ||||
| SUBDIRS += src | ||||
|  | ||||
| include(version.pri) | ||||
| include(qm_gen.pri) | ||||
|  | ||||
| # Make target to create release tarball. Use 'make tarball' | ||||
| tarball.commands += rm -fR ../$${PROJECT_NAME}-$${PROJECT_VERSION}/ && | ||||
| @@ -18,6 +17,10 @@ tarball.commands += rm -fR $${PROJECT_NAME}-$${PROJECT_VERSION} | ||||
|  | ||||
| QMAKE_EXTRA_TARGETS += tarball | ||||
|  | ||||
| # Translations included here (at top level) is to avoid regenerating the .qm files | ||||
| # every time when src.pro is processed | ||||
| include(src/lang/lang.pri) | ||||
|  | ||||
| # For Qt Creator beautifier | ||||
| DISTFILES += \ | ||||
|     uncrustify.cfg | ||||
|   | ||||
							
								
								
									
										21
									
								
								qm_gen.pri
									
									
									
									
									
								
							
							
						
						
									
										21
									
								
								qm_gen.pri
									
									
									
									
									
								
							| @@ -1,21 +0,0 @@ | ||||
| TS_IN = $$fromfile(src/src.pro,TRANSLATIONS) | ||||
| TS_IN_NOEXT = $$replace(TS_IN,".ts","") | ||||
|  | ||||
| isEmpty(QMAKE_LRELEASE) { | ||||
|     win32:QMAKE_LRELEASE = $$[QT_INSTALL_BINS]\\lrelease.exe | ||||
|     else:QMAKE_LRELEASE = $$[QT_INSTALL_BINS]/lrelease | ||||
|     unix { | ||||
|       equals(QT_MAJOR_VERSION, 5) { | ||||
|         !exists($$QMAKE_LRELEASE) { QMAKE_LRELEASE = lrelease-qt5 } | ||||
|       } | ||||
|     } else { | ||||
|         !exists($$QMAKE_LRELEASE) { QMAKE_LRELEASE = lrelease } | ||||
|     } | ||||
| } | ||||
|  | ||||
| message("Building translations") | ||||
| for(L,TS_IN_NOEXT) { | ||||
|     message("Processing $${L}") | ||||
|     system("$$QMAKE_LRELEASE -silent src/$${L}.ts -qm src/$${L}.qm") | ||||
|     !exists("src/$${L}.qm"):error("Building translations failed, cannot continue") | ||||
| } | ||||
| @@ -1,40 +1,45 @@ | ||||
| set(CMAKE_CXX_STANDARD_REQUIRED True) | ||||
| set(CMAKE_CXX_STANDARD "11") | ||||
| add_definitions(-DBOOST_NO_CXX11_RVALUE_REFERENCES) | ||||
|  | ||||
| include(MacroQbtCompilerSettings) | ||||
| qbt_set_compiler_options() | ||||
|  | ||||
| include(MacroLinkQtComponents) | ||||
| include(QbtTargetSources) | ||||
|  | ||||
| find_package(Boost ${requiredBoostVersion} REQUIRED) | ||||
| find_package(LibtorrentRasterbar REQUIRED) | ||||
|  | ||||
| # Qt | ||||
| list(APPEND QBT_QT_COMPONENTS Core Network Xml) | ||||
| if (GUI) | ||||
|     list (APPEND QBT_QT_COMPONENTS Gui Svg Widgets) | ||||
|     if (WIN32) | ||||
|         list (APPEND QBT_QT_COMPONENTS WinExtras) | ||||
|     endif(WIN32) | ||||
|     if (APPLE) | ||||
|         list (APPEND QBT_GUI_OPTIONAL_LINK_LIBRARIES objc) | ||||
|         list (APPEND QBT_QT_COMPONENTS MacExtras) | ||||
|     endif (APPLE) | ||||
| endif (GUI) | ||||
| if (DBUS) | ||||
|     list (APPEND QBT_QT_COMPONENTS DBus) | ||||
| endif (DBUS) | ||||
| find_package(Qt5 5.5.1 COMPONENTS ${QBT_QT_COMPONENTS} REQUIRED) | ||||
| if (Boost_VERSION VERSION_LESS 106000) | ||||
|     add_definitions(-DBOOST_NO_CXX11_RVALUE_REFERENCES) | ||||
| endif() | ||||
|  | ||||
| if (GUI AND APPLE) | ||||
|     # Fix MOC inability to detect macOS. This seems to only affect cmake. | ||||
|     # Relevant issue: https://bugreports.qt.io/browse/QTBUG-58325 | ||||
|     set(CMAKE_AUTOMOC_MOC_OPTIONS ${CMAKE_AUTOMOC_MOC_OPTIONS} -DQ_OS_MAC) | ||||
| endif () | ||||
| find_package(Qt5 ${requiredQtVersion} REQUIRED COMPONENTS Core Network Xml) | ||||
| find_package(Qt5Widgets ${requiredQtVersion}) | ||||
| if (Qt5Widgets_FOUND) | ||||
|     find_package(Qt5DBus ${requiredQtVersion}) | ||||
| else() | ||||
|     add_definitions(-DDISABLE_GUI) | ||||
| endif() | ||||
|  | ||||
| set_package_properties(Qt5Widgets PROPERTIES | ||||
|     DESCRIPTION "Set of components for creating classic desktop-style UIs for the Qt5 framework" | ||||
|     PURPOSE "Enables qBittorrent GUI. Unneeded for headless configuration." | ||||
|     TYPE OPTIONAL | ||||
| ) | ||||
|  | ||||
| set_package_properties(Qt5DBus PROPERTIES | ||||
|     DESCRIPTION "Qt5 module for inter-process communication over the D-Bus protocol" | ||||
|     PURPOSE "Enables communication with other system components (e.g. notification service) via D-Bus. " | ||||
|     TYPE RECOMMENDED | ||||
| ) | ||||
|  | ||||
| set(CMAKE_AUTOMOC True) | ||||
| list(APPEND CMAKE_AUTORCC_OPTIONS -compress 9 -threshold 5) | ||||
| if (APPLE) | ||||
|     # Workaround CMake bug (autogen does not pass required parameters to moc) | ||||
|     # Relevant issue: https://gitlab.kitware.com/cmake/cmake/issues/18041 | ||||
|     list(APPEND CMAKE_AUTOMOC_MOC_OPTIONS -DQ_OS_MAC -DQ_OS_DARWIN) | ||||
| endif () | ||||
|  | ||||
| include_directories(${CMAKE_CURRENT_SOURCE_DIR}) | ||||
|  | ||||
| @@ -43,56 +48,34 @@ add_definitions(-DQT_NO_CAST_TO_ASCII) | ||||
| # Efficient construction for QString & QByteArray (Qt >= 4.8) | ||||
| add_definitions(-DQT_USE_QSTRINGBUILDER) | ||||
|  | ||||
| if (NOT GUI) | ||||
|     add_definitions(-DDISABLE_GUI -DDISABLE_COUNTRIES_RESOLUTION) | ||||
| endif (NOT GUI) | ||||
|  | ||||
| if (NOT WEBUI) | ||||
|     add_definitions(-DDISABLE_WEBUI) | ||||
| endif (NOT WEBUI) | ||||
|  | ||||
| if (STACKTRACE) | ||||
|     add_definitions(-DSTACKTRACE) | ||||
| endif(STACKTRACE) | ||||
| # nogui { | ||||
| #     TARGET = qbittorrent-nox | ||||
| # } else { | ||||
| #     CONFIG(static) { | ||||
| #         DEFINES += QBT_STATIC_QT | ||||
| #         QTPLUGIN += qico | ||||
| #     } | ||||
| #     TARGET = qbittorrent | ||||
| # } | ||||
|  | ||||
| if (UNIX AND NOT APPLE) | ||||
|     add_compile_options(-Wformat -Wformat-security) | ||||
| endif () | ||||
|  | ||||
| if (CMAKE_BUILD_TYPE STREQUAL "Debug") | ||||
| if (CMAKE_BUILD_TYPE MATCHES "Debug") | ||||
|     message(STATUS "Project is built in DEBUG mode.") | ||||
| else (CMAKE_BUILD_TYPE STREQUAL "Debug") | ||||
| else() | ||||
|     message(STATUS "Project is built in RELEASE mode.") | ||||
|     message(STATUS "Disabling debug output.") | ||||
|     add_definitions(-DQT_NO_DEBUG_OUTPUT) | ||||
| endif (CMAKE_BUILD_TYPE STREQUAL "Debug") | ||||
|  | ||||
| set(QBT_USE_GUI ${GUI}) | ||||
| set(QBT_USE_WEBUI ${WEBUI}) | ||||
| endif() | ||||
|  | ||||
| configure_file(config.h.cmakein ${CMAKE_CURRENT_BINARY_DIR}/config.h) | ||||
|  | ||||
| if (SYSTEM_QTSINGLEAPPLICATION) | ||||
|     find_package(QtSingleApplication REQUIRED) | ||||
| else (SYSTEM_QTSINGLEAPPLICATION) | ||||
| find_package(QtSingleApplication) | ||||
| set_package_properties(QtSingleApplication PROPERTIES | ||||
|     URL "https://code.qt.io/cgit/qt-solutions/qt-solutions.git/" | ||||
|     DESCRIPTION "Qt library to start applications only once per user" | ||||
|     TYPE RECOMMENDED | ||||
|     PURPOSE "Use the system qtsingleapplication library or shipped one otherwise" | ||||
| ) | ||||
|  | ||||
| if (NOT QtSingleApplication_FOUND) | ||||
|     add_subdirectory(app/qtsingleapplication) | ||||
| endif (SYSTEM_QTSINGLEAPPLICATION) | ||||
| endif () | ||||
|  | ||||
| add_subdirectory(app) | ||||
| add_subdirectory(base) | ||||
|  | ||||
| if (GUI) | ||||
| if (Qt5Widgets_FOUND) | ||||
|     add_subdirectory(gui) | ||||
| endif (GUI) | ||||
| endif () | ||||
|  | ||||
| if (WEBUI) | ||||
|     add_subdirectory(webui) | ||||
|   | ||||
| @@ -1,19 +1,27 @@ | ||||
| project(qbt_executable) | ||||
| include_directories(${CMAKE_CURRENT_BINARY_DIR}) | ||||
|  | ||||
| set(QBT_APP_HEADERS | ||||
| add_executable(qBittorrent | ||||
| application.h | ||||
| cmdoptions.h | ||||
| filelogger.h | ||||
| ) | ||||
|  | ||||
| set(QBT_APP_SOURCES | ||||
| upgrade.h | ||||
| application.cpp | ||||
| cmdoptions.cpp | ||||
| filelogger.cpp | ||||
| main.cpp | ||||
| ) | ||||
|  | ||||
| target_include_directories(qBittorrent PRIVATE ${CMAKE_CURRENT_BINARY_DIR}) | ||||
| target_link_libraries(qBittorrent | ||||
|     PRIVATE | ||||
|         qbt_base | ||||
| ) | ||||
|  | ||||
| set_target_properties(qBittorrent | ||||
|     PROPERTIES | ||||
|         AUTOUIC True | ||||
|         AUTORCC True | ||||
|         MACOSX_BUNDLE True | ||||
| ) | ||||
|  | ||||
| # translations | ||||
| file(GLOB QBT_TS_FILES ../lang/*.ts) | ||||
| get_filename_component(QBT_QM_FILES_BINARY_DIR "${CMAKE_CURRENT_BINARY_DIR}/../lang" ABSOLUTE) | ||||
| @@ -22,9 +30,9 @@ set_source_files_properties(${QBT_TS_FILES} PROPERTIES OUTPUT_LOCATION "${QBT_QM | ||||
| find_package(Qt5 COMPONENTS LinguistTools REQUIRED) | ||||
| qt5_add_translation(QBT_QM_FILES ${QBT_TS_FILES}) | ||||
|  | ||||
| get_filename_component(_lang_qrc_src "${CMAKE_CURRENT_SOURCE_DIR}/../lang.qrc" ABSOLUTE) | ||||
| get_filename_component(_lang_qrc_dst "${CMAKE_CURRENT_BINARY_DIR}/../lang.qrc" ABSOLUTE) | ||||
| get_filename_component(_lang_qrc_dst_dir "${CMAKE_CURRENT_BINARY_DIR}/../" ABSOLUTE) | ||||
| get_filename_component(_lang_qrc_src "${CMAKE_CURRENT_SOURCE_DIR}/../lang/lang.qrc" ABSOLUTE) | ||||
| get_filename_component(_lang_qrc_dst "${CMAKE_CURRENT_BINARY_DIR}/../lang/lang.qrc" ABSOLUTE) | ||||
| get_filename_component(_lang_qrc_dst_dir "${CMAKE_CURRENT_BINARY_DIR}/../lang" ABSOLUTE) | ||||
|  | ||||
| message(STATUS "copying ${_lang_qrc_src} -> ${_lang_qrc_dst}") | ||||
| file(COPY ${_lang_qrc_src} DESTINATION ${_lang_qrc_dst_dir}) | ||||
| @@ -35,8 +43,8 @@ foreach(qm_file ${QBT_QM_FILES}) | ||||
| endforeach() | ||||
|  | ||||
| set(QBT_APP_RESOURCES | ||||
| ../icons.qrc | ||||
| ../searchengine.qrc | ||||
| ../icons/icons.qrc | ||||
| ../searchengine/searchengine.qrc | ||||
| "${_lang_qrc_dst}" | ||||
| ) | ||||
|  | ||||
| @@ -46,51 +54,41 @@ qt5_add_resources(QBT_APP_RESOURCE_SOURCE ${QBT_APP_RESOURCES}) | ||||
|  | ||||
| if (WIN32) | ||||
|     if (MINGW) | ||||
|         list (APPEND QBT_APP_SOURCES ../qbittorrent_mingw.rc) | ||||
|         target_sources(qBittorrent PRIVATE ../qbittorrent_mingw.rc) | ||||
|     else (MINGW) | ||||
|         list (APPEND QBT_APP_SOURCES ../qbittorrent.rc) | ||||
|         target_sources(qBittorrent PRIVATE ../qbittorrent.rc) | ||||
|     endif (MINGW) | ||||
|     list(APPEND QBT_APP_SOURCES ../qbittorrent.exe.manifest) | ||||
|     target_sources(qBittorrent PRIVATE ../qbittorrent.exe.manifest) | ||||
| endif (WIN32) | ||||
|  | ||||
| if (STACKTRACE) | ||||
|     if (UNIX) | ||||
|         list(APPEND QBT_APP_HEADERS stacktrace.h) | ||||
|         target_sources(qBittorrent PRIVATE stacktrace.h) | ||||
|     else (UNIX) | ||||
|         list(APPEND QBT_APP_HEADERS stacktrace_win.h) | ||||
|         if (GUI) | ||||
|             list(APPEND QBT_APP_HEADERS stacktrace_win_dlg.h) | ||||
|         endif (GUI) | ||||
|         target_sources(qBittorrent PRIVATE stacktrace_win.h) | ||||
|         if (Qt5Widgets_FOUND) | ||||
|             target_sources(qBittorrent PRIVATE stacktracedialog.h) | ||||
|         endif (Qt5Widgets_FOUND) | ||||
|     endif (UNIX) | ||||
| endif (STACKTRACE) | ||||
|  | ||||
| # usesystemqtsingleapplication { | ||||
| #     nogui { | ||||
| #         CONFIG += qtsinglecoreapplication | ||||
| #     } else { | ||||
| #         CONFIG += qtsingleapplication | ||||
| #     } | ||||
| # } else { | ||||
| #     nogui { | ||||
| #         include(qtsingleapplication/qtsinglecoreapplication.pri) | ||||
| #     } else { | ||||
| #         include(qtsingleapplication/qtsingleapplication.pri) | ||||
| #     } | ||||
| # } | ||||
|  | ||||
| # upgrade code | ||||
| list(APPEND QBT_APP_HEADERS upgrade.h) | ||||
| list(APPEND QBT_TARGET_LIBRARIES qbt_base) | ||||
|  | ||||
| if (GUI) | ||||
|     list(APPEND QBT_TARGET_LIBRARIES qbt_searchengine qbt_gui) | ||||
|     include_directories(../gui | ||||
|         ${CMAKE_CURRENT_BINARY_DIR}/../gui | ||||
| if (Qt5Widgets_FOUND) | ||||
|     target_link_libraries(qBittorrent PRIVATE qbt_searchengine qbt_gui) | ||||
|     set_target_properties(qBittorrent | ||||
|         PROPERTIES | ||||
|             OUTPUT_NAME qbittorrent | ||||
|             WIN32_EXECUTABLE True | ||||
|     ) | ||||
| endif (GUI) | ||||
| else(Qt5Widgets_FOUND) | ||||
|     set_target_properties(qBittorrent | ||||
|         PROPERTIES | ||||
|             OUTPUT_NAME qbittorrent-nox | ||||
|     ) | ||||
| endif (Qt5Widgets_FOUND) | ||||
|  | ||||
| if (WEBUI) | ||||
|     list(APPEND QBT_TARGET_LIBRARIES qbt_webui) | ||||
|     target_link_libraries(qBittorrent PRIVATE qbt_webui) | ||||
| endif (WEBUI) | ||||
|  | ||||
| # we have to include resources into the bundle | ||||
| @@ -142,30 +140,11 @@ if (APPLE) | ||||
|         PROPERTIES MACOSX_PACKAGE_LOCATION translations) | ||||
| endif (APPLE) | ||||
|  | ||||
| add_executable(qBittorrent ${QBT_APP_HEADERS} ${QBT_APP_SOURCES} ${QBT_QM_FILES} ${QBT_APP_RESOURCE_SOURCE}) | ||||
| if (GUI) | ||||
|     set_target_properties(qBittorrent | ||||
|         PROPERTIES | ||||
|             OUTPUT_NAME qbittorrent | ||||
|             WIN32_EXECUTABLE True | ||||
|     ) | ||||
| else (GUI) | ||||
|     set_target_properties(qBittorrent | ||||
|         PROPERTIES | ||||
|             OUTPUT_NAME qbittorrent-nox | ||||
|     ) | ||||
| endif (GUI) | ||||
|  | ||||
| set_target_properties(qBittorrent | ||||
|     PROPERTIES | ||||
|         AUTOUIC True | ||||
|         AUTORCC True | ||||
|         MACOSX_BUNDLE True | ||||
| ) | ||||
| target_sources(qBittorrent PRIVATE ${QBT_QM_FILES} ${QBT_APP_RESOURCE_SOURCE}) | ||||
|  | ||||
| get_target_property(QBT_EXECUTABLE_NAME qBittorrent OUTPUT_NAME) | ||||
|  | ||||
| target_link_libraries(qBittorrent ${QBT_TARGET_LIBRARIES} QtSingleApplication::QtSingleApplication) | ||||
| target_link_libraries(qBittorrent PRIVATE ${QBT_TARGET_LIBRARIES} QtSingleApplication::QtSingleApplication) | ||||
|  | ||||
| if (APPLE) | ||||
|     set(qbt_BUNDLE_NAME ${QBT_EXECUTABLE_NAME}) | ||||
| @@ -186,6 +165,7 @@ install(TARGETS qBittorrent | ||||
|     BUNDLE  DESTINATION . | ||||
|     COMPONENT runtime) | ||||
|  | ||||
| if (GUI AND APPLE) | ||||
| if (Qt5Widgets_FOUND AND APPLE) | ||||
|     find_package(Qt5Svg REQUIRED) | ||||
|     include(bundle) | ||||
| endif (GUI AND APPLE) | ||||
| endif (Qt5Widgets_FOUND AND APPLE) | ||||
|   | ||||
| @@ -32,8 +32,8 @@ stacktrace { | ||||
|     else { | ||||
|         HEADERS += $$PWD/stacktrace_win.h | ||||
|         !nogui { | ||||
|             HEADERS += $$PWD/stacktrace_win_dlg.h | ||||
|             FORMS += $$PWD/stacktrace_win_dlg.ui | ||||
|             HEADERS += $$PWD/stacktracedialog.h | ||||
|             FORMS += $$PWD/stacktracedialog.ui | ||||
|         } | ||||
|     } | ||||
| } | ||||
|   | ||||
| @@ -31,18 +31,34 @@ | ||||
|  | ||||
| #include <algorithm> | ||||
|  | ||||
| #ifdef Q_OS_WIN | ||||
| #include <memory> | ||||
| #endif | ||||
|  | ||||
| #include <QAtomicInt> | ||||
| #include <QDebug> | ||||
| #include <QFileInfo> | ||||
| #include <QLibraryInfo> | ||||
| #include <QLocale> | ||||
| #include <QProcess> | ||||
| #include <QSysInfo> | ||||
|  | ||||
| #ifdef Q_OS_WIN | ||||
| #include <memory> | ||||
| #include <Shellapi.h> | ||||
| #endif | ||||
|  | ||||
| #ifndef DISABLE_GUI | ||||
| #ifdef Q_OS_WIN | ||||
| #include <QSessionManager> | ||||
| #include <QSharedMemory> | ||||
| #endif // Q_OS_WIN | ||||
| #ifdef Q_OS_MAC | ||||
| #include <QFileOpenEvent> | ||||
| #endif // Q_OS_MAC | ||||
| #include "addnewtorrentdialog.h" | ||||
| #include "gui/guiiconprovider.h" | ||||
| #include "mainwindow.h" | ||||
| #include "shutdownconfirmdialog.h" | ||||
| #else // DISABLE_GUI | ||||
| #include <cstdio> | ||||
| #endif // DISABLE_GUI | ||||
|  | ||||
| #include "base/bittorrent/session.h" | ||||
| #include "base/bittorrent/torrenthandle.h" | ||||
| #include "base/iconprovider.h" | ||||
| @@ -62,28 +78,6 @@ | ||||
| #include "base/utils/string.h" | ||||
| #include "filelogger.h" | ||||
|  | ||||
| #ifndef DISABLE_GUI | ||||
| #ifdef Q_OS_WIN | ||||
| #include <QSessionManager> | ||||
| #include <QSharedMemory> | ||||
| #endif // Q_OS_WIN | ||||
| #ifdef Q_OS_MAC | ||||
| #include <QFileOpenEvent> | ||||
| #include <QFont> | ||||
| #include <QUrl> | ||||
| #endif // Q_OS_MAC | ||||
| #include "addnewtorrentdialog.h" | ||||
| #include "gui/guiiconprovider.h" | ||||
| #include "mainwindow.h" | ||||
| #include "shutdownconfirmdlg.h" | ||||
| #else // DISABLE_GUI | ||||
| #include <cstdio> | ||||
| #endif // DISABLE_GUI | ||||
|  | ||||
| #ifdef Q_OS_WIN | ||||
| #include <Shellapi.h> | ||||
| #endif | ||||
|  | ||||
| #ifndef DISABLE_WEBUI | ||||
| #include "webui/webui.h" | ||||
| #endif | ||||
| @@ -93,7 +87,7 @@ namespace | ||||
| #define SETTINGS_KEY(name) "Application/" name | ||||
|  | ||||
|     // FileLogger properties keys | ||||
| #define FILELOGGER_SETTINGS_KEY(name) SETTINGS_KEY("FileLogger/") name | ||||
| #define FILELOGGER_SETTINGS_KEY(name) QStringLiteral(SETTINGS_KEY("FileLogger/") name) | ||||
|     const QString KEY_FILELOGGER_ENABLED = FILELOGGER_SETTINGS_KEY("Enabled"); | ||||
|     const QString KEY_FILELOGGER_PATH = FILELOGGER_SETTINGS_KEY("Path"); | ||||
|     const QString KEY_FILELOGGER_BACKUP = FILELOGGER_SETTINGS_KEY("Backup"); | ||||
| @@ -102,13 +96,13 @@ namespace | ||||
|     const QString KEY_FILELOGGER_AGE = FILELOGGER_SETTINGS_KEY("Age"); | ||||
|     const QString KEY_FILELOGGER_AGETYPE = FILELOGGER_SETTINGS_KEY("AgeType"); | ||||
|  | ||||
|     //just a shortcut | ||||
|     // just a shortcut | ||||
|     inline SettingsStorage *settings() { return  SettingsStorage::instance(); } | ||||
|  | ||||
|     const QString LOG_FOLDER("logs"); | ||||
|     const char PARAMS_SEPARATOR[] = "|"; | ||||
|     const QString LOG_FOLDER = QStringLiteral("logs"); | ||||
|     const QChar PARAMS_SEPARATOR = '|'; | ||||
|  | ||||
|     const QString DEFAULT_PORTABLE_MODE_PROFILE_DIR = QLatin1String("profile"); | ||||
|     const QString DEFAULT_PORTABLE_MODE_PROFILE_DIR = QStringLiteral("profile"); | ||||
|  | ||||
|     const int MIN_FILELOG_SIZE = 1024; // 1KiB | ||||
|     const int MAX_FILELOG_SIZE = 1000 * 1024 * 1024; // 1000MiB | ||||
| @@ -151,11 +145,11 @@ Application::Application(const QString &id, int &argc, char **argv) | ||||
| #endif | ||||
|  | ||||
| #if defined(Q_OS_WIN) && !defined(DISABLE_GUI) | ||||
|     connect(this, SIGNAL(commitDataRequest(QSessionManager &)), this, SLOT(shutdownCleanup(QSessionManager &)), Qt::DirectConnection); | ||||
|     connect(this, &QGuiApplication::commitDataRequest, this, &Application::shutdownCleanup, Qt::DirectConnection); | ||||
| #endif | ||||
|  | ||||
|     connect(this, SIGNAL(messageReceived(const QString &)), SLOT(processMessage(const QString &))); | ||||
|     connect(this, SIGNAL(aboutToQuit()), SLOT(cleanup())); | ||||
|     connect(this, &Application::messageReceived, this, &Application::processMessage); | ||||
|     connect(this, &QCoreApplication::aboutToQuit, this, &Application::cleanup); | ||||
|  | ||||
|     if (isFileLoggerEnabled()) | ||||
|         m_fileLogger = new FileLogger(fileLoggerPath(), isFileLoggerBackup(), fileLoggerMaxSize(), isFileLoggerDeleteOld(), fileLoggerAge(), static_cast<FileLogger::FileLogAgeType>(fileLoggerAgeType())); | ||||
| @@ -261,17 +255,17 @@ void Application::setFileLoggerAge(const int value) | ||||
| int Application::fileLoggerAgeType() const | ||||
| { | ||||
|     int val = settings()->loadValue(KEY_FILELOGGER_AGETYPE, 1).toInt(); | ||||
|     return (val < 0 || val > 2) ? 1 : val; | ||||
|     return ((val < 0) || (val > 2)) ? 1 : val; | ||||
| } | ||||
|  | ||||
| void Application::setFileLoggerAgeType(const int value) | ||||
| { | ||||
|     settings()->storeValue(KEY_FILELOGGER_AGETYPE, (value < 0 || value > 2) ? 1 : value); | ||||
|     settings()->storeValue(KEY_FILELOGGER_AGETYPE, ((value < 0) || (value > 2)) ? 1 : value); | ||||
| } | ||||
|  | ||||
| void Application::processMessage(const QString &message) | ||||
| { | ||||
|     QStringList params = message.split(QLatin1String(PARAMS_SEPARATOR), QString::SkipEmptyParts); | ||||
|     QStringList params = message.split(PARAMS_SEPARATOR, QString::SkipEmptyParts); | ||||
|     // If Application is not running (i.e., other | ||||
|     // components are not ready) store params | ||||
|     if (m_running) | ||||
| @@ -290,9 +284,21 @@ void Application::runExternalProgram(const BitTorrent::TorrentHandle *torrent) c | ||||
|     std::sort(tags.begin(), tags.end(), Utils::String::naturalLessThan<Qt::CaseInsensitive>); | ||||
|     program.replace("%G", tags.join(',')); | ||||
|  | ||||
| #if defined(Q_OS_WIN) | ||||
|     const auto chopPathSep = [](const QString &str) -> QString | ||||
|     { | ||||
|         if (str.endsWith('\\')) | ||||
|             return str.mid(0, (str.length() -1)); | ||||
|         return str; | ||||
|     }; | ||||
|     program.replace("%F", chopPathSep(Utils::Fs::toNativePath(torrent->contentPath()))); | ||||
|     program.replace("%R", chopPathSep(Utils::Fs::toNativePath(torrent->rootPath()))); | ||||
|     program.replace("%D", chopPathSep(Utils::Fs::toNativePath(torrent->savePath()))); | ||||
| #else | ||||
|     program.replace("%F", Utils::Fs::toNativePath(torrent->contentPath())); | ||||
|     program.replace("%R", Utils::Fs::toNativePath(torrent->rootPath())); | ||||
|     program.replace("%D", Utils::Fs::toNativePath(torrent->savePath())); | ||||
| #endif | ||||
|     program.replace("%C", QString::number(torrent->filesCount())); | ||||
|     program.replace("%Z", QString::number(torrent->totalSize())); | ||||
|     program.replace("%T", torrent->currentTracker()); | ||||
| @@ -301,9 +307,7 @@ void Application::runExternalProgram(const BitTorrent::TorrentHandle *torrent) c | ||||
|     Logger *logger = Logger::instance(); | ||||
|     logger->addMessage(tr("Torrent: %1, running external program, command: %2").arg(torrent->name(), program)); | ||||
|  | ||||
| #if defined(Q_OS_UNIX) | ||||
|     QProcess::startDetached(QLatin1String("/bin/sh"), {QLatin1String("-c"), program}); | ||||
| #else | ||||
| #if defined(Q_OS_WIN) | ||||
|     std::unique_ptr<wchar_t[]> programWchar(new wchar_t[program.length() + 1] {}); | ||||
|     program.toWCharArray(programWchar.get()); | ||||
|  | ||||
| @@ -320,18 +324,20 @@ void Application::runExternalProgram(const BitTorrent::TorrentHandle *torrent) c | ||||
|     QProcess::startDetached(QString::fromWCharArray(args[0]), argList); | ||||
|  | ||||
|     ::LocalFree(args); | ||||
| #else | ||||
|     QProcess::startDetached(QLatin1String("/bin/sh"), {QLatin1String("-c"), program}); | ||||
| #endif | ||||
| } | ||||
|  | ||||
| void Application::sendNotificationEmail(const BitTorrent::TorrentHandle *torrent) | ||||
| { | ||||
|     // Prepare mail content | ||||
|     const QString content = tr("Torrent name: %1").arg(torrent->name()) + "\n" | ||||
|         + tr("Torrent size: %1").arg(Utils::Misc::friendlyUnit(torrent->wantedSize())) + "\n" | ||||
|     const QString content = tr("Torrent name: %1").arg(torrent->name()) + '\n' | ||||
|         + tr("Torrent size: %1").arg(Utils::Misc::friendlyUnit(torrent->wantedSize())) + '\n' | ||||
|         + tr("Save path: %1").arg(torrent->savePath()) + "\n\n" | ||||
|         + tr("The torrent was downloaded in %1.", "The torrent was downloaded in 1 hour and 20 seconds") | ||||
|             .arg(Utils::Misc::userFriendlyDuration(torrent->activeTime())) + "\n\n\n" | ||||
|         + tr("Thank you for using qBittorrent.") + "\n"; | ||||
|         + tr("Thank you for using qBittorrent.") + '\n'; | ||||
|  | ||||
|     // Send the notification email | ||||
|     const Preferences *pref = Preferences::instance(); | ||||
| @@ -382,7 +388,7 @@ void Application::allTorrentsFinished() | ||||
|         // do nothing & skip confirm | ||||
|     } | ||||
|     else { | ||||
|         if (!ShutdownConfirmDlg::askForConfirmation(m_window, action)) return; | ||||
|         if (!ShutdownConfirmDialog::askForConfirmation(m_window, action)) return; | ||||
|     } | ||||
| #endif // DISABLE_GUI | ||||
|  | ||||
| @@ -403,7 +409,7 @@ void Application::allTorrentsFinished() | ||||
|  | ||||
| bool Application::sendParams(const QStringList ¶ms) | ||||
| { | ||||
|     return sendMessage(params.join(QLatin1String(PARAMS_SEPARATOR))); | ||||
|     return sendMessage(params.join(PARAMS_SEPARATOR)); | ||||
| } | ||||
|  | ||||
| // As program parameters, we can get paths or urls. | ||||
| @@ -489,8 +495,8 @@ int Application::exec(const QStringList ¶ms) | ||||
| #endif | ||||
|  | ||||
|     BitTorrent::Session::initInstance(); | ||||
|     connect(BitTorrent::Session::instance(), SIGNAL(torrentFinished(BitTorrent::TorrentHandle *const)), SLOT(torrentFinished(BitTorrent::TorrentHandle *const))); | ||||
|     connect(BitTorrent::Session::instance(), SIGNAL(allTorrentsFinished()), SLOT(allTorrentsFinished()), Qt::QueuedConnection); | ||||
|     connect(BitTorrent::Session::instance(), &BitTorrent::Session::torrentFinished, this, &Application::torrentFinished); | ||||
|     connect(BitTorrent::Session::instance(), &BitTorrent::Session::allTorrentsFinished, this, &Application::allTorrentsFinished, Qt::QueuedConnection); | ||||
|  | ||||
| #ifndef DISABLE_COUNTRIES_RESOLUTION | ||||
|     Net::GeoIPManager::initInstance(); | ||||
| @@ -511,7 +517,7 @@ int Application::exec(const QStringList ¶ms) | ||||
|  | ||||
| #ifdef DISABLE_GUI | ||||
| #ifndef DISABLE_WEBUI | ||||
|     Preferences* const pref = Preferences::instance(); | ||||
|     Preferences *const pref = Preferences::instance(); | ||||
|     // Display some information to the user | ||||
|     const QString mesg = QString("\n******** %1 ********\n").arg(tr("Information")) | ||||
|         + tr("To control qBittorrent, access the Web UI at %1") | ||||
| @@ -607,7 +613,7 @@ bool Application::notify(QObject *receiver, QEvent *event) | ||||
|  | ||||
| void Application::initializeTranslation() | ||||
| { | ||||
|     Preferences* const pref = Preferences::instance(); | ||||
|     Preferences *const pref = Preferences::instance(); | ||||
|     // Load translation | ||||
|     QString localeStr = pref->getLocale(); | ||||
|  | ||||
| @@ -660,7 +666,7 @@ void Application::shutdownCleanup(QSessionManager &manager) | ||||
|     // According to the qt docs we shouldn't call quit() inside a slot. | ||||
|     // aboutToQuit() is never emitted if the user hits "Cancel" in | ||||
|     // the above dialog. | ||||
|     QTimer::singleShot(0, qApp, SLOT(quit())); | ||||
|     QTimer::singleShot(0, qApp, &QCoreApplication::quit); | ||||
| } | ||||
| #endif | ||||
|  | ||||
| @@ -673,7 +679,7 @@ void Application::cleanup() | ||||
|  | ||||
| #ifndef DISABLE_GUI | ||||
|     if (m_window) { | ||||
|         // Hide the window and not leave it on screen as | ||||
|         // Hide the window and don't leave it on screen as | ||||
|         // unresponsive. Also for Windows take the WinId | ||||
|         // after it's hidden, because hide() may cause a | ||||
|         // WinId change. | ||||
|   | ||||
| @@ -40,15 +40,13 @@ typedef QtSingleApplication BaseApplication; | ||||
| class MainWindow; | ||||
|  | ||||
| #ifdef Q_OS_WIN | ||||
| QT_BEGIN_NAMESPACE | ||||
| class QSessionManager; | ||||
| QT_END_NAMESPACE | ||||
| #endif // Q_OS_WIN | ||||
|  | ||||
| #else | ||||
| #include "qtsinglecoreapplication.h" | ||||
| typedef QtSingleCoreApplication BaseApplication; | ||||
| #endif | ||||
| #endif // DISABLE_GUI | ||||
|  | ||||
| #include "base/utils/misc.h" | ||||
| #include "cmdoptions.h" | ||||
| @@ -110,9 +108,9 @@ public: | ||||
| protected: | ||||
| #ifndef DISABLE_GUI | ||||
| #ifdef Q_OS_MAC | ||||
|     bool event(QEvent *); | ||||
|     bool event(QEvent *) override; | ||||
| #endif | ||||
|     bool notify(QObject* receiver, QEvent* event) override; | ||||
|     bool notify(QObject *receiver, QEvent *event) override; | ||||
| #endif | ||||
|  | ||||
| private slots: | ||||
|   | ||||
| @@ -2,7 +2,7 @@ | ||||
|  * Bittorrent Client using Qt and libtorrent. | ||||
|  * Copyright (C) 2016  Eugene Shalygin <eugene.shalygin@gmail.com> | ||||
|  * Copyright (C) 2014  Vladimir Golovnev <glassez@yandex.ru> | ||||
|  * Copyright (C) 2006  Christophe Dumez | ||||
|  * Copyright (C) 2006  Christophe Dumez <chris@qbittorrent.org> | ||||
|  * | ||||
|  * This program is free software; you can redistribute it and/or | ||||
|  * modify it under the terms of the GNU General Public License | ||||
| @@ -26,8 +26,6 @@ | ||||
|  * modify file(s), you may extend this exception to your version of the file(s), | ||||
|  * but you are not obligated to do so. If you do not wish to do so, delete this | ||||
|  * exception statement from your version. | ||||
|  * | ||||
|  * Contact : chris@qbittorrent.org | ||||
|  */ | ||||
|  | ||||
| #include "cmdoptions.h" | ||||
| @@ -100,7 +98,7 @@ namespace | ||||
|     }; | ||||
|  | ||||
|     // Boolean option. | ||||
|     class BoolOption: protected Option | ||||
|     class BoolOption : protected Option | ||||
|     { | ||||
|     public: | ||||
|         constexpr BoolOption(const char *name, char shortcut = 0) | ||||
| @@ -118,7 +116,7 @@ namespace | ||||
|         { | ||||
|             QString val = env.value(envVarName()); | ||||
|             // we accept "1" and "true" (upper or lower cased) as boolean 'true' values | ||||
|             return (val == QLatin1String("1") || val.toUpper() == QLatin1String("TRUE")); | ||||
|             return ((val == QLatin1String("1")) || (val.toUpper() == QLatin1String("TRUE"))); | ||||
|         } | ||||
|  | ||||
|         QString usage() const | ||||
| @@ -137,7 +135,7 @@ namespace | ||||
|     } | ||||
|  | ||||
|     // Option with string value. May not have a shortcut | ||||
|     struct StringOption: protected Option | ||||
|     struct StringOption : protected Option | ||||
|     { | ||||
|     public: | ||||
|         constexpr StringOption(const char *name) | ||||
| @@ -184,7 +182,7 @@ namespace | ||||
|     } | ||||
|  | ||||
|     // Option with integer value. May not have a shortcut | ||||
|     class IntOption: protected StringOption | ||||
|     class IntOption : protected StringOption | ||||
|     { | ||||
|     public: | ||||
|         constexpr IntOption(const char *name) | ||||
| @@ -230,7 +228,7 @@ namespace | ||||
|  | ||||
|     // Option that is explicitly set to true or false, and whose value is undefined when unspecified. | ||||
|     // May not have a shortcut. | ||||
|     class TriStateBoolOption: protected Option | ||||
|     class TriStateBoolOption : protected Option | ||||
|     { | ||||
|     public: | ||||
|         constexpr TriStateBoolOption(const char *name, bool defaultValue) | ||||
| @@ -260,10 +258,10 @@ namespace | ||||
|             else if (parts.size() == 2) { | ||||
|                 QString val = parts[1]; | ||||
|  | ||||
|                 if (val.toUpper() == QLatin1String("TRUE") || val == QLatin1String("1")) { | ||||
|                 if ((val.toUpper() == QLatin1String("TRUE")) || (val == QLatin1String("1"))) { | ||||
|                     return TriStateBool::True; | ||||
|                 } | ||||
|                 else if (val.toUpper() == QLatin1String("FALSE") || val == QLatin1String("0")) { | ||||
|                 else if ((val.toUpper() == QLatin1String("FALSE")) || (val == QLatin1String("0"))) { | ||||
|                     return TriStateBool::False; | ||||
|                 } | ||||
|             } | ||||
| @@ -285,10 +283,10 @@ namespace | ||||
|             else if (val == QLatin1String("-1")) { | ||||
|                 return TriStateBool::Undefined; | ||||
|             } | ||||
|             else if (val.toUpper() == QLatin1String("TRUE") || val == QLatin1String("1")) { | ||||
|             else if ((val.toUpper() == QLatin1String("TRUE")) || (val == QLatin1String("1"))) { | ||||
|                 return TriStateBool::True; | ||||
|             } | ||||
|             else if (val.toUpper() == QLatin1String("FALSE") || val == QLatin1String("0")) { | ||||
|             else if ((val.toUpper() == QLatin1String("FALSE")) || (val == QLatin1String("0"))) { | ||||
|                 return TriStateBool::False; | ||||
|             } | ||||
|             else { | ||||
| @@ -360,7 +358,7 @@ QStringList QBtCommandLineParameters::paramList() const | ||||
|     // the user has specified. Here we place special strings that are | ||||
|     // almost certainly not going to collide with a file path or URL | ||||
|     // specified by the user, and placing them at the beginning of the | ||||
|     // string listr so that they will be processed before the list of | ||||
|     // string list so that they will be processed before the list of | ||||
|     // torrent paths or URLs. | ||||
|  | ||||
|     if (!savePath.isEmpty()) | ||||
| @@ -404,9 +402,9 @@ QBtCommandLineParameters parseCommandLine(const QStringList &args) | ||||
|         const QString &arg = args[i]; | ||||
|  | ||||
|         if ((arg.startsWith("--") && !arg.endsWith(".torrent")) | ||||
|             || (arg.startsWith("-") && (arg.size() == 2))) { | ||||
|             || (arg.startsWith('-') && (arg.size() == 2))) { | ||||
|             // Parse known parameters | ||||
|             if ((arg == SHOW_HELP_OPTION)) { | ||||
|             if (arg == SHOW_HELP_OPTION) { | ||||
|                 result.showHelp = true; | ||||
|             } | ||||
| #ifndef Q_OS_WIN | ||||
| @@ -501,7 +499,7 @@ QString wrapText(const QString &text, int initialIndentation = USAGE_TEXT_COLUMN | ||||
|  | ||||
|     foreach (const QString &word, words.mid(1)) { | ||||
|         if (lines.last().length() + word.length() + 1 < currentLineMaxLength) { | ||||
|             lines.last().append(" " + word); | ||||
|             lines.last().append(' ' + word); | ||||
|         } | ||||
|         else { | ||||
|             lines.append(QString(initialIndentation, ' ') + word); | ||||
| @@ -509,7 +507,7 @@ QString wrapText(const QString &text, int initialIndentation = USAGE_TEXT_COLUMN | ||||
|         } | ||||
|     } | ||||
|  | ||||
|     return lines.join("\n"); | ||||
|     return lines.join('\n'); | ||||
| } | ||||
|  | ||||
| QString makeUsage(const QString &prgName) | ||||
|   | ||||
| @@ -2,7 +2,7 @@ | ||||
|  * Bittorrent Client using Qt and libtorrent. | ||||
|  * Copyright (C) 2016  Eugene Shalygin <eugene.shalygin@gmail.com> | ||||
|  * Copyright (C) 2014  Vladimir Golovnev <glassez@yandex.ru> | ||||
|  * Copyright (C) 2006  Christophe Dumez | ||||
|  * Copyright (C) 2006  Christophe Dumez <chris@qbittorrent.org> | ||||
|  * | ||||
|  * This program is free software; you can redistribute it and/or | ||||
|  * modify it under the terms of the GNU General Public License | ||||
| @@ -26,8 +26,6 @@ | ||||
|  * modify file(s), you may extend this exception to your version of the file(s), | ||||
|  * but you are not obligated to do so. If you do not wish to do so, delete this | ||||
|  * exception statement from your version. | ||||
|  * | ||||
|  * Contact : chris@qbittorrent.org | ||||
|  */ | ||||
|  | ||||
| #ifndef APP_OPTIONS_H | ||||
| @@ -62,11 +60,11 @@ struct QBtCommandLineParameters | ||||
|     QStringList paramList() const; | ||||
| }; | ||||
|  | ||||
| class CommandLineParameterError: public std::runtime_error | ||||
| class CommandLineParameterError : public std::runtime_error | ||||
| { | ||||
| public: | ||||
|     CommandLineParameterError(const QString &messageForUser); | ||||
|     const QString& messageForUser() const; | ||||
|     const QString &messageForUser() const; | ||||
|  | ||||
| private: | ||||
|     const QString m_messageForUser; | ||||
|   | ||||
| @@ -26,11 +26,13 @@ | ||||
|  * exception statement from your version. | ||||
|  */ | ||||
|  | ||||
| #include "filelogger.h" | ||||
|  | ||||
| #include <QDateTime> | ||||
| #include <QDir> | ||||
| #include <QFile> | ||||
| #include <QTextStream> | ||||
| #include "filelogger.h" | ||||
|  | ||||
| #include "base/logger.h" | ||||
| #include "base/utils/fs.h" | ||||
|  | ||||
| @@ -41,17 +43,17 @@ FileLogger::FileLogger(const QString &path, const bool backup, const int maxSize | ||||
| { | ||||
|     m_flusher.setInterval(0); | ||||
|     m_flusher.setSingleShot(true); | ||||
|     connect(&m_flusher, SIGNAL(timeout()), SLOT(flushLog())); | ||||
|     connect(&m_flusher, &QTimer::timeout, this, &FileLogger::flushLog); | ||||
|  | ||||
|     changePath(path); | ||||
|     if (deleteOld) | ||||
|         this->deleteOld(age, ageType); | ||||
|  | ||||
|     const Logger* const logger = Logger::instance(); | ||||
|     foreach (const Log::Msg& msg, logger->getMessages()) | ||||
|     const Logger *const logger = Logger::instance(); | ||||
|     foreach (const Log::Msg &msg, logger->getMessages()) | ||||
|         addLogMessage(msg); | ||||
|  | ||||
|     connect(logger, SIGNAL(newLogMessage(const Log::Msg &)), SLOT(addLogMessage(const Log::Msg &))); | ||||
|     connect(logger, &Logger::newLogMessage, this, &FileLogger::addLogMessage); | ||||
| } | ||||
|  | ||||
| FileLogger::~FileLogger() | ||||
| @@ -61,7 +63,7 @@ FileLogger::~FileLogger() | ||||
|     delete m_logFile; | ||||
| } | ||||
|  | ||||
| void FileLogger::changePath(const QString& newPath) | ||||
| void FileLogger::changePath(const QString &newPath) | ||||
| { | ||||
|     QString tmpPath = Utils::Fs::fromNativePath(newPath); | ||||
|     QDir dir(tmpPath); | ||||
| @@ -83,21 +85,21 @@ void FileLogger::changePath(const QString& newPath) | ||||
| void FileLogger::deleteOld(const int age, const FileLogAgeType ageType) | ||||
| { | ||||
|     QDateTime date = QDateTime::currentDateTime(); | ||||
|     QDir dir(m_path); | ||||
|  | ||||
|     switch (ageType) { | ||||
|     case DAYS: | ||||
|         date = date.addDays(age); | ||||
|         break; | ||||
|     case MONTHS: | ||||
|         date = date.addMonths(age); | ||||
|         break; | ||||
|     default: | ||||
|         date = date.addYears(age); | ||||
|     } | ||||
|     QDir dir(Utils::Fs::branchPath(m_path)); | ||||
|  | ||||
|     foreach (const QFileInfo file, dir.entryInfoList(QStringList("qbittorrent.log.bak*"), QDir::Files | QDir::Writable, QDir::Time | QDir::Reversed)) { | ||||
|         if (file.lastModified() < date) | ||||
|         QDateTime modificationDate = file.lastModified(); | ||||
|         switch (ageType) { | ||||
|         case DAYS: | ||||
|             modificationDate = modificationDate.addDays(age); | ||||
|             break; | ||||
|         case MONTHS: | ||||
|             modificationDate = modificationDate.addMonths(age); | ||||
|             break; | ||||
|         default: | ||||
|             modificationDate = modificationDate.addYears(age); | ||||
|         } | ||||
|         if (modificationDate > date) | ||||
|             break; | ||||
|         Utils::Fs::forceRemove(file.absoluteFilePath()); | ||||
|     } | ||||
|   | ||||
| @@ -76,4 +76,3 @@ private: | ||||
| }; | ||||
|  | ||||
| #endif // FILELOGGER_H | ||||
|  | ||||
|   | ||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user