-Added Songtexte.com Lyrics Hoster
-Repositioned the load more results button into the outline view -Improved the replacing of html escape characters -Lyrics Hosters can now be dragged into a preferred order in the preference window -Changed results outline's column ordering method -Some code changes -Replaced the Buttons in the lyrics pane with an action button -Preferred order of lyrics hosters will now be saved -Translation Improvements
This commit is contained in:
@@ -6,9 +6,9 @@
|
||||
// Copyright (c) 2012 __MyCompanyName__. All rights reserved.
|
||||
//
|
||||
//
|
||||
//TODO: Use correct Date
|
||||
|
||||
#import "Magistrix.h"
|
||||
#import "SearchResult.h"
|
||||
|
||||
typedef enum {
|
||||
LyricsPage,
|
||||
@@ -21,8 +21,11 @@ typedef enum {
|
||||
NSString *query;
|
||||
int loadedResults;
|
||||
int resultCount;
|
||||
NSString *firstPage;
|
||||
}
|
||||
|
||||
@synthesize enabled;
|
||||
|
||||
-(NSString*) name {
|
||||
return @"Magistrix";
|
||||
}
|
||||
@@ -34,6 +37,23 @@ typedef enum {
|
||||
-(void) startNewSearchForQuery: (NSString*) q {
|
||||
[self resetLoadedResults];
|
||||
query = q;
|
||||
int site = (loadedResults/10) + 1;
|
||||
NSString *searchPath = [NSString stringWithFormat:@"http://www.magistrix.de/lyrics/search?q=%@&page=%i", [query stringByFormattingForURL], site];
|
||||
NSURL *searchURL = [NSURL URLWithString:searchPath];
|
||||
NSError *error;
|
||||
firstPage = [NSString stringWithContentsOfURL:searchURL encoding:NSUTF8StringEncoding error:&error];
|
||||
if (error || firstPage == nil) {
|
||||
firstPage = nil;
|
||||
return;
|
||||
}
|
||||
PageType type = [self typeOfPage:firstPage];
|
||||
if (type == ResultsPage) {
|
||||
[self shouldSetResultCountFromPage:firstPage];
|
||||
} else if (type == LyricsPage) {
|
||||
resultCount = 1;
|
||||
} else {
|
||||
resultCount = 0;
|
||||
}
|
||||
}
|
||||
|
||||
-(BOOL) hasMoreResults {
|
||||
@@ -42,38 +62,33 @@ typedef enum {
|
||||
|
||||
-(NSArray*) nextResults {
|
||||
int site = (loadedResults/10) + 1;
|
||||
NSString *searchPath = [NSString stringWithFormat:@"http://www.magistrix.de/lyrics/search?q=%@&page=%i", [self stringByFormattingQuery:query], site];
|
||||
NSString *searchPath = [NSString stringWithFormat:@"http://www.magistrix.de/lyrics/search?q=%@&page=%i", [query stringByFormattingForURL] , site];
|
||||
NSURL *searchURL = [NSURL URLWithString:searchPath];
|
||||
NSError *error;
|
||||
NSString *page = [NSString stringWithContentsOfURL:searchURL encoding:NSUTF8StringEncoding error:&error];
|
||||
if (error) {
|
||||
//Network error or invalid query
|
||||
return nil;
|
||||
NSString *page;
|
||||
if (site == 1 && firstPage != nil) {
|
||||
page = firstPage;
|
||||
} else {
|
||||
NSError *error;
|
||||
page = [NSString stringWithContentsOfURL:searchURL encoding:NSUTF8StringEncoding error:&error];
|
||||
if (error) {
|
||||
//Network error or invalid query
|
||||
return nil;
|
||||
}
|
||||
}
|
||||
PageType pType = [self typeOfPage:page];
|
||||
if (pType == LyricsPage) {
|
||||
resultCount = 1;
|
||||
loadedResults = 1;
|
||||
return [NSArray arrayWithObject:[self searchResultFromLyricsPage:page atURL:searchURL]];
|
||||
} else if (pType == ResultsPage) {
|
||||
[self shouldSetResultCountFromPage:page];
|
||||
return [self searchResultsFromPage:page];
|
||||
} else if (pType == NoResultsPage) {
|
||||
resultCount = 0;
|
||||
return [[NSArray alloc] init];
|
||||
} else {
|
||||
NSRunAlertPanel(NSLocalizedString(@"Magistrix.messages.unknownPage.title", @""), NSLocalizedString(@"Magistrix.messages.unknownPage.detail", @""), NSLocalizedString(@"OK", @""), nil, nil);
|
||||
resultCount = 0;
|
||||
return [[NSArray alloc] init];
|
||||
}
|
||||
}
|
||||
|
||||
-(NSString *) stringByFormattingQuery: (NSString *) q {
|
||||
//Can replace äöü with aou, no difference in results
|
||||
NSCharacterSet *characters = [[NSCharacterSet alphanumericCharacterSet] invertedSet];
|
||||
return [[[q stringByReplacingOccurrencesOfString:@" " withString:@"+"] stringByAddingPercentEscapesUsingEncoding:NSUTF8StringEncoding] stringByTrimmingCharactersInSet:characters];
|
||||
}
|
||||
|
||||
-(PageType) typeOfPage: (NSString *) page {
|
||||
if ([page rangeOfString:@"<title>Songtext-Suche</title>"].location != NSNotFound) {
|
||||
if ([page rangeOfString:@"<div class='empty_collection'>"].location != NSNotFound) {
|
||||
@@ -96,12 +111,12 @@ typedef enum {
|
||||
int artistEnd = artistEndTag.location;
|
||||
int songNameStart = NSMaxRange(artistEndTag);
|
||||
int songNameEnd = headingEnd;
|
||||
NSString *artist = [self stringByRemovingHTMLTags:[page substringWithRange:NSMakeRange(artistStart, artistEnd-artistStart)]];
|
||||
NSString *artist = [[page substringWithRange:NSMakeRange(artistStart, artistEnd-artistStart)] stringByRemovingHTMLTags];
|
||||
NSString *songName = [page substringWithRange:NSMakeRange(songNameStart, songNameEnd-songNameStart)];
|
||||
//Remove the " Lyric" and the " – " from the Song name
|
||||
songName = [self stringByRemovingHTMLTags:[[songName substringToIndex:[songName length]-[@" Lyric" length]] substringFromIndex:[@" – " length]]];
|
||||
songName = [[[songName substringToIndex:[songName length]-[@" Lyric" length]] substringFromIndex:[@" – " length]] stringByRemovingHTMLTags];
|
||||
NSString *preview = [self lyricsFromPage:page];
|
||||
return [[SearchResult alloc]initWithName:songName fromArtist:artist preview:preview link:url];
|
||||
return [[SearchResult alloc]initWithName:songName fromArtist:artist preview:preview link:url loadedByHoster:self];
|
||||
}
|
||||
|
||||
-(NSArray*) searchResultsFromPage: (NSString *) page {
|
||||
@@ -139,8 +154,7 @@ typedef enum {
|
||||
NSRange artistStartRange = [tag rangeOfString:@">"];
|
||||
int artistEndIndex = [tag rangeOfString:@"<" options:NSCaseInsensitiveSearch range:[self restRangeFromString:tag subtractingRange:artistStartRange]].location;
|
||||
int artistStartIndex = NSMaxRange(artistStartRange);
|
||||
NSString *artist = [self stringByRemovingHTMLTags:[tag substringWithRange:NSMakeRange(artistStartIndex, artistEndIndex-artistStartIndex)]];
|
||||
|
||||
NSString *artist = [[tag substringWithRange:NSMakeRange(artistStartIndex, artistEndIndex-artistStartIndex)] stringByRemovingHTMLTags];
|
||||
NSRange restRange = [self restRangeFromString:tag subtractingRange:NSMakeRange(artistEndIndex, [@"</a>" length])];
|
||||
NSRange songNameTagStartRange = [tag rangeOfString:@"<a href=\"" options:NSCaseInsensitiveSearch range:restRange];
|
||||
int linkStart = NSMaxRange(songNameTagStartRange);
|
||||
@@ -148,12 +162,12 @@ typedef enum {
|
||||
NSURL *link = [self urlFromHref:[tag substringWithRange:NSMakeRange(linkStart, linkEndRage.location-linkStart)]];
|
||||
int songNameStart = NSMaxRange([tag rangeOfString:@">" options:NSCaseInsensitiveSearch range:[self restRangeFromString:tag subtractingRange:songNameTagStartRange]]);
|
||||
int songNameEnd = [tag rangeOfString:@"</a>" options:NSCaseInsensitiveSearch range:[self restRangeFromString:tag subtractingRange:songNameTagStartRange]].location;
|
||||
NSString *songName = [self stringByRemovingHTMLTags:[tag substringWithRange:NSMakeRange(songNameStart, songNameEnd-songNameStart)]];
|
||||
NSString *songName = [[tag substringWithRange:NSMakeRange(songNameStart, songNameEnd-songNameStart)] stringByRemovingHTMLTags];
|
||||
int previewStart = songNameEnd + [@"</a>" length] + [@"\n<p>" length];
|
||||
NSRange previewRestRange = NSMakeRange(previewStart, [tag length]-previewStart);
|
||||
int previewEnd = [tag rangeOfString:@"</p>" options:NSCaseInsensitiveSearch range:previewRestRange].location;
|
||||
NSString *preview = [self stringByRemovingHTMLTags:[tag substringWithRange:NSMakeRange(previewStart, previewEnd-previewStart)]];
|
||||
return [[SearchResult alloc] initWithName:songName fromArtist:artist preview:preview link:link];
|
||||
NSString *preview = [[tag substringWithRange:NSMakeRange(previewStart, previewEnd-previewStart)] stringByRemovingHTMLTags];
|
||||
return [[SearchResult alloc] initWithName:songName fromArtist:artist preview:preview link:link loadedByHoster:self];
|
||||
}
|
||||
|
||||
-(NSURL*) urlFromHref: (NSString *) link {
|
||||
@@ -164,9 +178,6 @@ typedef enum {
|
||||
}
|
||||
}
|
||||
|
||||
-(NSString*) stringByRemovingHTMLTags: (NSString *)string {
|
||||
return [[[[[[[[[[[string stringByReplacingOccurrencesOfString:@"<strong>" withString:@""] stringByReplacingOccurrencesOfString:@"</strong>" withString:@""] stringByReplacingOccurrencesOfString:@"<b>" withString:@""] stringByReplacingOccurrencesOfString:@"</b>" withString:@""] stringByReplacingOccurrencesOfString:@"<i>" withString:@""] stringByReplacingOccurrencesOfString:@"</i>" withString:@""] stringByReplacingOccurrencesOfString:@"<p>" withString:@""] stringByReplacingOccurrencesOfString:@"</p>" withString:@""] stringByReplacingOccurrencesOfString:@"<br />" withString:@""] stringByReplacingOccurrencesOfString:@""" withString:@"\""] stringByReplacingOccurrencesOfString:@"&" withString:@"&"];
|
||||
}
|
||||
|
||||
-(NSRange) restRangeFromString: (NSString *) page subtractingRange: (NSRange) aRange {
|
||||
int loc = NSMaxRange(aRange);
|
||||
@@ -174,7 +185,7 @@ typedef enum {
|
||||
}
|
||||
|
||||
-(void) shouldSetResultCountFromPage: (NSString *) page {
|
||||
if (resultCount == 0) {
|
||||
if (resultCount <= 0) {
|
||||
//Nothing loaded before
|
||||
NSRange resultsLabelStartRange = [page rangeOfString:@"<p>Ergebnisse 1 bis "];
|
||||
int resultsLabelEnd = [page rangeOfString:@"</p>" options:NSCaseInsensitiveSearch range:[self restRangeFromString:page subtractingRange:resultsLabelStartRange]].location;
|
||||
@@ -196,6 +207,7 @@ typedef enum {
|
||||
|
||||
-(void) resetLoadedResults {
|
||||
loadedResults = 0;
|
||||
firstPage = nil;
|
||||
}
|
||||
|
||||
-(Lyrics*) lyricsBySearchResult: (SearchResult *) result {
|
||||
@@ -208,13 +220,20 @@ typedef enum {
|
||||
return [[Lyrics alloc] initWithName:[result name] byArtist:[result artist] withLyrics:lyrics];
|
||||
}
|
||||
|
||||
|
||||
-(NSString *) lyricsFromPage: (NSString *)page {
|
||||
int lyricsStart = NSMaxRange([page rangeOfString:@"<div id='songtext'>"]) + [@"\n" length];
|
||||
NSRange restRange = NSMakeRange(lyricsStart, [page length]-lyricsStart);
|
||||
int lyricsEnd = [page rangeOfString:@"<div class='clear'></div>" options:NSCaseInsensitiveSearch range:restRange].location;
|
||||
NSString *lyrics = [self stringByRemovingHTMLTags:[page substringWithRange:NSMakeRange(lyricsStart, lyricsEnd-lyricsStart)]];
|
||||
NSString *lyrics = [[page substringWithRange:NSMakeRange(lyricsStart, lyricsEnd-lyricsStart)] stringByRemovingHTMLTags];
|
||||
return lyrics;
|
||||
}
|
||||
|
||||
-(BOOL)canShowInBrowser:(id)result {
|
||||
return YES;
|
||||
}
|
||||
|
||||
-(void)showInBrowser:(id)result {
|
||||
[[NSWorkspace sharedWorkspace] openURL:[result link]];
|
||||
}
|
||||
|
||||
@end
|
||||
|
||||
Reference in New Issue
Block a user