« get me outta code hell

mtui - Music Text User Interface - user-friendly command line music player
about summary refs log tree commit diff
diff options
context:
space:
mode:
-rw-r--r--playlist-utils.js22
1 files changed, 11 insertions, 11 deletions
diff --git a/playlist-utils.js b/playlist-utils.js
index 739652f..f58a9e8 100644
--- a/playlist-utils.js
+++ b/playlist-utils.js
@@ -847,12 +847,15 @@ export function getPathScore(path1, path2) {
   return scores.reduce((a, b) => a < b ? a : b)
 }
 
-export function findTrackObject(referenceData, sourcePlaylist) {
+export function findTrackObject(referenceData, sourcePlaylist, flattenedSourcePlaylist = null) {
   // Finds the track object in the source playlist which most closely resembles
   // the provided reference data. This is used for maintaining the identity of
   // track objects when reloading a playlist (see serialized-backend.js). It's
   // also usable in synchronizing the identity of tracks across linked clients
   // (see socket.js).
+  //
+  // NB: This function is many times more efficient if you pass a preemptively
+  // flattened version of the source playlist in as well!
 
   // Reference data includes track NAME, track SOURCE (downloaderArg), and
   // track PATH (names of parent groups). Specifics of how existing track
@@ -875,18 +878,15 @@ export function findTrackObject(referenceData, sourcePlaylist) {
     return getPathScore(path1, path2)
   }
 
-  function compareName(track) {
-    return track.name === referenceData.name
-  }
-
-  function compareSource(track) {
-    return track.downloaderArg === referenceData.downloaderArg
+  if (!flattenedSourcePlaylist) {
+    flattenedSourcePlaylist = flattenGrouplike(sourcePlaylist)
   }
 
   // The only tracks which will be considered at all are those which match at
   // least one of the reference name/source.
-  const baselineResemble = flattenGrouplike(sourcePlaylist).items.filter(
-    track => compareName(track) || compareSource(track))
+  const baselineResemble = flattenedSourcePlaylist.items.filter(track =>
+    track.name === referenceData.name ||
+    track.downloaderArg === referenceData.downloaderArg)
 
   // If no track matches the baseline conditions for resemblance at all,
   // return null. It's up to the caller to decide what to do in this case,
@@ -900,8 +900,8 @@ export function findTrackObject(referenceData, sourcePlaylist) {
   // be used as the factors in calculating which track resembles closest.
   const reasons = baselineResemble.map(track => ({
     track,
-    nameMatches: compareName(track),
-    sourceMatches: compareSource(track),
+    nameMatches: track.name === referenceData.name,
+    sourceMatches: track.downloaderArg === referenceData.downloaderArg,
     pathScore: getTrackPathScore(track)
   }))