Remaining changes needed for building libpdb on Windows (except for adding the extra...
[ardour.git] / libs / pbd / pbd / controllable.h
index f61a375ba7704695de5403ee08e5d1403ec74bfd..d9cd21d28dc24e3a455f2d8801793686b2fed9b9 100644 (file)
@@ -25,7 +25,7 @@
 #include <map>
 
 #include "pbd/signals.h"
-#include <glibmm/thread.h>
+#include <glibmm/threads.h>
 
 #include "pbd/statefuldestructible.h"
 
@@ -43,27 +43,27 @@ class Controllable : public PBD::StatefulDestructible {
        Controllable (const std::string& name, Flag f = Flag (0));
        virtual ~Controllable() { Destroyed (this); }
 
-       /* We express Controllable values in one of two ways:
-        * 1. `UI' --- as used in some cases for the internal representation
-        *    of the UI.  This may be the same as `user', or may be something
-        *    like the natural log of frequency in order that sliders operate
-        *    in a logarithmic fashion.
-        * 2. `user' --- as passed to a plugin, and presented to the user.
+       /* We express Controllable values in one of three ways:
+        * 1. `user' --- as presented to the user (e.g. dB, Hz, etc.)
+        * 2. `interface' --- as used in some cases for the UI representation
+        * (in order to make controls behave logarithmically).
+        * 3. `internal' --- as passed to a processor, track, plugin, or whatever.
+        *
+        * Note that in some cases user and processor may be the same
+        * (and interface different) e.g. frequency, which is presented
+        * to the user and passed to the processor in linear terms, but
+        * which needs log scaling in the interface.
+        *
+        * In other cases, user and interface may be the same (and processor different)
+        * e.g. gain, which is presented to the user in log terms (dB)
+        * but passed to the processor as a linear quantity.
         */
 
-       /** Set `user' value */
+       /** Set `internal' value */
        virtual void set_value (double) = 0;
-       /** @return `user' value */
+       /** @return `internal' value */
        virtual double get_value (void) const = 0;
 
-       virtual double user_to_ui (double v) const {
-               return v;
-       }
-
-       virtual double ui_to_user (double v) const {
-               return v;
-       }
-
        PBD::Signal0<void> LearningFinished;
        static PBD::Signal3<void,PBD::Controllable*,int,int> CreateBinding;
        static PBD::Signal1<void,PBD::Controllable*> DeleteBinding;
@@ -105,7 +105,7 @@ class Controllable : public PBD::StatefulDestructible {
        static void remove (Controllable*);
 
        typedef std::set<PBD::Controllable*> Controllables;
-       static Glib::StaticRWLock registry_lock;
+        static Glib::Threads::RWLock registry_lock;
        static Controllables registry;
 };