예제 #1
0
  /** Called by the providers when the details of a song have been updated. */
  @Override
  public void onSongUpdate(ProviderIdentifier provider, final Song s) throws RemoteException {
    if (s == null) {
      Log.w(TAG, "Provider " + provider.mName + " sent in a null songUpdate");
      return;
    }

    try {
      Song cached = mCache.getSong(s.getRef());
      boolean wasLoaded = false;
      boolean changed = false;

      if (cached == null) {
        mCache.putSong(provider, s);
        changed = true;
        cached = s;
      } else {
        wasLoaded = cached.isLoaded();
        if (s.isLoaded() && !cached.isIdentical(s)) {
          cached.setAlbum(s.getAlbum());
          cached.setArtist(s.getArtist());
          cached.setSourceLogo(s.getLogo());
          cached.setDuration(s.getDuration());
          cached.setTitle(s.getTitle());
          cached.setYear(s.getYear());
          cached.setOfflineStatus(s.getOfflineStatus());
          cached.setAvailable(s.isAvailable());
          cached.setIsLoaded(s.isLoaded());
          changed = true;
        }
      }

      if (!wasLoaded && cached.isLoaded()) {
        // Match the album with the artist
        Artist artist = mCache.getArtist(s.getArtist());
        if (artist == null && s.getArtist() != null) {
          artist = retrieveArtist(s.getArtist(), provider);
        }

        if (artist != null) {
          Album album = mCache.getAlbum(s.getAlbum());
          if (album == null && s.getAlbum() != null) {
            album = retrieveAlbum(s.getAlbum(), provider);
          }

          if (album != null) {
            artist.addAlbum(album.getRef());
          }
        }
      }

      if (changed) {
        postSongForUpdate(cached);
      }
    } catch (Exception e) {
      Log.e(TAG, "Exception while updating song data", e);
    }
  }
예제 #2
0
  /**
   * Retrieves a song from the provider, and put it in the cache
   *
   * @param ref The reference to the song
   * @param provider The provider from which retrieve the song (may be null to query cache only)
   * @return The song, or null if the provider says so
   */
  public Song retrieveSong(final String ref, final ProviderIdentifier provider) {
    if (ref == null) {
      // Force get stack trace
      try {
        throw new RuntimeException();
      } catch (RuntimeException e) {
        Log.e(TAG, "retrieveSong called with a null reference", e);
      }
      return null;
    }

    // Try from cache
    Song output = mCache.getSong(ref);

    if (output == null && provider != null) {
      // Get from provider then
      ProviderConnection pc = PluginsLookup.getDefault().getProvider(provider);
      if (pc != null) {
        IMusicProvider binder = pc.getBinder();

        if (binder != null) {
          try {
            output = binder.getSong(ref);
            if (output != null) {
              onSongUpdate(provider, output);
            }
          } catch (DeadObjectException e) {
            Log.e(TAG, "Provider died while retrieving song");
            return null;
          } catch (RemoteException e) {
            Log.e(TAG, "Unable to retrieve the song", e);
            return null;
          }
        } else {
          if (DEBUG) Log.e(TAG, "Binder null: provider not yet connected?");
        }
      } else {
        Log.e(TAG, "Unknown provider identifier: " + provider);
      }
    }

    if (output == null && provider != null) {
      Log.d(TAG, "Unable to get song " + ref + " from " + provider.mName);
    }

    return output;
  }