summaryrefslogtreecommitdiff
path: root/libs/pbd/base_ui.cc
diff options
context:
space:
mode:
authorPaul Davis <paul@linuxaudiosystems.com>2014-12-03 21:11:02 -0500
committerPaul Davis <paul@linuxaudiosystems.com>2014-12-03 21:11:02 -0500
commit7ab3da66b530daa0da099794b2e8a8b2d6236034 (patch)
treeba82a8e5ce0e0dee1b4f78f1a497f9985a8efe44 /libs/pbd/base_ui.cc
parentd3e2de8b4e006ac652b004cb44b66afa9f6584f6 (diff)
fix up BaseUI to use crossthreadchannel on all platforms
Diffstat (limited to 'libs/pbd/base_ui.cc')
-rw-r--r--libs/pbd/base_ui.cc40
1 files changed, 2 insertions, 38 deletions
diff --git a/libs/pbd/base_ui.cc b/libs/pbd/base_ui.cc
index 3a4257ebdd..99d9fbff5b 100644
--- a/libs/pbd/base_ui.cc
+++ b/libs/pbd/base_ui.cc
@@ -51,15 +51,10 @@ BaseUI::BaseUI (const string& str)
: m_context(MainContext::get_default())
, run_loop_thread (0)
, _name (str)
-#ifndef PLATFORM_WINDOWS
, request_channel (true)
-#endif
{
base_ui_instance = this;
-
-#ifndef PLATFORM_WINDOWS
- request_channel.ios()->connect (sigc::mem_fun (*this, &BaseUI::request_handler));
-#endif
+ request_channel.set_receive_handler (sigc::mem_fun (*this, &BaseUI::request_handler));
/* derived class must set _ok */
}
@@ -124,24 +119,6 @@ BaseUI::quit ()
}
}
-#ifdef PLATFORM_WINDOWS
-gboolean
-BaseUI::_request_handler (gpointer data)
-{
- BaseUI* ui = static_cast<BaseUI*>(data);
- return ui->request_handler ();
-}
-
-bool
-BaseUI::request_handler ()
-{
- DEBUG_TRACE (DEBUG::EventLoop, "BaseUI::request_handler\n");
- handle_ui_requests ();
- // keep calling indefinitely at the timeout interval
- return true;
-}
-
-#else
bool
BaseUI::request_handler (Glib::IOCondition ioc)
{
@@ -166,17 +143,12 @@ BaseUI::request_handler (Glib::IOCondition ioc)
return true;
}
-#endif
void
BaseUI::signal_new_request ()
{
DEBUG_TRACE (DEBUG::EventLoop, "BaseUI::signal_new_request\n");
-#ifdef PLATFORM_WINDOWS
- // handled in timeout, how to signal...?
-#else
request_channel.wakeup ();
-#endif
}
/**
@@ -186,13 +158,5 @@ void
BaseUI::attach_request_source ()
{
DEBUG_TRACE (DEBUG::EventLoop, "BaseUI::attach_request_source\n");
-#ifdef PLATFORM_WINDOWS
- GSource* request_source = g_timeout_source_new(200);
- g_source_set_callback (request_source, &BaseUI::_request_handler, this, NULL);
- g_source_attach (request_source, m_context->gobj());
-#else
- request_channel.ios()->attach (m_context);
- /* glibmm hack - drop the refptr to the IOSource now before it can hurt */
- request_channel.drop_ios ();
-#endif
+ request_channel.attach (m_context);
}