From 989b1fe59b1abc747aeb590447cd246bece1498b Mon Sep 17 00:00:00 2001 From: ben Date: Thu, 10 Jan 2008 23:32:50 +0000 Subject: [PATCH] allow profile loading per audio/video output git-svn-id: svn://svn.mplayerhq.hu/mplayer/trunk@25669 b3059339-0415-0410-9bf9-f77b7e298cf2 --- mplayer.c | 22 ++++++++++++++++++++++ 1 file changed, 22 insertions(+) diff --git a/mplayer.c b/mplayer.c index 06ea4fed3a..fc842e44c3 100644 --- a/mplayer.c +++ b/mplayer.c @@ -882,6 +882,23 @@ static void load_per_extension_config (m_config_t* conf, const char *const file) } } +#define PROFILE_CFG_VO "vo." +#define PROFILE_CFG_AO "ao." + +static void load_per_output_config (m_config_t* conf, char *cfg, char *out) +{ + char profile[strlen (cfg) + strlen (out) + 1]; + m_profile_t *p; + + sprintf (profile, "%s%s", cfg, out); + p = m_config_get_profile (conf, profile); + if (p) + { + mp_msg(MSGT_CPLAYER,MSGL_INFO,MSGTR_LoadingExtensionProfile, profile); + m_config_set_profile(conf,p); + } +} + static void load_per_file_config (m_config_t* conf, const char *const file) { char *confpath; @@ -2747,6 +2764,11 @@ play_next_file: load_per_file_config (mconfig, filename); } + if (video_driver_list) + load_per_output_config (mconfig, PROFILE_CFG_VO, video_driver_list[0]); + if (audio_driver_list) + load_per_output_config (mconfig, PROFILE_CFG_AO, audio_driver_list[0]); + // We must enable getch2 here to be able to interrupt network connection // or cache filling if(!noconsolecontrols && !slave_mode){