summaryrefslogtreecommitdiff
path: root/audio/liblastfm-qt5/files/patch-src_UrlBuilder.cpp
blob: dbe336905355a191660d714942641f39e022dc71 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
url():
  - Use https scheme to avoid 301 redirects
  - Override default QUrl::TolerantMode with QUrl::StrictMode for Qt 5.x to
    prevent overprocessing the already encoded input URL
localePath():
  - New function to return the base path of the localized website
host():
  - Just return www.last.fm since the localized hosts 301 redirect there
localize():
  - Set the path of the url instead of the host since the localized
    hosts 301 redirect to the main website with a localized path
mobilize():
  - Mobile website 301 redirects to main website, so just return the url as-is

--- src/UrlBuilder.cpp.orig	2014-10-02 14:05:46 UTC
+++ src/UrlBuilder.cpp
@@ -32,7 +32,7 @@ class lastfm::UrlBuilderPrivate (public)
 lastfm::UrlBuilder::UrlBuilder( const QString& base )
     : d( new UrlBuilderPrivate )
 {
-    d->path = '/' + base.toLatin1();
+    d->path = localePath().toLatin1() + '/' + base.toLatin1();
 }
 
 
@@ -60,10 +60,10 @@ QUrl
 lastfm::UrlBuilder::url() const
 {
     QUrl url;
-    url.setScheme( "http" );
+    url.setScheme( "https" );
     url.setHost( host() );
 #if QT_VERSION >= QT_VERSION_CHECK( 5, 0, 0 )
-    url.setPath( d->path );
+    url.setPath( d->path, QUrl::StrictMode );
 #else
     url.setEncodedPath( d->path );
 #endif
@@ -85,49 +85,50 @@ lastfm::UrlBuilder::encode( QString s )
 
 
 QString //static
-lastfm::UrlBuilder::host( const QLocale& locale )
+lastfm::UrlBuilder::localePath( const QLocale& locale )
 {
     switch (locale.language())
     {
-        case QLocale::Portuguese: return "www.lastfm.com.br";
-        case QLocale::Turkish:    return "www.lastfm.com.tr";
-        case QLocale::French:     return "www.lastfm.fr";
-        case QLocale::Italian:    return "www.lastfm.it";
-        case QLocale::German:     return "www.lastfm.de";
-        case QLocale::Spanish:    return "www.lastfm.es";
-        case QLocale::Polish:     return "www.lastfm.pl";
-        case QLocale::Russian:    return "www.lastfm.ru";
-        case QLocale::Japanese:   return "www.lastfm.jp";
-        case QLocale::Swedish:    return "www.lastfm.se";
-        case QLocale::Chinese:    return "cn.last.fm";
-        default:                  return "www.last.fm";
+        case QLocale::Chinese:    return "/zh";
+        case QLocale::French:     return "/fr";
+        case QLocale::German:     return "/de";
+        case QLocale::Italian:    return "/it";
+        case QLocale::Japanese:   return "/ja";
+        case QLocale::Polish:     return "/pl";
+        case QLocale::Portuguese: return "/pt";
+        case QLocale::Russian:    return "/ru";
+        case QLocale::Spanish:    return "/es";
+        case QLocale::Swedish:    return "/sv";
+        case QLocale::Turkish:    return "/tr";
+        default:                  return "";
     }
 }
 
 
+QString //static
+lastfm::UrlBuilder::host( const QLocale& locale )
+{
+    return "www.last.fm";
+}
+
+
 bool // static
 lastfm::UrlBuilder::isHost( const QUrl& url )
 {
-    QStringList hosts = QStringList() << "www.lastfm.com.br"
-                    <<  "www.lastfm.com.tr"
-                    << "www.lastfm.fr"
-                    << "www.lastfm.it"
-                    << "www.lastfm.de"
-                    << "www.lastfm.es"
-                    << "www.lastfm.pl"
-                    << "www.lastfm.ru"
-                    << "www.lastfm.jp"
-                    << "www.lastfm.se"
-                    << "cn.last.fm"
-                    << "www.last.fm";
+    QStringList hosts = QStringList() << "www.last.fm";
 
     return hosts.contains( url.host() );
 }
 
+
 QUrl //static
 lastfm::UrlBuilder::localize( QUrl url)
 {
-    url.setHost( url.host().replace( QRegExp("^(www.)?last.fm"), host() ) );
+#if QT_VERSION >= QT_VERSION_CHECK( 5, 0, 0 )
+    url.setPath( url.path().prepend( localePath() ), QUrl::DecodedMode );
+#else
+    url.setPath( url.path().prepend( localePath() ) );
+#endif
     return url;
 }
 
@@ -135,7 +136,6 @@ lastfm::UrlBuilder::localize( QUrl url)
 QUrl //static
 lastfm::UrlBuilder::mobilize( QUrl url )
 {
-    url.setHost( url.host().replace( QRegExp("^(www.)?last"), "m.last" ) );
     return url;
 }