aboutsummaryrefslogtreecommitdiffstats
path: root/src (follow)
Commit message (Collapse)AuthorAgeFilesLines
* state_file: use g_timeout_add_seconds()Max Kellermann2009-10-131-2/+3
|
* configure.ac: require GLib 2.16Max Kellermann2009-10-135-29/+0
| | | | | | | Accidently, MPD has been using several GLib 2.16 functions for a while, and nobody noticed yet. To simplify the code base, let's bump the minimum GLib version for MPD to 2.16. That version is old enough, and it's reasonable to expect users to have it.
* playlist_plugin: new plugin API for playlist parsersMax Kellermann2009-10-125-0/+451
| | | | | | | | Based on this API, we will add parsers for EXTM3U, PLS, ASX, last.fm radio and others. There is no integration into the MPD core yet. Right now, we have a command line test program. This is work in progress.
* text_input_stream: input_stream wrapper for reading text filesMax Kellermann2009-10-122-0/+140
|
* song: moved code to song_update.cMax Kellermann2009-10-122-147/+172
| | | | | Moved all the code which depends on the decoder plugins to a separate source. That allows leaner test programs.
* decoder_thread: removed redundant NULL assignmentsMax Kellermann2009-10-111-2/+1
| | | | | The while() clause resets the "plugin" variable. We don't need to reset it at the end of the loop body.
* input_stream: use "goffset" instead of "off_t"Max Kellermann2009-10-1110-25/+25
| | | | | | | | | | | | The "off_t" type may change when you enable or disable large file support on 32 bit platforms. This caused severe ABI problems within MPD when we enabled LFS for the first time: two sources included config.h and sys/types.h in different order, and had different off_t sizes - leading to memory corruption because of ABI incompatibility. This patch attempts to get rid of all public "off_t" uses: it removes "off_t" from the input_stream ABI/API, and switches to GLib's 64 bit "goffset" type. This may hurt 32 bit embedded platforms a tiny bit, but that's not even measurable.
* Merge branch 'v0.15.x'Max Kellermann2009-10-114-54/+69
|\ | | | | | | | | | | | | Conflicts: NEWS configure.ac
| * riff, aiff: fixed "limited range" gcc warningMax Kellermann2009-10-112-10/+10
| | | | | | | | | | | | On 32 bit systems with large file support enabled (i.e. "sizeof(off_t) > sizeof(size_t)") gcc emits a warning because a size_t cast to off_t can never become negative.
| * decoder_thread: change the fallback decoder name to "mad"Max Kellermann2009-10-111-1/+1
| | | | | | | | | | | | When there is no Content-Type response header, try the "mad" decoder plugin. It uesd to be named "mp3", and we forgot to change the fallback name in decoder_thread.c.
| * input/curl: don't abort if a packet has only metadataMax Kellermann2009-10-111-20/+22
| | | | | | | | | | | | | | | | | | When a received chunk of data has only icy-metadata, there was no usable data left for input_curl_read() to return, and thus it returned 0 bytes. "0" however is a special value for "end of file" or "error". This patch makes input_curl_read() read more data from the socket, until the read request can be fulfilled (or until there's really EOF).
| * input/curl: moved code to fill_buffer()Max Kellermann2009-10-111-27/+40
| |
* | player_thread: get "elapsed" from audio outputsMax Kellermann2009-10-085-4/+42
| | | | | | | | | | | | | | | | | | | | | | | | | | | | | | Tracking the "elapsed" time from the chunks which we have sent to the output pipe is very imprecise: since we have implemented the music pipe, we're sending large number of chunks at once, giving the "elapsed" time stamp a resolution of usually more than a second. This patch changes the source of this information to the outputs. If a chunk has been played by all outputs, the "elapsed" time stamp is updated. The new command PLAYER_COMMAND_REFRESH makes the player thread update its status information: it tells the outputs to update the chunk time stamp. After that, player_control.elapsed_time is current.
* | player_thread: always clear player_control.next_song on returnMax Kellermann2009-10-081-5/+3
| | | | | | | | | | | | pc.next_song might be non-NULL even if player.queued==true: when the decoder has started decoding the next song, but the result hasn't been read yet.
* | player_control: eliminate PLAYER_COMMAND_PLAYMax Kellermann2009-10-083-5/+1
| | | | | | | | | | Sending PLAYER_COMMAND_STOP followed by PLAYER_COMMAND_QUEUE does the same. PLAYER_COMMAND_PLAY is redundant.
* | player_control: added several assertions on pc.next_song==NULLMax Kellermann2009-10-081-0/+6
| | | | | | | | | | After some of the commands, the player thread must have reset the pc.next_song attribute.
* | player_control: no CamelCaseMax Kellermann2009-10-089-62/+79
| |
* | player_control: clear errored_song in clearPlayerError()Max Kellermann2009-10-081-1/+2
| | | | | | | | | | Without the player error code, it errored_song variable is not used, and should be cleared, to avoid invalid access in pc_song_deleted().
* | player_control: bundle "get" functions in pc_get_status()Max Kellermann2009-10-084-34/+46
| | | | | | | | | | | | The new player_status struct replaces a bunch of playerGetX() functions. When we add proper locking to the player_control struct, we will only need to lock once for the "status" command.
* | player_control: allocate getPlayerErrorStr() resultMax Kellermann2009-10-083-21/+23
| | | | | | | | This lets us eliminate the static fixed-size buffer.
* | playlist_control: "previous" really plays the previous songMax Kellermann2009-10-083-39/+12
| | | | | | | | | | | | | | No more CD player emulation. The current behaviour of "previous" is difficult for a client to predict, because it does not definitely know the current position within the song. If a client wants to restart the current song, it can always send "playid".
* | input_stream: include config.h for AC_SYS_LARGEFILE macrosMax Kellermann2009-10-081-0/+2
| | | | | | | | | | AC_SYS_LARGEFILE defines macros for config.h. If we don't include config.h, we don't get large file support.
* | decoder_api: document all function parametersMax Kellermann2009-10-081-27/+73
| |
* | state_file: save only if something has changedMax Kellermann2009-10-088-0/+86
| | | | | | | | | | | | If nothing has changed since the last save, don't save the state file. Saving will spin up the hard drive, which is undesirable on hosts where MPD is idling in background.
* | output_state: no CamelCaseMax Kellermann2009-10-063-6/+6
| |
* | Merged release 0.15.4 from branch 'v0.15.x'Max Kellermann2009-10-035-5/+48
|\| | | | | | | | | | | Conflicts: NEWS configure.ac
| * decoder/ffmpeg: use the "artist" tag if "author" is not presentMax Kellermann2009-09-301-2/+5
| | | | | | | | | | | | | | Usually, we read our "artist" tag from ffmpeg's "author" tag. In some cases however (e.g. APE), this tag is named "artist". This patch implements a fallback: if no "author" is found, MPD tries to use "artist".
| * decoder/faad: skip assertion failure on large ID3 tagsMax Kellermann2009-09-301-2/+6
| | | | | | | | | | | | When the ID3 tag in an AAC file is larger than the current buffer, the function decoder_buffer_consume() aborts. By using the new function decoder_buffer_skip() instead, we can safely skip the ID3 tag.
| * decoder_buffer: added function decoder_buffer_skip()Max Kellermann2009-09-302-0/+36
| |
| * input/mms: fix G_LOG_DOMAIN valueSerge Ziryukin2009-09-201-1/+1
| |
| * output/osx: fix the OS X 10.6 buildPatrik Weiskircher2009-09-201-0/+1
| | | | | | | | Include CoreServices/CoreServices.h.
* | command: range support for "delete"Max Kellermann2009-09-303-3/+38
| |
* | playlist_edit: moved code to playlist_delete_internal()Max Kellermann2009-09-301-10/+19
| |
* | Make the sidplay decoder filter configurable.Tony2009-09-281-1/+5
| |
* | automatically update the database with Linux inotifyMax Kellermann2009-09-257-0/+792
| | | | | | | | | | | | This patch implements a light-weight inotify library, and watches all directories below the music directory. It updates all directories where files changed after a delay of 5 seconds.
* | update: added missing stdbool.h includeMax Kellermann2009-09-251-0/+2
| |
* | command: relax requirements for unquoted wordsMax Kellermann2009-09-253-6/+75
| | | | | | | | | | | | Allow most printable characters in unquoted words. The tokenizer patch introduced very strict requirements for command parameters - those were undocumented, and we're reverting the strictness now.
* | command: added command "rescan"Max Kellermann2009-09-247-27/+67
| | | | | | | | | | "rescan" is the same as "update", but it discards existing songs in the database.
* | configure.ac: rename HAVE_CURL to ENABLE_CURLMax Kellermann2009-09-242-3/+3
| |
* | conf: handle fatal errors with GErrorMax Kellermann2009-09-243-54/+115
| | | | | | | | | | | | | | Don't call g_error(), which will abort the process and dump core. This patch does not affect all the config_get_X() functions. These need some more refactoring.
* | conf: splitted function config_param_free()Max Kellermann2009-09-241-4/+11
| |
* | cmdline: handle fatal errors with GErrorMax Kellermann2009-09-243-5/+30
| | | | | | | | Don't call g_error(), which will abort the process and dump core.
* | listen: handle fatal errors with GErrorMax Kellermann2009-09-243-10/+29
| | | | | | | | Don't call g_error(), which will abort the process and dump core.
* | update: splitted update.c into several sourcesMax Kellermann2009-09-245-770/+987
| |
* | update: pass const string to update_enqueue()Max Kellermann2009-09-243-14/+20
| | | | | | | | | | Duplicate the path string within update.c, do not expect an allocated string as parameter.
* | update: renamed directory_update_init() to update_enqueue()Max Kellermann2009-09-244-4/+4
| |
* | decoder/sidplay: free songlength data blob in error handlerMax Kellermann2009-09-241-3/+4
| | | | | | | | | | When parsing the songlength database fails, the code forgot to free the memory allocated by the raw file data.
* | decoder/sidplay: moved code to sidplay_load_songlength_db()Max Kellermann2009-09-241-29/+36
| |
* | decoder/sidplay: free GError objectsMax Kellermann2009-09-241-0/+2
| | | | | | | | | | The caller is responsible fro freeing GError objects. That g_error_free() call was missing in two places.
* | decoder/sidplay: pass GError** to g_file_get_contents()Max Kellermann2009-09-241-1/+2
| | | | | | | | | | The error handler dereferences GError*, but did not retrieve that object from g_file_get_contents().