From 35eeabbfb577be2b0de06d06bb7bf2a190fdebbe Mon Sep 17 00:00:00 2001
From: Jean-Baptiste Kempf <jb@videolan.org>
Date: Fri, 3 Sep 2010 20:57:00 +0200
Subject: [PATCH] Qt: compressor UI, foolproofing the controls values

And translate strings
---
 .../gui/qt4/components/extended_panels.cpp    | 74 +++++++++----------
 1 file changed, 33 insertions(+), 41 deletions(-)

diff --git a/modules/gui/qt4/components/extended_panels.cpp b/modules/gui/qt4/components/extended_panels.cpp
index 47dadbd3cd..b1a37b7ade 100644
--- a/modules/gui/qt4/components/extended_panels.cpp
+++ b/modules/gui/qt4/components/extended_panels.cpp
@@ -1122,35 +1122,27 @@ void Equalizer::addCallbacks( aout_instance_t *p_aout )
 /**********************************************************************
  * Dynamic range compressor
  **********************************************************************/
-static const char *psz_comp_control_names[] =
-{
-    "compressor-rms-peak", "compressor-attack", "compressor-release",
-    "compressor-threshold", "compressor-ratio", "compressor-knee",
-    "compressor-makeup-gain"
-};
 
-static const char *psz_comp_control_descs[] =
+typedef struct
 {
-    "RMS/peak", "Attack",
-    "Release", "Threshold", "Ratio", "Knee\nradius", "Makeup\ngain"
-};
-
-static const char *psz_comp_control_units[] =
-{
-    "", " ms", " ms", " dB", ":1", " dB", " dB"
-};
-
-static const float f_comp_min_max_val_res_data[] =
+    const char *psz_name;
+    const char *psz_descs;
+    const char *psz_units;
+    const float f_min;      // min
+    const float f_max;      // max
+    const float f_value;    // value
+    const float f_resolution; // resolution
+} comp_controls_t;
+
+static const comp_controls_t controls[] =
 {
-    // min     max   value  resolution
-    //----  ------  ------  ----------
-      0.0f,   1.0f,   0.00f, 0.001f,  // RMS/peak
-      1.5f, 400.0f,  25.00f, 0.100f,  // Attack
-      2.0f, 800.0f, 100.00f, 0.100f,  // Release
-    -30.0f,   0.0f, -11.00f, 0.010f,  // Threshold
-      1.0f,  20.0f,   8.00f, 0.010f,  // Ratio
-      1.0f,  10.0f,   2.50f, 0.010f,  // Knee radius
-      0.0f,  24.0f,   7.00f, 0.010f   // Makeup gain
+    { "compressor-rms-peak",    _("RMS/peak"),       "",       0.0f,   1.0f,   0.00f, 0.001f },
+    { "compressor-attack",      _("Attack"),       _(" ms"),   1.5f, 400.0f,  25.00f, 0.100f },
+    { "compressor-release",     _("Release"),      _(" ms"),   2.0f, 800.0f, 100.00f, 0.100f },
+    { "compressor-threshold",   _("Threshold"),    _(" dB"), -30.0f,   0.0f, -11.00f, 0.010f },
+    { "compressor-ratio",       _("Ratio"),          ":1",     1.0f,  20.0f,   8.00f, 0.010f },
+    { "compressor-knee",        _("Knee\nradius"), _(" dB"),   1.0f,  10.0f,   2.50f, 0.010f },
+    { "compressor-makeup-gain", _("Makeup\ngain"), _(" dB"),   0.0f,  24.0f,   7.00f, 0.010f },
 };
 
 Compressor::Compressor( intf_thread_t *_p_intf, QWidget *_parent ) :
@@ -1169,19 +1161,19 @@ Compressor::Compressor( intf_thread_t *_p_intf, QWidget *_parent ) :
     {
         compCtrl[i] = new QSlider( Qt::Vertical );
 
-        const int i_min = (int)( f_comp_min_max_val_res_data[4 * i + 0]
-                               / f_comp_min_max_val_res_data[4 * i + 3] );
-        const int i_max = (int)( f_comp_min_max_val_res_data[4 * i + 1]
-                               / f_comp_min_max_val_res_data[4 * i + 3] );
-        const int i_val = (int)( f_comp_min_max_val_res_data[4 * i + 2]
-                               / f_comp_min_max_val_res_data[4 * i + 3] );
+        const int i_min = (int)( controls[i].f_min
+                               / controls[i].f_resolution );
+        const int i_max = (int)( controls[i].f_max
+                               / controls[i].f_resolution );
+        const int i_val = (int)( controls[i].f_value
+                               / controls[i].f_resolution );
 
         compCtrl[i]->setMinimum( i_min );
         compCtrl[i]->setMaximum( i_max );
         compCtrl[i]->setValue(   i_val );
-        oldControlVars[i] = f_comp_min_max_val_res_data[4 * i + 2];
+        oldControlVars[i] = controls[i].f_value;
         CONNECT( compCtrl[i], valueChanged( int ), this, setInitValues() );
-        ctrl_texts[i] = new QLabel( qtr( psz_comp_control_descs[i] )
+        ctrl_texts[i] = new QLabel( qtr( controls[i].psz_descs )
                                   + qtr( "\n" ) );
         ctrl_texts[i]->setFont( smallFont );
         ctrl_texts[i]->setAlignment( Qt::AlignHCenter );
@@ -1205,7 +1197,7 @@ Compressor::Compressor( intf_thread_t *_p_intf, QWidget *_parent ) :
         for( int i = 0; i < NUM_CP_CTRL; i++ )
         {
             controlVars[i] = var_GetFloat( p_aout,
-                                           psz_comp_control_names[i] );
+                                           controls[i].psz_name );
         }
         vlc_object_release( p_aout );
     }
@@ -1215,7 +1207,7 @@ Compressor::Compressor( intf_thread_t *_p_intf, QWidget *_parent ) :
         for( int i = 0; i < NUM_CP_CTRL; i++ )
         {
             controlVars[i] = config_GetFloat( p_intf,
-                                              psz_comp_control_names[i] );
+                                              controls[i].psz_name );
         }
     }
     if( psz_af && strstr( psz_af, "compressor" ) != NULL )
@@ -1252,7 +1244,7 @@ void Compressor::updateSliders( float * controlVars )
         if( oldControlVars[i] != controlVars[i] )
         {
             const int i_val = (int)( controlVars[i]
-                                   / f_comp_min_max_val_res_data[4 * i + 3] );
+                                   / controls[i].f_resolution );
             compCtrl[i]->setValue( i_val );
         }
     }
@@ -1270,16 +1262,16 @@ void Compressor::setValues( float * controlVars )
     for( int i = 0 ; i < NUM_CP_CTRL ; i++ )
     {
         float f = (float)( compCtrl[i]->value() )
-                * ( f_comp_min_max_val_res_data[4 * i + 3] );
+                * ( controls[i].f_resolution );
         ctrl_readout[i]->setText( QString::number( f, 'f', 1 )
-                                + qtr( psz_comp_control_units[i] ) );
+                                + qtr( controls[i].psz_units ) );
         if( oldControlVars[i] != f )
         {
             if( p_aout )
             {
-                var_SetFloat( p_aout, psz_comp_control_names[i], f );
+                var_SetFloat( p_aout, controls[i].psz_name, f );
             }
-            config_PutFloat( p_intf, psz_comp_control_names[i], f );
+            config_PutFloat( p_intf, controls[i].psz_name, f );
             oldControlVars[i] = f;
         }
     }
-- 
2.25.4