2 Copyright (C) 2000 Paul Davis
4 This program is free software; you can redistribute it and/or modify
5 it under the terms of the GNU General Public License as published by
6 the Free Software Foundation; either version 2 of the License, or
7 (at your option) any later version.
9 This program is distributed in the hope that it will be useful,
10 but WITHOUT ANY WARRANTY; without even the implied warranty of
11 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
12 GNU General Public License for more details.
14 You should have received a copy of the GNU General Public License
15 along with this program; if not, write to the Free Software
16 Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
31 #include <glibmm/thread.h>
32 #include <pbd/xml++.h>
33 #include <pbd/pthread_utils.h>
35 #include <ardour/source.h>
36 #include <ardour/playlist.h>
43 using namespace ARDOUR;
45 Source::Source (Session& s, string name, DataType type)
49 assert(_name.find("/") == string::npos);
57 Source::Source (Session& s, const XMLNode& node)
59 , _type(DataType::AUDIO)
65 if (set_state (node) || _type == DataType::NIL) {
66 throw failed_constructor();
68 assert(_name.find("/") == string::npos);
79 XMLNode *node = new XMLNode ("Source");
82 node->add_property ("name", _name);
83 node->add_property ("type", _type.to_string());
84 _id.print (buf, sizeof (buf));
85 node->add_property ("id", buf);
87 if (_timestamp != 0) {
88 snprintf (buf, sizeof (buf), "%ld", _timestamp);
89 node->add_property ("timestamp", buf);
96 Source::set_state (const XMLNode& node)
98 const XMLProperty* prop;
100 if ((prop = node.property ("name")) != 0) {
101 _name = prop->value();
106 if ((prop = node.property ("id")) != 0) {
107 _id = prop->value ();
112 if ((prop = node.property ("type")) != 0) {
113 _type = DataType(prop->value());
116 if ((prop = node.property ("timestamp")) != 0) {
117 sscanf (prop->value().c_str(), "%ld", &_timestamp);
119 assert(_name.find("/") == string::npos);
125 Source::update_length (jack_nframes_t pos, jack_nframes_t cnt)
127 if (pos + cnt > _length) {
133 Source::add_playlist (boost::shared_ptr<Playlist> pl)
135 std::pair<PlaylistMap::iterator,bool> res;
136 std::pair<boost::shared_ptr<Playlist>, uint32_t> newpair (pl, 1);
137 Glib::Mutex::Lock lm (playlist_lock);
139 res = _playlists.insert (newpair);
142 /* it already existed, bump count */
146 pl->GoingAway.connect (bind (mem_fun (*this, &Source::remove_playlist), boost::weak_ptr<Playlist> (pl)));
150 Source::remove_playlist (boost::weak_ptr<Playlist> wpl)
152 boost::shared_ptr<Playlist> pl (wpl.lock());
158 PlaylistMap::iterator x;
159 Glib::Mutex::Lock lm (playlist_lock);
161 if ((x = _playlists.find (pl)) != _playlists.end()) {
165 _playlists.erase (x);
171 Source::used () const
173 return _playlists.size();