X-Git-Url: https://main.carlh.net/gitweb/?a=blobdiff_plain;f=libs%2Fardour%2Fardour%2Fbutler.h;h=44ce7848990f534b3a7261a5997d1415a9a737c7;hb=25a4cae8ad30dc090f2313600456d759ab7e81a5;hp=efdaad1621a12dc88e0b658519424303c08946eb;hpb=86343b6c15a3a43f082802484d2bc813d34db821;p=ardour.git diff --git a/libs/ardour/ardour/butler.h b/libs/ardour/ardour/butler.h index efdaad1621..44ce784899 100644 --- a/libs/ardour/ardour/butler.h +++ b/libs/ardour/ardour/butler.h @@ -24,10 +24,7 @@ #include -#ifdef PLATFORM_WINDOWS -#include "pbd/glib_semaphore.h" -#endif - +#include "pbd/crossthread.h" #include "pbd/ringbuffer.h" #include "pbd/pool.h" #include "ardour/libardour_visibility.h" @@ -60,10 +57,14 @@ class LIBARDOUR_API Butler : public SessionHandleRef bool transport_work_requested() const; void drop_references (); + void map_parameters (); + framecnt_t audio_diskstream_capture_buffer_size() const { return audio_dstream_capture_buffer_size; } framecnt_t audio_diskstream_playback_buffer_size() const { return audio_dstream_playback_buffer_size; } uint32_t midi_diskstream_buffer_size() const { return midi_dstream_buffer_size; } + bool flush_tracks_to_disk_after_locate (boost::shared_ptr, uint32_t& errors); + static void* _thread_work(void *arg); void* thread_work(); @@ -76,6 +77,7 @@ class LIBARDOUR_API Butler : public SessionHandleRef }; pthread_t thread; + bool have_thread; Glib::Threads::Mutex request_lock; Glib::Threads::Cond paused; bool should_run; @@ -85,38 +87,19 @@ class LIBARDOUR_API Butler : public SessionHandleRef uint32_t midi_dstream_buffer_size; RingBuffer pool_trash; -#ifdef PLATFORM_WINDOWS - PBD::atomic_counter m_request_state; - PBD::GlibSemaphore m_request_sem; -#else - int request_pipe[2]; -#endif - private: void empty_pool_trash (); void config_changed (std::string); -#ifndef PLATFORM_WINDOWS - int setup_request_pipe (); -#endif - - /** - * return true if there are requests to be processed - */ - bool wait_for_requests (); - - /** - * Remove request from butler request queue - * - * return true if there was another request and req is valid - */ - bool dequeue_request (Request::Type& req); + bool flush_tracks_to_disk_normal (boost::shared_ptr, uint32_t& errors); /** * Add request to butler thread request queue */ void queue_request (Request::Type r); + CrossThreadChannel _xthread; + }; } // namespace ARDOUR