You've already forked qBittorrent
							
							
				mirror of
				https://github.com/qbittorrent/qBittorrent
				synced 2025-11-02 08:10:54 +01:00 
			
		
		
		
	Compare commits
	
		
			258 Commits
		
	
	
		
			release-2.
			...
			release-3.
		
	
	| Author | SHA1 | Date | |
|---|---|---|---|
| 
						 | 
					14b3414e9d | ||
| 
						 | 
					73254962f1 | ||
| 
						 | 
					74f042516b | ||
| 
						 | 
					8c0853248c | ||
| 
						 | 
					80ea0a67b5 | ||
| 
						 | 
					6d2b51203c | ||
| 
						 | 
					8ac82156b3 | ||
| 
						 | 
					c1806b099a | ||
| 
						 | 
					1046c816bf | ||
| 
						 | 
					cfbb5ecde5 | ||
| 
						 | 
					afdec02674 | ||
| 
						 | 
					927e6bc6cc | ||
| 
						 | 
					e862d3332c | ||
| 
						 | 
					699144a83d | ||
| 
						 | 
					1792f44bfa | ||
| 
						 | 
					64e4095ef1 | ||
| 
						 | 
					1d1ffcec7c | ||
| 
						 | 
					e73bff817c | ||
| 
						 | 
					486779ceb2 | ||
| 
						 | 
					283a9950f3 | ||
| 
						 | 
					4d601f5383 | ||
| 
						 | 
					4d76bd33fc | ||
| 
						 | 
					179985954c | ||
| 
						 | 
					ef34285855 | ||
| 
						 | 
					bbd1c9ee42 | ||
| 
						 | 
					7cffd267d8 | ||
| 
						 | 
					bb11d11a72 | ||
| 
						 | 
					ae09bee193 | ||
| 
						 | 
					abf8c179fc | ||
| 
						 | 
					5874c7bd57 | ||
| 
						 | 
					12280c6a0f | ||
| 
						 | 
					c40801ce99 | ||
| 
						 | 
					cc192d7d47 | ||
| 
						 | 
					64c256109a | ||
| 
						 | 
					d93a63e01a | ||
| 
						 | 
					1c6ef50b77 | ||
| 
						 | 
					497e2e92f8 | ||
| 
						 | 
					2e950cc28b | ||
| 
						 | 
					f09ea1a884 | ||
| 
						 | 
					eebb7c8477 | ||
| 
						 | 
					8feb6644a3 | ||
| 
						 | 
					dd30ada095 | ||
| 
						 | 
					0627968c2f | ||
| 
						 | 
					89249c140f | ||
| 
						 | 
					90373897d6 | ||
| 
						 | 
					a85ddada25 | ||
| 
						 | 
					3bb474e12f | ||
| 
						 | 
					3b4a312b97 | ||
| 
						 | 
					7a58df594d | ||
| 
						 | 
					524f837ca5 | ||
| 
						 | 
					4800b456c2 | ||
| 
						 | 
					4652eb8ff3 | ||
| 
						 | 
					c2096e2ecd | ||
| 
						 | 
					e27a648594 | ||
| 
						 | 
					90b1567d13 | ||
| 
						 | 
					41132d39ae | ||
| 
						 | 
					0ffba231d4 | ||
| 
						 | 
					c6ab0b148b | ||
| 
						 | 
					183453488e | ||
| 
						 | 
					c96f14a7c8 | ||
| 
						 | 
					c5841146ff | ||
| 
						 | 
					4ff249525b | ||
| 
						 | 
					5d5bf403a8 | ||
| 
						 | 
					2747481816 | ||
| 
						 | 
					c9591a66e8 | ||
| 
						 | 
					02c4be4eaa | ||
| 
						 | 
					ee96f83211 | ||
| 
						 | 
					b095a1e3fe | ||
| 
						 | 
					d5aaa24ad6 | ||
| 
						 | 
					9efd576d53 | ||
| 
						 | 
					8e0d01643f | ||
| 
						 | 
					cb817bc06f | ||
| 
						 | 
					1b905d5126 | ||
| 
						 | 
					ca26cc0000 | ||
| 
						 | 
					00f40e6771 | ||
| 
						 | 
					7a64c1ebb4 | ||
| 
						 | 
					5d5f3cbdfd | ||
| 
						 | 
					8bd35852dc | ||
| 
						 | 
					92189b6c50 | ||
| 
						 | 
					e50ab2639e | ||
| 
						 | 
					33832a46c1 | ||
| 
						 | 
					6a905fc9e0 | ||
| 
						 | 
					15d1e3505c | ||
| 
						 | 
					fda1797149 | ||
| 
						 | 
					096baaf441 | ||
| 
						 | 
					69cb9b906f | ||
| 
						 | 
					755dc40ee4 | ||
| 
						 | 
					f601aa3cfb | ||
| 
						 | 
					79cb430878 | ||
| 
						 | 
					90f90936e1 | ||
| 
						 | 
					a98ad63d8b | ||
| 
						 | 
					6d31af676e | ||
| 
						 | 
					1204bf6e80 | ||
| 
						 | 
					48f2b6fb66 | ||
| 
						 | 
					10a4556479 | ||
| 
						 | 
					f4320cb58a | ||
| 
						 | 
					d31d935522 | ||
| 
						 | 
					85d2fd8ce0 | ||
| 
						 | 
					ad79cbb9a1 | ||
| 
						 | 
					bdb0e125a4 | ||
| 
						 | 
					d26179cca0 | ||
| 
						 | 
					8d612e8e2d | ||
| 
						 | 
					e74b39f5af | ||
| 
						 | 
					aaf3194670 | ||
| 
						 | 
					74079b2c86 | ||
| 
						 | 
					2eae22ac06 | ||
| 
						 | 
					80359f3e5e | ||
| 
						 | 
					ccefe68e4c | ||
| 
						 | 
					f039cec4ca | ||
| 
						 | 
					5a65580169 | ||
| 
						 | 
					39ea57fe29 | ||
| 
						 | 
					361db3d2cd | ||
| 
						 | 
					83494f999a | ||
| 
						 | 
					de4cb2ede7 | ||
| 
						 | 
					2f6ef9af51 | ||
| 
						 | 
					2f0e15bc25 | ||
| 
						 | 
					0cd4c079e9 | ||
| 
						 | 
					3197d5cc2f | ||
| 
						 | 
					81e4e39878 | ||
| 
						 | 
					55a6bc3855 | ||
| 
						 | 
					acd4b64a8b | ||
| 
						 | 
					984acc581c | ||
| 
						 | 
					75a65a5f49 | ||
| 
						 | 
					91af418254 | ||
| 
						 | 
					901326c004 | ||
| 
						 | 
					8986d87ef3 | ||
| 
						 | 
					a0d21ead18 | ||
| 
						 | 
					122655758d | ||
| 
						 | 
					9a964d871d | ||
| 
						 | 
					fc4989d738 | ||
| 
						 | 
					5f59ab7e48 | ||
| 
						 | 
					99557543fc | ||
| 
						 | 
					d7c907d17d | ||
| 
						 | 
					fd9ae50a57 | ||
| 
						 | 
					1398a39768 | ||
| 
						 | 
					7b4b2fe0f5 | ||
| 
						 | 
					23848be6eb | ||
| 
						 | 
					d55f3b5aff | ||
| 
						 | 
					716e84264e | ||
| 
						 | 
					600c33dfa3 | ||
| 
						 | 
					e6e2baf3a8 | ||
| 
						 | 
					cfb4ded943 | ||
| 
						 | 
					dfe5fbe34c | ||
| 
						 | 
					82788b9a02 | ||
| 
						 | 
					ff3cc4b8de | ||
| 
						 | 
					f74a471177 | ||
| 
						 | 
					50ee44a1cf | ||
| 
						 | 
					7a29f3d71d | ||
| 
						 | 
					30d5273bb5 | ||
| 
						 | 
					0f291629cc | ||
| 
						 | 
					e6e63fa529 | ||
| 
						 | 
					766b210d06 | ||
| 
						 | 
					c502edf9e1 | ||
| 
						 | 
					53f55a79b3 | ||
| 
						 | 
					f05ecf900a | ||
| 
						 | 
					810a9710d7 | ||
| 
						 | 
					ef6c3f5a64 | ||
| 
						 | 
					0e425d6a04 | ||
| 
						 | 
					29d28b1d96 | ||
| 
						 | 
					c12467ee3e | ||
| 
						 | 
					82e2b3a6cd | ||
| 
						 | 
					33a0828a33 | ||
| 
						 | 
					95e2b7ee1a | ||
| 
						 | 
					bc6fd3aa72 | ||
| 
						 | 
					a940917144 | ||
| 
						 | 
					7bd4a1b849 | ||
| 
						 | 
					f62c38a8a7 | ||
| 
						 | 
					41c503eb54 | ||
| 
						 | 
					8cc538085f | ||
| 
						 | 
					b93cebacb2 | ||
| 
						 | 
					30a3110ca7 | ||
| 
						 | 
					cf447296fb | ||
| 
						 | 
					dfc5e02edd | ||
| 
						 | 
					bcb29fb5fa | ||
| 
						 | 
					41b57a0878 | ||
| 
						 | 
					0b13fa6914 | ||
| 
						 | 
					c32e651c39 | ||
| 
						 | 
					fefc7df910 | ||
| 
						 | 
					90b520651b | ||
| 
						 | 
					3389820c73 | ||
| 
						 | 
					85167c9043 | ||
| 
						 | 
					ce6f942ed3 | ||
| 
						 | 
					5cf7e47ffa | ||
| 
						 | 
					bd4bb42e95 | ||
| 
						 | 
					6778b7460a | ||
| 
						 | 
					0c279e0567 | ||
| 
						 | 
					1bee9c6a9d | ||
| 
						 | 
					691b976e11 | ||
| 
						 | 
					75efd4ea6b | ||
| 
						 | 
					9363b1b4f2 | ||
| 
						 | 
					a69cbd2289 | ||
| 
						 | 
					ca6f732c7b | ||
| 
						 | 
					5f5382297c | ||
| 
						 | 
					a5452d04ae | ||
| 
						 | 
					8f4c4e8c40 | ||
| 
						 | 
					b1f1fbf114 | ||
| 
						 | 
					a2d9cce181 | ||
| 
						 | 
					06ccae591e | ||
| 
						 | 
					30bc14c940 | ||
| 
						 | 
					33f5c8e903 | ||
| 
						 | 
					8e529fc179 | ||
| 
						 | 
					f3448125c3 | ||
| 
						 | 
					00b4ad6ec8 | ||
| 
						 | 
					a8a7b61ea9 | ||
| 
						 | 
					9acac03f14 | ||
| 
						 | 
					b78d6ba243 | ||
| 
						 | 
					d53ca1d096 | ||
| 
						 | 
					50a3e4e776 | ||
| 
						 | 
					a13bb06ec3 | ||
| 
						 | 
					32a6c89c8c | ||
| 
						 | 
					1905a6f0d1 | ||
| 
						 | 
					3bc75bb068 | ||
| 
						 | 
					f0f7924325 | ||
| 
						 | 
					5e48708920 | ||
| 
						 | 
					58603451b4 | ||
| 
						 | 
					9e3deb68de | ||
| 
						 | 
					2fea7eaef2 | ||
| 
						 | 
					a53a70742d | ||
| 
						 | 
					0c9dbc15f9 | ||
| 
						 | 
					ed468083c5 | ||
| 
						 | 
					737982e92f | ||
| 
						 | 
					b43e641d21 | ||
| 
						 | 
					c25586b500 | ||
| 
						 | 
					60d9bfe077 | ||
| 
						 | 
					0d0c7559bf | ||
| 
						 | 
					de4559659d | ||
| 
						 | 
					16071ec266 | ||
| 
						 | 
					fb03682df4 | ||
| 
						 | 
					68041e382d | ||
| 
						 | 
					fb60a6489b | ||
| 
						 | 
					dd7e515f9c | ||
| 
						 | 
					1bc6130da5 | ||
| 
						 | 
					323275c340 | ||
| 
						 | 
					3da9fec665 | ||
| 
						 | 
					f6254e9db6 | ||
| 
						 | 
					f06f820047 | ||
| 
						 | 
					05643ca5d9 | ||
| 
						 | 
					c0eb048fe2 | ||
| 
						 | 
					78bb4104b0 | ||
| 
						 | 
					6c10936f6d | ||
| 
						 | 
					4ca665eb0c | ||
| 
						 | 
					39e1ebaa9b | ||
| 
						 | 
					0a0033b242 | ||
| 
						 | 
					9eea35f530 | ||
| 
						 | 
					345e9ec870 | ||
| 
						 | 
					53be56746b | ||
| 
						 | 
					26b8decb24 | ||
| 
						 | 
					a275e26ba7 | ||
| 
						 | 
					96c918ff8d | ||
| 
						 | 
					2283bd2358 | ||
| 
						 | 
					f6b7b8bd6e | ||
| 
						 | 
					1b8a2bf7c1 | ||
| 
						 | 
					33325cdfee | ||
| 
						 | 
					d81f633d6b | ||
| 
						 | 
					422b483d78 | ||
| 
						 | 
					ec5b9c769a | ||
| 
						 | 
					74081bc6f8 | ||
| 
						 | 
					3c650038e2 | 
							
								
								
									
										5
									
								
								AUTHORS
									
									
									
									
									
								
							
							
						
						
									
										5
									
								
								AUTHORS
									
									
									
									
									
								
							@@ -74,6 +74,8 @@ Translations authors:
 | 
			
		||||
  copyright:
 | 
			
		||||
  - Arabic: SDERAWI (abz8868@msn.com) and sn51234 (nesseyan@gmail.com)
 | 
			
		||||
  - Armenian: Hrant Ohanyan (hrantohanyan@mail.am)
 | 
			
		||||
  - Basque: Xabier Aramendi (azpidatziak@gmail.com)
 | 
			
		||||
  - Belarusian: Mihas Varantsou (meequz@gmail.com)
 | 
			
		||||
  - Brazilian: Nick Marinho (nickmarinho@gmail.com)
 | 
			
		||||
  - Bulgarian: Tsvetan & Boyko Bankoff (emerge_life@users.sourceforge.net)
 | 
			
		||||
  - Catalan: Francisco Luque Contreras (frannoe@ya.com)
 | 
			
		||||
@@ -87,6 +89,7 @@ Translations authors:
 | 
			
		||||
  - Finnish: Niklas Laxström (nikerabbit@users.sourceforge.net)
 | 
			
		||||
  - French: Christophe Dumez (chris@qbittorrent.org)
 | 
			
		||||
  - Galician: Marcos Lans (marcoslansgarza@gmail.com)
 | 
			
		||||
  - Georgian: Beqa Arabuli (arabulibeqa@yahoo.com)
 | 
			
		||||
  - German: Niels Hoffmann (zentralmaschine@users.sourceforge.net)
 | 
			
		||||
  - Greek: Tsvetan Bankov (emerge_life@users.sourceforge.net) and Stephanos Antaris (santaris@csd.auth.gr)
 | 
			
		||||
  - Hungarian: Majoros Péter (majoros.j.p@t-online.hu)
 | 
			
		||||
@@ -104,5 +107,5 @@ Translations authors:
 | 
			
		||||
  - Spanish: Francisco Luque Contreras (frannoe@ya.com)
 | 
			
		||||
  - Swedish: Daniel Nylander (po@danielnylander.se)
 | 
			
		||||
  - Turkish: Hasan Yilmaz (iletisim@hedefturkce.com)
 | 
			
		||||
  - Ukrainian: Andrey Shpachenko (masterfix@users.sourceforge.net) and Oleh Prypin (blaxpirit@gmail.com)
 | 
			
		||||
  - Ukrainian: Oleh Prypin (blaxpirit@gmail.com)
 | 
			
		||||
  license: GPLv2
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										18
									
								
								Changelog
									
									
									
									
									
								
							
							
						
						
									
										18
									
								
								Changelog
									
									
									
									
									
								
							@@ -1,3 +1,21 @@
 | 
			
		||||
