X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Fardour%2Fsource.h;h=18de40771c9799bddec7668d6d8a7fe66ad908a5;hb=d854c5d93c71d3d607dd22970f1a06f078f350ea;hp=1728cdb4779ea36e6b1fceae87b21abaa6f1c940;hpb=82232f06ba3eea4a2b4342ad91fab552f4044402;p=ardour.git diff --git a/libs/ardour/ardour/source.h b/libs/ardour/ardour/source.h index 1728cdb477..18de40771c 100644 --- a/libs/ardour/ardour/source.h +++ b/libs/ardour/ardour/source.h @@ -1,5 +1,5 @@ /* - Copyright (C) 2000 Paul Davis + Copyright (C) 2000 Paul Davis This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by @@ -15,64 +15,119 @@ along with this program; if not, write to the Free Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA. - $Id$ */ #ifndef __ardour_source_h__ #define __ardour_source_h__ #include +#include -#include -#include +#include -#include +#include +#include "pbd/statefuldestructible.h" -#include -#include +#include "ardour/ardour.h" +#include "ardour/session_object.h" +#include "ardour/data_type.h" namespace ARDOUR { -class Source : public PBD::StatefulDestructible, public sigc::trackable, public boost::enable_shared_from_this +class Session; + +class LIBARDOUR_API Source : public SessionObject { public: - Source (std::string name, DataType type); - Source (const XMLNode&); - virtual ~Source (); + enum Flag { + Writable = 0x1, + CanRename = 0x2, + Broadcast = 0x4, + Removable = 0x8, + RemovableIfEmpty = 0x10, + RemoveAtDestroy = 0x20, + NoPeakFile = 0x40, + Destructive = 0x80, + Empty = 0x100, /* used for MIDI only */ + }; + + typedef Glib::Threads::Mutex::Lock Lock; + + Source (Session&, DataType type, const std::string& name, Flag flags=Flag(0)); + Source (Session&, const XMLNode&); - std::string name() const { return _name; } - int set_name (std::string str, bool destructive); + virtual ~Source (); DataType type() { return _type; } - const PBD::ID& id() const { return _id; } - time_t timestamp() const { return _timestamp; } void stamp (time_t when) { _timestamp = when; } - - /** @return the number of items in this source */ - jack_nframes_t length() const { return _length; } - virtual jack_nframes_t natural_position() const { return 0; } + virtual bool empty () const = 0; + virtual framecnt_t length (framepos_t pos) const = 0; + virtual void update_length (framecnt_t cnt) = 0; + + virtual framepos_t natural_position() const { return 0; } - virtual void mark_for_remove() = 0; - virtual void mark_streaming_write_completed () = 0; + void mark_for_remove(); + + virtual void mark_streaming_write_started (const Lock& lock) {} + virtual void mark_streaming_write_completed (const Lock& lock) = 0; + + virtual void session_saved() {} XMLNode& get_state (); - int set_state (const XMLNode&); - - static sigc::signal SourceCreated; + int set_state (const XMLNode&, int version); - protected: - void update_length (jack_nframes_t pos, jack_nframes_t cnt); + bool destructive() const { return (_flags & Destructive); } + bool writable () const; + virtual bool set_destructive (bool /*yn*/) { return false; } + virtual bool length_mutable() const { return false; } + + static PBD::Signal1 SourceCreated; - string _name; - DataType _type; - time_t _timestamp; - jack_nframes_t _length; + bool has_been_analysed() const; + virtual bool can_be_analysed() const { return false; } + virtual void set_been_analysed (bool yn); + virtual bool check_for_analysis_data_on_disk(); + + PBD::Signal0 AnalysisChanged; + + AnalysisFeatureList transients; + std::string get_transients_path() const; + int load_transients (const std::string&); + + 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::Threads::Mutex& mutex() { return _lock; } + Flag flags() const { return _flags; } + + virtual void inc_use_count (); + virtual void dec_use_count (); + int use_count() const { return g_atomic_int_get (const_cast(&_use_count)); } + bool used() const { return use_count() > 0; } + uint32_t level() const { return _level; } + + std::string ancestor_name() { return _ancestor_name.empty() ? name() : _ancestor_name; } + void set_ancestor_name(const std::string& name) { _ancestor_name = name; } + + protected: + DataType _type; + Flag _flags; + time_t _timestamp; + framepos_t _timeline_position; + bool _analysed; + 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 */ + std::string _ancestor_name; private: - PBD::ID _id; + void fix_writable_flags (); }; }