public void RatingUpdateReceiver(QuerySong song, SongRating oldRating, SongRating newRating)
        {
            if (!IsEnabled || !_scrobbler.BaseScrobbler.HasSession)
            {
                return;
            }

            try
            {
                Log.O("LastFM, Rating: {0} - {1} - {2}", song.Artist, song.Title, newRating.ToString());
                Track track = null;

                //Get corrected track if there is one
                //Without getting the corrected track,
                //ratings will not work if there were corrections.
                if (song.Meta == null)
                {
                    track = QuerySongToTrack(song);
                }
                else
                {
                    track = (Track)song.Meta;
                }

                switch (newRating)
                {
                case SongRating.love:
                    _scrobbler.UnBan(track);
                    _scrobbler.Love(track);
                    break;

                case SongRating.ban:
                    _scrobbler.UnLove(track);
                    _scrobbler.Ban(track);
                    break;

                case SongRating.none:
                    if (oldRating == SongRating.love)
                    {
                        _scrobbler.UnLove(track);
                    }
                    else if (oldRating == SongRating.ban)
                    {
                        _scrobbler.UnBan(track);
                    }
                    break;
                }

                if (_scrobbler.QueuedCount > 0)
                {
                    ProcessScrobbles();
                }
            }
            catch (Exception ex)
            {
                Log.O("Last.FM Error!: " + ex.ToString());
            }
        }
        public void RatingUpdateReceiver(QuerySong song, SongRating oldRating, SongRating newRating)
        {
            if (!IsEnabled || !_scrobbler.BaseScrobbler.HasSession) return;

            try
            {
                Log.O("LastFM, Rating: {0} - {1} - {2}", song.Artist, song.Title, newRating.ToString());
                Track track = null;

                //Get corrected track if there is one
                //Without getting the corrected track,
                //ratings will not work if there were corrections.
                if (song.Meta == null)
                {
                    track = QuerySongToTrack(song);
                }
                else
                    track = (Track)song.Meta;

                switch (newRating)
                {
                    case SongRating.love:
                        _scrobbler.UnBan(track);
                        _scrobbler.Love(track);
                        break;
                    case SongRating.ban:
                        _scrobbler.UnLove(track);
                        _scrobbler.Ban(track);
                        break;
                    case SongRating.none:
                        if(oldRating == SongRating.love)
                            _scrobbler.UnLove(track);
                        else if(oldRating == SongRating.ban)
                            _scrobbler.UnBan(track);
                        break;
                }

                if (_scrobbler.QueuedCount > 0) ProcessScrobbles();
            }
            catch (Exception ex)
            {
                Log.O("Last.FM Error!: " + ex.ToString());
            }
        }