* Tue Aug 21 2012 - Christophe Dumez <chris@qbittorrent.org> - v3.0.1
 | 
			
		||||
    - BUGFIX: Fix possible crash when adding a tracker to a magnet torrent without metadata (Closes #1034254)
 | 
			
		||||
    - BUGFIX: Remember queue position for torrents without metadata (closes #17)
 | 
			
		||||
    - BUGFIX: Fix crash when using unauthorized characters in label names (closes #19)
 | 
			
		||||
    - BUGFIX: Fix search plugins updating (closes #25)
 | 
			
		||||
    - BUGFIX: Make uTP connections rate limited by default
 | 
			
		||||
 | 
			
		||||
* Thu Aug 09 2012 - Christophe Dumez <chris@qbittorrent.org> - v3.0.0
 | 
			
		||||
    - FEATURE: Brand new torrent addition dialog
 | 
			
		||||
    - FEATURE: Add the ability to choose the save path when using magnet links (mutoso)
 | 
			
		||||
    - FEATURE: Add support for adding multiple local torrents at once (Web UI)
 | 
			
		||||
    - COSMETIC: Improve style of left panel
 | 
			
		||||
    - BUGFIX: Lower panels no longer gets disabled
 | 
			
		||||
    - BUGFIX: Major code refactoring and various optimizations.
 | 
			
		||||
    - BUGFIX: No longer strip root folder from torrent files
 | 
			
		||||
    - OTHER: Drop support for libtorrent v0.14.x
 | 
			
		||||
    - OTHER: Drop support for Qt 4.5
 | 
			
		||||
 | 
			
		||||
* Sat Oct 08 2011 - Christophe Dumez <chris@qbittorrent.org> - v2.9.0
 | 
			
		||||
    - FEATURE: Add file association settings to program preferences (Windows)
 | 
			
		||||
    - FEATURE: Add setting to ignore slow torrents in queueing system
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										14
									
								
								INSTALL
									
									
									
									
									
								
							
							
						
						
									
										14
									
								
								INSTALL
									
									
									
									
									
								
							@@ -10,19 +10,21 @@ qBittorrent - A BitTorrent client in C++ / Qt4
 | 
			
		||||
  will install and execute qBittorrent hopefully without any problems.
 | 
			
		||||
 | 
			
		||||
  Dependencies:
 | 
			
		||||
    - Qt >= 4.5.0 (libqtgui, libqtcore, libqtnetwork, libqtxml, libqtdbus/optional)
 | 
			
		||||
    - Qt >= 4.6.0 (libqtgui, libqtcore, libqtnetwork, libqtxml, libqtdbus/optional)
 | 
			
		||||
 | 
			
		||||
    - pkg-config executable
 | 
			
		||||
 | 
			
		||||
    - libtorrent-rasterbar by Arvid Norberg (>= 0.14.4 REQUIRED, compatible with v0.15.x)
 | 
			
		||||
    - libtorrent-rasterbar by Arvid Norberg (>= 0.15.0)
 | 
			
		||||
        -> http://www.libtorrent.net
 | 
			
		||||
        Be careful: another library (the one used by rTorrent) uses a similar name.
 | 
			
		||||
 | 
			
		||||
    - libboost 1.34.x (libboost-filesystem, libboost-date-time) + libasio
 | 
			
		||||
    - libboost 1.34.x (libboost-filesystem°) + libasio
 | 
			
		||||
      or
 | 
			
		||||
    - libboost >= 1.35.x (libboost-system, libboost-filesystem, libboost-date-time)
 | 
			
		||||
    - libboost >= 1.35.x (libboost-system, libboost-filesystem°)
 | 
			
		||||
      
 | 
			
		||||
    °libboost-filesystem is not needed if libtorrent-rasterbar >= v0.16.x is used
 | 
			
		||||
 | 
			
		||||
    - python >= 2.3 && < 3.0 (needed by search engine)
 | 
			
		||||
    - python >= 2.3 (needed by search engine)
 | 
			
		||||
        * Run time only dependency
 | 
			
		||||
 | 
			
		||||
    - geoip-database (optional)
 | 
			
		||||
@@ -42,7 +44,7 @@ qBittorrent - A BitTorrent client in C++ / Qt4
 | 
			
		||||
 | 
			
		||||
    - pkg-config executable
 | 
			
		||||
 | 
			
		||||
    - libtorrent-rasterbar by Arvid Norberg (>= 0.14.4 REQUIRED, >= v0.15.0 ADVISED)
 | 
			
		||||
    - libtorrent-rasterbar by Arvid Norberg (>= v0.15.0)
 | 
			
		||||
        -> http://www.libtorrent.net
 | 
			
		||||
        Be careful: another library (the one used by rTorrent) uses a similar name.
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
@@ -27,7 +27,6 @@ First you need to create the conf.pri file in the same dir as this readme.os2 is
 | 
			
		||||
the conf.pri file has the following content:
 | 
			
		||||
 | 
			
		||||
##### conf.pri content beginn #####
 | 
			
		||||
PREFIX = .
 | 
			
		||||
BINDIR = ./bin
 | 
			
		||||
INCDIR = ./include
 | 
			
		||||
LIBDIR = ./lib
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										124
									
								
								configure
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										124
									
								
								configure
									
									
									
									
										vendored
									
									
								
							@@ -325,7 +325,7 @@ cat >$1/modules.cpp <<EOT
 | 
			
		||||
#line 1 "qt4.qcm"
 | 
			
		||||
/*
 | 
			
		||||
-----BEGIN QCMOD-----
 | 
			
		||||
name: Qt >= 4.5
 | 
			
		||||
name: Qt >= 4.6
 | 
			
		||||
arg: enable-debug, Enable debug mode
 | 
			
		||||
arg: disable-gui, Disable qBittorrent Graphical user interface for headless running
 | 
			
		||||
-----END QCMOD-----
 | 
			
		||||
@@ -334,8 +334,8 @@ class qc_qt4 : public ConfObj
 | 
			
		||||
{
 | 
			
		||||
public:
 | 
			
		||||
	qc_qt4(Conf *c) : ConfObj(c) {}
 | 
			
		||||
	QString name() const { return "Qt >= 4.5"; }
 | 
			
		||||
	QString shortname() const { return "Qt 4.5"; }
 | 
			
		||||
	QString name() const { return "Qt >= 4.6"; }
 | 
			
		||||
	QString shortname() const { return "Qt 4.6"; }
 | 
			
		||||
	bool exec()
 | 
			
		||||
	{
 | 
			
		||||
                // NOX mode
 | 
			
		||||
@@ -356,7 +356,7 @@ public:
 | 
			
		||||
                #else
 | 
			
		||||
                  conf->addExtra("MANPREFIX = \$\$PREFIX/share"); 
 | 
			
		||||
                #endif
 | 
			
		||||
		return(QT_VERSION >= 0x040500);
 | 
			
		||||
		return(QT_VERSION >= 0x040600);
 | 
			
		||||
	}
 | 
			
		||||
};
 | 
			
		||||
#line 1 "qt-dbus.qcm"
 | 
			
		||||
@@ -419,11 +419,11 @@ class qc_libtorrent_rasterbar : public ConfObj
 | 
			
		||||
{
 | 
			
		||||
public:
 | 
			
		||||
	qc_libtorrent_rasterbar(Conf *c) : ConfObj(c) {}
 | 
			
		||||
	QString name() const { return "libtorrent-rasterbar >= 0.14.4"; }
 | 
			
		||||
	QString name() const { return "libtorrent-rasterbar >= 0.15.0"; }
 | 
			
		||||
	QString shortname() const { return "libtorrent-rasterbar"; }
 | 
			
		||||
	bool exec(){
 | 
			
		||||
		QStringList incs;
 | 
			
		||||
		QString req_ver = "0.14.4";
 | 
			
		||||
		QString req_ver = "0.15.0";
 | 
			
		||||
		QString version, libs, other;
 | 
			
		||||
		VersionMode mode = VersionMin;
 | 
			
		||||
		if(!conf->findPkgConfig("libtorrent-rasterbar", mode, req_ver, &version, &incs, &libs, &other))
 | 
			
		||||
@@ -442,12 +442,15 @@ arg: with-libboost-lib=[path], Path to libboost library files
 | 
			
		||||
-----END QCMOD-----
 | 
			
		||||
*/
 | 
			
		||||
#include <boost/version.hpp>
 | 
			
		||||
#include <libtorrent/version.hpp>
 | 
			
		||||
 | 
			
		||||
class qc_libboost : public ConfObj
 | 
			
		||||
{
 | 
			
		||||
public:
 | 
			
		||||
	qc_libboost(Conf *c) : ConfObj(c) {}
 | 
			
		||||
	QString name() const { return "libboost"; }
 | 
			
		||||
	QString shortname() const { return "libboost"; }
 | 
			
		||||
  qc_libboost(Conf *c) : ConfObj(c) {}
 | 
			
		||||
  QString name() const { return "libboost"; }
 | 
			
		||||
  QString shortname() const { return "libboost"; }
 | 
			
		||||
 | 
			
		||||
  QString findBoostLib(QString path, QString lib) const {
 | 
			
		||||
    QString name;
 | 
			
		||||
    QDir libDir(path);
 | 
			
		||||
@@ -471,77 +474,62 @@ public:
 | 
			
		||||
    }
 | 
			
		||||
    return name;
 | 
			
		||||
  }
 | 
			
		||||
	bool exec(){
 | 
			
		||||
        	QString s;
 | 
			
		||||
		s = conf->getenv("QC_WITH_LIBBOOST_INC");
 | 
			
		||||
		if(!s.isEmpty()) {
 | 
			
		||||
			if(!conf->checkHeader(s, "boost/format.hpp")) {
 | 
			
		||||
				return false;
 | 
			
		||||
      			}
 | 
			
		||||
			if(!conf->checkHeader(s, "boost/date_time/posix_time/posix_time.hpp")) {
 | 
			
		||||
				return false;
 | 
			
		||||
      			}
 | 
			
		||||
			if(!conf->checkHeader(s, "boost/filesystem/path.hpp")) {
 | 
			
		||||
				return false;
 | 
			
		||||
      			}
 | 
			
		||||
		}else{
 | 
			
		||||
			QStringList sl;
 | 
			
		||||
			sl << "/usr/include";
 | 
			
		||||
			sl << "/usr/local/include";
 | 
			
		||||
			bool found = false;
 | 
			
		||||
			foreach(s, sl){
 | 
			
		||||
				if(conf->checkHeader(s, "boost/format.hpp")){
 | 
			
		||||
					found = true;
 | 
			
		||||
					break;
 | 
			
		||||
				}
 | 
			
		||||
			}
 | 
			
		||||
			if(!found) {
 | 
			
		||||
				return false;
 | 
			
		||||
          		}
 | 
			
		||||
			if(!conf->checkHeader(s, "boost/date_time/posix_time/posix_time.hpp")) {
 | 
			
		||||
				return false;
 | 
			
		||||
      			}
 | 
			
		||||
			if(!conf->checkHeader(s, "boost/filesystem/path.hpp")) {
 | 
			
		||||
				return false;
 | 
			
		||||
      			}
 | 
			
		||||
		}
 | 
			
		||||
		conf->addIncludePath(s);
 | 
			
		||||
		// Find library
 | 
			
		||||
		s = conf->getenv("QC_WITH_LIBBOOST_LIB");
 | 
			
		||||
 | 
			
		||||
  bool exec(){
 | 
			
		||||
    QStringList sl;
 | 
			
		||||
    QString s = conf->getenv("QC_WITH_LIBBOOST_INC");
 | 
			
		||||
    if (!s.isEmpty())
 | 
			
		||||
      sl << s;
 | 
			
		||||
    sl << "/usr/include";
 | 
			
		||||
    sl << "/usr/local/include";
 | 
			
		||||
    bool found = false;
 | 
			
		||||
    foreach (s, sl) {
 | 
			
		||||
      if (conf->checkHeader(s, "boost/format.hpp")
 | 
			
		||||
#if LIBTORRENT_VERSION_MAJOR == 0 && LIBTORRENT_VERSION_MINOR < 16
 | 
			
		||||
          && conf->checkHeader(s, "boost/filesystem/path.hpp")
 | 
			
		||||
#endif
 | 
			
		||||
         ) {
 | 
			
		||||
        found = true;
 | 
			
		||||
        break;
 | 
			
		||||
      }
 | 
			
		||||
    }
 | 
			
		||||
    if (!found)
 | 
			
		||||
      return false;
 | 
			
		||||
 | 
			
		||||
    conf->addIncludePath(s);
 | 
			
		||||
 | 
			
		||||
    // Find library
 | 
			
		||||
    s = conf->getenv("QC_WITH_LIBBOOST_LIB");
 | 
			
		||||
    QStringList required_libs;
 | 
			
		||||
#if BOOST_VERSION >= 103500
 | 
			
		||||
      required_libs << "system"; 
 | 
			
		||||
#endif
 | 
			
		||||
#if LIBTORRENT_VERSION_MAJOR == 0 && LIBTORRENT_VERSION_MINOR < 16
 | 
			
		||||
    required_libs << "filesystem" ;
 | 
			
		||||
#endif
 | 
			
		||||
    required_libs << "thread";
 | 
			
		||||
    QStringList libDirs;
 | 
			
		||||
    if (!s.isEmpty())
 | 
			
		||||
      libDirs << s;
 | 
			
		||||
    libDirs << "/usr/lib/" << "/usr/lib64/" << "/usr/local/lib/" << "/usr/local/lib64/";
 | 
			
		||||
 | 
			
		||||
    foreach(const QString& lib, required_libs) {
 | 
			
		||||
      if(!s.isEmpty()) {
 | 
			
		||||
        QString detected_name = findBoostLib(s, lib);
 | 
			
		||||
        if(detected_name.isEmpty()) {
 | 
			
		||||
          printf("Could not find boost %s library!\n", qPrintable(lib));
 | 
			
		||||
          return false;
 | 
			
		||||
        } else {
 | 
			
		||||
      bool found = false;
 | 
			
		||||
      foreach(const QString& libDir, libDirs) {
 | 
			
		||||
        QString detected_name = findBoostLib(libDir, lib);
 | 
			
		||||
        if(!detected_name.isEmpty()) {
 | 
			
		||||
          conf->addLib("-l"+detected_name);
 | 
			
		||||
        }
 | 
			
		||||
      } else {
 | 
			
		||||
        bool found = false;
 | 
			
		||||
        foreach(const QString& libDir, libDirs) {
 | 
			
		||||
          QString detected_name = findBoostLib(libDir, lib);
 | 
			
		||||
          if(!detected_name.isEmpty()) {
 | 
			
		||||
            conf->addLib("-l"+detected_name);
 | 
			
		||||
            found = true;
 | 
			
		||||
            break;
 | 
			
		||||
          }
 | 
			
		||||
        }
 | 
			
		||||
        if(!found) {
 | 
			
		||||
          printf("Could not find boost %s library!\n", qPrintable(lib));
 | 
			
		||||
          return false;
 | 
			
		||||
          found = true;
 | 
			
		||||
          break;
 | 
			
		||||
        }
 | 
			
		||||
      }
 | 
			
		||||
      if(!found) {
 | 
			
		||||
        printf("Could not find boost %s library!\n", qPrintable(lib));
 | 
			
		||||
        return false;
 | 
			
		||||
      }
 | 
			
		||||
    }
 | 
			
		||||
		return true;
 | 
			
		||||
	}
 | 
			
		||||
    return true;
 | 
			
		||||
  }
 | 
			
		||||
};
 | 
			
		||||
#line 1 "geoip-database.qcm"
 | 
			
		||||
/*
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										118
									
								
								install.os2
									
									
									
									
									
								
							
							
						
						
									
										118
									
								
								install.os2
									
									
									
									
									
								
							@@ -11,7 +11,7 @@ QBittorrent installation
 | 
			
		||||
 | 
			
		||||
3. INSTALLATION
 | 
			
		||||
 | 
			
		||||
4. CONTACT
 | 
			
		||||
4. BUGREPORTS
 | 
			
		||||
 | 
			
		||||
5. CREDITS
 | 
			
		||||
 | 
			
		||||
@@ -29,17 +29,70 @@ Welcome to QBittorrent port for OS/2 and eComStation.
 | 
			
		||||
2. REQUIREMENTS
 | 
			
		||||
===============
 | 
			
		||||
 | 
			
		||||
* klibc 0.6.3 or later
 | 
			
		||||
The following requirements can be installed either by rpm or by zip files.
 | 
			
		||||
 | 
			
		||||
    ftp://ftp.netlabs.org/pub/gcc/libc-0_6_3-csd3.wpi
 | 
			
		||||
RPM Installation:
 | 
			
		||||
 | 
			
		||||
* openssl 1.0
 | 
			
		||||
 
 | 
			
		||||
    ftp://ftp.netlabs.org/pub/unixos2/ssl10.zip
 | 
			
		||||
klibc
 | 
			
		||||
-----
 | 
			
		||||
 | 
			
		||||
* Qt4 dll
 | 
			
		||||
  1. yum install libc
 | 
			
		||||
 | 
			
		||||
    see http://svn.netlabs.org/qt4 for more information whats needed and where to get the latest
 | 
			
		||||
openssl 1.0
 | 
			
		||||
-----------
 | 
			
		||||
 | 
			
		||||
  1. yum install openssl
 | 
			
		||||
 | 
			
		||||
pthread
 | 
			
		||||
-------
 | 
			
		||||
 | 
			
		||||
  1. yum install pthread
 | 
			
		||||
 | 
			
		||||
GCC4Core
 | 
			
		||||
--------
 | 
			
		||||
 | 
			
		||||
  1. yum install libgcc
 | 
			
		||||
  2. yum install gcc-stack-protector
 | 
			
		||||
  3. yum install gcc-stdc++-shared-library
 | 
			
		||||
  4. yum install gcc-supc++-shared-library
 | 
			
		||||
 | 
			
		||||
Qt4 dll
 | 
			
		||||
-------
 | 
			
		||||
 | 
			
		||||
  1. yum install libqt4
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
ZIP Installation:
 | 
			
		||||
 | 
			
		||||
klibc
 | 
			
		||||
-----
 | 
			
		||||
 | 
			
		||||
  1. Download klibc 0.6.4 or better (see http://svn.netlabs.org/libc for more information)
 | 
			
		||||
  2. Install the files to your libpath eg x:\ecs\dll
 | 
			
		||||
 | 
			
		||||
openssl 1.0
 | 
			
		||||
-----------
 | 
			
		||||
 | 
			
		||||
  1. Download the zip file from http://rpm.netlabs.org/release/00/zip
 | 
			
		||||
  2. Install the files to your libpath eg. x:\ecs\dll
 | 
			
		||||
 | 
			
		||||
pthread
 | 
			
		||||
-------
 | 
			
		||||
 | 
			
		||||
  1. Download pthread 2012-03-13 or better from http://rpm.netlabs.org/release/00/zip
 | 
			
		||||
  2. Install the files to your libpath eg. x:\ecs\dll
 | 
			
		||||
 | 
			
		||||
GCC4Core
 | 
			
		||||
--------
 | 
			
		||||
 | 
			
		||||
  1. Download GCC4Core 1.2.1 or better from http://ftp.netlabs.org/pub/gcc
 | 
			
		||||
  2. Install the files to your libpath eg. x:\ecs\dll
 | 
			
		||||
 | 
			
		||||
Qt4 dll
 | 
			
		||||
-------
 | 
			
		||||
 | 
			
		||||
  1. Download Qt4 4.7.3 or better (see http://svn.netlabs.org/qt4 for more information)
 | 
			
		||||
  2. Install the files according to the readme
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
3. INSTALLATION
 | 
			
		||||
@@ -47,30 +100,6 @@ Welcome to QBittorrent port for OS/2 and eComStation.
 | 
			
		||||
          
 | 
			
		||||
To install QBittorrent, do the following:
 | 
			
		||||
 | 
			
		||||
klibc
 | 
			
		||||
-----
 | 
			
		||||
 | 
			
		||||
  1. Download klibc 0.6.3 csd3 or later.
 | 
			
		||||
  2. Install the package by double-clicking on the WPI file.
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
openssl 1.0
 | 
			
		||||
-----------
 | 
			
		||||
 | 
			
		||||
  1. Download the zip file
 | 
			
		||||
  2. Install the files to your libpath eg. x:\ecs\dll
 | 
			
		||||
 | 
			
		||||
Qt4 dll
 | 
			
		||||
-------
 | 
			
		||||
 | 
			
		||||
  1. Download the package
 | 
			
		||||
  2. Install the package by double-clicking on the wpi file.
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
QBittorrent
 | 
			
		||||
-----------
 | 
			
		||||
 | 
			
		||||
  1. Create a directory for QBittorrent.
 | 
			
		||||
  2. Extract the QBittorrent package to the new directory.
 | 
			
		||||
  3. Create a WPS object for QBittorrent.exe.
 | 
			
		||||
@@ -78,18 +107,13 @@ QBittorrent
 | 
			
		||||
  5. Happy torrenting
 | 
			
		||||
  
 | 
			
		||||
 | 
			
		||||
4. BUGREPORTS
 | 
			
		||||
=============
 | 
			
		||||
 | 
			
		||||
4. CONTACT
 | 
			
		||||
==========
 | 
			
		||||
 | 
			
		||||
Please send bugreports to:
 | 
			
		||||
 | 
			
		||||
  ecs@aroa.ch
 | 
			
		||||
 | 
			
		||||
Please create bugreports at http://svn.netlabs.org/qtapps
 | 
			
		||||
Only bug reports with a reproducable bug are accepted. :-)
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
 | 
			
		||||
5. CREDITS
 | 
			
		||||
==========
 | 
			
		||||
 | 
			
		||||
@@ -122,6 +146,20 @@ development, you can do so in one of the following ways:
 | 
			
		||||
7. HISTORY
 | 
			
		||||
==========
 | 
			
		||||
 | 
			
		||||
2012-03-15
 | 
			
		||||
 | 
			
		||||
  * updated to 2.9.5 code level of QBittorrent
 | 
			
		||||
 | 
			
		||||
2011-09-26
 | 
			
		||||
 | 
			
		||||
  * updated to 2.8.5 code level of QBittorrent
 | 
			
		||||
  * updated to Qt 4.7.3
 | 
			
		||||
 | 
			
		||||
2011-06-20
 | 
			
		||||
 | 
			
		||||
  * updated to 2.7.3 code level of QBittorrent
 | 
			
		||||
  * updated libtorrent to 0.15.6 level
 | 
			
		||||
 | 
			
		||||
2010-12-23
 | 
			
		||||
 | 
			
		||||
  * updated to 2.5.2 code level of QBittorrent
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										19
									
								
								macxconf.pri
									
									
									
									
									
								
							
							
						
						
									
										19
									
								
								macxconf.pri
									
									
									
									
									
								
							@@ -2,8 +2,23 @@ PREFIX = /usr/local
 | 
			
		||||
BINDIR = /usr/local/bin
 | 
			
		||||
DATADIR = /usr/local/share
 | 
			
		||||
 | 
			
		||||
INCLUDEPATH += /usr/local/include/libtorrent /usr/include/openssl /usr/include /opt/local/include/boost /opt/local/include
 | 
			
		||||
LIBS += -ltorrent-rasterbar -lcrypto -L/opt/local/lib -lboost_system-mt -lboost_filesystem-mt -lboost_thread-mt -framework Cocoa -framework Carbon -framework IOKit
 | 
			
		||||
# Use pkg-config to get all necessary libtorrent DEFINES
 | 
			
		||||
CONFIG += link_pkgconfig
 | 
			
		||||
PKGCONFIG += libtorrent-rasterbar
 | 
			
		||||
DEFINES += BOOST_ASIO_DYN_LINK
 | 
			
		||||
 | 
			
		||||
# Special include/libs paths (macports)
 | 
			
		||||
INCLUDEPATH += /usr/include/openssl /usr/include /opt/local/include/boost /opt/local/include
 | 
			
		||||
LIBS += -L/opt/local/lib
 | 
			
		||||
 | 
			
		||||
# OpenSSL lib
 | 
			
		||||
LIBS += -lssl -lcrypto
 | 
			
		||||
# Boost system lib
 | 
			
		||||
LIBS += -lboost_system-mt
 | 
			
		||||
# Boost filesystem lib (Not needed for libtorrent >= 0.16.0)
 | 
			
		||||
LIBS += -lboost_filesystem-mt
 | 
			
		||||
# Carbon
 | 
			
		||||
LIBS += -framework Carbon -framework IOKit
 | 
			
		||||
 | 
			
		||||
document_icon.path = Contents/Resources
 | 
			
		||||
document_icon.files = Icons/qBitTorrentDocument.icns
 | 
			
		||||
 
 | 
			
		||||
@@ -9,7 +9,10 @@ dist.commands += rm -fR ../$${PROJECT_NAME}-$${PROJECT_VERSION}/ &&
 | 
			
		||||
dist.commands += git clone . ../$${PROJECT_NAME}-$${PROJECT_VERSION} &&
 | 
			
		||||
dist.commands += rm -fR ../$${PROJECT_NAME}-$${PROJECT_VERSION}/.git &&
 | 
			
		||||
dist.commands += rm -f ../$${PROJECT_NAME}-$${PROJECT_VERSION}/.gitignore &&
 | 
			
		||||
dist.commands += tar zcpvf ../$${PROJECT_NAME}-$${PROJECT_VERSION}.tar.gz ../$${PROJECT_NAME}-$${PROJECT_VERSION} &&
 | 
			
		||||
dist.commands += rm -fR ../$${PROJECT_NAME}-$${PROJECT_VERSION}
 | 
			
		||||
dist.commands += cd .. &&
 | 
			
		||||
dist.commands += tar czf $${PROJECT_NAME}-$${PROJECT_VERSION}.tar.gz $${PROJECT_NAME}-$${PROJECT_VERSION} &&
 | 
			
		||||
dist.commands += tar cf $${PROJECT_NAME}-$${PROJECT_VERSION}.tar $${PROJECT_NAME}-$${PROJECT_VERSION} &&
 | 
			
		||||
dist.commands += xz -f $${PROJECT_NAME}-$${PROJECT_VERSION}.tar &&
 | 
			
		||||
dist.commands += rm -fR $${PROJECT_NAME}-$${PROJECT_VERSION}
 | 
			
		||||
 | 
			
		||||
QMAKE_EXTRA_TARGETS += dist
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										112
									
								
								qcm/libboost.qcm
									
									
									
									
									
								
							
							
						
						
									
										112
									
								
								qcm/libboost.qcm
									
									
									
									
									
								
							@@ -6,12 +6,15 @@ arg: with-libboost-lib=[path], Path to libboost library files
 | 
			
		||||
-----END QCMOD-----
 | 
			
		||||
*/
 | 
			
		||||
#include <boost/version.hpp>
 | 
			
		||||
#include <libtorrent/version.hpp>
 | 
			
		||||
 | 
			
		||||
class qc_libboost : public ConfObj
 | 
			
		||||
{
 | 
			
		||||
public:
 | 
			
		||||
	qc_libboost(Conf *c) : ConfObj(c) {}
 | 
			
		||||
	QString name() const { return "libboost"; }
 | 
			
		||||
	QString shortname() const { return "libboost"; }
 | 
			
		||||
  qc_libboost(Conf *c) : ConfObj(c) {}
 | 
			
		||||
  QString name() const { return "libboost"; }
 | 
			
		||||
  QString shortname() const { return "libboost"; }
 | 
			
		||||
 | 
			
		||||
  QString findBoostLib(QString path, QString lib) const {
 | 
			
		||||
    QString name;
 | 
			
		||||
    QDir libDir(path);
 | 
			
		||||
@@ -35,75 +38,60 @@ public:
 | 
			
		||||
    }
 | 
			
		||||
    return name;
 | 
			
		||||
  }
 | 
			
		||||
	bool exec(){
 | 
			
		||||
        	QString s;
 | 
			
		||||
		s = conf->getenv("QC_WITH_LIBBOOST_INC");
 | 
			
		||||
		if(!s.isEmpty()) {
 | 
			
		||||
			if(!conf->checkHeader(s, "boost/format.hpp")) {
 | 
			
		||||
				return false;
 | 
			
		||||
      			}
 | 
			
		||||
			if(!conf->checkHeader(s, "boost/date_time/posix_time/posix_time.hpp")) {
 | 
			
		||||
				return false;
 | 
			
		||||
      			}
 | 
			
		||||
			if(!conf->checkHeader(s, "boost/filesystem/path.hpp")) {
 | 
			
		||||
				return false;
 | 
			
		||||
      			}
 | 
			
		||||
		}else{
 | 
			
		||||
			QStringList sl;
 | 
			
		||||
			sl << "/usr/include";
 | 
			
		||||
			sl << "/usr/local/include";
 | 
			
		||||
			bool found = false;
 | 
			
		||||
			foreach(s, sl){
 | 
			
		||||
				if(conf->checkHeader(s, "boost/format.hpp")){
 | 
			
		||||
					found = true;
 | 
			
		||||
					break;
 | 
			
		||||
				}
 | 
			
		||||
			}
 | 
			
		||||
			if(!found) {
 | 
			
		||||
				return false;
 | 
			
		||||
          		}
 | 
			
		||||
			if(!conf->checkHeader(s, "boost/date_time/posix_time/posix_time.hpp")) {
 | 
			
		||||
				return false;
 | 
			
		||||
      			}
 | 
			
		||||
			if(!conf->checkHeader(s, "boost/filesystem/path.hpp")) {
 | 
			
		||||
				return false;
 | 
			
		||||
      			}
 | 
			
		||||
		}
 | 
			
		||||
		conf->addIncludePath(s);
 | 
			
		||||
		// Find library
 | 
			
		||||
		s = conf->getenv("QC_WITH_LIBBOOST_LIB");
 | 
			
		||||
 | 
			
		||||
  bool exec(){
 | 
			
		||||
    QStringList sl;
 | 
			
		||||
    QString s = conf->getenv("QC_WITH_LIBBOOST_INC");
 | 
			
		||||
    if (!s.isEmpty())
 | 
			
		||||
      sl << s;
 | 
			
		||||
    sl << "/usr/include";
 | 
			
		||||
    sl << "/usr/local/include";
 | 
			
		||||
    bool found = false;
 | 
			
		||||
    foreach (s, sl) {
 | 
			
		||||
      if (conf->checkHeader(s, "boost/format.hpp")
 | 
			
		||||
#if LIBTORRENT_VERSION_MAJOR == 0 && LIBTORRENT_VERSION_MINOR < 16
 | 
			
		||||
          && conf->checkHeader(s, "boost/filesystem/path.hpp")
 | 
			
		||||
#endif
 | 
			
		||||
         ) {
 | 
			
		||||
        found = true;
 | 
			
		||||
        break;
 | 
			
		||||
      }
 | 
			
		||||
    }
 | 
			
		||||
    if (!found)
 | 
			
		||||
      return false;
 | 
			
		||||
 | 
			
		||||
    conf->addIncludePath(s);
 | 
			
		||||
 | 
			
		||||
    // Find library
 | 
			
		||||
    s = conf->getenv("QC_WITH_LIBBOOST_LIB");
 | 
			
		||||
    QStringList required_libs;
 | 
			
		||||
#if BOOST_VERSION >= 103500
 | 
			
		||||
      required_libs << "system"; 
 | 
			
		||||
#endif
 | 
			
		||||
#if LIBTORRENT_VERSION_MAJOR == 0 && LIBTORRENT_VERSION_MINOR < 16
 | 
			
		||||
    required_libs << "filesystem" ;
 | 
			
		||||
#endif
 | 
			
		||||
    required_libs << "thread";
 | 
			
		||||
    QStringList libDirs;
 | 
			
		||||
    if (!s.isEmpty())
 | 
			
		||||
      libDirs << s;
 | 
			
		||||
    libDirs << "/usr/lib/" << "/usr/lib64/" << "/usr/local/lib/" << "/usr/local/lib64/";
 | 
			
		||||
 | 
			
		||||
    foreach(const QString& lib, required_libs) {
 | 
			
		||||
      if(!s.isEmpty()) {
 | 
			
		||||
        QString detected_name = findBoostLib(s, lib);
 | 
			
		||||
        if(detected_name.isEmpty()) {
 | 
			
		||||
          printf("Could not find boost %s library!\n", qPrintable(lib));
 | 
			
		||||
          return false;
 | 
			
		||||
        } else {
 | 
			
		||||
      bool found = false;
 | 
			
		||||
      foreach(const QString& libDir, libDirs) {
 | 
			
		||||
        QString detected_name = findBoostLib(libDir, lib);
 | 
			
		||||
        if(!detected_name.isEmpty()) {
 | 
			
		||||
          conf->addLib("-l"+detected_name);
 | 
			
		||||
        }
 | 
			
		||||
      } else {
 | 
			
		||||
        bool found = false;
 | 
			
		||||
        foreach(const QString& libDir, libDirs) {
 | 
			
		||||
          QString detected_name = findBoostLib(libDir, lib);
 | 
			
		||||
          if(!detected_name.isEmpty()) {
 | 
			
		||||
            conf->addLib("-l"+detected_name);
 | 
			
		||||
            found = true;
 | 
			
		||||
            break;
 | 
			
		||||
          }
 | 
			
		||||
        }
 | 
			
		||||
        if(!found) {
 | 
			
		||||
          printf("Could not find boost %s library!\n", qPrintable(lib));
 | 
			
		||||
          return false;
 | 
			
		||||
          found = true;
 | 
			
		||||
          break;
 | 
			
		||||
        }
 | 
			
		||||
      }
 | 
			
		||||
      if(!found) {
 | 
			
		||||
        printf("Could not find boost %s library!\n", qPrintable(lib));
 | 
			
		||||
        return false;
 | 
			
		||||
      }
 | 
			
		||||
    }
 | 
			
		||||
		return true;
 | 
			
		||||
	}
 | 
			
		||||
    return true;
 | 
			
		||||
  }
 | 
			
		||||
};
 | 
			
		||||
 
 | 
			
		||||
@@ -8,11 +8,11 @@ class qc_libtorrent_rasterbar : public ConfObj
 | 
			
		||||
{
 | 
			
		||||
public:
 | 
			
		||||
	qc_libtorrent_rasterbar(Conf *c) : ConfObj(c) {}
 | 
			
		||||
	QString name() const { return "libtorrent-rasterbar >= 0.14.4"; }
 | 
			
		||||
	QString name() const { return "libtorrent-rasterbar >= 0.15.0"; }
 | 
			
		||||
	QString shortname() const { return "libtorrent-rasterbar"; }
 | 
			
		||||
	bool exec(){
 | 
			
		||||
		QStringList incs;
 | 
			
		||||
		QString req_ver = "0.14.4";
 | 
			
		||||
		QString req_ver = "0.15.0";
 | 
			
		||||
		QString version, libs, other;
 | 
			
		||||
		VersionMode mode = VersionMin;
 | 
			
		||||
		if(!conf->findPkgConfig("libtorrent-rasterbar", mode, req_ver, &version, &incs, &libs, &other))
 | 
			
		||||
 
 | 
			
		||||
@@ -1,6 +1,6 @@
 | 
			
		||||
/*
 | 
			
		||||
-----BEGIN QCMOD-----
 | 
			
		||||
name: Qt >= 4.5
 | 
			
		||||
name: Qt >= 4.6
 | 
			
		||||
arg: enable-debug, Enable debug mode
 | 
			
		||||
arg: disable-gui, Disable qBittorrent Graphical user interface for headless running
 | 
			
		||||
-----END QCMOD-----
 | 
			
		||||
@@ -9,8 +9,8 @@ class qc_qt4 : public ConfObj
 | 
			
		||||
{
 | 
			
		||||
public:
 | 
			
		||||
	qc_qt4(Conf *c) : ConfObj(c) {}
 | 
			
		||||
	QString name() const { return "Qt >= 4.5"; }
 | 
			
		||||
	QString shortname() const { return "Qt 4.5"; }
 | 
			
		||||
	QString name() const { return "Qt >= 4.6"; }
 | 
			
		||||
	QString shortname() const { return "Qt 4.6"; }
 | 
			
		||||
	bool exec()
 | 
			
		||||
	{
 | 
			
		||||
                // NOX mode
 | 
			
		||||
@@ -31,6 +31,6 @@ public:
 | 
			
		||||
                #else
 | 
			
		||||
                  conf->addExtra("MANPREFIX = $$PREFIX/share"); 
 | 
			
		||||
                #endif
 | 
			
		||||
		return(QT_VERSION >= 0x040500);
 | 
			
		||||
		return(QT_VERSION >= 0x040600);
 | 
			
		||||
	}
 | 
			
		||||
};
 | 
			
		||||
 
 | 
			
		||||
@@ -13,10 +13,6 @@
 | 
			
		||||
			<string>qBitTorrentDocument</string>
 | 
			
		||||
			<key>CFBundleTypeName</key>
 | 
			
		||||
			<string>BitTorrent Document</string>
 | 
			
		||||
			<key>CFBundleTypeMIMETypes</key>
 | 
			
		||||
			<array>
 | 
			
		||||
				<string>application/x-bittorrent</string>
 | 
			
		||||
			</array>
 | 
			
		||||
			<key>CFBundleTypeRole</key>
 | 
			
		||||
			<string>Viewer</string>
 | 
			
		||||
			<key>LSHandlerRank</key>
 | 
			
		||||
@@ -40,21 +36,55 @@
 | 
			
		||||
			<string>BitTorrent Magnet URL</string>
 | 
			
		||||
		</dict>
 | 
			
		||||
	</array>
 | 
			
		||||
	<key>CFBundleName</key>
 | 
			
		||||
	<string>qBittorrent</string>
 | 
			
		||||
	<key>CFBundleIconFile</key>
 | 
			
		||||
	<string>qbittorrent_mac.icns</string>
 | 
			
		||||
	<key>CFBundleInfoDictionaryVersion</key>
 | 
			
		||||
	<string>6.0</string>
 | 
			
		||||
	<key>CFBundlePackageType</key>
 | 
			
		||||
	<string>APPL</string>
 | 
			
		||||
	<key>CFBundleGetInfoString</key>
 | 
			
		||||
	<string>2.8.0</string>
 | 
			
		||||
	<key>CFBundleShortVersionString</key>
 | 
			
		||||
	<string>3.0.1</string>
 | 
			
		||||
	<key>CFBundleSignature</key>
 | 
			
		||||
	<string>????</string>
 | 
			
		||||
	<string>qBit</string>
 | 
			
		||||
	<key>CFBundleExecutable</key>
 | 
			
		||||
	<string>qbittorrent</string>
 | 
			
		||||
	<key>CFBundleIdentifier</key>
 | 
			
		||||
	<string>org.qbittorrent</string>
 | 
			
		||||
	<key>NOTE</key>
 | 
			
		||||
	<string>This file was generated by Qt/QMake.</string>
 | 
			
		||||
	<key>NSAppleScriptEnabled</key>
 | 
			
		||||
	<string>YES</string>
 | 
			
		||||
	<key>NSHumanReadableCopyright</key>
 | 
			
		||||
	<string>Copyright © 2006-2012 Christophe Dumez</string>
 | 
			
		||||
	<key>UTExportedTypeDeclarations</key>
 | 
			
		||||
	<array>
 | 
			
		||||
		<dict>
 | 
			
		||||
			<key>UTTypeConformsTo</key>
 | 
			
		||||
			<array>
 | 
			
		||||
				<string>public.data</string>
 | 
			
		||||
				<string>public.item</string>
 | 
			
		||||
				<string>com.bittorrent.torrent</string>
 | 
			
		||||
			</array>
 | 
			
		||||
			<key>UTTypeDescription</key>
 | 
			
		||||
			<string>BitTorrent Document</string>
 | 
			
		||||
			<key>UTTypeIconFile</key>
 | 
			
		||||
			<string>qBitTorrentDocument</string>
 | 
			
		||||
			<key>UTTypeIdentifier</key>
 | 
			
		||||
			<string>org.bittorrent.torrent</string>
 | 
			
		||||
			<key>UTTypeReferenceURL</key>
 | 
			
		||||
			<string>http://www.bittorrent.org/beps/bep_0000.html</string>
 | 
			
		||||
			<key>UTTypeTagSpecification</key>
 | 
			
		||||
			<dict>
 | 
			
		||||
				<key>com.apple.ostype</key>
 | 
			
		||||
				<string>TORR</string>
 | 
			
		||||
				<key>public.filename-extension</key>
 | 
			
		||||
				<array>
 | 
			
		||||
					<string>torrent</string>
 | 
			
		||||
				</array>
 | 
			
		||||
				<key>public.mime-type</key>
 | 
			
		||||
				<string>application/x-bittorrent</string>
 | 
			
		||||
			</dict>
 | 
			
		||||
		</dict>
 | 
			
		||||
	</array>
 | 
			
		||||
</dict>
 | 
			
		||||
</plist>
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										26
									
								
								src/about.ui
									
									
									
									
									
								
							
							
						
						
									
										26
									
								
								src/about.ui
									
									
									
									
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							@@ -45,7 +45,7 @@ class about : public QDialog, private Ui::AboutDlg{
 | 
			
		||||
      qDebug("Deleting about dlg");
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    about(QWidget *parent): QDialog(parent){
 | 
			
		||||
    about(QWidget *parent): QDialog(parent) {
 | 
			
		||||
      setupUi(this);
 | 
			
		||||
      setAttribute(Qt::WA_DeleteOnClose);
 | 
			
		||||
      // Set icons
 | 
			
		||||
@@ -64,6 +64,8 @@ class about : public QDialog, private Ui::AboutDlg{
 | 
			
		||||
      QString trans_txt = "<p>"+tr("I would like to thank the following people who volunteered to translate qBittorrent:")+"</p>";
 | 
			
		||||
      trans_txt += QString::fromUtf8("<ul><li><u>Arabic:</u> SDERAWI (abz8868@msn.com) and sn51234 (nesseyan@gmail.com)</li>\
 | 
			
		||||
          <li><u>Armenian:</u> Hrant Ohanyan (hrantohanyan@mail.am)</li>\
 | 
			
		||||
          <li><u>Basque:</u> Xabier Aramendi (azpidatziak@gmail.com)</li>\
 | 
			
		||||
          <li><u>Belarusian:</u> Mihas Varantsou (meequz@gmail.com)</li>\
 | 
			
		||||
          <li><u>Brazilian:</u> Nick Marinho (nickmarinho@gmail.com)</li>\
 | 
			
		||||
          <li><u>Bulgarian:</u> Tsvetan & Boyko Bankoff (emerge_life@users.sourceforge.net)</li>\
 | 
			
		||||
          <li><u>Catalan:</u> Francisco Luque Contreras (frannoe@ya.com)</li>\
 | 
			
		||||
@@ -75,6 +77,7 @@ class about : public QDialog, private Ui::AboutDlg{
 | 
			
		||||
          <li><u>Dutch:</u> Pieter Heyvaert (pieter_heyvaert@hotmail.com)</li>\
 | 
			
		||||
          <li><u>Finnish:</u> Niklas Laxström (nikerabbit@users.sourceforge.net) and Pekka Niemi (pekka.niemi@iki.fi)</li>\
 | 
			
		||||
          <li><u>Galician:</u> Marcos Lans (marcoslansgarza@gmail.com)</li>\
 | 
			
		||||
          <li><u>Georgian:</u> Beqa Arabuli (arabulibeqa@yahoo.com)</li>\
 | 
			
		||||
          <li><u>German:</u> Niels Hoffmann (zentralmaschine@users.sourceforge.net)</li>\
 | 
			
		||||
          <li><u>Greek:</u> Tsvetan Bankov (emerge_life@users.sourceforge.net)</li>\
 | 
			
		||||
          <li><u>Hungarian:</u> Majoros Péter (majoros.peterj@gmail.com)</li>\
 | 
			
		||||
@@ -92,13 +95,13 @@ class about : public QDialog, private Ui::AboutDlg{
 | 
			
		||||
          <li><u>Spanish:</u> Francisco Luque Contreras (frannoe@ya.com)</li>\
 | 
			
		||||
          <li><u>Swedish:</u> Daniel Nylander (po@danielnylander.se)</li>\
 | 
			
		||||
          <li><u>Turkish:</u> Hasan YILMAZ (iletisim@hedefturkce.com) and Erdem Bingöl (erdem84@gmail.com)</li>\
 | 
			
		||||
          <li><u>Ukrainian:</u> Andrey Shpachenko (masterfix@users.sourceforge.net) and Oleh Prypin (blaxpirit@gmail.com)</li></ul>");
 | 
			
		||||
          <li><u>Ukrainian:</u> Oleh Prypin (blaxpirit@gmail.com)</li></ul>");
 | 
			
		||||
      trans_txt += "<p>"+tr("Please contact me if you would like to translate qBittorrent into your own language.")+"</p>";
 | 
			
		||||
      te_translation->setHtml(trans_txt);
 | 
			
		||||
      // License
 | 
			
		||||
      te_license->append(QString::fromUtf8("<a name='top'></a>"));
 | 
			
		||||
      QFile licensefile(":/gpl.html");
 | 
			
		||||
      if(licensefile.open(QIODevice::ReadOnly|QIODevice::Text)) {
 | 
			
		||||
      if (licensefile.open(QIODevice::ReadOnly|QIODevice::Text)) {
 | 
			
		||||
        te_license->setHtml(licensefile.readAll());
 | 
			
		||||
        licensefile.close();
 | 
			
		||||
      }
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										599
									
								
								src/addnewtorrentdialog.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										599
									
								
								src/addnewtorrentdialog.cpp
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							@@ -1,6 +1,6 @@
 | 
			
		||||
/*
 | 
			
		||||
 * Bittorrent Client using Qt4 and libtorrent.
 | 
			
		||||
 * Copyright (C) 2006  Christophe Dumez
 | 
			
		||||
 * Copyright (C) 2012  Christophe Dumez
 | 
			
		||||
 *
 | 
			
		||||
 * This program is free software; you can redistribute it and/or
 | 
			
		||||
 * modify it under the terms of the GNU General Public License
 | 
			
		||||
@@ -28,70 +28,64 @@
 | 
			
		||||
 * Contact : chris@qbittorrent.org
 | 
			
		||||
 */
 | 
			
		||||
 | 
			
		||||
#ifndef TORRENTADDITION_H
 | 
			
		||||
#define TORRENTADDITION_H
 | 
			
		||||
 | 
			
		||||
#include <QStringList>
 | 
			
		||||
 | 
			
		||||
#include "ui_torrentadditiondlg.h"
 | 
			
		||||
#ifndef ADDNEWTORRENTDIALOG_H
 | 
			
		||||
#define ADDNEWTORRENTDIALOG_H
 | 
			
		||||
 | 
			
		||||
#include <QDialog>
 | 
			
		||||
#include <QUrl>
 | 
			
		||||
#include <libtorrent/torrent_info.hpp>
 | 
			
		||||
 | 
			
		||||
class TorrentFilesFilterModel;
 | 
			
		||||
QT_BEGIN_NAMESPACE
 | 
			
		||||
namespace Ui {
 | 
			
		||||
class AddNewTorrentDialog;
 | 
			
		||||
}
 | 
			
		||||
QT_END_NAMESPACE
 | 
			
		||||
 | 
			
		||||
class TorrentContentFilterModel;
 | 
			
		||||
class PropListDelegate;
 | 
			
		||||
 | 
			
		||||
class torrentAdditionDialog : public QDialog, private Ui_addTorrentDialog{
 | 
			
		||||
class AddNewTorrentDialog : public QDialog
 | 
			
		||||
{
 | 
			
		||||
  Q_OBJECT
 | 
			
		||||
 | 
			
		||||
  
 | 
			
		||||
public:
 | 
			
		||||
  torrentAdditionDialog(QWidget *parent);
 | 
			
		||||
  ~torrentAdditionDialog();
 | 
			
		||||
  void showLoadMagnetURI(QString magnet_uri);
 | 
			
		||||
  void showLoad(QString filePath, QString from_url=QString::null);
 | 
			
		||||
  QString getCurrentTruncatedSavePath(QString* root_folder_or_file_name = 0) const;
 | 
			
		||||
  QString getTruncatedSavePath(QString save_path, QString* root_folder_or_file_name = 0) const;
 | 
			
		||||
  bool allFiltered() const;
 | 
			
		||||
  ~AddNewTorrentDialog();
 | 
			
		||||
 | 
			
		||||
public slots:
 | 
			
		||||
  void displayContentListMenu(const QPoint&);
 | 
			
		||||
  static void showTorrent(const QString& torrent_path, const QString& from_url = QString());
 | 
			
		||||
  static void showMagnet(const QString& torrent_link);
 | 
			
		||||
 | 
			
		||||
private slots:
 | 
			
		||||
  void showAdvancedSettings(bool show);
 | 
			
		||||
  void displayContentTreeMenu(const QPoint&);
 | 
			
		||||
  void on_buttonBox_accepted();
 | 
			
		||||
  void updateDiskSpaceLabel();
 | 
			
		||||
  void onSavePathChanged(int);
 | 
			
		||||
  void relayout();
 | 
			
		||||
  void renameSelectedFile();
 | 
			
		||||
  void updateDiskSpaceLabels();
 | 
			
		||||
  void on_browseButton_clicked();
 | 
			
		||||
  void on_CancelButton_clicked();
 | 
			
		||||
  void savePiecesPriorities();
 | 
			
		||||
  void on_OkButton_clicked();
 | 
			
		||||
  void hideTorrentContent();
 | 
			
		||||
  void limitDialogWidth();
 | 
			
		||||
  void saveTruncatedPathHistory();
 | 
			
		||||
  void setdialogPosition();
 | 
			
		||||
 | 
			
		||||
private:
 | 
			
		||||
  explicit AddNewTorrentDialog(QWidget *parent = 0);
 | 
			
		||||
  bool loadTorrent(const QString& torrent_path, const QString& from_url);
 | 
			
		||||
  bool loadMagnet(const QString& magnet_uri);
 | 
			
		||||
  void loadSavePathHistory();
 | 
			
		||||
  void updateLabelInSavePath(QString label);
 | 
			
		||||
  void updateSavePathCurrentText();
 | 
			
		||||
  void resetComboLabelIndex(QString text);
 | 
			
		||||
 | 
			
		||||
protected:
 | 
			
		||||
  void closeEvent(QCloseEvent *event);
 | 
			
		||||
  void saveSavePathHistory() const;
 | 
			
		||||
  int indexOfSavePath(const QString& save_path);
 | 
			
		||||
  void updateFileNameInSavePaths(const QString& new_filename);
 | 
			
		||||
  void loadState();
 | 
			
		||||
  void saveState();
 | 
			
		||||
 | 
			
		||||
private:
 | 
			
		||||
  void readSettings();
 | 
			
		||||
  void saveSettings();
 | 
			
		||||
 | 
			
		||||
private:
 | 
			
		||||
  QString fileName;
 | 
			
		||||
  QString hash;
 | 
			
		||||
  QString filePath;
 | 
			
		||||
  QString from_url;
 | 
			
		||||
  QString defaultSavePath;
 | 
			
		||||
  QString old_label;
 | 
			
		||||
  bool appendLabelToSavePath;
 | 
			
		||||
  TorrentFilesFilterModel *PropListModel;
 | 
			
		||||
  PropListDelegate *PropDelegate;
 | 
			
		||||
  unsigned int nbFiles;
 | 
			
		||||
  boost::intrusive_ptr<libtorrent::torrent_info> t;
 | 
			
		||||
  QStringList files_path;
 | 
			
		||||
  bool is_magnet;
 | 
			
		||||
  int hidden_height;
 | 
			
		||||
  QStringList path_history;
 | 
			
		||||
  bool m_showContentList;
 | 
			
		||||
  Ui::AddNewTorrentDialog *ui;
 | 
			
		||||
  TorrentContentFilterModel *m_contentModel;
 | 
			
		||||
  PropListDelegate *m_contentDelegate;
 | 
			
		||||
  bool m_isMagnet;
 | 
			
		||||
  QString m_filePath;
 | 
			
		||||
  QString m_url;
 | 
			
		||||
  QString m_hash;
 | 
			
		||||
  boost::intrusive_ptr<libtorrent::torrent_info> m_torrentInfo;
 | 
			
		||||
  QStringList m_filesPath;
 | 
			
		||||
  bool m_hasRenamedFile;
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
#endif
 | 
			
		||||
#endif // ADDNEWTORRENTDIALOG_H
 | 
			
		||||
							
								
								
									
										274
									
								
								src/addnewtorrentdialog.ui
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										274
									
								
								src/addnewtorrentdialog.ui
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							@@ -59,7 +59,7 @@ class DeletionConfirmationDlg : public QDialog, private Ui::confirmDeletionDlg {
 | 
			
		||||
 | 
			
		||||
  static bool askForDeletionConfirmation(bool *delete_local_files) {
 | 
			
		||||
    DeletionConfirmationDlg dlg;
 | 
			
		||||
    if(dlg.exec() == QDialog::Accepted) {
 | 
			
		||||
    if (dlg.exec() == QDialog::Accepted) {
 | 
			
		||||
      *delete_local_files = dlg.shouldDeleteLocalFiles();
 | 
			
		||||
      return true;
 | 
			
		||||
    }
 | 
			
		||||
 
 | 
			
		||||
@@ -50,7 +50,7 @@ DNSUpdater::DNSUpdater(QObject *parent) :
 | 
			
		||||
  m_ipCheckTimer.start();
 | 
			
		||||
 | 
			
		||||
  // Check lastUpdate to avoid flooding
 | 
			
		||||
  if(!m_lastIPCheckTime.isValid() ||
 | 
			
		||||
  if (!m_lastIPCheckTime.isValid() ||
 | 
			
		||||
      m_lastIPCheckTime.secsTo(QDateTime::currentDateTime())*1000 > IP_CHECK_INTERVAL_MS) {
 | 
			
		||||
    checkPublicIP();
 | 
			
		||||
  }
 | 
			
		||||
@@ -79,19 +79,19 @@ void DNSUpdater::checkPublicIP()
 | 
			
		||||
void DNSUpdater::ipRequestFinished(QNetworkReply *reply)
 | 
			
		||||
{
 | 
			
		||||
  qDebug() << Q_FUNC_INFO;
 | 
			
		||||
  if(reply->error()) {
 | 
			
		||||
  if (reply->error()) {
 | 
			
		||||
    // Error
 | 
			
		||||
    qWarning() << Q_FUNC_INFO << "Error:" << reply->errorString();
 | 
			
		||||
  } else {
 | 
			
		||||
    // Parse response
 | 
			
		||||
    QRegExp ipregex("Current IP Address:\\s+([^<]+)</body>");
 | 
			
		||||
    QString ret = reply->readAll();
 | 
			
		||||
    if(ipregex.indexIn(ret) >= 0) {
 | 
			
		||||
    if (ipregex.indexIn(ret) >= 0) {
 | 
			
		||||
      QString ip_str = ipregex.cap(1);
 | 
			
		||||
      qDebug() << Q_FUNC_INFO << "Regular expression captured the following IP:" << ip_str;
 | 
			
		||||
      QHostAddress new_ip(ip_str);
 | 
			
		||||
      if(!new_ip.isNull()) {
 | 
			
		||||
        if(m_lastIP != new_ip) {
 | 
			
		||||
      if (!new_ip.isNull()) {
 | 
			
		||||
        if (m_lastIP != new_ip) {
 | 
			
		||||
          qDebug() << Q_FUNC_INFO << "The IP address changed, report the change to DynDNS...";
 | 
			
		||||
          qDebug() << m_lastIP.toString() << "->" << new_ip.toString();
 | 
			
		||||
          m_lastIP = new_ip;
 | 
			
		||||
@@ -157,7 +157,7 @@ QUrl DNSUpdater::getUpdateUrl() const
 | 
			
		||||
 | 
			
		||||
void DNSUpdater::ipUpdateFinished(QNetworkReply *reply)
 | 
			
		||||
{
 | 
			
		||||
  if(reply->error()) {
 | 
			
		||||
  if (reply->error()) {
 | 
			
		||||
    // Error
 | 
			
		||||
    qWarning() << Q_FUNC_INFO << "Error:" << reply->errorString();
 | 
			
		||||
  } else {
 | 
			
		||||
@@ -174,11 +174,11 @@ void DNSUpdater::processIPUpdateReply(const QString &reply)
 | 
			
		||||
  qDebug() << Q_FUNC_INFO << reply;
 | 
			
		||||
  QString code = reply.split(" ").first();
 | 
			
		||||
  qDebug() << Q_FUNC_INFO << "Code:" << code;
 | 
			
		||||
  if(code == "good" || code == "nochg") {
 | 
			
		||||
    QBtSession::instance()->addConsoleMessage(tr("Your dynamic DNS was successfuly updated."), "green");
 | 
			
		||||
  if (code == "good" || code == "nochg") {
 | 
			
		||||
    QBtSession::instance()->addConsoleMessage(tr("Your dynamic DNS was successfully updated."), "green");
 | 
			
		||||
    return;
 | 
			
		||||
  }
 | 
			
		||||
  if(code == "911" || code == "dnserr") {
 | 
			
		||||
  if (code == "911" || code == "dnserr") {
 | 
			
		||||
    QBtSession::instance()->addConsoleMessage(tr("Dynamic DNS error: The service is temporarily unavailable, it will be retried in 30 minutes."),
 | 
			
		||||
                                              "red");
 | 
			
		||||
    m_lastIP.clear();
 | 
			
		||||
@@ -188,30 +188,30 @@ void DNSUpdater::processIPUpdateReply(const QString &reply)
 | 
			
		||||
  // Everything bellow is an error, stop updating until the user updates something
 | 
			
		||||
  m_ipCheckTimer.stop();
 | 
			
		||||
  m_lastIP.clear();
 | 
			
		||||
  if(code == "nohost") {
 | 
			
		||||
  if (code == "nohost") {
 | 
			
		||||
    QBtSession::instance()->addConsoleMessage(tr("Dynamic DNS error: hostname supplied does not exist under specified account."),
 | 
			
		||||
                                              "red");
 | 
			
		||||
    m_state = INVALID_CREDS;
 | 
			
		||||
    return;
 | 
			
		||||
  }
 | 
			
		||||
  if(code == "badauth") {
 | 
			
		||||
  if (code == "badauth") {
 | 
			
		||||
    QBtSession::instance()->addConsoleMessage(tr("Dynamic DNS error: Invalid username/password."), "red");
 | 
			
		||||
    m_state = INVALID_CREDS;
 | 
			
		||||
    return;
 | 
			
		||||
  }
 | 
			
		||||
  if(code == "badagent") {
 | 
			
		||||
  if (code == "badagent") {
 | 
			
		||||
    QBtSession::instance()->addConsoleMessage(tr("Dynamic DNS error: qBittorrent was blacklisted by the service, please report a bug at http://bugs.qbittorrent.org."),
 | 
			
		||||
                                              "red");
 | 
			
		||||
    m_state = FATAL;
 | 
			
		||||
    return;
 | 
			
		||||
  }
 | 
			
		||||
  if(code == "!donator") {
 | 
			
		||||
  if (code == "!donator") {
 | 
			
		||||
    QBtSession::instance()->addConsoleMessage(tr("Dynamic DNS error: %1 was returned by the service, please report a bug at http://bugs.qbittorrent.org.").arg("!donator"),
 | 
			
		||||
                                              "red");
 | 
			
		||||
    m_state = FATAL;
 | 
			
		||||
    return;
 | 
			
		||||
  }
 | 
			
		||||
  if(code == "abuse") {
 | 
			
		||||
  if (code == "abuse") {
 | 
			
		||||
    QBtSession::instance()->addConsoleMessage(tr("Dynamic DNS error: Your username was blocked due to abuse."),
 | 
			
		||||
                                              "red");
 | 
			
		||||
    m_state = FATAL;
 | 
			
		||||
@@ -221,18 +221,18 @@ void DNSUpdater::processIPUpdateReply(const QString &reply)
 | 
			
		||||
 | 
			
		||||
void DNSUpdater::updateCredentials()
 | 
			
		||||
{
 | 
			
		||||
  if(m_state == FATAL) return;
 | 
			
		||||
  if (m_state == FATAL) return;
 | 
			
		||||
  Preferences pref;
 | 
			
		||||
  bool change = false;
 | 
			
		||||
  // Get DNS service information
 | 
			
		||||
  if(m_service != pref.getDynDNSService()) {
 | 
			
		||||
  if (m_service != pref.getDynDNSService()) {
 | 
			
		||||
    m_service = pref.getDynDNSService();
 | 
			
		||||
    change = true;
 | 
			
		||||
  }
 | 
			
		||||
  if(m_domain != pref.getDynDomainName()) {
 | 
			
		||||
  if (m_domain != pref.getDynDomainName()) {
 | 
			
		||||
    m_domain = pref.getDynDomainName();
 | 
			
		||||
    QRegExp domain_regex("^(?:(?!\\d|-)[a-zA-Z0-9\\-]{1,63}\\.)+[a-zA-Z]{2,}$");
 | 
			
		||||
    if(domain_regex.indexIn(m_domain) < 0) {
 | 
			
		||||
    if (domain_regex.indexIn(m_domain) < 0) {
 | 
			
		||||
      QBtSession::instance()->addConsoleMessage(tr("Dynamic DNS error: supplied domain name is invalid."),
 | 
			
		||||
                                                "red");
 | 
			
		||||
      m_lastIP.clear();
 | 
			
		||||
@@ -242,9 +242,9 @@ void DNSUpdater::updateCredentials()
 | 
			
		||||
    }
 | 
			
		||||
    change = true;
 | 
			
		||||
  }
 | 
			
		||||
  if(m_username != pref.getDynDNSUsername()) {
 | 
			
		||||
  if (m_username != pref.getDynDNSUsername()) {
 | 
			
		||||
    m_username = pref.getDynDNSUsername();
 | 
			
		||||
    if(m_username.length() < 4) {
 | 
			
		||||
    if (m_username.length() < 4) {
 | 
			
		||||
      QBtSession::instance()->addConsoleMessage(tr("Dynamic DNS error: supplied username is too short."),
 | 
			
		||||
                                                "red");
 | 
			
		||||
      m_lastIP.clear();
 | 
			
		||||
@@ -254,9 +254,9 @@ void DNSUpdater::updateCredentials()
 | 
			
		||||
    }
 | 
			
		||||
    change = true;
 | 
			
		||||
  }
 | 
			
		||||
  if(m_password != pref.getDynDNSPassword()) {
 | 
			
		||||
  if (m_password != pref.getDynDNSPassword()) {
 | 
			
		||||
    m_password = pref.getDynDNSPassword();
 | 
			
		||||
    if(m_password.length() < 4) {
 | 
			
		||||
    if (m_password.length() < 4) {
 | 
			
		||||
      QBtSession::instance()->addConsoleMessage(tr("Dynamic DNS error: supplied password is too short."),
 | 
			
		||||
                                                "red");
 | 
			
		||||
      m_lastIP.clear();
 | 
			
		||||
@@ -267,7 +267,7 @@ void DNSUpdater::updateCredentials()
 | 
			
		||||
    change = true;
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  if(m_state == INVALID_CREDS && change) {
 | 
			
		||||
  if (m_state == INVALID_CREDS && change) {
 | 
			
		||||
    m_state = OK; // Try again
 | 
			
		||||
    m_ipCheckTimer.start();
 | 
			
		||||
    checkPublicIP();
 | 
			
		||||
 
 | 
			
		||||
@@ -43,38 +43,38 @@ class downloadFromURL : public QDialog, private Ui::downloadFromURL{
 | 
			
		||||
  Q_OBJECT
 | 
			
		||||
 | 
			
		||||
  public:
 | 
			
		||||
    downloadFromURL(QWidget *parent): QDialog(parent){
 | 
			
		||||
    downloadFromURL(QWidget *parent): QDialog(parent) {
 | 
			
		||||
      setupUi(this);
 | 
			
		||||
      setAttribute(Qt::WA_DeleteOnClose);
 | 
			
		||||
      setModal(true);
 | 
			
		||||
      show();
 | 
			
		||||
      // Paste clipboard if there is an URL in it
 | 
			
		||||
      QString clip_txt = qApp->clipboard()->text();
 | 
			
		||||
      if(clip_txt.startsWith("http://", Qt::CaseInsensitive) || clip_txt.startsWith("https://", Qt::CaseInsensitive) || clip_txt.startsWith("ftp://", Qt::CaseInsensitive) || clip_txt.startsWith("magnet:", Qt::CaseInsensitive) || clip_txt.startsWith("bc://bt/", Qt::CaseInsensitive)) {
 | 
			
		||||
      if (clip_txt.startsWith("http://", Qt::CaseInsensitive) || clip_txt.startsWith("https://", Qt::CaseInsensitive) || clip_txt.startsWith("ftp://", Qt::CaseInsensitive) || clip_txt.startsWith("magnet:", Qt::CaseInsensitive) || clip_txt.startsWith("bc://bt/", Qt::CaseInsensitive)) {
 | 
			
		||||
        textUrls->setText(clip_txt);
 | 
			
		||||
      }
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    ~downloadFromURL(){}
 | 
			
		||||
    ~downloadFromURL() {}
 | 
			
		||||
 | 
			
		||||
  signals:
 | 
			
		||||
    void urlsReadyToBeDownloaded(const QStringList& torrent_urls);
 | 
			
		||||
 | 
			
		||||
  public slots:
 | 
			
		||||
    void on_downloadButton_clicked(){
 | 
			
		||||
    void on_downloadButton_clicked() {
 | 
			
		||||
      QString urls = textUrls->toPlainText();
 | 
			
		||||
      QStringList url_list = urls.split(QString::fromUtf8("\n"));
 | 
			
		||||
      QString url;
 | 
			
		||||
      QStringList url_list_cleaned;
 | 
			
		||||
      foreach(url, url_list){
 | 
			
		||||
      foreach (url, url_list) {
 | 
			
		||||
        url = url.trimmed();
 | 
			
		||||
        if(!url.isEmpty()){
 | 
			
		||||
          if(url_list_cleaned.indexOf(QRegExp(url, Qt::CaseInsensitive, QRegExp::FixedString)) < 0){
 | 
			
		||||
        if (!url.isEmpty()) {
 | 
			
		||||
          if (url_list_cleaned.indexOf(QRegExp(url, Qt::CaseInsensitive, QRegExp::FixedString)) < 0) {
 | 
			
		||||
            url_list_cleaned << url;
 | 
			
		||||
          }
 | 
			
		||||
        }
 | 
			
		||||
      }
 | 
			
		||||
      if(!url_list_cleaned.size()){
 | 
			
		||||
      if (!url_list_cleaned.size()) {
 | 
			
		||||
        QMessageBox::critical(0, tr("No URL entered"), tr("Please type at least one URL."));
 | 
			
		||||
        return;
 | 
			
		||||
      }
 | 
			
		||||
@@ -83,7 +83,7 @@ class downloadFromURL : public QDialog, private Ui::downloadFromURL{
 | 
			
		||||
      close();
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    void on_cancelButton_clicked(){
 | 
			
		||||
    void on_cancelButton_clicked() {
 | 
			
		||||
      close();
 | 
			
		||||
    }
 | 
			
		||||
};
 | 
			
		||||
 
 | 
			
		||||
@@ -14,31 +14,14 @@
 | 
			
		||||
   <string>Download from urls</string>
 | 
			
		||||
  </property>
 | 
			
		||||
  <layout class="QVBoxLayout">
 | 
			
		||||
   <property name="spacing">
 | 
			
		||||
    <number>6</number>
 | 
			
		||||
   </property>
 | 
			
		||||
   <property name="margin">
 | 
			
		||||
    <number>9</number>
 | 
			
		||||
   </property>
 | 
			
		||||
   <item>
 | 
			
		||||
    <layout class="QHBoxLayout">
 | 
			
		||||
     <property name="spacing">
 | 
			
		||||
      <number>6</number>
 | 
			
		||||
     </property>
 | 
			
		||||
     <property name="margin">
 | 
			
		||||
      <number>0</number>
 | 
			
		||||
     </property>
 | 
			
		||||
     <item>
 | 
			
		||||
      <widget class="QLabel" name="downloadURL_lbl">
 | 
			
		||||
       <property name="font">
 | 
			
		||||
        <font>
 | 
			
		||||
         <family>Sans Serif</family>
 | 
			
		||||
         <pointsize>12</pointsize>
 | 
			
		||||
         <weight>75</weight>
 | 
			
		||||
         <italic>false</italic>
 | 
			
		||||
         <bold>true</bold>
 | 
			
		||||
         <underline>false</underline>
 | 
			
		||||
         <strikeout>false</strikeout>
 | 
			
		||||
        </font>
 | 
			
		||||
       </property>
 | 
			
		||||
       <property name="text">
 | 
			
		||||
@@ -65,13 +48,7 @@
 | 
			
		||||
     </property>
 | 
			
		||||
     <property name="font">
 | 
			
		||||
      <font>
 | 
			
		||||
       <family>Sans Serif</family>
 | 
			
		||||
       <pointsize>9</pointsize>
 | 
			
		||||
       <weight>50</weight>
 | 
			
		||||
       <italic>true</italic>
 | 
			
		||||
       <bold>false</bold>
 | 
			
		||||
       <underline>false</underline>
 | 
			
		||||
       <strikeout>false</strikeout>
 | 
			
		||||
      </font>
 | 
			
		||||
     </property>
 | 
			
		||||
     <property name="text">
 | 
			
		||||
@@ -81,12 +58,6 @@
 | 
			
		||||
   </item>
 | 
			
		||||
   <item>
 | 
			
		||||
    <layout class="QHBoxLayout">
 | 
			
		||||
     <property name="spacing">
 | 
			
		||||
      <number>6</number>
 | 
			
		||||
     </property>
 | 
			
		||||
     <property name="margin">
 | 
			
		||||
      <number>0</number>
 | 
			
		||||
     </property>
 | 
			
		||||
     <item>
 | 
			
		||||
      <spacer>
 | 
			
		||||
       <property name="orientation">
 | 
			
		||||
 
 | 
			
		||||
@@ -32,7 +32,6 @@
 | 
			
		||||
#include <QNetworkAccessManager>
 | 
			
		||||
#include <QNetworkRequest>
 | 
			
		||||
#include <QNetworkProxy>
 | 
			
		||||
#include <QNetworkCookie>
 | 
			
		||||
#include <QNetworkCookieJar>
 | 
			
		||||
 | 
			
		||||
#include "downloadthread.h"
 | 
			
		||||
@@ -55,7 +54,7 @@ void DownloadThread::processDlFinished(QNetworkReply* reply) {
 | 
			
		||||
  QString url = reply->url().toString();
 | 
			
		||||
  qDebug("Download finished: %s", qPrintable(url));
 | 
			
		||||
  // Check if the request was successful
 | 
			
		||||
  if(reply->error() != QNetworkReply::NoError) {
 | 
			
		||||
  if (reply->error() != QNetworkReply::NoError) {
 | 
			
		||||
    // Failure
 | 
			
		||||
    qDebug("Download failure (%s), reason: %s", qPrintable(url), qPrintable(errorCodeToString(reply->error())));
 | 
			
		||||
    emit downloadFailure(url, errorCodeToString(reply->error()));
 | 
			
		||||
@@ -64,16 +63,21 @@ void DownloadThread::processDlFinished(QNetworkReply* reply) {
 | 
			
		||||
  }
 | 
			
		||||
  // Check if the server ask us to redirect somewhere lese
 | 
			
		||||
  const QVariant redirection = reply->attribute(QNetworkRequest::RedirectionTargetAttribute);
 | 
			
		||||
  if(redirection.isValid()) {
 | 
			
		||||
  if (redirection.isValid()) {
 | 
			
		||||
    // We should redirect
 | 
			
		||||
    qDebug("Redirecting from %s to %s", qPrintable(url), qPrintable(redirection.toUrl().toString()));
 | 
			
		||||
    m_redirectMapping.insert(redirection.toUrl().toString(), url);
 | 
			
		||||
    downloadUrl(redirection.toUrl().toString());
 | 
			
		||||
    QUrl newUrl = redirection.toUrl();
 | 
			
		||||
    // Resolve relative urls
 | 
			
		||||
    if (newUrl.isRelative())
 | 
			
		||||
        newUrl = reply->url().resolved(newUrl);
 | 
			
		||||
    const QString newUrlString = newUrl.toString();
 | 
			
		||||
    qDebug("Redirecting from %s to %s", qPrintable(url), qPrintable(newUrlString));
 | 
			
		||||
    m_redirectMapping.insert(newUrlString, url);
 | 
			
		||||
    downloadUrl(newUrlString);
 | 
			
		||||
    reply->deleteLater();
 | 
			
		||||
    return;
 | 
			
		||||
  }
 | 
			
		||||
  // Checking if it was redirected, restoring initial URL
 | 
			
		||||
  if(m_redirectMapping.contains(url)) {
 | 
			
		||||
  if (m_redirectMapping.contains(url)) {
 | 
			
		||||
    url = m_redirectMapping.take(url);
 | 
			
		||||
  }
 | 
			
		||||
  // Success
 | 
			
		||||
@@ -82,7 +86,7 @@ void DownloadThread::processDlFinished(QNetworkReply* reply) {
 | 
			
		||||
  if (tmpfile->open()) {
 | 
			
		||||
    QString filePath = tmpfile->fileName();
 | 
			
		||||
    qDebug("Temporary filename is: %s", qPrintable(filePath));
 | 
			
		||||
    if(reply->isOpen() || reply->open(QIODevice::ReadOnly)) {
 | 
			
		||||
    if (reply->isOpen() || reply->open(QIODevice::ReadOnly)) {
 | 
			
		||||
      // TODO: Support GZIP compression
 | 
			
		||||
      tmpfile->write(reply->readAll());
 | 
			
		||||
      tmpfile->close();
 | 
			
		||||
@@ -104,39 +108,21 @@ void DownloadThread::processDlFinished(QNetworkReply* reply) {
 | 
			
		||||
  reply->deleteLater();
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#ifndef DISABLE_GUI
 | 
			
		||||
void DownloadThread::loadCookies(const QString &host_name, QString url) {
 | 
			
		||||
  const QList<QByteArray> raw_cookies = RssSettings().getHostNameCookies(host_name);
 | 
			
		||||
  QNetworkCookieJar *cookie_jar = m_networkManager.cookieJar();
 | 
			
		||||
  QList<QNetworkCookie> cookies;
 | 
			
		||||
  qDebug("Loading cookies for host name: %s", qPrintable(host_name));
 | 
			
		||||
  foreach(const QByteArray& raw_cookie, raw_cookies) {
 | 
			
		||||
    QList<QByteArray> cookie_parts = raw_cookie.split('=');
 | 
			
		||||
    if(cookie_parts.size() == 2) {
 | 
			
		||||
      qDebug("Loading cookie: %s", raw_cookie.constData());
 | 
			
		||||
      cookies << QNetworkCookie(cookie_parts.first(), cookie_parts.last());
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
  cookie_jar->setCookiesFromUrl(cookies, url);
 | 
			
		||||
  m_networkManager.setCookieJar(cookie_jar);
 | 
			
		||||
}
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
void DownloadThread::downloadTorrentUrl(const QString &url) {
 | 
			
		||||
void DownloadThread::downloadTorrentUrl(const QString &url, const QList<QNetworkCookie>& cookies)
 | 
			
		||||
{
 | 
			
		||||
  // Process request
 | 
			
		||||
  QNetworkReply *reply = downloadUrl(url);
 | 
			
		||||
  QNetworkReply *reply = downloadUrl(url, cookies);
 | 
			
		||||
  connect(reply, SIGNAL(downloadProgress(qint64,qint64)), this, SLOT(checkDownloadSize(qint64,qint64)));
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
QNetworkReply* DownloadThread::downloadUrl(const QString &url){
 | 
			
		||||
QNetworkReply* DownloadThread::downloadUrl(const QString &url, const QList<QNetworkCookie>& cookies) {
 | 
			
		||||
  // Update proxy settings
 | 
			
		||||
  applyProxySettings();
 | 
			
		||||
#ifndef DISABLE_GUI
 | 
			
		||||
  // Load cookies
 | 
			
		||||
  QString host_name = QUrl::fromEncoded(url.toUtf8()).host();
 | 
			
		||||
  if(!host_name.isEmpty())
 | 
			
		||||
    loadCookies(host_name, url);
 | 
			
		||||
#endif
 | 
			
		||||
  // Set cookies
 | 
			
		||||
  if (!cookies.empty()) {
 | 
			
		||||
    qDebug("Setting %d cookies for url: %s", cookies.size(), qPrintable(url));
 | 
			
		||||
    m_networkManager.cookieJar()->setCookiesFromUrl(cookies, url);
 | 
			
		||||
  }
 | 
			
		||||
  // Process download request
 | 
			
		||||
  qDebug("url is %s", qPrintable(url));
 | 
			
		||||
  const QUrl qurl = QUrl::fromEncoded(url.toUtf8());
 | 
			
		||||
@@ -146,7 +132,7 @@ QNetworkReply* DownloadThread::downloadUrl(const QString &url){
 | 
			
		||||
  request.setRawHeader("User-Agent", "Mozilla/5.0 (X11; U; Linux i686 (x86_64); en-US; rv:1.9.1.5) Gecko/20091102 Firefox/3.5.5");
 | 
			
		||||
  qDebug("Downloading %s...", request.url().toEncoded().data());
 | 
			
		||||
  qDebug("%d cookies for this URL", m_networkManager.cookieJar()->cookiesForUrl(url).size());
 | 
			
		||||
  for(int i=0; i<m_networkManager.cookieJar()->cookiesForUrl(url).size(); ++i) {
 | 
			
		||||
  for (int i=0; i<m_networkManager.cookieJar()->cookiesForUrl(url).size(); ++i) {
 | 
			
		||||
    qDebug("%s=%s", m_networkManager.cookieJar()->cookiesForUrl(url).at(i).name().data(), m_networkManager.cookieJar()->cookiesForUrl(url).at(i).value().data());
 | 
			
		||||
    qDebug("Domain: %s, Path: %s", qPrintable(m_networkManager.cookieJar()->cookiesForUrl(url).at(i).domain()), qPrintable(m_networkManager.cookieJar()->cookiesForUrl(url).at(i).path()));
 | 
			
		||||
  }
 | 
			
		||||
@@ -155,10 +141,10 @@ QNetworkReply* DownloadThread::downloadUrl(const QString &url){
 | 
			
		||||
 | 
			
		||||
void DownloadThread::checkDownloadSize(qint64 bytesReceived, qint64 bytesTotal) {
 | 
			
		||||
  QNetworkReply *reply = qobject_cast<QNetworkReply*>(sender());
 | 
			
		||||
  if(!reply) return;
 | 
			
		||||
  if(bytesTotal > 0) {
 | 
			
		||||
  if (!reply) return;
 | 
			
		||||
  if (bytesTotal > 0) {
 | 
			
		||||
    // Total number of bytes is available
 | 
			
		||||
    if(bytesTotal > 1048576) {
 | 
			
		||||
    if (bytesTotal > 1048576) {
 | 
			
		||||
      // More than 1MB, this is probably not a torrent file, aborting...
 | 
			
		||||
      reply->abort();
 | 
			
		||||
      reply->deleteLater();
 | 
			
		||||
@@ -166,7 +152,7 @@ void DownloadThread::checkDownloadSize(qint64 bytesReceived, qint64 bytesTotal)
 | 
			
		||||
      disconnect(reply, SIGNAL(downloadProgress(qint64,qint64)), this, SLOT(checkDownloadSize(qint64,qint64)));
 | 
			
		||||
    }
 | 
			
		||||
  } else {
 | 
			
		||||
    if(bytesReceived  > 1048576) {
 | 
			
		||||
    if (bytesReceived  > 1048576) {
 | 
			
		||||
      // More than 1MB, this is probably not a torrent file, aborting...
 | 
			
		||||
      reply->abort();
 | 
			
		||||
      reply->deleteLater();
 | 
			
		||||
@@ -177,13 +163,13 @@ void DownloadThread::checkDownloadSize(qint64 bytesReceived, qint64 bytesTotal)
 | 
			
		||||
void DownloadThread::applyProxySettings() {
 | 
			
		||||
  QNetworkProxy proxy;
 | 
			
		||||
  const Preferences pref;
 | 
			
		||||
  if(pref.isProxyEnabled()) {
 | 
			
		||||
  if (pref.isProxyEnabled()) {
 | 
			
		||||
    // Proxy enabled
 | 
			
		||||
    proxy.setHostName(pref.getProxyIp());
 | 
			
		||||
    proxy.setPort(pref.getProxyPort());
 | 
			
		||||
    // Default proxy type is HTTP, we must change if it is SOCKS5
 | 
			
		||||
    const int proxy_type = pref.getProxyType();
 | 
			
		||||
    if(proxy_type == Proxy::SOCKS5 || proxy_type == Proxy::SOCKS5_PW) {
 | 
			
		||||
    if (proxy_type == Proxy::SOCKS5 || proxy_type == Proxy::SOCKS5_PW) {
 | 
			
		||||
      qDebug() << Q_FUNC_INFO << "using SOCKS proxy";
 | 
			
		||||
      proxy.setType(QNetworkProxy::Socks5Proxy);
 | 
			
		||||
    } else {
 | 
			
		||||
@@ -191,7 +177,7 @@ void DownloadThread::applyProxySettings() {
 | 
			
		||||
      proxy.setType(QNetworkProxy::HttpProxy);
 | 
			
		||||
    }
 | 
			
		||||
    // Authentication?
 | 
			
		||||
    if(pref.isProxyAuthEnabled()) {
 | 
			
		||||
    if (pref.isProxyAuthEnabled()) {
 | 
			
		||||
      qDebug("Proxy requires authentication, authenticating");
 | 
			
		||||
      proxy.setUser(pref.getProxyUsername());
 | 
			
		||||
      proxy.setPassword(pref.getProxyPassword());
 | 
			
		||||
@@ -203,7 +189,7 @@ void DownloadThread::applyProxySettings() {
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
QString DownloadThread::errorCodeToString(QNetworkReply::NetworkError status) {
 | 
			
		||||
  switch(status){
 | 
			
		||||
  switch(status) {
 | 
			
		||||
  case QNetworkReply::HostNotFoundError:
 | 
			
		||||
    return tr("The remote host name was not found (invalid hostname)");
 | 
			
		||||
  case QNetworkReply::OperationCanceledError:
 | 
			
		||||
 
 | 
			
		||||
@@ -32,6 +32,7 @@
 | 
			
		||||
#define DOWNLOADTHREAD_H
 | 
			
		||||
 | 
			
		||||
#include <QNetworkReply>
 | 
			
		||||
#include <QNetworkCookie>
 | 
			
		||||
#include <QObject>
 | 
			
		||||
#include <QHash>
 | 
			
		||||
#include <QSslError>
 | 
			
		||||
@@ -45,8 +46,8 @@ class DownloadThread : public QObject {
 | 
			
		||||
 | 
			
		||||
public:
 | 
			
		||||
  DownloadThread(QObject* parent = 0);
 | 
			
		||||
  QNetworkReply* downloadUrl(const QString &url);
 | 
			
		||||
  void downloadTorrentUrl(const QString &url);
 | 
			
		||||
  QNetworkReply* downloadUrl(const QString &url, const QList<QNetworkCookie>& raw_cookies = QList<QNetworkCookie>());
 | 
			
		||||
  void downloadTorrentUrl(const QString &url, const QList<QNetworkCookie>& raw_cookies = QList<QNetworkCookie>());
 | 
			
		||||
  //void setProxy(QString IP, int port, QString username, QString password);
 | 
			
		||||
 | 
			
		||||
signals:
 | 
			
		||||
@@ -63,9 +64,6 @@ private slots:
 | 
			
		||||
private:
 | 
			
		||||
  QString errorCodeToString(QNetworkReply::NetworkError status);
 | 
			
		||||
  void applyProxySettings();
 | 
			
		||||
#ifndef DISABLE_GUI
 | 
			
		||||
  void loadCookies(const QString &host_name, QString url);
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
private:
 | 
			
		||||
  QNetworkAccessManager m_networkManager;
 | 
			
		||||
 
 | 
			
		||||
@@ -50,10 +50,10 @@ ExecutionLog::ExecutionLog(QWidget *parent) :
 | 
			
		||||
    ui->tabBan->layout()->addWidget(m_banList);
 | 
			
		||||
 | 
			
		||||
    const QStringList log_msgs = QBtSession::instance()->getConsoleMessages();
 | 
			
		||||
    foreach(const QString& msg, log_msgs)
 | 
			
		||||
    foreach (const QString& msg, log_msgs)
 | 
			
		||||
      addLogMessage(msg);
 | 
			
		||||
    const QStringList ban_msgs = QBtSession::instance()->getPeerBanMessages();
 | 
			
		||||
    foreach(const QString& msg, ban_msgs)
 | 
			
		||||
    foreach (const QString& msg, ban_msgs)
 | 
			
		||||
      addBanMessage(msg);
 | 
			
		||||
    connect(QBtSession::instance(), SIGNAL(newConsoleMessage(QString)), SLOT(addLogMessage(QString)));
 | 
			
		||||
    connect(QBtSession::instance(), SIGNAL(newBanMessage(QString)), SLOT(addBanMessage(QString)));
 | 
			
		||||
 
 | 
			
		||||
@@ -37,8 +37,8 @@ QT_BEGIN_NAMESPACE
 | 
			
		||||
namespace Ui {
 | 
			
		||||
    class ExecutionLog;
 | 
			
		||||
}
 | 
			
		||||
class LogListWidget;
 | 
			
		||||
QT_END_NAMESPACE
 | 
			
		||||
class LogListWidget;
 | 
			
		||||
 | 
			
		||||
class ExecutionLog : public QWidget
 | 
			
		||||
{
 | 
			
		||||
 
 | 
			
		||||
@@ -21,6 +21,7 @@
 | 
			
		||||
#endif
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
#include "fs_utils.h"
 | 
			
		||||
#include "misc.h"
 | 
			
		||||
 | 
			
		||||
#ifndef CIFS_MAGIC_NUMBER
 | 
			
		||||
@@ -59,11 +60,11 @@ private:
 | 
			
		||||
private:
 | 
			
		||||
  static bool isNetworkFileSystem(QString path) {
 | 
			
		||||
    QString file = path;
 | 
			
		||||
    if(!file.endsWith(QDir::separator()))
 | 
			
		||||
    if (!file.endsWith(QDir::separator()))
 | 
			
		||||
      file += QDir::separator();
 | 
			
		||||
    file += ".";
 | 
			
		||||
    struct statfs buf;
 | 
			
		||||
    if(!statfs(file.toLocal8Bit().constData(), &buf)) {
 | 
			
		||||
    if (!statfs(file.toLocal8Bit().constData(), &buf)) {
 | 
			
		||||
#ifdef Q_WS_MAC
 | 
			
		||||
      // XXX: should we make sure HAVE_STRUCT_FSSTAT_F_FSTYPENAME is defined?
 | 
			
		||||
      return (strcmp(buf.f_fstypename, "nfs") == 0 || strcmp(buf.f_fstypename, "cifs") == 0 || strcmp(buf.f_fstypename, "smbfs") == 0);
 | 
			
		||||
@@ -118,23 +119,23 @@ private:
 | 
			
		||||
 | 
			
		||||
public:
 | 
			
		||||
  FileSystemWatcher(QObject *parent): QFileSystemWatcher(parent) {
 | 
			
		||||
    m_filters << "*.torrent";
 | 
			
		||||
    m_filters << "*.torrent" << "*.magnet";
 | 
			
		||||
    connect(this, SIGNAL(directoryChanged(QString)), this, SLOT(scanLocalFolder(QString)));
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  ~FileSystemWatcher() {
 | 
			
		||||
#ifndef Q_WS_WIN
 | 
			
		||||
    if(watch_timer)
 | 
			
		||||
    if (watch_timer)
 | 
			
		||||
      delete watch_timer;
 | 
			
		||||
#endif
 | 
			
		||||
    if(m_partialTorrentTimer)
 | 
			
		||||
    if (m_partialTorrentTimer)
 | 
			
		||||
      delete m_partialTorrentTimer;
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
  QStringList directories() const {
 | 
			
		||||
    QStringList dirs;
 | 
			
		||||
#ifndef Q_WS_WIN
 | 
			
		||||
    if(watch_timer) {
 | 
			
		||||
    if (watch_timer) {
 | 
			
		||||
      foreach (const QDir &dir, watched_folders)
 | 
			
		||||
        dirs << dir.canonicalPath();
 | 
			
		||||
    }
 | 
			
		||||
@@ -149,7 +150,7 @@ public:
 | 
			
		||||
    if (!dir.exists())
 | 
			
		||||
      return;
 | 
			
		||||
    // Check if the path points to a network file system or not
 | 
			
		||||
    if(isNetworkFileSystem(path)) {
 | 
			
		||||
    if (isNetworkFileSystem(path)) {
 | 
			
		||||
      // Network mode
 | 
			
		||||
      qDebug("Network folder detected: %s", qPrintable(path));
 | 
			
		||||
      qDebug("Using file polling mode instead of inotify...");
 | 
			
		||||
@@ -194,7 +195,7 @@ protected slots:
 | 
			
		||||
    // Local folders scan
 | 
			
		||||
    addTorrentsFromDir(QDir(path), torrents);
 | 
			
		||||
    // Report detected torrent files
 | 
			
		||||
    if(!torrents.empty()) {
 | 
			
		||||
    if (!torrents.empty()) {
 | 
			
		||||
      qDebug("The following files are being reported: %s", qPrintable(torrents.join("\n")));
 | 
			
		||||
      emit torrentsAdded(torrents);
 | 
			
		||||
    }
 | 
			
		||||
@@ -210,7 +211,7 @@ protected slots:
 | 
			
		||||
      addTorrentsFromDir(dir, torrents);
 | 
			
		||||
    }
 | 
			
		||||
    // Report detected torrent files
 | 
			
		||||
    if(!torrents.empty()) {
 | 
			
		||||
    if (!torrents.empty()) {
 | 
			
		||||
      qDebug("The following files are being reported: %s", qPrintable(torrents.join("\n")));
 | 
			
		||||
      emit torrentsAdded(torrents);
 | 
			
		||||
    }
 | 
			
		||||
@@ -221,16 +222,16 @@ protected slots:
 | 
			
		||||
    QStringList no_longer_partial;
 | 
			
		||||
 | 
			
		||||
    // Check which torrents are still partial
 | 
			
		||||
    foreach(const QString& torrent_path, m_partialTorrents.keys()) {
 | 
			
		||||
      if(!QFile::exists(torrent_path)) {
 | 
			
		||||
    foreach (const QString& torrent_path, m_partialTorrents.keys()) {
 | 
			
		||||
      if (!QFile::exists(torrent_path)) {
 | 
			
		||||
        m_partialTorrents.remove(torrent_path);
 | 
			
		||||
        continue;
 | 
			
		||||
      }
 | 
			
		||||
      if(misc::isValidTorrentFile(torrent_path)) {
 | 
			
		||||
      if (fsutils::isValidTorrentFile(torrent_path)) {
 | 
			
		||||
        no_longer_partial << torrent_path;
 | 
			
		||||
         m_partialTorrents.remove(torrent_path);
 | 
			
		||||
      } else {
 | 
			
		||||
        if(m_partialTorrents[torrent_path] >= MAX_PARTIAL_RETRIES) {
 | 
			
		||||
        if (m_partialTorrents[torrent_path] >= MAX_PARTIAL_RETRIES) {
 | 
			
		||||
          m_partialTorrents.remove(torrent_path);
 | 
			
		||||
          QFile::rename(torrent_path, torrent_path+".invalid");
 | 
			
		||||
        } else {
 | 
			
		||||
@@ -240,7 +241,7 @@ protected slots:
 | 
			
		||||
    }
 | 
			
		||||
 | 
			
		||||
    // Stop the partial timer if necessary
 | 
			
		||||
    if(m_partialTorrents.empty()) {
 | 
			
		||||
    if (m_partialTorrents.empty()) {
 | 
			
		||||
      m_partialTorrentTimer->stop();
 | 
			
		||||
      m_partialTorrentTimer->deleteLater();
 | 
			
		||||
      qDebug("No longer any partial torrent.");
 | 
			
		||||
@@ -249,7 +250,7 @@ protected slots:
 | 
			
		||||
      m_partialTorrentTimer->start(WATCH_INTERVAL);
 | 
			
		||||
    }
 | 
			
		||||
    // Notify of new torrents
 | 
			
		||||
    if(!no_longer_partial.isEmpty())
 | 
			
		||||
    if (!no_longer_partial.isEmpty())
 | 
			
		||||
      emit torrentsAdded(no_longer_partial);
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
@@ -259,7 +260,7 @@ signals:
 | 
			
		||||
private:
 | 
			
		||||
  void startPartialTorrentTimer() {
 | 
			
		||||
    Q_ASSERT(!m_partialTorrents.isEmpty());
 | 
			
		||||
    if(!m_partialTorrentTimer) {
 | 
			
		||||
    if (!m_partialTorrentTimer) {
 | 
			
		||||
      m_partialTorrentTimer = new QTimer();
 | 
			
		||||
      connect(m_partialTorrentTimer, SIGNAL(timeout()), SLOT(processPartialTorrents()));
 | 
			
		||||
      m_partialTorrentTimer->setSingleShot(true);
 | 
			
		||||
@@ -269,19 +270,25 @@ private:
 | 
			
		||||
 | 
			
		||||
  void addTorrentsFromDir(const QDir &dir, QStringList &torrents) {
 | 
			
		||||
    const QStringList files = dir.entryList(m_filters, QDir::Files, QDir::Unsorted);
 | 
			
		||||
    foreach(const QString &file, files) {
 | 
			
		||||
    foreach (const QString &file, files) {
 | 
			
		||||
      const QString file_abspath = dir.absoluteFilePath(file);
 | 
			
		||||
      if(misc::isValidTorrentFile(file_abspath)) {
 | 
			
		||||
      if (file_abspath.endsWith(".magnet")) {
 | 
			
		||||
        QFile f(file_abspath);
 | 
			
		||||
        if (f.open(QIODevice::ReadOnly)
 | 
			
		||||
            && !misc::magnetUriToHash(QString::fromLocal8Bit(f.readAll())).isEmpty()) {
 | 
			
		||||
          torrents << file_abspath;
 | 
			
		||||
        }
 | 
			
		||||
      } else if (fsutils::isValidTorrentFile(file_abspath)) {
 | 
			
		||||
        torrents << file_abspath;
 | 
			
		||||
      } else {
 | 
			
		||||
        if(!m_partialTorrents.contains(file_abspath)) {
 | 
			
		||||
        if (!m_partialTorrents.contains(file_abspath)) {
 | 
			
		||||
          qDebug("Partial torrent detected at: %s", qPrintable(file_abspath));
 | 
			
		||||
          qDebug("Delay the file's processing...");
 | 
			
		||||
          m_partialTorrents.insert(file_abspath, 0);
 | 
			
		||||
        }
 | 
			
		||||
      }
 | 
			
		||||
    }
 | 
			
		||||
    if(!m_partialTorrents.empty())
 | 
			
		||||
    if (!m_partialTorrents.empty())
 | 
			
		||||
      startPartialTorrentTimer();
 | 
			
		||||
  }
 | 
			
		||||
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										505
									
								
								src/fs_utils.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										505
									
								
								src/fs_utils.cpp
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										73
									
								
								src/fs_utils.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										73
									
								
								src/fs_utils.h
									
									
									
									
									
										Normal file
									
								
							@@ -0,0 +1,73 @@
 | 
			
		||||
/*
 | 
			
		||||
 * Bittorrent Client using Qt4 and libtorrent.
 | 
			
		||||
 * Copyright (C) 2012  Christophe Dumez
 | 
			
		||||
 *
 | 
			
		||||
 * This program is free software; you can redistribute it and/or
 | 
			
		||||
 * modify it under the terms of the GNU General Public License
 | 
			
		||||
 * as published by the Free Software Foundation; either version 2
 | 
			
		||||
 * of the License, or (at your option) any later version.
 | 
			
		||||
 *
 | 
			
		||||
 * This program is distributed in the hope that it will be useful,
 | 
			
		||||
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | 
			
		||||
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | 
			
		||||
 * 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, write to the Free Software
 | 
			
		||||
 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
 | 
			
		||||
 *
 | 
			
		||||
 * In addition, as a special exception, the copyright holders give permission to
 | 
			
		||||
 * link this program with the OpenSSL project's "OpenSSL" library (or with
 | 
			
		||||
 * modified versions of it that use the same license as the "OpenSSL" library),
 | 
			
		||||
 * and distribute the linked executables. You must obey the GNU General Public
 | 
			
		||||
 * License in all respects for all of the code used other than "OpenSSL".  If you
 | 
			
		||||
 * 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 FS_UTILS_H
 | 
			
		||||
#define FS_UTILS_H
 | 
			
		||||
 | 
			
		||||
#include <QString>
 | 
			
		||||
#include <QCoreApplication>
 | 
			
		||||
 | 
			
		||||
/**
 | 
			
		||||
 * Utility functions related to file system.
 | 
			
		||||
 */
 | 
			
		||||
class fsutils
 | 
			
		||||
{
 | 
			
		||||
  Q_DECLARE_TR_FUNCTIONS(fsutils)
 | 
			
		||||
 | 
			
		||||
public:
 | 
			
		||||
static QString toDisplayPath(const QString& path);
 | 
			
		||||
static QString fileExtension(const QString& filename);
 | 
			
		||||
static QString fileName(const QString& file_path);
 | 
			
		||||
static qint64 computePathSize(const QString& path);
 | 
			
		||||
static bool sameFiles(const QString& path1, const QString& path2);
 | 
			
		||||
static QString updateLabelInSavePath(QString defaultSavePath, QString save_path, const QString& old_label, const QString& new_label);
 | 
			
		||||
static QString toValidFileSystemName(QString filename);
 | 
			
		||||
static bool isValidFileSystemName(const QString& filename);
 | 
			
		||||
static long long freeDiskSpaceOnPath(QString path);
 | 
			
		||||
static QString branchPath(const QString& file_path, QString* removed = 0);
 | 
			
		||||
static bool sameFileNames(const QString& first, const QString& second);
 | 
			
		||||
static QString expandPath(const QString& path);
 | 
			
		||||
static bool isValidTorrentFile(const QString& path);
 | 
			
		||||
static bool smartRemoveEmptyFolderTree(const QString& dir_path);
 | 
			
		||||
static bool forceRemove(const QString& file_path);
 | 
			
		||||
 | 
			
		||||
/* Ported from Qt4 to drop dependency on QtGui */
 | 
			
		||||
static QString QDesktopServicesDataLocation();
 | 
			
		||||
static QString QDesktopServicesCacheLocation();
 | 
			
		||||
static QString QDesktopServicesDownloadLocation();
 | 
			
		||||
/* End of Qt4 code */
 | 
			
		||||
static QString searchEngineLocation();
 | 
			
		||||
static QString BTBackupLocation();
 | 
			
		||||
static QString cacheLocation();
 | 
			
		||||
 | 
			
		||||
};
 | 
			
		||||
 | 
			
		||||
#endif // FS_UTILS_H
 | 
			
		||||
 | 
			
		||||
@@ -64,20 +64,20 @@
 | 
			
		||||
#include <QFile>
 | 
			
		||||
#include <QChar>
 | 
			
		||||
 | 
			
		||||
#include "misc.h"
 | 
			
		||||
#include "fs_utils.h"
 | 
			
		||||
 | 
			
		||||
using namespace libtorrent;
 | 
			
		||||
 | 
			
		||||
QString GeoIPManager::geoipFolder(bool embedded) {
 | 
			
		||||
#ifdef WITH_GEOIP_EMBEDDED
 | 
			
		||||
  if(embedded)
 | 
			
		||||
  if (embedded)
 | 
			
		||||
    return ":/geoip/";
 | 
			
		||||
  return misc::QDesktopServicesDataLocation()+"geoip"+QDir::separator();
 | 
			
		||||
  return fsutils::QDesktopServicesDataLocation()+"geoip"+QDir::separator();
 | 
			
		||||
#else
 | 
			
		||||
  Q_UNUSED(embedded);
 | 
			
		||||
  if(QFile::exists("/usr/local/share/GeoIP/GeoIP.dat"))
 | 
			
		||||
  if (QFile::exists("/usr/local/share/GeoIP/GeoIP.dat"))
 | 
			
		||||
    return "/usr/local/share/GeoIP/";
 | 
			
		||||
  if(QFile::exists("/var/lib/GeoIP/GeoIP.dat"))
 | 
			
		||||
  if (QFile::exists("/var/lib/GeoIP/GeoIP.dat"))
 | 
			
		||||
    return "/var/lib/GeoIP/";
 | 
			
		||||
  return "/usr/share/GeoIP/";
 | 
			
		||||
#endif
 | 
			
		||||
@@ -89,22 +89,22 @@ QString GeoIPManager::geoipDBpath(bool embedded) {
 | 
			
		||||
 | 
			
		||||
#ifdef WITH_GEOIP_EMBEDDED
 | 
			
		||||
void GeoIPManager::exportEmbeddedDb() {
 | 
			
		||||
  if(!QFile::exists(geoipDBpath(false)) || QFile(geoipDBpath(false)).size() != QFile(geoipDBpath(true)).size()) { // Export is required
 | 
			
		||||
  if (!QFile::exists(geoipDBpath(false)) || QFile(geoipDBpath(false)).size() != QFile(geoipDBpath(true)).size()) { // Export is required
 | 
			
		||||
    qDebug("A local Geoip database update is required, proceeding...");
 | 
			
		||||
    // Create geoip folder is necessary
 | 
			
		||||
    QDir gfolder(geoipFolder(false));
 | 
			
		||||
    if(!gfolder.exists()) {
 | 
			
		||||
      if(!gfolder.mkpath(geoipFolder(false))) {
 | 
			
		||||
    if (!gfolder.exists()) {
 | 
			
		||||
      if (!gfolder.mkpath(geoipFolder(false))) {
 | 
			
		||||
        std::cerr << "Failed to create geoip folder at " << qPrintable(geoipFolder(false)) << std::endl;
 | 
			
		||||
        return;
 | 
			
		||||
      }
 | 
			
		||||
    }
 | 
			
		||||
    // Remove destination files
 | 
			
		||||
    if(QFile::exists(geoipDBpath(false)))
 | 
			
		||||
      misc::safeRemove(geoipDBpath(false));
 | 
			
		||||
    if (QFile::exists(geoipDBpath(false)))
 | 
			
		||||
      fsutils::forceRemove(geoipDBpath(false));
 | 
			
		||||
    // Copy from executable to hard disk
 | 
			
		||||
    qDebug("%s -> %s", qPrintable(geoipDBpath(true)), qPrintable(geoipDBpath(false)));
 | 
			
		||||
    if(!QFile::copy(geoipDBpath(true), geoipDBpath(false))) {
 | 
			
		||||
    if (!QFile::copy(geoipDBpath(true), geoipDBpath(false))) {
 | 
			
		||||
      std::cerr << "ERROR: Failed to copy geoip.dat from executable to hard disk" << std::endl;
 | 
			
		||||
    }
 | 
			
		||||
    qDebug("Local Geoip database was updated");
 | 
			
		||||
@@ -116,7 +116,7 @@ void GeoIPManager::loadDatabase(session *s) {
 | 
			
		||||
#ifdef WITH_GEOIP_EMBEDDED
 | 
			
		||||
  exportEmbeddedDb();
 | 
			
		||||
#endif
 | 
			
		||||
  if(QFile::exists(geoipDBpath(false))) {
 | 
			
		||||
  if (QFile::exists(geoipDBpath(false))) {
 | 
			
		||||
    qDebug("Loading GeoIP database from %s...", qPrintable(geoipDBpath(false)));
 | 
			
		||||
    s->load_country_db(geoipDBpath(false).toLocal8Bit().constData());
 | 
			
		||||
  } else {
 | 
			
		||||
@@ -183,9 +183,9 @@ const char * country_name[253] =
 | 
			
		||||
 "Saint Barthelemy","Saint Martin"};
 | 
			
		||||
 | 
			
		||||
QString GeoIPManager::CountryISOCodeToName(const char* iso) {
 | 
			
		||||
  if(iso[0] == 0) return "N/A";
 | 
			
		||||
  for(uint i = 0; i < num_countries; ++i) {
 | 
			
		||||
    if(iso[0] == country_code[i][0] &&  iso[1] == country_code[i][1]) {
 | 
			
		||||
  if (iso[0] == 0) return "N/A";
 | 
			
		||||
  for (uint i = 0; i < num_countries; ++i) {
 | 
			
		||||
    if (iso[0] == country_code[i][0] &&  iso[1] == country_code[i][1]) {
 | 
			
		||||
      return QLatin1String(country_name[i]);
 | 
			
		||||
    }
 | 
			
		||||
  }
 | 
			
		||||
@@ -195,7 +195,7 @@ QString GeoIPManager::CountryISOCodeToName(const char* iso) {
 | 
			
		||||
 | 
			
		||||
// http://www.iso.org/iso/country_codes/iso_3166_code_lists/english_country_names_and_code_elements.htm
 | 
			
		||||
QIcon GeoIPManager::CountryISOCodeToIcon(const char* iso) {
 | 
			
		||||
  if(iso[0] == 0 || iso[0] == '!') return QIcon();
 | 
			
		||||
  if (iso[0] == 0 || iso[0] == '!') return QIcon();
 | 
			
		||||
  const QString isoStr = QString(QByteArray(iso, 2)).toLower();
 | 
			
		||||
  return QIcon(":/Icons/flags/"+isoStr+".png");
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
@@ -55,7 +55,7 @@ public:
 | 
			
		||||
    std::cout << qPrintable(tr("To control qBittorrent, access the Web UI at http://localhost:%1").arg(QString::number(pref.getWebUiPort()))) << std::endl;
 | 
			
		||||
    std::cout << qPrintable(tr("The Web UI administrator user name is: %1").arg(pref.getWebUiUsername())) << std::endl;
 | 
			
		||||
    qDebug() << "Password:" << pref.getWebUiPassword();
 | 
			
		||||
    if(pref.getWebUiPassword() == "32fe0bd2bb001911bb8bcfe23fc92b63") {
 | 
			
		||||
    if (pref.getWebUiPassword() == "32fe0bd2bb001911bb8bcfe23fc92b63") {
 | 
			
		||||
      std::cout << qPrintable(tr("The Web UI administrator password is still the default one: %1").arg("adminadmin")) << std::endl;
 | 
			
		||||
      std::cout << qPrintable(tr("This is a security risk, please consider changing your password from program preferences.")) << std::endl;
 | 
			
		||||
    }
 | 
			
		||||
@@ -85,16 +85,16 @@ public slots:
 | 
			
		||||
  // the right addTorrent function, considering
 | 
			
		||||
  // the parameter type.
 | 
			
		||||
  void processParams(const QStringList& params) {
 | 
			
		||||
    foreach(QString param, params) {
 | 
			
		||||
    foreach (QString param, params) {
 | 
			
		||||
      param = param.trimmed();
 | 
			
		||||
      if(param.startsWith(QString::fromUtf8("http://"), Qt::CaseInsensitive) || param.startsWith(QString::fromUtf8("ftp://"), Qt::CaseInsensitive) || param.startsWith(QString::fromUtf8("https://"), Qt::CaseInsensitive)) {
 | 
			
		||||
      if (param.startsWith(QString::fromUtf8("http://"), Qt::CaseInsensitive) || param.startsWith(QString::fromUtf8("ftp://"), Qt::CaseInsensitive) || param.startsWith(QString::fromUtf8("https://"), Qt::CaseInsensitive)) {
 | 
			
		||||
        QBtSession::instance()->downloadFromUrl(param);
 | 
			
		||||
      }else{
 | 
			
		||||
        if(param.startsWith("bc://bt/", Qt::CaseInsensitive)) {
 | 
			
		||||
        if (param.startsWith("bc://bt/", Qt::CaseInsensitive)) {
 | 
			
		||||
          qDebug("Converting bc link to magnet link");
 | 
			
		||||
          param = misc::bcLinkToMagnet(param);
 | 
			
		||||
        }
 | 
			
		||||
        if(param.startsWith("magnet:", Qt::CaseInsensitive)) {
 | 
			
		||||
        if (param.startsWith("magnet:", Qt::CaseInsensitive)) {
 | 
			
		||||
          QBtSession::instance()->addMagnetUri(param);
 | 
			
		||||
        } else {
 | 
			
		||||
          QBtSession::instance()->addTorrent(param);
 | 
			
		||||
 
 | 
			
		||||
@@ -44,7 +44,7 @@ public:
 | 
			
		||||
protected:
 | 
			
		||||
  void tabInserted(int index) {
 | 
			
		||||
    QTabWidget::tabInserted(index);
 | 
			
		||||
    if(count() == 1) {
 | 
			
		||||
    if (count() == 1) {
 | 
			
		||||
      showTabBar(false);
 | 
			
		||||
    } else {
 | 
			
		||||
      showTabBar(true);
 | 
			
		||||
@@ -53,7 +53,7 @@ protected:
 | 
			
		||||
 | 
			
		||||
  void tabRemoved(int index) {
 | 
			
		||||
    QTabWidget::tabInserted(index);
 | 
			
		||||
    if(count() == 1) {
 | 
			
		||||
    if (count() == 1) {
 | 
			
		||||
      showTabBar(false);
 | 
			
		||||
    } else {
 | 
			
		||||
      showTabBar(true);
 | 
			
		||||
 
 | 
			
		||||
@@ -35,21 +35,21 @@ IconProvider* IconProvider::m_instance = 0;
 | 
			
		||||
 | 
			
		||||
IconProvider::IconProvider()
 | 
			
		||||
{
 | 
			
		||||
#if defined(Q_WS_X11) && (QT_VERSION >= QT_VERSION_CHECK(4,6,0))
 | 
			
		||||
#if defined(Q_WS_X11)
 | 
			
		||||
  m_useSystemTheme = Preferences().useSystemIconTheme();
 | 
			
		||||
#endif
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
IconProvider * IconProvider::instance()
 | 
			
		||||
{
 | 
			
		||||
  if(!m_instance)
 | 
			
		||||
  if (!m_instance)
 | 
			
		||||
    m_instance = new IconProvider;
 | 
			
		||||
  return m_instance;
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
void IconProvider::drop()
 | 
			
		||||
{
 | 
			
		||||
  if(m_instance) {
 | 
			
		||||
  if (m_instance) {
 | 
			
		||||
    delete m_instance;
 | 
			
		||||
    m_instance = 0;
 | 
			
		||||
  }
 | 
			
		||||
@@ -57,8 +57,8 @@ void IconProvider::drop()
 | 
			
		||||
 | 
			
		||||
QIcon IconProvider::getIcon(const QString &iconId)
 | 
			
		||||
{
 | 
			
		||||
#if defined(Q_WS_X11) && (QT_VERSION >= QT_VERSION_CHECK(4,6,0))
 | 
			
		||||
  if(m_useSystemTheme) {
 | 
			
		||||
#if defined(Q_WS_X11)
 | 
			
		||||
  if (m_useSystemTheme) {
 | 
			
		||||
    QIcon icon = QIcon::fromTheme(iconId, QIcon(":/Icons/oxygen/"+iconId+".png"));
 | 
			
		||||
    icon = generateDifferentSizes(icon);
 | 
			
		||||
    return icon;
 | 
			
		||||
@@ -67,7 +67,7 @@ QIcon IconProvider::getIcon(const QString &iconId)
 | 
			
		||||
  return QIcon(":/Icons/oxygen/"+iconId+".png");
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
#if defined(Q_WS_X11) && (QT_VERSION >= QT_VERSION_CHECK(4,6,0))
 | 
			
		||||
#if defined(Q_WS_X11)
 | 
			
		||||
void IconProvider::useSystemIconTheme(bool enable)
 | 
			
		||||
{
 | 
			
		||||
  m_useSystemTheme = enable;
 | 
			
		||||
@@ -77,21 +77,21 @@ void IconProvider::useSystemIconTheme(bool enable)
 | 
			
		||||
// It scales the icon from the theme if necessary
 | 
			
		||||
// Otherwise, the UI looks broken if the icon is not available
 | 
			
		||||
// in the correct size.
 | 
			
		||||
QIcon IconProvider::generateDifferentSizes(const QIcon &icon)
 | 
			
		||||
QIcon IconProvider::generateDifferentSizes(const QIcon& icon)
 | 
			
		||||
{
 | 
			
		||||
  QIcon new_icon;
 | 
			
		||||
  QList<QSize> required_sizes;
 | 
			
		||||
  required_sizes << QSize(16, 16) << QSize(24, 24);
 | 
			
		||||
  QList<QIcon::Mode> modes;
 | 
			
		||||
  modes << QIcon::Normal << QIcon::Active << QIcon::Selected << QIcon::Disabled;
 | 
			
		||||
  foreach(const QSize& size, required_sizes) {
 | 
			
		||||
    foreach(QIcon::Mode mode, modes) {
 | 
			
		||||
  foreach (const QSize& size, required_sizes) {
 | 
			
		||||
    foreach (QIcon::Mode mode, modes) {
 | 
			
		||||
      QPixmap pixoff = icon.pixmap(size, mode, QIcon::Off);
 | 
			
		||||
      if(pixoff.height() > size.height())
 | 
			
		||||
      if (pixoff.height() > size.height())
 | 
			
		||||
        pixoff = pixoff.scaled(size, Qt::KeepAspectRatio,  Qt::SmoothTransformation);
 | 
			
		||||
      new_icon.addPixmap(pixoff, mode, QIcon::Off);
 | 
			
		||||
      QPixmap pixon = icon.pixmap(size, mode, QIcon::On);
 | 
			
		||||
      if(pixon.height() > size.height())
 | 
			
		||||
      if (pixon.height() > size.height())
 | 
			
		||||
        pixon = pixoff.scaled(size, Qt::KeepAspectRatio,  Qt::SmoothTransformation);
 | 
			
		||||
      new_icon.addPixmap(pixon, mode, QIcon::On);
 | 
			
		||||
    }
 | 
			
		||||
@@ -100,14 +100,14 @@ QIcon IconProvider::generateDifferentSizes(const QIcon &icon)
 | 
			
		||||
}
 | 
			
		||||
#endif
 | 
			
		||||
 | 
			
		||||
QString IconProvider::getIconPath(const QString &iconId)
 | 
			
		||||
QString IconProvider::getIconPath(const QString& iconId)
 | 
			
		||||
{
 | 
			
		||||
#if defined(Q_WS_X11) && (QT_VERSION >= QT_VERSION_CHECK(4,6,0))
 | 
			
		||||
  if(m_useSystemTheme) {
 | 
			
		||||
#if defined(Q_WS_X11)
 | 
			
		||||
  if (m_useSystemTheme) {
 | 
			
		||||
    QString path = QDir::temp().absoluteFilePath(iconId+".png");
 | 
			
		||||
    if(!QFile::exists(path)) {
 | 
			
		||||
    if (!QFile::exists(path)) {
 | 
			
		||||
      const QIcon icon = QIcon::fromTheme(iconId);
 | 
			
		||||
      if(icon.isNull()) return ":/Icons/oxygen/"+iconId+".png";
 | 
			
		||||
      if (icon.isNull()) return ":/Icons/oxygen/"+iconId+".png";
 | 
			
		||||
      QPixmap px = icon.pixmap(32);
 | 
			
		||||
      px.save(path);
 | 
			
		||||
    }
 | 
			
		||||
 
 | 
			
		||||
Some files were not shown because too many files have changed in this diff Show More
		Reference in New Issue
	
	Block a user