diff options
author | Scott Jackson <daneren2005@gmail.com> | 2013-01-18 21:18:21 -0800 |
---|---|---|
committer | Scott Jackson <daneren2005@gmail.com> | 2013-01-18 21:18:21 -0800 |
commit | 8df5cf2a2bc4fae340c13973c8bdef84cb6b88ae (patch) | |
tree | fe3a3a1bb42b70ecc19f6ab82575815492cec27b /subsonic-android/src | |
parent | 556db33a418083bb10f626b1a5f2a1938a6e2568 (diff) | |
download | dsub-8df5cf2a2bc4fae340c13973c8bdef84cb6b88ae.tar.gz dsub-8df5cf2a2bc4fae340c13973c8bdef84cb6b88ae.tar.bz2 dsub-8df5cf2a2bc4fae340c13973c8bdef84cb6b88ae.zip |
Sort offline search results by relevance
Diffstat (limited to 'subsonic-android/src')
3 files changed, 73 insertions, 7 deletions
diff --git a/subsonic-android/src/github/daneren2005/dsub/domain/Artist.java b/subsonic-android/src/github/daneren2005/dsub/domain/Artist.java index 202af627..e4a9001b 100644 --- a/subsonic-android/src/github/daneren2005/dsub/domain/Artist.java +++ b/subsonic-android/src/github/daneren2005/dsub/domain/Artist.java @@ -29,6 +29,7 @@ public class Artist implements Serializable { private String name; private String index; private boolean starred; + private int closeness; public String getId() { return id; @@ -61,6 +62,14 @@ public class Artist implements Serializable { public void setStarred(boolean starred) { this.starred = starred; } + + public int getCloseness() { + return closeness; + } + + public void setCloseness(int closeness) { + this.closeness = closeness; + } @Override public String toString() { diff --git a/subsonic-android/src/github/daneren2005/dsub/domain/MusicDirectory.java b/subsonic-android/src/github/daneren2005/dsub/domain/MusicDirectory.java index da0d8cbc..b89417c0 100644 --- a/subsonic-android/src/github/daneren2005/dsub/domain/MusicDirectory.java +++ b/subsonic-android/src/github/daneren2005/dsub/domain/MusicDirectory.java @@ -81,6 +81,7 @@ public class MusicDirectory { private String path; private boolean video; private boolean starred; + private int closeness; public String getId() { return id; @@ -241,6 +242,14 @@ public class MusicDirectory { public void setStarred(boolean starred) { this.starred = starred; } + + public int getCloseness() { + return closeness; + } + + public void setCloseness(int closeness) { + this.closeness = closeness; + } @Override public boolean equals(Object o) { diff --git a/subsonic-android/src/github/daneren2005/dsub/service/OfflineMusicService.java b/subsonic-android/src/github/daneren2005/dsub/service/OfflineMusicService.java index 5f643ccb..5f55df6d 100644 --- a/subsonic-android/src/github/daneren2005/dsub/service/OfflineMusicService.java +++ b/subsonic-android/src/github/daneren2005/dsub/service/OfflineMusicService.java @@ -51,6 +51,7 @@ import github.daneren2005.dsub.util.FileUtil; import github.daneren2005.dsub.util.ProgressListener; import github.daneren2005.dsub.util.Util; import java.io.*; +import java.util.Comparator; /** * @author Sindre Mehus @@ -173,14 +174,16 @@ public class OfflineMusicService extends RESTMusicService { List<MusicDirectory.Entry> albums = new ArrayList<MusicDirectory.Entry>(); List<MusicDirectory.Entry> songs = new ArrayList<MusicDirectory.Entry>(); File root = FileUtil.getMusicDirectory(context); + int closeness = 0; for (File artistFile : FileUtil.listFiles(root)) { String artistName = artistFile.getName(); if (artistFile.isDirectory()) { - if(matchCriteria(criteria, artistName)) { + if((closeness = matchCriteria(criteria, artistName)) > 0) { Artist artist = new Artist(); artist.setId(artistFile.getPath()); artist.setIndex(artistFile.getName().substring(0, 1)); artist.setName(artistName); + artist.setCloseness(closeness); artists.add(artist); } @@ -188,16 +191,58 @@ public class OfflineMusicService extends RESTMusicService { } } + Collections.sort(artists, new Comparator<Artist>() { + public int compare(Artist lhs, Artist rhs) { + if(lhs.getCloseness() == rhs.getCloseness()) { + return 0; + } + else if(lhs.getCloseness() > rhs.getCloseness()) { + return -1; + } + else { + return 1; + } + } + }); + Collections.sort(albums, new Comparator<MusicDirectory.Entry>() { + public int compare(MusicDirectory.Entry lhs, MusicDirectory.Entry rhs) { + if(lhs.getCloseness() == rhs.getCloseness()) { + return 0; + } + else if(lhs.getCloseness() > rhs.getCloseness()) { + return -1; + } + else { + return 1; + } + } + }); + Collections.sort(songs, new Comparator<MusicDirectory.Entry>() { + public int compare(MusicDirectory.Entry lhs, MusicDirectory.Entry rhs) { + if(lhs.getCloseness() == rhs.getCloseness()) { + return 0; + } + else if(lhs.getCloseness() > rhs.getCloseness()) { + return -1; + } + else { + return 1; + } + } + }); + return new SearchResult(artists, albums, songs); } private void recursiveAlbumSearch(String artistName, File file, SearchCritera criteria, Context context, List<MusicDirectory.Entry> albums, List<MusicDirectory.Entry> songs) { + int closeness; for(File albumFile : FileUtil.listMediaFiles(file)) { if(albumFile.isDirectory()) { String albumName = getName(albumFile); - if(matchCriteria(criteria, albumName)) { + if((closeness = matchCriteria(criteria, albumName)) > 0) { MusicDirectory.Entry album = createEntry(context, albumFile, albumName); album.setArtist(artistName); + album.setCloseness(closeness); albums.add(album); } @@ -206,39 +251,42 @@ public class OfflineMusicService extends RESTMusicService { if(songFile.isDirectory()) { recursiveAlbumSearch(artistName, songFile, criteria, context, albums, songs); } - else if(matchCriteria(criteria, songName)){ + else if((closeness = matchCriteria(criteria, songName)) > 0){ MusicDirectory.Entry song = createEntry(context, albumFile, songName); song.setArtist(artistName); song.setAlbum(albumName); + song.setCloseness(closeness); songs.add(song); } } } else { String songName = getName(albumFile); - if(matchCriteria(criteria, songName)) { + if((closeness = matchCriteria(criteria, songName)) > 0) { MusicDirectory.Entry song = createEntry(context, albumFile, songName); song.setArtist(artistName); song.setAlbum(songName); + song.setCloseness(closeness); songs.add(song); } } } } - private boolean matchCriteria(SearchCritera criteria, String name) { + private int matchCriteria(SearchCritera criteria, String name) { String query = criteria.getQuery().toLowerCase(); String[] queryParts = query.split(" "); String[] nameParts = name.toLowerCase().split(" "); + int closeness = 0; for(String queryPart : queryParts) { for(String namePart : nameParts) { if(namePart.equals(queryPart)) { - return true; + closeness++; } } } - return false; + return closeness; } @Override |