aboutsummaryrefslogtreecommitdiffstats
path: root/src (follow)
Commit message (Collapse)AuthorAgeFilesLines
* log: use GLib loggingMax Kellermann2008-12-281-13/+13
|
* log: don't keep log file openMax Kellermann2008-12-281-14/+15
| | | | | | The log file is duped to STDOUT_FILENO and STDERR_FILENO. No need to keep another copy of it in out_fd all the time. We only need it once once in setup_log_output().
* decoder: terminate decoder thread before MPD cleanupMax Kellermann2008-12-284-2/+14
| | | | | | When MPD exits, it should manually free all resources in use, to allow easy memory leak debugging. Make the decoder thread terminate during that.
* log: support syslog()Max Kellermann2008-12-281-6/+103
| | | | Allow logging to syslog if log_file is configured to "syslog".
* log: moved code to log_init_file()Max Kellermann2008-12-281-15/+27
| | | | | Added log_init_file() and log_init_stdout(), preparing for other logging targets.
* log: merged initLog() and open_log_files().Max Kellermann2008-12-283-12/+3
| | | | | | The logging library currently has 3 constructor functions: initLog(), open_log_files(), setup_log_output(), called in this order. Merged the first two.
* log: moved code to parse_log_level()Max Kellermann2008-12-281-15/+17
|
* log: use the GLogLevelFlags typeMax Kellermann2008-12-281-3/+3
| | | | Declare log_threshold as GLogLevelFlags.
* log: don't manipulate the umaskMax Kellermann2008-12-281-9/+1
| | | | | | | | If the user wants the log files with a specific mode, he has to start MPD with the correct umask. Don't hard-code that. This fixes a bug: when log cycling failed, MPD would not restore the old umask.
* log: moved code to open_log_file()Max Kellermann2008-12-281-12/+19
| | | | Merged code from open_log_files() and cycle_log_files().
* log: deprecated "error_file" optionMax Kellermann2008-12-282-27/+3
| | | | | Removed the "error_file" option. There is only one log file now. If a user wants to see only the errors, he should configure a log_level.
* decoder: new plugin using modplug libraryViliam Mateicka2008-12-283-0/+210
|
* Add RVA2 tag support to MPDPauli Virtanen2008-12-281-0/+94
| | | | | | | | | | This patch adds RVA2 (relative volume adjustment) tag support to mpd, as a fallback if no replaygain tags are found. The code is almost directly from madplay (GPL). RVA2 tags are generated for example by the "normalize" utility. Updated by: Avuton Olrich <avuton@gmail.com>
* notify: use GLib lockingMax Kellermann2008-12-273-27/+15
| | | | | Use GLib locking (GMutex, GCond) instead of pthread because GLib is more portable, e.g. on mingw32.
* output_control: no static "notify" initializationMax Kellermann2008-12-272-1/+5
| | | | Don't use NOTIFY_INITIALIZER to initialize audio_output_client_notify.
* cmdline: fixed option_no_createdb usageViliam Mateicka2008-12-271-1/+1
|
* cmdline: use g_build_filename() for ~/.mpdconfMax Kellermann2008-12-271-20/+10
| | | | | Build the path with g_build_filename(). Also use g_get_home_dir() and g_file_test().
* cmdline: use GLib's option parserMax Kellermann2008-12-271-84/+75
| | | | | Eliminate duplicated code. The GLib code is much more mature than MPD's custom parser.
* cmdline: use gboolean instead of intMax Kellermann2008-12-272-15/+15
| | | | | Prepare for the migration to the GLib option parser, which uses gboolean for flags.
* moved command line parser to cmdline.cMax Kellermann2008-12-274-137/+200
|
* audiofile: don't close onput stream in libaudiofile destroy()Max Kellermann2008-12-271-2/+3
| | | | | | The input_stream object should only be closed by the MPD core (i.e. decoder_thread.c / decoder_run()). A decoder plugin which attempts to close it will result in a segmentation fault.
* disable archive API without pluginsMax Kellermann2008-12-275-5/+33
| | | | | When there are no archive plugins, we do not need the archive API at all. Drop all its overhead.
* Merge branch 'experimental' of git://git.musicpd.org/metyl/mpdMax Kellermann2008-12-2724-30/+1574
|\ | | | | | | | | | | | | | | Conflicts: configure.ac src/ls.h src/output/shout_plugin.c
| * shout: fixed bad error message printoutViliam Mateicka2008-12-231-3/+3
| |
| * archiveapi: archive plugin for ISO filesViliam Mateicka2008-12-163-0/+266
| |
| * archiveapi: archive plugin for ZIP filesViliam Mateicka2008-12-163-0/+203
| |
| * archiveapi: archive plugin for BZ2 filesViliam Mateicka2008-12-163-0/+317
| |
| * update: adding archive updating related codeViliam Mateicka2008-12-161-1/+64
| |
| * song: adding support for songs in archivesViliam Mateicka2008-12-163-1/+39
| |
| * ls: adding get_archive_by_suffix() functionViliam Mateicka2008-12-162-0/+19
| |
| * new archive api, input_archive streamViliam Mateicka2008-12-1611-2/+578
| |
| * utils: moving stringFoundInStringArray() from decoder into utilsViliam Mateicka2008-12-093-11/+14
| |
| * decoder: audiofile plugin using input stream instead of fileViliam Mateicka2008-12-031-15/+74
| |
* | playlist: fix stored playlist modifications with absolute pathsMax Kellermann2008-12-243-2/+20
| | | | | | | | | | | | | | | | When save_absolute_paths_in_playlists was enabled in mpd.conf, MPD broke all playlists when manipulated using the "playlistdelete" command. The reason was that map_directory_child_fs() was used, which doesn't accept slashes in the file name. Use the new map_uri_fs() function instead.
* | stored_playlist: fix integer overflow in length estimationMax Kellermann2008-12-241-1/+1
| | | | | | | | | | | | | | With a large maximum playlist length, the integer multiplication "playlist_max_length * MPD_PATH_MAX" may overflow. Change that to a division. This was not a dangerous bug, since it was only used for a quick estimate.
* | ffmpeg: case AV_NOPTS_VALUE to int64_tMax Kellermann2008-12-241-2/+2
| | | | | | | | | | The old code casted it to a 32 bit integer, which cut off bits. AVFormatContext.duration is a int64_t, so use this type.
* | ffmpeg: don't assign "0" to pointerMax Kellermann2008-12-241-1/+1
| | | | | | | | Use NULL instead. Found by sparse.
* | Makefile.am: fix sparse invocationMax Kellermann2008-12-241-1/+4
| | | | | | | | Added missing includes.
* | mp3: "tag" argument is unused when libid3tag is disabledMax Kellermann2008-12-241-2/+2
| | | | | | | | Add G_GNUC_UNUSED attributes.
* | listen: "port" argument is unused when TCP support is disabledMax Kellermann2008-12-241-1/+2
| | | | | | | | Add a G_GNUC_UNUSED attribute.
* | pcm_utils: check pcm_convert()==0Max Kellermann2008-12-243-5/+16
| | | | | | | | | | | | | | | | It is illegal to pass an empty audio buffer around. pcm_resample() sometimes seems to result in 0 samples, maybe related to libsamplerate. To work around that problem, add special checks after both pcm_convert() invocations. Removed the pcm_resample()==0 checks from pcm_convert().
* | client: always attempt to flush deferred buffersMax Kellermann2008-12-241-2/+11
| | | | | | | | | | | | | | | | | | | | | | When a response is very long (e.g. a large playlist > 100k songs), most of it will end up in the deferred buffers. Filling the deferred queue is very expensive currently, because a new buffer is allocated for every client_write() operation. This may lead to long delays, and the client might give up and disconnect meanwhile. This patch makes MPD attempt to flush the deferred queue as often as possible, to work around this problem. Due to the MPD 0.14 code freeze, we should not optimize the buffering code now.
* | shout: fixed bad error message printoutViliam Mateicka2008-12-231-2/+2
| |
* | Merge branch 'http_buffer_remove' of git://git.musicpd.org/avuton/mpdMax Kellermann2008-12-212-4/+0
|\ \
| * | Remove obsolete http_buffer* stuff that went away with the new curl backend.Avuton Olrich2008-12-202-4/+0
| | |
* | | log: map log level "SECURE" to GLib's "INFO"Max Kellermann2008-12-201-3/+3
|/ / | | | | | | | | | | Make "secure" a log level different from "default". "secure" should be right between "default" and "verbose". Map "default" to Glib's "MESSAGE" log level.
* | Remove useless statement.Emanuele Giaquinta2008-12-171-1/+0
| |
* | player_control: check if errored_song is setMax Kellermann2008-12-171-4/+14
| | | | | | | | | | | | getPlayerErrorStr() assumes that pc.errored_song is set when an error occured. Since the song may have been deleted meanwhile, add a NULL check.
* | playlist: clear pc.errored_song on deleteMax Kellermann2008-12-173-2/+23
| | | | | | | | | | When a (remote) song is deleted from the playlist, there may still be a reference to it in pc.errored_song. Clear this reference.
* | Remove useless computation. After the pthread_cond_wait loop there are at ↵Emanuele Giaquinta2008-12-171-2/+0
| | | | | | | | least MIN(od->bufferSize, size) free bytes in the buffer. Thus MIN(od->bufferSize - od->len, size) is always equal to MIN(od->bufferSize, size).