Sorting artist index
This commit is contained in:
@@ -121,16 +121,19 @@ func (r *BaseRepository) toEntity(response [][]byte, entity interface{}) error {
|
|||||||
}
|
}
|
||||||
|
|
||||||
// TODO Optimize it! Probably very slow (and confusing!)
|
// TODO Optimize it! Probably very slow (and confusing!)
|
||||||
func (r *BaseRepository) loadAll(entities interface{}) error {
|
func (r *BaseRepository) loadAll(entities interface{}, sortBy string) error {
|
||||||
total, err := r.CountAll()
|
total, err := r.CountAll()
|
||||||
if (err != nil) {
|
if (err != nil) {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|
||||||
reflected := reflect.ValueOf(entities).Elem()
|
reflected := reflect.ValueOf(entities).Elem()
|
||||||
|
var sortKey []byte = nil
|
||||||
|
if sortBy != "" {
|
||||||
|
sortKey = []byte(fmt.Sprintf("%s:*:%s", r.table, sortBy))
|
||||||
|
}
|
||||||
setName := r.table + "s:all"
|
setName := r.table + "s:all"
|
||||||
response, err := db().XSSort([]byte(setName), 0, 0, true, false, nil, r.getFieldKeys("*"))
|
response, err := db().XSSort([]byte(setName), 0, 0, true, false, sortKey, r.getFieldKeys("*"))
|
||||||
if (err != nil) {
|
if (err != nil) {
|
||||||
return err
|
return err
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -131,7 +131,7 @@ func TestBaseRepository(t *testing.T) {
|
|||||||
|
|
||||||
Convey("When I call loadAll", func() {
|
Convey("When I call loadAll", func() {
|
||||||
var es = make([]TestEntity, 0)
|
var es = make([]TestEntity, 0)
|
||||||
err := repo.loadAll(&es)
|
err := repo.loadAll(&es, "")
|
||||||
Convey("Then It should not return any error", func() {
|
Convey("Then It should not return any error", func() {
|
||||||
So(err, ShouldBeNil)
|
So(err, ShouldBeNil)
|
||||||
})
|
})
|
||||||
|
|||||||
@@ -3,6 +3,8 @@ package repositories
|
|||||||
import (
|
import (
|
||||||
"github.com/deluan/gosonic/models"
|
"github.com/deluan/gosonic/models"
|
||||||
"errors"
|
"errors"
|
||||||
|
"sort"
|
||||||
|
"github.com/deluan/gosonic/utils"
|
||||||
)
|
)
|
||||||
|
|
||||||
type ArtistIndex interface {
|
type ArtistIndex interface {
|
||||||
@@ -36,8 +38,17 @@ func (r *artistIndex) Get(id string) (*models.ArtistIndex, error) {
|
|||||||
|
|
||||||
func (r *artistIndex) GetAll() ([]models.ArtistIndex, error) {
|
func (r *artistIndex) GetAll() ([]models.ArtistIndex, error) {
|
||||||
var indices = make([]models.ArtistIndex, 0)
|
var indices = make([]models.ArtistIndex, 0)
|
||||||
err := r.loadAll(&indices)
|
err := r.loadAll(&indices, "")
|
||||||
|
if err == nil {
|
||||||
|
for _, idx := range indices {
|
||||||
|
sort.Sort(byArtistName(idx.Artists))
|
||||||
|
}
|
||||||
|
}
|
||||||
return indices, err
|
return indices, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
type byArtistName []models.ArtistInfo
|
||||||
|
|
||||||
|
func (a byArtistName) Len() int { return len(a) }
|
||||||
|
func (a byArtistName) Swap(i, j int) { a[i], a[j] = a[j], a[i] }
|
||||||
|
func (a byArtistName) Less(i, j int) bool { return utils.NoArticle(a[i].Artist) < utils.NoArticle(a[j].Artist) }
|
||||||
|
|||||||
@@ -16,7 +16,7 @@ func (s *ItunesScanner) LoadFolder(path string) []Track {
|
|||||||
mediaFiles := make([]Track, len(l.Tracks))
|
mediaFiles := make([]Track, len(l.Tracks))
|
||||||
i := 0
|
i := 0
|
||||||
for id, t := range l.Tracks {
|
for id, t := range l.Tracks {
|
||||||
if t.Location != "" && strings.Contains(t.Kind, "audio") {
|
if strings.HasPrefix(t.Location, "file://") && strings.Contains(t.Kind, "audio") {
|
||||||
mediaFiles[i].Id = id
|
mediaFiles[i].Id = id
|
||||||
mediaFiles[i].Album = unescape(t.Album)
|
mediaFiles[i].Album = unescape(t.Album)
|
||||||
mediaFiles[i].Title = unescape(t.Name)
|
mediaFiles[i].Title = unescape(t.Name)
|
||||||
|
|||||||
Reference in New Issue
Block a user