diff options
author | Robin Gareus <robin@gareus.org> | 2013-08-03 21:35:19 +0200 |
---|---|---|
committer | Robin Gareus <robin@gareus.org> | 2013-08-03 21:35:19 +0200 |
commit | 91e0e0f9f83496fd5ec8f40844ba02df61de37f4 (patch) | |
tree | bee80a49e90f3f94b49c51ec746ad7c7905f8857 /libs/ardour/audio_track.cc | |
parent | 43ae996b3a18ecad15f6fe872c4194d23b2200cf (diff) |
advance track's play-position even if processing is locked
fixes
* http://tracker.ardour.org/view.php?id=5628
* http://tracker.ardour.org/view.php?id=5561
Diffstat (limited to 'libs/ardour/audio_track.cc')
-rw-r--r-- | libs/ardour/audio_track.cc | 6 |
1 files changed, 6 insertions, 0 deletions
diff --git a/libs/ardour/audio_track.cc b/libs/ardour/audio_track.cc index 6de833aeb4..0530dbfce9 100644 --- a/libs/ardour/audio_track.cc +++ b/libs/ardour/audio_track.cc @@ -313,6 +313,12 @@ AudioTrack::roll (pframes_t nframes, framepos_t start_frame, framepos_t end_fram Glib::Threads::RWLock::ReaderLock lm (_processor_lock, Glib::Threads::TRY_LOCK); if (!lm.locked()) { + boost::shared_ptr<AudioDiskstream> diskstream = audio_diskstream(); + framecnt_t playback_distance = diskstream->calculate_playback_distance(nframes); + if (can_internal_playback_seek(llabs(playback_distance))) { + /* TODO should declick */ + internal_playback_seek(playback_distance); + } return 0; } |