convert from Glib:: to Glib::Threads for all thread-related API
[ardour.git] / libs / ardour / ardour / source.h
index 16a762eb9459b884a53432b54fa5865c3d3bbf68..a3b5fd817a14f9d4b308c81d4b4c027a8cefa12f 100644 (file)
@@ -23,7 +23,7 @@
 #include <string>
 #include <set>
 
-#include <glib.h>
+#include <glibmm/threads.h>
 
 #include <boost/utility.hpp>
 #include "pbd/statefuldestructible.h"
@@ -60,10 +60,9 @@ class Source : public SessionObject
        time_t timestamp() const { return _timestamp; }
        void stamp (time_t when) { _timestamp = when; }
 
+       virtual bool       empty () const = 0;
        virtual framecnt_t length (framepos_t pos) const = 0;
-       virtual void       update_length (framepos_t pos, framecnt_t cnt) = 0;
-
-       virtual const Glib::ustring& path() const = 0;
+       virtual void       update_length (framecnt_t cnt) = 0;
 
        virtual framepos_t natural_position() const { return 0; }
 
@@ -78,12 +77,11 @@ class Source : public SessionObject
        int set_state (const XMLNode&, int version);
 
        bool         destructive() const       { return (_flags & Destructive); }
-       bool         writable () const         { return (_flags & Writable); }
+       bool         writable () const;
        virtual bool set_destructive (bool /*yn*/) { return false; }
        virtual bool length_mutable() const    { return false; }
 
        static PBD::Signal1<void,Source*>             SourceCreated;
-       PBD::Signal1<void,boost::shared_ptr<Source> > Switched;
 
        bool has_been_analysed() const;
        virtual bool can_be_analysed() const { return false; }
@@ -96,33 +94,30 @@ class Source : public SessionObject
        std::string get_transients_path() const;
        int load_transients (const std::string&);
 
-       sframes_t    timeline_position() const { return _timeline_position; }
-       virtual void set_timeline_position (sframes_t pos);
+       framepos_t    timeline_position() const { return _timeline_position; }
+       virtual void set_timeline_position (framepos_t pos);
 
        void set_allow_remove_if_empty (bool yn);
 
-       Glib::Mutex& mutex()       { return _lock; }
+        Glib::Threads::Mutex& mutex() { return _lock; }
        Flag         flags() const { return _flags; }
 
-        void inc_use_count () { g_atomic_int_inc (&_use_count); }
-        void dec_use_count () { 
-                gint oldval = g_atomic_int_exchange_and_add (&_use_count, -1);
-                assert (oldval > 0);
-        }
-
-        int  use_count() const { return g_atomic_int_get (&_use_count); }
-        bool used() const { return use_count() > 0; }
+       virtual void inc_use_count ();
+       virtual void dec_use_count ();
+       int  use_count() const { return g_atomic_int_get (&_use_count); }
+       bool used() const { return use_count() > 0; }
+       uint32_t level() const { return _level; }
 
   protected:
        DataType            _type;
        Flag                _flags;
        time_t              _timestamp;
-       sframes_t           _timeline_position;
+       framepos_t          _timeline_position;
        bool                _analysed;
-       mutable Glib::Mutex _lock;
-       mutable Glib::Mutex _analysis_lock;
-       Glib::Mutex         _playlist_lock;
-        gint                _use_count; /* atomic */
+        mutable Glib::Threads::Mutex _lock;
+        mutable Glib::Threads::Mutex _analysis_lock;
+       gint                _use_count; /* atomic */
+       uint32_t            _level; /* how deeply nested is this source w.r.t a disk file */
 
   private:
        void fix_writable_flags ();