summaryrefslogtreecommitdiffstats
path: root/Source/WebKit2/Platform/gtk
diff options
context:
space:
mode:
Diffstat (limited to 'Source/WebKit2/Platform/gtk')
-rw-r--r--Source/WebKit2/Platform/gtk/RunLoopGtk.cpp135
-rw-r--r--Source/WebKit2/Platform/gtk/SharedMemoryGtk.cpp84
-rw-r--r--Source/WebKit2/Platform/gtk/WorkQueueGtk.cpp202
3 files changed, 421 insertions, 0 deletions
diff --git a/Source/WebKit2/Platform/gtk/RunLoopGtk.cpp b/Source/WebKit2/Platform/gtk/RunLoopGtk.cpp
new file mode 100644
index 0000000..2c183fa
--- /dev/null
+++ b/Source/WebKit2/Platform/gtk/RunLoopGtk.cpp
@@ -0,0 +1,135 @@
+/*
+ * Copyright (C) 2010 Apple Inc. All rights reserved.
+ * Portions Copyright (c) 2010 Motorola Mobility, Inc. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS''
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
+ * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+ * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+ * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
+ * THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#include "RunLoop.h"
+
+#include "WKBase.h"
+#include <glib.h>
+
+RunLoop::RunLoop()
+{
+ m_runLoopContext = g_main_context_default();
+ ASSERT(m_runLoopContext);
+ m_runLoopMain = g_main_loop_new(m_runLoopContext, FALSE);
+ ASSERT(m_runLoopMain);
+}
+
+RunLoop::~RunLoop()
+{
+ if (m_runLoopMain) {
+ g_main_loop_quit(m_runLoopMain);
+ g_main_loop_unref(m_runLoopMain);
+ }
+
+ if (m_runLoopContext)
+ g_main_context_unref(m_runLoopContext);
+}
+
+void RunLoop::run()
+{
+ g_main_loop_run(RunLoop::main()->mainLoop());
+}
+
+GMainLoop* RunLoop::mainLoop()
+{
+ return m_runLoopMain;
+}
+
+void RunLoop::stop()
+{
+ g_main_loop_quit(m_runLoopMain);
+}
+
+gboolean RunLoop::queueWork(RunLoop* runLoop)
+{
+ runLoop->performWork();
+ return FALSE;
+}
+
+void RunLoop::wakeUp()
+{
+ GSource* source = g_timeout_source_new(0);
+ g_source_set_callback(source, reinterpret_cast<GSourceFunc>(&RunLoop::queueWork), this, 0);
+ g_source_attach(source, m_runLoopContext);
+
+ g_main_context_wakeup(m_runLoopContext);
+}
+
+RunLoop::TimerBase::TimerBase(RunLoop* runLoop)
+ : m_runLoop(runLoop)
+ , m_timerSource(0)
+{
+}
+
+RunLoop::TimerBase::~TimerBase()
+{
+ stop();
+}
+
+void RunLoop::TimerBase::resetTimerSource()
+{
+ m_timerSource = 0;
+}
+
+gboolean RunLoop::TimerBase::oneShotTimerFired(RunLoop::TimerBase* timer)
+{
+ timer->fired();
+ timer->resetTimerSource();
+ return FALSE;
+}
+
+gboolean RunLoop::TimerBase::repeatingTimerFired(RunLoop::TimerBase* timer)
+{
+ timer->fired();
+ return TRUE;
+}
+
+void RunLoop::TimerBase::start(double fireInterval, bool repeat)
+{
+ if (m_timerSource)
+ stop();
+
+ m_timerSource = g_timeout_source_new(static_cast<guint>(fireInterval));
+ if (repeat)
+ g_source_set_callback(m_timerSource, reinterpret_cast<GSourceFunc>(&RunLoop::TimerBase::repeatingTimerFired), this, 0);
+ else
+ g_source_set_callback(m_timerSource, reinterpret_cast<GSourceFunc>(&RunLoop::TimerBase::oneShotTimerFired), this, 0);
+ g_source_attach(m_timerSource, m_runLoop->m_runLoopContext);
+}
+
+void RunLoop::TimerBase::stop()
+{
+ if (!m_timerSource)
+ return;
+
+ g_source_destroy(m_timerSource);
+ m_timerSource = 0;
+}
+
+bool RunLoop::TimerBase::isActive() const
+{
+ return m_timerSource;
+}
diff --git a/Source/WebKit2/Platform/gtk/SharedMemoryGtk.cpp b/Source/WebKit2/Platform/gtk/SharedMemoryGtk.cpp
new file mode 100644
index 0000000..93fda95
--- /dev/null
+++ b/Source/WebKit2/Platform/gtk/SharedMemoryGtk.cpp
@@ -0,0 +1,84 @@
+/*
+ * Copyright (C) 2010 Apple Inc. All rights reserved.
+ * Portions Copyright (c) 2010 Motorola Mobility, Inc. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS''
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
+ * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+ * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+ * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
+ * THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#include "SharedMemory.h"
+
+#include "NotImplemented.h"
+
+namespace WebKit {
+
+SharedMemory::Handle::Handle()
+{
+ notImplemented();
+}
+
+SharedMemory::Handle::~Handle()
+{
+ notImplemented();
+}
+
+void SharedMemory::Handle::encode(CoreIPC::ArgumentEncoder* encoder) const
+{
+ notImplemented();
+}
+
+bool SharedMemory::Handle::decode(CoreIPC::ArgumentDecoder* decoder, Handle& handle)
+{
+ notImplemented();
+ return false;
+}
+
+PassRefPtr<SharedMemory> SharedMemory::create(size_t size)
+{
+ notImplemented();
+ return 0;
+}
+
+PassRefPtr<SharedMemory> SharedMemory::create(const Handle& handle, Protection protection)
+{
+ notImplemented();
+ return 0;
+}
+
+SharedMemory::~SharedMemory()
+{
+ notImplemented();
+}
+
+bool SharedMemory::createHandle(Handle& handle, Protection protection)
+{
+ notImplemented();
+ return false;
+}
+
+unsigned SharedMemory::systemPageSize()
+{
+ unsigned pageSize = 0;
+
+ return pageSize;
+}
+
+}
diff --git a/Source/WebKit2/Platform/gtk/WorkQueueGtk.cpp b/Source/WebKit2/Platform/gtk/WorkQueueGtk.cpp
new file mode 100644
index 0000000..995b531
--- /dev/null
+++ b/Source/WebKit2/Platform/gtk/WorkQueueGtk.cpp
@@ -0,0 +1,202 @@
+/*
+ * Copyright (C) 2010 Apple Inc. All rights reserved.
+ * Portions Copyright (c) 2010 Motorola Mobility, Inc. All rights reserved.
+ *
+ * Redistribution and use in source and binary forms, with or without
+ * modification, are permitted provided that the following conditions
+ * are met:
+ * 1. Redistributions of source code must retain the above copyright
+ * notice, this list of conditions and the following disclaimer.
+ * 2. Redistributions in binary form must reproduce the above copyright
+ * notice, this list of conditions and the following disclaimer in the
+ * documentation and/or other materials provided with the distribution.
+ *
+ * THIS SOFTWARE IS PROVIDED BY APPLE INC. AND ITS CONTRIBUTORS ``AS IS''
+ * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
+ * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
+ * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR ITS CONTRIBUTORS
+ * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+ * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+ * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+ * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
+ * THE POSSIBILITY OF SUCH DAMAGE.
+ */
+
+#include "WorkQueue.h"
+
+#include "NotImplemented.h"
+#include "WKBase.h"
+#include <glib.h>
+
+// WorkQueue::EventSource
+class WorkQueue::EventSource {
+public:
+ EventSource(GSource* dispatchSource, PassOwnPtr<WorkItem> workItem, WorkQueue* workQueue)
+ : m_dispatchSource(dispatchSource)
+ , m_workItem(workItem)
+ , m_workQueue(workQueue)
+ {
+ }
+
+ GSource* dispatchSource() { return m_dispatchSource; }
+
+ static gboolean performWorkOnce(EventSource* eventSource)
+ {
+ ASSERT(eventSource);
+ WorkQueue* queue = eventSource->m_workQueue;
+ {
+ MutexLocker locker(queue->m_isValidMutex);
+ if (!queue->m_isValid)
+ return FALSE;
+ }
+
+ eventSource->m_workItem->execute();
+ return FALSE;
+ }
+
+ static gboolean performWork(GIOChannel* channel, GIOCondition condition, EventSource* eventSource)
+ {
+ ASSERT(eventSource);
+
+ if (!(condition & G_IO_IN) && !(condition & G_IO_HUP) && !(condition & G_IO_ERR))
+ return FALSE;
+
+ WorkQueue* queue = eventSource->m_workQueue;
+ {
+ MutexLocker locker(queue->m_isValidMutex);
+ if (!queue->m_isValid)
+ return FALSE;
+ }
+
+ eventSource->m_workItem->execute();
+
+ if ((condition & G_IO_HUP) || (condition & G_IO_ERR))
+ return FALSE;
+
+ return TRUE;
+ }
+
+ static void deleteEventSource(EventSource* eventSource)
+ {
+ ASSERT(eventSource);
+ delete eventSource;
+ }
+
+public:
+ GSource* m_dispatchSource;
+ PassOwnPtr<WorkItem> m_workItem;
+ WorkQueue* m_workQueue;
+};
+
+// WorkQueue
+void WorkQueue::platformInitialize(const char* name)
+{
+ m_eventContext = g_main_context_new();
+ ASSERT(m_eventContext);
+ m_eventLoop = g_main_loop_new(m_eventContext, FALSE);
+ ASSERT(m_eventLoop);
+ m_workQueueThread = createThread(reinterpret_cast<WTF::ThreadFunction>(&WorkQueue::startWorkQueueThread), this, name);
+}
+
+void WorkQueue::platformInvalidate()
+{
+ MutexLocker locker(m_eventLoopLock);
+
+ if (m_eventLoop) {
+ if (g_main_loop_is_running(m_eventLoop))
+ g_main_loop_quit(m_eventLoop);
+
+ g_main_loop_unref(m_eventLoop);
+ m_eventLoop = 0;
+ }
+
+ if (m_eventContext) {
+ g_main_context_unref(m_eventContext);
+ m_eventContext = 0;
+ }
+}
+
+void* WorkQueue::startWorkQueueThread(WorkQueue* workQueue)
+{
+ workQueue->workQueueThreadBody();
+ return 0;
+}
+
+void WorkQueue::workQueueThreadBody()
+{
+ g_main_loop_run(m_eventLoop);
+}
+
+void WorkQueue::registerEventSourceHandler(int fileDescriptor, int condition, PassOwnPtr<WorkItem> item)
+{
+ GIOChannel* channel = g_io_channel_unix_new(fileDescriptor);
+ ASSERT(channel);
+ GSource* dispatchSource = g_io_create_watch(channel, static_cast<GIOCondition>(condition));
+ ASSERT(dispatchSource);
+ EventSource* eventSource = new EventSource(dispatchSource, item, this);
+ ASSERT(eventSource);
+
+ g_source_set_callback(dispatchSource, reinterpret_cast<GSourceFunc>(&WorkQueue::EventSource::performWork),
+ eventSource, reinterpret_cast<GDestroyNotify>(&WorkQueue::EventSource::deleteEventSource));
+
+ // Set up the event sources under the mutex since this is shared across multiple threads.
+ {
+ MutexLocker locker(m_eventSourcesLock);
+ ASSERT(!m_eventSources.contains(fileDescriptor));
+ Vector<EventSource*> sources;
+ EventSourceIterator it = m_eventSources.find(fileDescriptor);
+ if (it != m_eventSources.end())
+ sources = it->second;
+
+ sources.append(eventSource);
+ m_eventSources.set(fileDescriptor, sources);
+ }
+
+ // Attach the event source to the GMainContext under the mutex since this is shared across multiple threads.
+ {
+ MutexLocker locker(m_eventLoopLock);
+ g_source_attach(dispatchSource, m_eventContext);
+ }
+}
+
+void WorkQueue::unregisterEventSourceHandler(int fileDescriptor)
+{
+ ASSERT(fileDescriptor);
+
+ MutexLocker locker(m_eventSourcesLock);
+
+ EventSourceIterator it = m_eventSources.find(fileDescriptor);
+ ASSERT(it != m_eventSources.end());
+ ASSERT(m_eventSources.contains(fileDescriptor));
+
+ if (it != m_eventSources.end()) {
+ Vector<EventSource*> sources = it->second;
+ for (unsigned i = 0; i < sources.size(); i++)
+ g_source_destroy(sources[i]->dispatchSource());
+
+ m_eventSources.remove(it);
+ }
+}
+
+void WorkQueue::scheduleWork(PassOwnPtr<WorkItem> item)
+{
+ GSource* dispatchSource = g_timeout_source_new(0);
+ ASSERT(dispatchSource);
+ EventSource* eventSource = new EventSource(dispatchSource, item, this);
+
+ g_source_set_callback(dispatchSource,
+ reinterpret_cast<GSourceFunc>(&WorkQueue::EventSource::performWorkOnce),
+ eventSource,
+ reinterpret_cast<GDestroyNotify>(&WorkQueue::EventSource::deleteEventSource));
+ {
+ MutexLocker locker(m_eventLoopLock);
+ g_source_attach(dispatchSource, m_eventContext);
+ }
+}
+
+void WorkQueue::scheduleWorkAfterDelay(PassOwnPtr<WorkItem>, double)
+{
+ notImplemented();
+}