mirror of
https://github.com/navidrome/navidrome.git
synced 2025-04-04 21:17:37 +03:00
Fix extracting tags with spaces in the tagname ("Ex: Album Artist")
This commit is contained in:
parent
9edd7e9025
commit
afe5a5b32a
3 changed files with 21 additions and 9 deletions
|
@ -51,7 +51,7 @@ var (
|
||||||
inputRegex = regexp.MustCompile(`(?m)^Input #\d+,.*,\sfrom\s'(.*)'`)
|
inputRegex = regexp.MustCompile(`(?m)^Input #\d+,.*,\sfrom\s'(.*)'`)
|
||||||
|
|
||||||
// TITLE : Back In Black
|
// TITLE : Back In Black
|
||||||
tagsRx = regexp.MustCompile(`(?i)^\s{4,6}([\w-]+)\s*:(.*)`)
|
tagsRx = regexp.MustCompile(`(?i)^\s{4,6}([\w\s-]+)\s*:(.*)`)
|
||||||
|
|
||||||
// Duration: 00:04:16.00, start: 0.000000, bitrate: 995 kb/s`
|
// Duration: 00:04:16.00, start: 0.000000, bitrate: 995 kb/s`
|
||||||
durationRx = regexp.MustCompile(`^\s\sDuration: ([\d.:]+).*bitrate: (\d+)`)
|
durationRx = regexp.MustCompile(`^\s\sDuration: ([\d.:]+).*bitrate: (\d+)`)
|
||||||
|
@ -114,7 +114,7 @@ func (m *ffmpegMetadata) parseInfo(info string) {
|
||||||
}
|
}
|
||||||
match := tagsRx.FindStringSubmatch(line)
|
match := tagsRx.FindStringSubmatch(line)
|
||||||
if len(match) > 0 {
|
if len(match) > 0 {
|
||||||
tagName := strings.ToLower(match[1])
|
tagName := strings.TrimSpace(strings.ToLower(match[1]))
|
||||||
tagValue := strings.TrimSpace(match[2])
|
tagValue := strings.TrimSpace(match[2])
|
||||||
|
|
||||||
// Skip when the tag was previously found
|
// Skip when the tag was previously found
|
||||||
|
|
|
@ -213,6 +213,16 @@ Input #0, mp3, from '/Users/deluan/Downloads/椎名林檎 - 加爾基 精液 栗
|
||||||
Expect(md.SortArtist()).To(Equal("Shiina, Ringo"))
|
Expect(md.SortArtist()).To(Equal("Shiina, Ringo"))
|
||||||
Expect(md.SortAlbumArtist()).To(Equal("Shiina, Ringo"))
|
Expect(md.SortAlbumArtist()).To(Equal("Shiina, Ringo"))
|
||||||
})
|
})
|
||||||
|
|
||||||
|
It("parses tags with spaces in the name", func() {
|
||||||
|
const output = `
|
||||||
|
Input #0, mp3, from '/Users/deluan/Music/Music/Media/_/Wyclef Jean - From the Hut, to the Projects, to the Mansion/10 - The Struggle (interlude).mp3':
|
||||||
|
Metadata:
|
||||||
|
ALBUM ARTIST : Wyclef Jean
|
||||||
|
`
|
||||||
|
md, _ := e.extractMetadata("tests/fixtures/test.mp3", output)
|
||||||
|
Expect(md.AlbumArtist()).To(Equal("Wyclef Jean"))
|
||||||
|
})
|
||||||
})
|
})
|
||||||
|
|
||||||
It("creates a valid command line", func() {
|
It("creates a valid command line", func() {
|
||||||
|
|
|
@ -65,13 +65,15 @@ type baseMetadata struct {
|
||||||
tags map[string]string
|
tags map[string]string
|
||||||
}
|
}
|
||||||
|
|
||||||
func (m *baseMetadata) Title() string { return m.getTag("title", "sort_name", "titlesort") }
|
func (m *baseMetadata) Title() string { return m.getTag("title", "sort_name", "titlesort") }
|
||||||
func (m *baseMetadata) Album() string { return m.getTag("album", "sort_album", "albumsort") }
|
func (m *baseMetadata) Album() string { return m.getTag("album", "sort_album", "albumsort") }
|
||||||
func (m *baseMetadata) Artist() string { return m.getTag("artist", "sort_artist", "artistsort") }
|
func (m *baseMetadata) Artist() string { return m.getTag("artist", "sort_artist", "artistsort") }
|
||||||
func (m *baseMetadata) AlbumArtist() string { return m.getTag("album_artist", "albumartist") }
|
func (m *baseMetadata) AlbumArtist() string {
|
||||||
func (m *baseMetadata) SortTitle() string { return m.getSortTag("", "title", "name") }
|
return m.getTag("album_artist", "album artist", "albumartist")
|
||||||
func (m *baseMetadata) SortAlbum() string { return m.getSortTag("", "album") }
|
}
|
||||||
func (m *baseMetadata) SortArtist() string { return m.getSortTag("", "artist") }
|
func (m *baseMetadata) SortTitle() string { return m.getSortTag("", "title", "name") }
|
||||||
|
func (m *baseMetadata) SortAlbum() string { return m.getSortTag("", "album") }
|
||||||
|
func (m *baseMetadata) SortArtist() string { return m.getSortTag("", "artist") }
|
||||||
func (m *baseMetadata) SortAlbumArtist() string {
|
func (m *baseMetadata) SortAlbumArtist() string {
|
||||||
return m.getSortTag("tso2", "albumartist", "album_artist")
|
return m.getSortTag("tso2", "albumartist", "album_artist")
|
||||||
}
|
}
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue