Merge pull request #4 from WorldObservationLog/main

fix: panic when the resp data of lyrics is empty
pull/6/head
zhaarey 5 months ago committed by GitHub
commit e0520a9400
No known key found for this signature in database
GPG Key ID: B5690EEEBB952194
  1. 8
      main.go
  2. 6
      main_atmos.go
  3. 8
      main_select.go

@ -1013,7 +1013,11 @@ func getSongLyrics(songId string, storefront string, token string, userToken str
defer do.Body.Close() defer do.Body.Close()
obj := new(SongLyrics) obj := new(SongLyrics)
err = json.NewDecoder(do.Body).Decode(&obj) err = json.NewDecoder(do.Body).Decode(&obj)
return obj.Data[0].Attributes.Ttml, nil if obj.Data != nil {
return obj.Data[0].Attributes.Ttml, nil
} else {
return "", errors.New("failed to get lyrics")
}
} }
func writeCover(sanAlbumFolder, url string) error { func writeCover(sanAlbumFolder, url string) error {
@ -1159,7 +1163,7 @@ func rip(albumId string, token string, storefront string, userToken string) erro
fmt.Sprintf("cover=%s/cover.jpg", sanAlbumFolder), fmt.Sprintf("cover=%s/cover.jpg", sanAlbumFolder),
} }
tagsString := strings.Join(tags, ":") tagsString := strings.Join(tags, ":")
cmd := exec.Command("MP4Box","-itags", tagsString, trackPath) cmd := exec.Command("MP4Box", "-itags", tagsString, trackPath)
if err := cmd.Run(); err != nil { if err := cmd.Run(); err != nil {
fmt.Printf("Embed failed: %v\n", err) fmt.Printf("Embed failed: %v\n", err)
continue continue

@ -1019,7 +1019,11 @@ func getSongLyrics(songId string, storefront string, token string, userToken str
defer do.Body.Close() defer do.Body.Close()
obj := new(SongLyrics) obj := new(SongLyrics)
err = json.NewDecoder(do.Body).Decode(&obj) err = json.NewDecoder(do.Body).Decode(&obj)
return obj.Data[0].Attributes.Ttml, nil if obj.Data != nil {
return obj.Data[0].Attributes.Ttml, nil
} else {
return "", errors.New("failed to get lyrics")
}
} }
func writeCover(sanAlbumFolder, url string) error { func writeCover(sanAlbumFolder, url string) error {

@ -1012,7 +1012,11 @@ func getSongLyrics(songId string, storefront string, token string, userToken str
defer do.Body.Close() defer do.Body.Close()
obj := new(SongLyrics) obj := new(SongLyrics)
err = json.NewDecoder(do.Body).Decode(&obj) err = json.NewDecoder(do.Body).Decode(&obj)
return obj.Data[0].Attributes.Ttml, nil if obj.Data != nil {
return obj.Data[0].Attributes.Ttml, nil
} else {
return "", errors.New("failed to get lyrics")
}
} }
func writeCover(sanAlbumFolder, url string) error { func writeCover(sanAlbumFolder, url string) error {
@ -1194,7 +1198,7 @@ func rip(albumId string, token string, storefront string, userToken string) erro
fmt.Sprintf("cover=%s/cover.jpg", sanAlbumFolder), fmt.Sprintf("cover=%s/cover.jpg", sanAlbumFolder),
} }
tagsString := strings.Join(tags, ":") tagsString := strings.Join(tags, ":")
cmd := exec.Command("MP4Box","-itags", tagsString, trackPath) cmd := exec.Command("MP4Box", "-itags", tagsString, trackPath)
if err := cmd.Run(); err != nil { if err := cmd.Run(); err != nil {
fmt.Printf("Embed failed: %v\n", err) fmt.Printf("Embed failed: %v\n", err)
continue continue

Loading…
Cancel
Save