/* * Copyright 2008-2013, ETH Zürich, Samuel Welten, Michael Kuhn, Tobias Langner, * Sandro Affentranger, Lukas Bossard, Michael Grob, Rahul Jain, * Dominic Langenegger, Sonia Mayor Alonso, Roger Odermatt, Tobias Schlueter, * Yannick Stucki, Sebastian Wendland, Samuel Zehnder, Samuel Zihlmann, * Samuel Zweifel * * This file is part of Jukefox. * * Jukefox is free software: you can redistribute it and/or modify it under the * terms of the GNU General Public License as published by the Free Software * Foundation, either version 3 of the License, or any later version. Jukefox is * distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; * without even the implied warranty of MERCHANTABILITY or FITNESS FOR A * PARTICULAR PURPOSE. See the GNU General Public License for more details. * * You should have received a copy of the GNU General Public License along with * Jukefox. If not, see <http://www.gnu.org/licenses/>. */ package ch.ethz.dcg.jukefox.controller.player.playlistmanager; import ch.ethz.dcg.jukefox.model.collection.BaseAlbum; import ch.ethz.dcg.jukefox.model.collection.BaseArtist; import ch.ethz.dcg.jukefox.model.collection.IReadOnlyPlaylist; import ch.ethz.dcg.jukefox.model.collection.PlaylistSong; import ch.ethz.dcg.jukefox.model.commons.EmptyPlaylistException; import ch.ethz.dcg.jukefox.playmode.IPlayMode; /** * The readonly part of the playlist manager contains the registration of * listeners. */ public interface IReadOnlyPlaylistManager { /** * Returns a readonly version of the current playlist. */ IReadOnlyPlaylist getCurrentPlaylist(); /** * Returns the current song. */ PlaylistSong<BaseArtist, BaseAlbum> getCurrentSong() throws EmptyPlaylistException; /** * Returns the the playmode that is used in the current playlist. */ IPlayMode getPlayMode(); /** * Returns the current position, i.e. the song which is being played (or is * paused). */ int getCurrentSongIndex() throws EmptyPlaylistException; /** * Returns true if the current song is at the end of the playlist or if the * playlist is empty. */ boolean isPlaylistEmptyOrAtEnd(); }