From 989b1fe59b1abc747aeb590447cd246bece1498b Mon Sep 17 00:00:00 2001
From: ben <ben@b3059339-0415-0410-9bf9-f77b7e298cf2>
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){