author | Sebastian Brannstrom <sebastianb@symbian.org> |
Tue, 16 Nov 2010 12:21:47 +0000 | |
branch | symbian1 |
changeset 366 | f015466e6642 |
parent 336 | 3d6c1417e8bd |
child 372 | ad9eb3eed056 |
permissions | -rw-r--r-- |
2 | 1 |
/* |
2 |
* Copyright (c) 2007-2010 Sebastian Brannstrom, Lars Persson, EmbedDev AB |
|
3 |
* |
|
4 |
* All rights reserved. |
|
5 |
* This component and the accompanying materials are made available |
|
6 |
* under the terms of the License "Eclipse Public License v1.0" |
|
7 |
* which accompanies this distribution, and is available |
|
8 |
* at the URL "http://www.eclipse.org/legal/epl-v10.html". |
|
9 |
* |
|
10 |
* Initial Contributors: |
|
11 |
* EmbedDev AB - initial contribution. |
|
12 |
* |
|
13 |
* Contributors: |
|
14 |
* |
|
15 |
* Description: |
|
16 |
* |
|
17 |
*/ |
|
18 |
||
19 |
#include <e32std.h> |
|
20 |
#include <e32base.h> |
|
21 |
#include <TXTETEXT.H> // for ELineBreak |
|
22 |
#include "PodcastUtils.h" |
|
23 |
#include "debug.h" |
|
24 |
#include "FeedEngine.h" // for KMaxDescriptionLength |
|
25 |
||
26 |
EXPORT_C void PodcastUtils::FixProtocolsL(TDes &aUrl) |
|
27 |
{ |
|
28 |
HBufC* urlCopy = aUrl.AllocLC(); |
|
29 |
TPtr urlCopyPtr (urlCopy->Des()); |
|
30 |
urlCopyPtr.LowerCase(); |
|
31 |
||
32 |
// url is always present so access that |
|
33 |
// Some pod links are written in format itpc://mylink.net/podcast.xml |
|
34 |
// Symbian HTTP stack does not like itpc:// |
|
35 |
// Try to use a HTTP instead. |
|
36 |
TInt p = urlCopyPtr.Find(KItpcPrefix); |
|
37 |
if (p >= 0) |
|
38 |
{ |
|
39 |
aUrl.Delete(p, KItpcPrefix().Length()); |
|
40 |
} |
|
41 |
||
42 |
// Some pod links are written in format pcast://mylink.net/podcast.xml |
|
43 |
// Symbian HTTP stack does not like itpc:// |
|
44 |
// Try to use a HTTP instead. |
|
45 |
p = urlCopyPtr.Find(KPcastPrefix); |
|
46 |
if (p >= 0) |
|
47 |
{ |
|
48 |
aUrl.Delete(p, KPcastPrefix().Length()); |
|
49 |
} |
|
50 |
||
51 |
// The URL must start with http://, otherwise the HTTP stack fails. |
|
52 |
TInt pos = urlCopyPtr.Find(KURLPrefix); |
|
53 |
if (pos == KErrNotFound) |
|
54 |
{ |
|
55 |
HBufC* newUrl = HBufC::NewL(aUrl.Length() + KURLPrefix().Length()); |
|
56 |
TPtr ptr = newUrl->Des(); |
|
57 |
ptr.Append(KURLPrefix()); |
|
58 |
ptr.Append(aUrl); |
|
59 |
||
60 |
// replace the url buffer |
|
61 |
aUrl.Copy(*newUrl); |
|
62 |
delete newUrl; |
|
63 |
} |
|
64 |
||
65 |
CleanupStack::PopAndDestroy(urlCopy); |
|
66 |
} |
|
67 |
||
68 |
||
69 |
EXPORT_C void PodcastUtils::CleanHtmlL(TDes &str) |
|
70 |
{ |
|
240
03e8cc4066ba
Fix for bug 2818
Sebastian Brannstrom <sebastianb@symbian.org>
parents:
161
diff
changeset
|
71 |
DP("PodcastUtils::CleanHtmlL BEGIN"); |
21 | 72 |
if (str.Length() == 0) |
73 |
{ |
|
74 |
return; |
|
75 |
} |
|
18 | 76 |
// miscellaneous cleanup |
336
3d6c1417e8bd
Merged all the later Symbian3 updates into Symbian1 branch; new SIS v. 1.00.32
Sebastian Brannstrom <sebastianb@symbian.org>
parents:
246
diff
changeset
|
77 |
DP(" miscellaneous cleanup"); |
2 | 78 |
const TChar KLineBreak(CEditableText::ELineBreak); |
79 |
_LIT(KNewLine, "\n"); |
|
19 | 80 |
_LIT(KNewLineWindows, "\r\n"); |
2 | 81 |
ReplaceString(str, KNewLine, KNullDesC); |
19 | 82 |
ReplaceString(str, KNewLineWindows, KNullDesC); |
18 | 83 |
|
84 |
// strip out HTML tags |
|
336
3d6c1417e8bd
Merged all the later Symbian3 updates into Symbian1 branch; new SIS v. 1.00.32
Sebastian Brannstrom <sebastianb@symbian.org>
parents:
246
diff
changeset
|
85 |
DP(" strip out HTML tags"); |
2 | 86 |
TInt startPos = str.Locate('<'); |
87 |
TInt endPos = str.Locate('>'); |
|
88 |
HBufC* tmpBuf = HBufC::NewLC(KMaxDescriptionLength); |
|
89 |
TPtr tmp(tmpBuf->Des()); |
|
90 |
while (startPos != KErrNotFound && endPos != KErrNotFound && endPos > startPos) { |
|
91 |
//DP1("Cleaning out %S", &str.Mid(startPos, endPos-startPos+1)); |
|
92 |
tmp.Copy(str.Left(startPos)); |
|
93 |
TPtrC ptr=str.Mid(startPos, endPos-startPos+1); |
|
94 |
_LIT(KHtmlBr, "<br>"); |
|
95 |
_LIT(KHtmlBr2, "<br />"); |
|
96 |
_LIT(KHtmlBr3, "<br/>"); |
|
97 |
_LIT(KHtmlP, "<p>"); |
|
98 |
if (ptr.CompareF(KHtmlBr)== 0 || ptr.CompareF(KHtmlBr2)== 0 || ptr.CompareF(KHtmlBr3)== 0) |
|
99 |
{ |
|
100 |
tmp.Append(KLineBreak); |
|
101 |
} |
|
102 |
else if (ptr.CompareF(KHtmlP) == 0) |
|
103 |
{ |
|
104 |
tmp.Append(KLineBreak); |
|
105 |
tmp.Append(KLineBreak); |
|
106 |
} |
|
107 |
||
108 |
if (str.Length() > endPos+1) { |
|
109 |
tmp.Append(str.Mid(endPos+1)); |
|
110 |
} |
|
111 |
||
112 |
str.Copy(tmp); |
|
113 |
startPos = str.Locate('<'); |
|
114 |
endPos = str.Locate('>'); |
|
115 |
} |
|
18 | 116 |
|
336
3d6c1417e8bd
Merged all the later Symbian3 updates into Symbian1 branch; new SIS v. 1.00.32
Sebastian Brannstrom <sebastianb@symbian.org>
parents:
246
diff
changeset
|
117 |
// change HTML encoded chars to unicode |
240
03e8cc4066ba
Fix for bug 2818
Sebastian Brannstrom <sebastianb@symbian.org>
parents:
161
diff
changeset
|
118 |
DP(" change HTML encoded chars to unicode"); |
18 | 119 |
startPos = str.Locate('&'); |
120 |
endPos = str.Locate(';'); |
|
366
f015466e6642
Fix for bug 3942
Sebastian Brannstrom <sebastianb@symbian.org>
parents:
336
diff
changeset
|
121 |
while (startPos != KErrNotFound && endPos != KErrNotFound && endPos > startPos && endPos < str.Length()) |
18 | 122 |
{ |
366
f015466e6642
Fix for bug 3942
Sebastian Brannstrom <sebastianb@symbian.org>
parents:
336
diff
changeset
|
123 |
// DP2("startPos=%d, endPos=%d", startPos, endPos); |
18 | 124 |
TPtrC ptr(str.Mid(startPos+1, endPos-startPos)); |
125 |
// check for whitespace |
|
126 |
if (ptr.Locate(' ') == KErrNotFound) |
|
127 |
{ |
|
128 |
// numerical constant |
|
129 |
if (ptr[0] == '#') |
|
130 |
{ |
|
131 |
TUint length = endPos - startPos; |
|
132 |
if (length > 2) |
|
133 |
{ |
|
134 |
tmp.Copy(str.Left(startPos)); |
|
135 |
ptr.Set(str.Mid(startPos+2, length-2)); |
|
136 |
||
137 |
TUint charCode = 0; |
|
138 |
||
139 |
if (ptr[0] == 'x') |
|
140 |
{ |
|
141 |
// hexadecimal |
|
142 |
ptr.Set(ptr.Mid(1)); |
|
143 |
TLex16 lex(ptr); |
|
144 |
lex.Val(charCode, EHex); |
|
145 |
} |
|
146 |
else |
|
147 |
{ |
|
148 |
//decimal |
|
149 |
TLex16 lex(ptr); |
|
150 |
lex.Val(charCode, EDecimal); |
|
151 |
} |
|
152 |
||
153 |
TChar charChar(charCode); |
|
154 |
tmp.Append(charChar); |
|
155 |
tmp.Append(str.Mid(endPos+1)); |
|
156 |
str.Copy(tmp); |
|
157 |
} |
|
158 |
} |
|
159 |
// literal constant |
|
160 |
else |
|
161 |
{ |
|
162 |
_LIT(KAmp, "amp;"); |
|
163 |
_LIT(KQuot, "quot;"); |
|
164 |
_LIT(KNbsp, "nbsp;"); |
|
165 |
_LIT(KCopy, "copy;"); |
|
366
f015466e6642
Fix for bug 3942
Sebastian Brannstrom <sebastianb@symbian.org>
parents:
336
diff
changeset
|
166 |
|
18 | 167 |
// copy start of string |
168 |
tmp.Copy(str.Left(startPos)); |
|
169 |
if (ptr.CompareF(KAmp) == 0) |
|
170 |
{ |
|
171 |
tmp.Append('&'); |
|
172 |
} |
|
173 |
else if (ptr.CompareF(KQuot) == 0) |
|
174 |
{ |
|
175 |
tmp.Append('"'); |
|
176 |
} |
|
177 |
else if (ptr.CompareF(KNbsp) == 0) |
|
178 |
{ |
|
179 |
tmp.Append(' '); |
|
180 |
} |
|
181 |
else if (ptr.CompareF(KCopy) == 0) |
|
182 |
{ |
|
183 |
tmp.Append('\xA9'); |
|
184 |
} |
|
185 |
// copy end of string |
|
186 |
tmp.Append(str.Mid(endPos+1)); |
|
187 |
str.Copy(tmp); |
|
188 |
} |
|
189 |
} |
|
190 |
||
366
f015466e6642
Fix for bug 3942
Sebastian Brannstrom <sebastianb@symbian.org>
parents:
336
diff
changeset
|
191 |
if (startPos+1 <= str.Length()) { |
f015466e6642
Fix for bug 3942
Sebastian Brannstrom <sebastianb@symbian.org>
parents:
336
diff
changeset
|
192 |
TInt newPos = str.Mid(startPos+1).Locate('&'); |
f015466e6642
Fix for bug 3942
Sebastian Brannstrom <sebastianb@symbian.org>
parents:
336
diff
changeset
|
193 |
DP("two"); |
f015466e6642
Fix for bug 3942
Sebastian Brannstrom <sebastianb@symbian.org>
parents:
336
diff
changeset
|
194 |
if (newPos != KErrNotFound) |
f015466e6642
Fix for bug 3942
Sebastian Brannstrom <sebastianb@symbian.org>
parents:
336
diff
changeset
|
195 |
{ |
f015466e6642
Fix for bug 3942
Sebastian Brannstrom <sebastianb@symbian.org>
parents:
336
diff
changeset
|
196 |
startPos = startPos+1 + newPos; |
f015466e6642
Fix for bug 3942
Sebastian Brannstrom <sebastianb@symbian.org>
parents:
336
diff
changeset
|
197 |
endPos = str.Locate(';'); |
f015466e6642
Fix for bug 3942
Sebastian Brannstrom <sebastianb@symbian.org>
parents:
336
diff
changeset
|
198 |
} |
f015466e6642
Fix for bug 3942
Sebastian Brannstrom <sebastianb@symbian.org>
parents:
336
diff
changeset
|
199 |
else |
f015466e6642
Fix for bug 3942
Sebastian Brannstrom <sebastianb@symbian.org>
parents:
336
diff
changeset
|
200 |
{ |
f015466e6642
Fix for bug 3942
Sebastian Brannstrom <sebastianb@symbian.org>
parents:
336
diff
changeset
|
201 |
startPos = KErrNotFound; |
f015466e6642
Fix for bug 3942
Sebastian Brannstrom <sebastianb@symbian.org>
parents:
336
diff
changeset
|
202 |
endPos = KErrNotFound; |
f015466e6642
Fix for bug 3942
Sebastian Brannstrom <sebastianb@symbian.org>
parents:
336
diff
changeset
|
203 |
} |
18 | 204 |
} |
205 |
} |
|
2 | 206 |
CleanupStack::PopAndDestroy(tmpBuf); |
19 | 207 |
|
161 | 208 |
if(str.Length()>1) |
209 |
{ |
|
210 |
// chop away newlines at start |
|
336
3d6c1417e8bd
Merged all the later Symbian3 updates into Symbian1 branch; new SIS v. 1.00.32
Sebastian Brannstrom <sebastianb@symbian.org>
parents:
246
diff
changeset
|
211 |
DP(" chop away newlines at start"); |
3d6c1417e8bd
Merged all the later Symbian3 updates into Symbian1 branch; new SIS v. 1.00.32
Sebastian Brannstrom <sebastianb@symbian.org>
parents:
246
diff
changeset
|
212 |
while (str.Length() > 0 && (str[0] == KLineBreak)) { |
161 | 213 |
str = str.Mid(1); |
214 |
} |
|
215 |
||
216 |
// chop away newlines at end |
|
336
3d6c1417e8bd
Merged all the later Symbian3 updates into Symbian1 branch; new SIS v. 1.00.32
Sebastian Brannstrom <sebastianb@symbian.org>
parents:
246
diff
changeset
|
217 |
DP(" chop away newlines at end"); |
3d6c1417e8bd
Merged all the later Symbian3 updates into Symbian1 branch; new SIS v. 1.00.32
Sebastian Brannstrom <sebastianb@symbian.org>
parents:
246
diff
changeset
|
218 |
while (str.Length() > 0 && (str[str.Length()-1] == KLineBreak)) { |
161 | 219 |
str = str.Left(str.Length()-1); |
220 |
} |
|
19 | 221 |
|
161 | 222 |
str.Trim(); |
223 |
} |
|
240
03e8cc4066ba
Fix for bug 2818
Sebastian Brannstrom <sebastianb@symbian.org>
parents:
161
diff
changeset
|
224 |
DP("PodcastUtils::CleanHtmlL END"); |
2 | 225 |
} |
226 |
||
15
93d9f66bf50b
Cleaning description better for second line in search results
teknolog
parents:
2
diff
changeset
|
227 |
EXPORT_C void PodcastUtils::RemoveAllFormatting(TDes & aString) |
93d9f66bf50b
Cleaning description better for second line in search results
teknolog
parents:
2
diff
changeset
|
228 |
{ |
93d9f66bf50b
Cleaning description better for second line in search results
teknolog
parents:
2
diff
changeset
|
229 |
// check for combination first so we prevent adding two spaces |
93d9f66bf50b
Cleaning description better for second line in search results
teknolog
parents:
2
diff
changeset
|
230 |
ReplaceString(aString,_L("\r\n"), _L(" ")); |
93d9f66bf50b
Cleaning description better for second line in search results
teknolog
parents:
2
diff
changeset
|
231 |
|
93d9f66bf50b
Cleaning description better for second line in search results
teknolog
parents:
2
diff
changeset
|
232 |
ReplaceString(aString,_L("\n"), _L(" ")); |
93d9f66bf50b
Cleaning description better for second line in search results
teknolog
parents:
2
diff
changeset
|
233 |
ReplaceString(aString,_L("\r"), _L(" ")); |
93d9f66bf50b
Cleaning description better for second line in search results
teknolog
parents:
2
diff
changeset
|
234 |
|
93d9f66bf50b
Cleaning description better for second line in search results
teknolog
parents:
2
diff
changeset
|
235 |
} |
93d9f66bf50b
Cleaning description better for second line in search results
teknolog
parents:
2
diff
changeset
|
236 |
|
2 | 237 |
EXPORT_C void PodcastUtils::ReplaceString(TDes & aString, const TDesC& aStringToReplace, const TDesC& aReplacement) |
238 |
{ |
|
239 |
TInt pos=aString.Find(aStringToReplace); |
|
240 |
TInt offset = 0; |
|
241 |
while (pos != KErrNotFound) |
|
242 |
{ |
|
243 |
aString.Replace(offset+pos, aStringToReplace.Length(), aReplacement); |
|
244 |
offset += pos + aStringToReplace.Length()+1; |
|
245 |
if (offset > aString.Length()) |
|
246 |
{ |
|
247 |
return; |
|
248 |
} |
|
249 |
||
250 |
pos=aString.Mid(offset).Find(aStringToReplace); |
|
251 |
} |
|
252 |
} |
|
253 |
||
254 |
EXPORT_C void PodcastUtils::ReplaceChar(TDes & aString, TUint aCharToReplace, TUint aReplacement) |
|
255 |
{ |
|
256 |
TInt strLen=aString.Length(); |
|
257 |
for (TInt i=0; i < strLen; i++) |
|
258 |
{ |
|
259 |
if (aString[i] == aCharToReplace) |
|
260 |
{ |
|
261 |
aString[i] = aReplacement; |
|
262 |
} |
|
263 |
} |
|
264 |
} |
|
265 |
||
266 |
EXPORT_C void PodcastUtils::EnsureProperPathName(TFileName &aPath) |
|
267 |
{ |
|
268 |
// from the SDK: The following characters cannot occur in the path: < >: " / |* |
|
269 |
||
270 |
ReplaceChar(aPath, '/', '_'); // better not to add \\ in case we have multiple / |
|
271 |
ReplaceChar(aPath, ':', '_'); |
|
272 |
ReplaceChar(aPath, '?', '_'); |
|
273 |
ReplaceChar(aPath, '|', '_'); |
|
274 |
ReplaceChar(aPath, '*', '_'); |
|
275 |
ReplaceChar(aPath, '<', '_'); |
|
276 |
ReplaceChar(aPath, '>', '_'); |
|
277 |
ReplaceChar(aPath, '"', '_'); |
|
278 |
||
279 |
//buf.Append(_L("\\")); |
|
280 |
} |
|
281 |
||
282 |
EXPORT_C void PodcastUtils::FileNameFromUrl(const TDesC& aUrl, TFileName &aFileName) |
|
283 |
{ |
|
284 |
TInt pos = aUrl.LocateReverse('/'); |
|
285 |
||
286 |
if (pos != KErrNotFound) |
|
287 |
{ |
|
288 |
TPtrC str = aUrl.Mid(pos+1); |
|
289 |
pos = str.Locate('?'); |
|
290 |
if (pos != KErrNotFound) |
|
291 |
{ |
|
292 |
aFileName.Copy(str.Left(pos)); |
|
293 |
} |
|
294 |
else |
|
295 |
{ |
|
296 |
aFileName.Copy(str); |
|
297 |
} |
|
298 |
} |
|
299 |
DP2("FileNameFromUrl in: %S, out: %S", &aUrl, &aFileName); |
|
300 |
} |
|
301 |
||
302 |
EXPORT_C void PodcastUtils::SQLEncode(TDes &aString) |
|
303 |
{ |
|
304 |
ReplaceString(aString, _L("\""), _L("\"\"")); |
|
305 |
//ReplaceString(aString, _L("'"), _L("''")); |
|
306 |
} |
|
307 |
||
308 |
EXPORT_C void PodcastUtils::XMLEncode(TDes &aString) |
|
309 |
{ |
|
310 |
ReplaceString(aString, _L("\""), _L(""")); |
|
311 |
ReplaceString(aString, _L("<"), _L("<")); |
|
312 |
ReplaceString(aString, _L(">"), _L(">")); |
|
313 |
ReplaceString(aString, _L("&"), _L("&")); |
|
314 |
} |
|
60 | 315 |
|
316 |
EXPORT_C TBool PodcastUtils::IsVideoShow(TDesC &aUrl) |
|
317 |
{ |
|
318 |
if (aUrl.Find(KVideoFormat1) != KErrNotFound || |
|
319 |
aUrl.Find(KVideoFormat2) != KErrNotFound || |
|
246
140a404c6b53
Fix for bug 3626 - show filenames are now generated from UIDs
Sebastian Brannstrom <sebastianb@symbian.org>
parents:
240
diff
changeset
|
320 |
aUrl.Find(KVideoFormat3) != KErrNotFound || |
140a404c6b53
Fix for bug 3626 - show filenames are now generated from UIDs
Sebastian Brannstrom <sebastianb@symbian.org>
parents:
240
diff
changeset
|
321 |
aUrl.Find(KVideoFormat4) != KErrNotFound) |
60 | 322 |
{ |
323 |
return ETrue; |
|
324 |
} |
|
325 |
||
326 |
return EFalse; |
|
327 |
} |