<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.1//EN"
"http://www.w3.org/TR/xhtml11/DTD/xhtml11.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head><meta http-equiv="content-type" content="text/html; charset=utf-8" />
<title>[168611] trunk/Source/WebCore</title>
</head>
<body>

<style type="text/css"><!--
#msg dl.meta { border: 1px #006 solid; background: #369; padding: 6px; color: #fff; }
#msg dl.meta dt { float: left; width: 6em; font-weight: bold; }
#msg dt:after { content:':';}
#msg dl, #msg dt, #msg ul, #msg li, #header, #footer, #logmsg { font-family: verdana,arial,helvetica,sans-serif; font-size: 10pt;  }
#msg dl a { font-weight: bold}
#msg dl a:link    { color:#fc3; }
#msg dl a:active  { color:#ff0; }
#msg dl a:visited { color:#cc6; }
h3 { font-family: verdana,arial,helvetica,sans-serif; font-size: 10pt; font-weight: bold; }
#msg pre { overflow: auto; background: #ffc; border: 1px #fa0 solid; padding: 6px; }
#logmsg { background: #ffc; border: 1px #fa0 solid; padding: 1em 1em 0 1em; }
#logmsg p, #logmsg pre, #logmsg blockquote { margin: 0 0 1em 0; }
#logmsg p, #logmsg li, #logmsg dt, #logmsg dd { line-height: 14pt; }
#logmsg h1, #logmsg h2, #logmsg h3, #logmsg h4, #logmsg h5, #logmsg h6 { margin: .5em 0; }
#logmsg h1:first-child, #logmsg h2:first-child, #logmsg h3:first-child, #logmsg h4:first-child, #logmsg h5:first-child, #logmsg h6:first-child { margin-top: 0; }
#logmsg ul, #logmsg ol { padding: 0; list-style-position: inside; margin: 0 0 0 1em; }
#logmsg ul { text-indent: -1em; padding-left: 1em; }#logmsg ol { text-indent: -1.5em; padding-left: 1.5em; }
#logmsg > ul, #logmsg > ol { margin: 0 0 1em 0; }
#logmsg pre { background: #eee; padding: 1em; }
#logmsg blockquote { border: 1px solid #fa0; border-left-width: 10px; padding: 1em 1em 0 1em; background: white;}
#logmsg dl { margin: 0; }
#logmsg dt { font-weight: bold; }
#logmsg dd { margin: 0; padding: 0 0 0.5em 0; }
#logmsg dd:before { content:'\00bb';}
#logmsg table { border-spacing: 0px; border-collapse: collapse; border-top: 4px solid #fa0; border-bottom: 1px solid #fa0; background: #fff; }
#logmsg table th { text-align: left; font-weight: normal; padding: 0.2em 0.5em; border-top: 1px dotted #fa0; }
#logmsg table td { text-align: right; border-top: 1px dotted #fa0; padding: 0.2em 0.5em; }
#logmsg table thead th { text-align: center; border-bottom: 1px solid #fa0; }
#logmsg table th.Corner { text-align: left; }
#logmsg hr { border: none 0; border-top: 2px dashed #fa0; height: 1px; }
#header, #footer { color: #fff; background: #636; border: 1px #300 solid; padding: 6px; }
#patch { width: 100%; }
#patch h4 {font-family: verdana,arial,helvetica,sans-serif;font-size:10pt;padding:8px;background:#369;color:#fff;margin:0;}
#patch .propset h4, #patch .binary h4 {margin:0;}
#patch pre {padding:0;line-height:1.2em;margin:0;}
#patch .diff {width:100%;background:#eee;padding: 0 0 10px 0;overflow:auto;}
#patch .propset .diff, #patch .binary .diff  {padding:10px 0;}
#patch span {display:block;padding:0 10px;}
#patch .modfile, #patch .addfile, #patch .delfile, #patch .propset, #patch .binary, #patch .copfile {border:1px solid #ccc;margin:10px 0;}
#patch ins {background:#dfd;text-decoration:none;display:block;padding:0 10px;}
#patch del {background:#fdd;text-decoration:none;display:block;padding:0 10px;}
#patch .lines, .info {color:#888;background:#fff;}
--></style>
<div id="msg">
<dl class="meta">
<dt>Revision</dt> <dd><a href="http://trac.webkit.org/projects/webkit/changeset/168611">168611</a></dd>
<dt>Author</dt> <dd>zandobersek@gmail.com</dd>
<dt>Date</dt> <dd>2014-05-12 00:04:59 -0700 (Mon, 12 May 2014)</dd>
</dl>

<h3>Log Message</h3>
<pre>Clean up MainThreadTask
https://bugs.webkit.org/show_bug.cgi?id=132799

Reviewed by Darin Adler.

Only have one simple MainThreadTask class that derives from std::function&lt;void ()&gt;.
Its templated constructor takes in the method and a variadic pack of parameters.
The cross-thread copies of the parameter are then bound to the given method through
std::bind(), with the resulting bind expression used to initialize the base
std::function&lt;void ()&gt; class.

The WebCore::callOnMainThread() functions and the helper classes are removed in favor
of passing MainThreadTask rvalues directly to WTF::callOnMainThread().

* fileapi/AsyncFileStream.cpp:
(WebCore::AsyncFileStream::startOnFileThread):
(WebCore::AsyncFileStream::stopOnFileThread):
(WebCore::AsyncFileStream::getSizeOnFileThread):
(WebCore::AsyncFileStream::openForReadOnFileThread):
(WebCore::AsyncFileStream::openForWriteOnFileThread):
(WebCore::AsyncFileStream::readOnFileThread):
(WebCore::AsyncFileStream::writeOnFileThread):
(WebCore::AsyncFileStream::truncateOnFileThread):
* platform/MainThreadTask.h:
(WebCore::MainThreadTask::MainThreadTask):
(WebCore::MainThreadTaskBase::MainThreadTaskBase): Deleted.
(WebCore::MainThreadTaskBase::~MainThreadTaskBase): Deleted.
(WebCore::MainThreadTask1::create): Deleted.
(WebCore::MainThreadTask1::MainThreadTask1): Deleted.
(WebCore::MainThreadTask2::create): Deleted.
(WebCore::MainThreadTask2::MainThreadTask2): Deleted.
(WebCore::MainThreadTask3::create): Deleted.
(WebCore::MainThreadTask3::MainThreadTask3): Deleted.
(WebCore::MainThreadTask4::create): Deleted.
(WebCore::MainThreadTask4::MainThreadTask4): Deleted.
(WebCore::MainThreadTask5::create): Deleted.
(WebCore::MainThreadTask5::MainThreadTask5): Deleted.
(WebCore::MainThreadTask6::create): Deleted.
(WebCore::MainThreadTask6::MainThreadTask6): Deleted.
(WebCore::MainThreadTask7::create): Deleted.
(WebCore::MainThreadTask7::MainThreadTask7): Deleted.
(WebCore::MainThreadTask8::create): Deleted.
(WebCore::MainThreadTask8::MainThreadTask8): Deleted.
(WebCore::executeMainThreadTask): Deleted.
(WebCore::callOnMainThread): Deleted.</pre>

<h3>Modified Paths</h3>
<ul>
<li><a href="#trunkSourceWebCoreChangeLog">trunk/Source/WebCore/ChangeLog</a></li>
<li><a href="#trunkSourceWebCorefileapiAsyncFileStreamcpp">trunk/Source/WebCore/fileapi/AsyncFileStream.cpp</a></li>
<li><a href="#trunkSourceWebCoreplatformMainThreadTaskh">trunk/Source/WebCore/platform/MainThreadTask.h</a></li>
</ul>

</div>
<div id="patch">
<h3>Diff</h3>
<a id="trunkSourceWebCoreChangeLog"></a>
<div class="modfile"><h4>Modified: trunk/Source/WebCore/ChangeLog (168610 => 168611)</h4>
<pre class="diff"><span>
<span class="info">--- trunk/Source/WebCore/ChangeLog        2014-05-12 07:01:24 UTC (rev 168610)
+++ trunk/Source/WebCore/ChangeLog        2014-05-12 07:04:59 UTC (rev 168611)
</span><span class="lines">@@ -1,3 +1,51 @@
</span><ins>+2014-05-12  Zan Dobersek  &lt;zdobersek@igalia.com&gt;
+
+        Clean up MainThreadTask
+        https://bugs.webkit.org/show_bug.cgi?id=132799
+
+        Reviewed by Darin Adler.
+
+        Only have one simple MainThreadTask class that derives from std::function&lt;void ()&gt;.
+        Its templated constructor takes in the method and a variadic pack of parameters.
+        The cross-thread copies of the parameter are then bound to the given method through
+        std::bind(), with the resulting bind expression used to initialize the base
+        std::function&lt;void ()&gt; class.
+
+        The WebCore::callOnMainThread() functions and the helper classes are removed in favor
+        of passing MainThreadTask rvalues directly to WTF::callOnMainThread().
+
+        * fileapi/AsyncFileStream.cpp:
+        (WebCore::AsyncFileStream::startOnFileThread):
+        (WebCore::AsyncFileStream::stopOnFileThread):
+        (WebCore::AsyncFileStream::getSizeOnFileThread):
+        (WebCore::AsyncFileStream::openForReadOnFileThread):
+        (WebCore::AsyncFileStream::openForWriteOnFileThread):
+        (WebCore::AsyncFileStream::readOnFileThread):
+        (WebCore::AsyncFileStream::writeOnFileThread):
+        (WebCore::AsyncFileStream::truncateOnFileThread):
+        * platform/MainThreadTask.h:
+        (WebCore::MainThreadTask::MainThreadTask):
+        (WebCore::MainThreadTaskBase::MainThreadTaskBase): Deleted.
+        (WebCore::MainThreadTaskBase::~MainThreadTaskBase): Deleted.
+        (WebCore::MainThreadTask1::create): Deleted.
+        (WebCore::MainThreadTask1::MainThreadTask1): Deleted.
+        (WebCore::MainThreadTask2::create): Deleted.
+        (WebCore::MainThreadTask2::MainThreadTask2): Deleted.
+        (WebCore::MainThreadTask3::create): Deleted.
+        (WebCore::MainThreadTask3::MainThreadTask3): Deleted.
+        (WebCore::MainThreadTask4::create): Deleted.
+        (WebCore::MainThreadTask4::MainThreadTask4): Deleted.
+        (WebCore::MainThreadTask5::create): Deleted.
+        (WebCore::MainThreadTask5::MainThreadTask5): Deleted.
+        (WebCore::MainThreadTask6::create): Deleted.
+        (WebCore::MainThreadTask6::MainThreadTask6): Deleted.
+        (WebCore::MainThreadTask7::create): Deleted.
+        (WebCore::MainThreadTask7::MainThreadTask7): Deleted.
+        (WebCore::MainThreadTask8::create): Deleted.
+        (WebCore::MainThreadTask8::MainThreadTask8): Deleted.
+        (WebCore::executeMainThreadTask): Deleted.
+        (WebCore::callOnMainThread): Deleted.
+
</ins><span class="cx"> 2014-05-11  Zan Dobersek  &lt;zdobersek@igalia.com&gt;
</span><span class="cx"> 
</span><span class="cx">         Simplify FileThread::Task usage
</span></span></pre></div>
<a id="trunkSourceWebCorefileapiAsyncFileStreamcpp"></a>
<div class="modfile"><h4>Modified: trunk/Source/WebCore/fileapi/AsyncFileStream.cpp (168610 => 168611)</h4>
<pre class="diff"><span>
<span class="info">--- trunk/Source/WebCore/fileapi/AsyncFileStream.cpp        2014-05-12 07:01:24 UTC (rev 168610)
+++ trunk/Source/WebCore/fileapi/AsyncFileStream.cpp        2014-05-12 07:04:59 UTC (rev 168611)
</span><span class="lines">@@ -100,7 +100,7 @@
</span><span class="cx">     if (!m_client)
</span><span class="cx">         return;
</span><span class="cx">     m_stream-&gt;start();
</span><del>-    callOnMainThread(didStart, AllowCrossThreadAccess(this));
</del><ins>+    callOnMainThread(MainThreadTask(didStart, AllowCrossThreadAccess(this)));
</ins><span class="cx"> }
</span><span class="cx"> 
</span><span class="cx"> void AsyncFileStream::stop()
</span><span class="lines">@@ -121,7 +121,7 @@
</span><span class="cx"> void AsyncFileStream::stopOnFileThread()
</span><span class="cx"> {
</span><span class="cx">     m_stream-&gt;stop();
</span><del>-    callOnMainThread(derefProxyOnMainThread, AllowCrossThreadAccess(this));
</del><ins>+    callOnMainThread(MainThreadTask(derefProxyOnMainThread, AllowCrossThreadAccess(this)));
</ins><span class="cx"> }
</span><span class="cx"> 
</span><span class="cx"> static void didGetSize(AsyncFileStream* proxy, long long size)
</span><span class="lines">@@ -138,7 +138,7 @@
</span><span class="cx"> void AsyncFileStream::getSizeOnFileThread(const String&amp; path, double expectedModificationTime)
</span><span class="cx"> {
</span><span class="cx">     long long size = m_stream-&gt;getSize(path, expectedModificationTime);
</span><del>-    callOnMainThread(didGetSize, AllowCrossThreadAccess(this), size);
</del><ins>+    callOnMainThread(MainThreadTask(didGetSize, AllowCrossThreadAccess(this), size));
</ins><span class="cx"> }
</span><span class="cx"> 
</span><span class="cx"> static void didOpen(AsyncFileStream* proxy, bool success)
</span><span class="lines">@@ -155,7 +155,7 @@
</span><span class="cx"> void AsyncFileStream::openForReadOnFileThread(const String&amp; path, long long offset, long long length)
</span><span class="cx"> {
</span><span class="cx">     bool success = m_stream-&gt;openForRead(path, offset, length);
</span><del>-    callOnMainThread(didOpen, AllowCrossThreadAccess(this), success);
</del><ins>+    callOnMainThread(MainThreadTask(didOpen, AllowCrossThreadAccess(this), success));
</ins><span class="cx"> }
</span><span class="cx"> 
</span><span class="cx"> void AsyncFileStream::openForWrite(const String&amp; path)
</span><span class="lines">@@ -166,7 +166,7 @@
</span><span class="cx"> void AsyncFileStream::openForWriteOnFileThread(const String&amp; path)
</span><span class="cx"> {
</span><span class="cx">     bool success = m_stream-&gt;openForWrite(path);
</span><del>-    callOnMainThread(didOpen, AllowCrossThreadAccess(this), success);
</del><ins>+    callOnMainThread(MainThreadTask(didOpen, AllowCrossThreadAccess(this), success));
</ins><span class="cx"> }
</span><span class="cx"> 
</span><span class="cx"> void AsyncFileStream::close()
</span><span class="lines">@@ -193,7 +193,7 @@
</span><span class="cx"> void AsyncFileStream::readOnFileThread(char* buffer, int length)
</span><span class="cx"> {
</span><span class="cx">     int bytesRead = m_stream-&gt;read(buffer, length);
</span><del>-    callOnMainThread(didRead, AllowCrossThreadAccess(this), bytesRead);
</del><ins>+    callOnMainThread(MainThreadTask(didRead, AllowCrossThreadAccess(this), bytesRead));
</ins><span class="cx"> }
</span><span class="cx"> 
</span><span class="cx"> static void didWrite(AsyncFileStream* proxy, int bytesWritten)
</span><span class="lines">@@ -210,7 +210,7 @@
</span><span class="cx"> void AsyncFileStream::writeOnFileThread(const URL&amp; blobURL, long long position, int length)
</span><span class="cx"> {
</span><span class="cx">     int bytesWritten = m_stream-&gt;write(blobURL, position, length);
</span><del>-    callOnMainThread(didWrite, AllowCrossThreadAccess(this), bytesWritten);
</del><ins>+    callOnMainThread(MainThreadTask(didWrite, AllowCrossThreadAccess(this), bytesWritten));
</ins><span class="cx"> }
</span><span class="cx"> 
</span><span class="cx"> static void didTruncate(AsyncFileStream* proxy, bool success)
</span><span class="lines">@@ -227,7 +227,7 @@
</span><span class="cx"> void AsyncFileStream::truncateOnFileThread(long long position)
</span><span class="cx"> {
</span><span class="cx">     bool success = m_stream-&gt;truncate(position);
</span><del>-    callOnMainThread(didTruncate, AllowCrossThreadAccess(this), success);
</del><ins>+    callOnMainThread(MainThreadTask(didTruncate, AllowCrossThreadAccess(this), success));
</ins><span class="cx"> }
</span><span class="cx"> 
</span><span class="cx"> } // namespace WebCore
</span></span></pre></div>
<a id="trunkSourceWebCoreplatformMainThreadTaskh"></a>
<div class="modfile"><h4>Modified: trunk/Source/WebCore/platform/MainThreadTask.h (168610 => 168611)</h4>
<pre class="diff"><span>
<span class="info">--- trunk/Source/WebCore/platform/MainThreadTask.h        2014-05-12 07:01:24 UTC (rev 168610)
+++ trunk/Source/WebCore/platform/MainThreadTask.h        2014-05-12 07:04:59 UTC (rev 168611)
</span><span class="lines">@@ -33,460 +33,19 @@
</span><span class="cx"> #define MainThreadTask_h
</span><span class="cx"> 
</span><span class="cx"> #include &quot;CrossThreadCopier.h&quot;
</span><del>-#include &lt;memory&gt;
-#include &lt;wtf/MainThread.h&gt;
-#include &lt;wtf/PassOwnPtr.h&gt;
-#include &lt;wtf/PassRefPtr.h&gt;
</del><ins>+#include &lt;functional&gt;
</ins><span class="cx"> 
</span><span class="cx"> namespace WebCore {
</span><span class="cx"> 
</span><del>-// Traits for the MainThreadTask.
-template&lt;typename T&gt; struct MainThreadTaskTraits {
-    typedef const T&amp; ParamType;
-};
-
-template&lt;typename T&gt; struct MainThreadTaskTraits&lt;T*&gt; {
-    typedef T* ParamType;
-};
-
-template&lt;typename T&gt; struct MainThreadTaskTraits&lt;PassRefPtr&lt;T&gt;&gt; {
-    typedef PassRefPtr&lt;T&gt; ParamType;
-};
-
-template&lt;typename T&gt; struct MainThreadTaskTraits&lt;PassOwnPtr&lt;T&gt;&gt; {
-    typedef PassOwnPtr&lt;T&gt; ParamType;
-};
-
-class MainThreadTaskBase {
-WTF_MAKE_NONCOPYABLE(MainThreadTaskBase);
-WTF_MAKE_FAST_ALLOCATED;
</del><ins>+class MainThreadTask : public std::function&lt;void ()&gt; {
</ins><span class="cx"> public:
</span><del>-    MainThreadTaskBase() { }
-    virtual void performTask() = 0;
-    virtual ~MainThreadTaskBase() { }
-};
-
-template&lt;typename P1, typename MP1&gt;
-class MainThreadTask1 : public MainThreadTaskBase {
-public:
-    typedef void (*Method)(MP1);
-    typedef MainThreadTask1&lt;P1, MP1&gt; MainThreadTask;
-    typedef typename MainThreadTaskTraits&lt;P1&gt;::ParamType Param1;
-
-    static PassOwnPtr&lt;MainThreadTask&gt; create(Method method, Param1 parameter1)
</del><ins>+    template&lt;typename Method, typename... Parameters&gt;
+    MainThreadTask(Method method, const Parameters&amp;... parameters)
+        : std::function&lt;void ()&gt;(std::bind(method, typename CrossThreadCopier&lt;Parameters&gt;::Type(CrossThreadCopier&lt;Parameters&gt;::copy(parameters))...))
</ins><span class="cx">     {
</span><del>-        return adoptPtr(new MainThreadTask(method, parameter1));
</del><span class="cx">     }
</span><del>-
-private:
-    MainThreadTask1(Method method, Param1 parameter1)
-        : m_method(method)
-        , m_parameter1(parameter1)
-    {
-    }
-
-    virtual void performTask() override
-    {
-        (*m_method)(m_parameter1);
-    }
-
-private:
-    Method m_method;
-    P1 m_parameter1;
</del><span class="cx"> };
</span><span class="cx"> 
</span><del>-template&lt;typename P1, typename MP1, typename P2, typename MP2&gt;
-class MainThreadTask2 : public MainThreadTaskBase {
-public:
-    typedef void (*Method)(MP1, MP2);
-    typedef MainThreadTask2&lt;P1, MP1, P2, MP2&gt; MainThreadTask;
-    typedef typename MainThreadTaskTraits&lt;P1&gt;::ParamType Param1;
-    typedef typename MainThreadTaskTraits&lt;P2&gt;::ParamType Param2;
-
-    static PassOwnPtr&lt;MainThreadTask&gt; create(Method method, Param1 parameter1, Param2 parameter2)
-    {
-        return adoptPtr(new MainThreadTask(method, parameter1, parameter2));
-    }
-
-private:
-    MainThreadTask2(Method method, Param1 parameter1, Param2 parameter2)
-        : m_method(method)
-        , m_parameter1(parameter1)
-        , m_parameter2(parameter2)
-    {
-    }
-
-    virtual void performTask() override
-    {
-        (*m_method)(m_parameter1, m_parameter2);
-    }
-
-private:
-    Method m_method;
-    P1 m_parameter1;
-    P2 m_parameter2;
-};
-
-template&lt;typename P1, typename MP1, typename P2, typename MP2, typename P3, typename MP3&gt;
-class MainThreadTask3 : public MainThreadTaskBase {
-public:
-    typedef void (*Method)(MP1, MP2, MP3);
-    typedef MainThreadTask3&lt;P1, MP1, P2, MP2, P3, MP3&gt; MainThreadTask;
-    typedef typename MainThreadTaskTraits&lt;P1&gt;::ParamType Param1;
-    typedef typename MainThreadTaskTraits&lt;P2&gt;::ParamType Param2;
-    typedef typename MainThreadTaskTraits&lt;P3&gt;::ParamType Param3;
-
-    static PassOwnPtr&lt;MainThreadTask&gt; create(Method method, Param1 parameter1, Param2 parameter2, Param3 parameter3)
-    {
-        return adoptPtr(new MainThreadTask(method, parameter1, parameter2, parameter3));
-    }
-
-private:
-    MainThreadTask3(Method method, Param1 parameter1, Param2 parameter2, Param3 parameter3)
-        : m_method(method)
-        , m_parameter1(parameter1)
-        , m_parameter2(parameter2)
-        , m_parameter3(parameter3)
-    {
-    }
-
-    virtual void performTask() override
-    {
-        (*m_method)(m_parameter1, m_parameter2, m_parameter3);
-    }
-
-private:
-    Method m_method;
-    P1 m_parameter1;
-    P2 m_parameter2;
-    P3 m_parameter3;
-};
-
-template&lt;typename P1, typename MP1, typename P2, typename MP2, typename P3, typename MP3, typename P4, typename MP4&gt;
-class MainThreadTask4 : public MainThreadTaskBase {
-public:
-    typedef void (*Method)(MP1, MP2, MP3, MP4);
-    typedef MainThreadTask4&lt;P1, MP1, P2, MP2, P3, MP3, P4, MP4&gt; MainThreadTask;
-    typedef typename MainThreadTaskTraits&lt;P1&gt;::ParamType Param1;
-    typedef typename MainThreadTaskTraits&lt;P2&gt;::ParamType Param2;
-    typedef typename MainThreadTaskTraits&lt;P3&gt;::ParamType Param3;
-    typedef typename MainThreadTaskTraits&lt;P4&gt;::ParamType Param4;
-
-    static PassOwnPtr&lt;MainThreadTask&gt; create(Method method, Param1 parameter1, Param2 parameter2, Param3 parameter3, Param4 parameter4)
-    {
-        return adoptPtr(new MainThreadTask(method, parameter1, parameter2, parameter3, parameter4));
-    }
-
-private:
-    MainThreadTask4(Method method, Param1 parameter1, Param2 parameter2, Param3 parameter3, Param4 parameter4)
-        : m_method(method)
-        , m_parameter1(parameter1)
-        , m_parameter2(parameter2)
-        , m_parameter3(parameter3)
-        , m_parameter4(parameter4)
-    {
-    }
-
-    virtual void performTask() override
-    {
-        (*m_method)(m_parameter1, m_parameter2, m_parameter3, m_parameter4);
-    }
-
-private:
-    Method m_method;
-    P1 m_parameter1;
-    P2 m_parameter2;
-    P3 m_parameter3;
-    P4 m_parameter4;
-};
-
-template&lt;typename P1, typename MP1, typename P2, typename MP2, typename P3, typename MP3, typename P4, typename MP4, typename P5, typename MP5&gt;
-class MainThreadTask5 : public MainThreadTaskBase {
-public:
-    typedef void (*Method)(MP1, MP2, MP3, MP4, MP5);
-    typedef MainThreadTask5&lt;P1, MP1, P2, MP2, P3, MP3, P4, MP4, P5, MP5&gt; MainThreadTask;
-    typedef typename MainThreadTaskTraits&lt;P1&gt;::ParamType Param1;
-    typedef typename MainThreadTaskTraits&lt;P2&gt;::ParamType Param2;
-    typedef typename MainThreadTaskTraits&lt;P3&gt;::ParamType Param3;
-    typedef typename MainThreadTaskTraits&lt;P4&gt;::ParamType Param4;
-    typedef typename MainThreadTaskTraits&lt;P5&gt;::ParamType Param5;
-
-    static PassOwnPtr&lt;MainThreadTask&gt; create(Method method, Param1 parameter1, Param2 parameter2, Param3 parameter3, Param4 parameter4, Param5 parameter5)
-    {
-        return adoptPtr(new MainThreadTask(method, parameter1, parameter2, parameter3, parameter4, parameter5));
-    }
-
-private:
-    MainThreadTask5(Method method, Param1 parameter1, Param2 parameter2, Param3 parameter3, Param4 parameter4, Param5 parameter5)
-        : m_method(method)
-        , m_parameter1(parameter1)
-        , m_parameter2(parameter2)
-        , m_parameter3(parameter3)
-        , m_parameter4(parameter4)
-        , m_parameter5(parameter5)
-    {
-    }
-
-    virtual void performTask() override
-    {
-        (*m_method)(m_parameter1, m_parameter2, m_parameter3, m_parameter4, m_parameter5);
-    }
-
-private:
-    Method m_method;
-    P1 m_parameter1;
-    P2 m_parameter2;
-    P3 m_parameter3;
-    P4 m_parameter4;
-    P5 m_parameter5;
-};
-
-template&lt;typename P1, typename MP1, typename P2, typename MP2, typename P3, typename MP3, typename P4, typename MP4, typename P5, typename MP5, typename P6, typename MP6&gt;
-class MainThreadTask6 : public MainThreadTaskBase {
-public:
-    typedef void (*Method)(MP1, MP2, MP3, MP4, MP5, MP6);
-    typedef MainThreadTask6&lt;P1, MP1, P2, MP2, P3, MP3, P4, MP4, P5, MP5, P6, MP6&gt; MainThreadTask;
-    typedef typename MainThreadTaskTraits&lt;P1&gt;::ParamType Param1;
-    typedef typename MainThreadTaskTraits&lt;P2&gt;::ParamType Param2;
-    typedef typename MainThreadTaskTraits&lt;P3&gt;::ParamType Param3;
-    typedef typename MainThreadTaskTraits&lt;P4&gt;::ParamType Param4;
-    typedef typename MainThreadTaskTraits&lt;P5&gt;::ParamType Param5;
-    typedef typename MainThreadTaskTraits&lt;P6&gt;::ParamType Param6;
-
-    static PassOwnPtr&lt;MainThreadTask&gt; create(Method method, Param1 parameter1, Param2 parameter2, Param3 parameter3, Param4 parameter4, Param5 parameter5, Param6 parameter6)
-    {
-        return adoptPtr(new MainThreadTask(method, parameter1, parameter2, parameter3, parameter4, parameter5, parameter6));
-    }
-
-private:
-    MainThreadTask6(Method method, Param1 parameter1, Param2 parameter2, Param3 parameter3, Param4 parameter4, Param5 parameter5, Param6 parameter6)
-        : m_method(method)
-        , m_parameter1(parameter1)
-        , m_parameter2(parameter2)
-        , m_parameter3(parameter3)
-        , m_parameter4(parameter4)
-        , m_parameter5(parameter5)
-        , m_parameter6(parameter6)
-    {
-    }
-
-    virtual void performTask() override
-    {
-        (*m_method)(m_parameter1, m_parameter2, m_parameter3, m_parameter4, m_parameter5, m_parameter6);
-    }
-
-private:
-    Method m_method;
-    P1 m_parameter1;
-    P2 m_parameter2;
-    P3 m_parameter3;
-    P4 m_parameter4;
-    P5 m_parameter5;
-    P6 m_parameter6;
-};
-
-template&lt;typename P1, typename MP1, typename P2, typename MP2, typename P3, typename MP3, typename P4, typename MP4, typename P5, typename MP5, typename P6, typename MP6, typename P7, typename MP7&gt;
-class MainThreadTask7 : public MainThreadTaskBase {
-public:
-    typedef void (*Method)(MP1, MP2, MP3, MP4, MP5, MP6, MP7);
-    typedef MainThreadTask7&lt;P1, MP1, P2, MP2, P3, MP3, P4, MP4, P5, MP5, P6, MP6, P7, MP7&gt; MainThreadTask;
-    typedef typename MainThreadTaskTraits&lt;P1&gt;::ParamType Param1;
-    typedef typename MainThreadTaskTraits&lt;P2&gt;::ParamType Param2;
-    typedef typename MainThreadTaskTraits&lt;P3&gt;::ParamType Param3;
-    typedef typename MainThreadTaskTraits&lt;P4&gt;::ParamType Param4;
-    typedef typename MainThreadTaskTraits&lt;P5&gt;::ParamType Param5;
-    typedef typename MainThreadTaskTraits&lt;P6&gt;::ParamType Param6;
-    typedef typename MainThreadTaskTraits&lt;P7&gt;::ParamType Param7;
-
-    static PassOwnPtr&lt;MainThreadTask&gt; create(Method method, Param1 parameter1, Param2 parameter2, Param3 parameter3, Param4 parameter4, Param5 parameter5, Param6 parameter6, Param7 parameter7)
-    {
-        return adoptPtr(new MainThreadTask(method, parameter1, parameter2, parameter3, parameter4, parameter5, parameter6, parameter7));
-    }
-
-private:
-    MainThreadTask7(Method method, Param1 parameter1, Param2 parameter2, Param3 parameter3, Param4 parameter4, Param5 parameter5, Param6 parameter6, Param7 parameter7)
-        : m_method(method)
-        , m_parameter1(parameter1)
-        , m_parameter2(parameter2)
-        , m_parameter3(parameter3)
-        , m_parameter4(parameter4)
-        , m_parameter5(parameter5)
-        , m_parameter6(parameter6)
-        , m_parameter7(parameter7)
-    {
-    }
-
-    virtual void performTask() override
-    {
-        (*m_method)(m_parameter1, m_parameter2, m_parameter3, m_parameter4, m_parameter5, m_parameter6, m_parameter7);
-    }
-
-private:
-    Method m_method;
-    P1 m_parameter1;
-    P2 m_parameter2;
-    P3 m_parameter3;
-    P4 m_parameter4;
-    P5 m_parameter5;
-    P6 m_parameter6;
-    P7 m_parameter7;
-};
-
-template&lt;typename P1, typename MP1, typename P2, typename MP2, typename P3, typename MP3, typename P4, typename MP4, typename P5, typename MP5, typename P6, typename MP6, typename P7, typename MP7, typename P8, typename MP8&gt;
-class MainThreadTask8 : public MainThreadTaskBase {
-public:
-    typedef void (*Method)(MP1, MP2, MP3, MP4, MP5, MP6, MP7, MP8);
-    typedef MainThreadTask8&lt;P1, MP1, P2, MP2, P3, MP3, P4, MP4, P5, MP5, P6, MP6, P7, MP7, P8, MP8&gt; MainThreadTask;
-    typedef typename MainThreadTaskTraits&lt;P1&gt;::ParamType Param1;
-    typedef typename MainThreadTaskTraits&lt;P2&gt;::ParamType Param2;
-    typedef typename MainThreadTaskTraits&lt;P3&gt;::ParamType Param3;
-    typedef typename MainThreadTaskTraits&lt;P4&gt;::ParamType Param4;
-    typedef typename MainThreadTaskTraits&lt;P5&gt;::ParamType Param5;
-    typedef typename MainThreadTaskTraits&lt;P6&gt;::ParamType Param6;
-    typedef typename MainThreadTaskTraits&lt;P7&gt;::ParamType Param7;
-    typedef typename MainThreadTaskTraits&lt;P8&gt;::ParamType Param8;
-    
-    static PassOwnPtr&lt;MainThreadTask&gt; create(Method method, Param1 parameter1, Param2 parameter2, Param3 parameter3, Param4 parameter4, Param5 parameter5, Param6 parameter6, Param7 parameter7, Param8 parameter8)
-    {
-        return adoptPtr(new MainThreadTask(method, parameter1, parameter2, parameter3, parameter4, parameter5, parameter6, parameter7, parameter8));
-    }
-    
-private:
-    MainThreadTask8(Method method, Param1 parameter1, Param2 parameter2, Param3 parameter3, Param4 parameter4, Param5 parameter5, Param6 parameter6, Param7 parameter7, Param8 parameter8)
-        : m_method(method)
-        , m_parameter1(parameter1)
-        , m_parameter2(parameter2)
-        , m_parameter3(parameter3)
-        , m_parameter4(parameter4)
-        , m_parameter5(parameter5)
-        , m_parameter6(parameter6)
-        , m_parameter7(parameter7)
-        , m_parameter8(parameter8)
-    {
-    }
-    
-    virtual void performTask() override
-    {
-        (*m_method)(m_parameter1, m_parameter2, m_parameter3, m_parameter4, m_parameter5, m_parameter6, m_parameter7, m_parameter8);
-    }
-    
-private:
-    Method m_method;
-    P1 m_parameter1;
-    P2 m_parameter2;
-    P3 m_parameter3;
-    P4 m_parameter4;
-    P5 m_parameter5;
-    P6 m_parameter6;
-    P7 m_parameter7;
-    P8 m_parameter8;
-};
-
-static void executeMainThreadTask(void* context)
-{
-    OwnPtr&lt;MainThreadTaskBase&gt; task = adoptPtr(static_cast&lt;MainThreadTaskBase*&gt;(context));
-    task-&gt;performTask();
-}
-
-template&lt;typename P1, typename MP1&gt;
-void callOnMainThread(
-    void (*method)(MP1),
-    const P1&amp; parameter1)
-{
-    WTF::callOnMainThread(executeMainThreadTask, MainThreadTask1&lt;typename CrossThreadCopier&lt;P1&gt;::Type, MP1&gt;::create(
-        method,
-        CrossThreadCopier&lt;P1&gt;::copy(parameter1)).leakPtr());
-}
-
-template&lt;typename P1, typename MP1, typename P2, typename MP2&gt;
-void callOnMainThread(
-    void (*method)(MP1, MP2),
-    const P1&amp; parameter1, const P2&amp; parameter2)
-{
-    WTF::callOnMainThread(executeMainThreadTask, MainThreadTask2&lt;typename CrossThreadCopier&lt;P1&gt;::Type, MP1, typename CrossThreadCopier&lt;P2&gt;::Type, MP2&gt;::create(
-        method,
-        CrossThreadCopier&lt;P1&gt;::copy(parameter1), CrossThreadCopier&lt;P2&gt;::copy(parameter2)).leakPtr());
-}
-
-template&lt;typename P1, typename MP1, typename P2, typename MP2, typename P3, typename MP3&gt;
-void callOnMainThread(
-    void (*method)(MP1, MP2, MP3),
-    const P1&amp; parameter1, const P2&amp; parameter2, const P3&amp; parameter3)
-{
-    WTF::callOnMainThread(executeMainThreadTask, MainThreadTask3&lt;typename CrossThreadCopier&lt;P1&gt;::Type, MP1, typename CrossThreadCopier&lt;P2&gt;::Type, MP2, typename CrossThreadCopier&lt;P3&gt;::Type, MP3&gt;::create(
-        method,
-        CrossThreadCopier&lt;P1&gt;::copy(parameter1), CrossThreadCopier&lt;P2&gt;::copy(parameter2),
-        CrossThreadCopier&lt;P3&gt;::copy(parameter3)).leakPtr());
-}
-
-template&lt;typename P1, typename MP1, typename P2, typename MP2, typename P3, typename MP3, typename P4, typename MP4&gt;
-void callOnMainThread(
-    void (*method)(MP1, MP2, MP3, MP4),
-    const P1&amp; parameter1, const P2&amp; parameter2, const P3&amp; parameter3, const P4&amp; parameter4)
-{
-    WTF::callOnMainThread(executeMainThreadTask, MainThreadTask4&lt;typename CrossThreadCopier&lt;P1&gt;::Type, MP1, typename CrossThreadCopier&lt;P2&gt;::Type, MP2, typename CrossThreadCopier&lt;P3&gt;::Type, MP3,
-        typename CrossThreadCopier&lt;P4&gt;::Type, MP4&gt;::create(
-            method,
-            CrossThreadCopier&lt;P1&gt;::copy(parameter1), CrossThreadCopier&lt;P2&gt;::copy(parameter2),
-            CrossThreadCopier&lt;P3&gt;::copy(parameter3), CrossThreadCopier&lt;P4&gt;::copy(parameter4)).leakPtr());
-}
-
-template&lt;typename P1, typename MP1, typename P2, typename MP2, typename P3, typename MP3, typename P4, typename MP4, typename P5, typename MP5&gt;
-void callOnMainThread(
-    void (*method)(MP1, MP2, MP3, MP4, MP5),
-    const P1&amp; parameter1, const P2&amp; parameter2, const P3&amp; parameter3, const P4&amp; parameter4, const P5&amp; parameter5)
-{
-    WTF::callOnMainThread(executeMainThreadTask, MainThreadTask5&lt;typename CrossThreadCopier&lt;P1&gt;::Type, MP1, typename CrossThreadCopier&lt;P2&gt;::Type, MP2, typename CrossThreadCopier&lt;P3&gt;::Type, MP3,
-        typename CrossThreadCopier&lt;P4&gt;::Type, MP4, typename CrossThreadCopier&lt;P5&gt;::Type, MP5&gt;::create(
-            method,
-            CrossThreadCopier&lt;P1&gt;::copy(parameter1), CrossThreadCopier&lt;P2&gt;::copy(parameter2),
-            CrossThreadCopier&lt;P3&gt;::copy(parameter3), CrossThreadCopier&lt;P4&gt;::copy(parameter4),
-            CrossThreadCopier&lt;P5&gt;::copy(parameter5)).leakPtr());
-}
-
-template&lt;typename P1, typename MP1, typename P2, typename MP2, typename P3, typename MP3, typename P4, typename MP4, typename P5, typename MP5, typename P6, typename MP6&gt;
-void callOnMainThread(
-    void (*method)(MP1, MP2, MP3, MP4, MP5, MP6),
-    const P1&amp; parameter1, const P2&amp; parameter2, const P3&amp; parameter3, const P4&amp; parameter4, const P5&amp; parameter5, const P6&amp; parameter6)
-{
-    WTF::callOnMainThread(executeMainThreadTask, MainThreadTask6&lt;typename CrossThreadCopier&lt;P1&gt;::Type, MP1, typename CrossThreadCopier&lt;P2&gt;::Type, MP2, typename CrossThreadCopier&lt;P3&gt;::Type, MP3,
-        typename CrossThreadCopier&lt;P4&gt;::Type, MP4, typename CrossThreadCopier&lt;P5&gt;::Type, MP5, typename CrossThreadCopier&lt;P6&gt;::Type, MP6&gt;::create(
-            method,
-            CrossThreadCopier&lt;P1&gt;::copy(parameter1), CrossThreadCopier&lt;P2&gt;::copy(parameter2),
-            CrossThreadCopier&lt;P3&gt;::copy(parameter3), CrossThreadCopier&lt;P4&gt;::copy(parameter4),
-            CrossThreadCopier&lt;P5&gt;::copy(parameter5), CrossThreadCopier&lt;P6&gt;::copy(parameter6)).leakPtr());
-}
-
-template&lt;typename P1, typename MP1, typename P2, typename MP2, typename P3, typename MP3, typename P4, typename MP4, typename P5, typename MP5, typename P6, typename MP6, typename P7, typename MP7&gt;
-void callOnMainThread(
-    void (*method)(MP1, MP2, MP3, MP4, MP5, MP6, MP7),
-    const P1&amp; parameter1, const P2&amp; parameter2, const P3&amp; parameter3, const P4&amp; parameter4, const P5&amp; parameter5, const P6&amp; parameter6, const P7&amp; parameter7)
-{
-    WTF::callOnMainThread(executeMainThreadTask, MainThreadTask7&lt;typename CrossThreadCopier&lt;P1&gt;::Type, MP1, typename CrossThreadCopier&lt;P2&gt;::Type, MP2, typename CrossThreadCopier&lt;P3&gt;::Type, MP3,
-        typename CrossThreadCopier&lt;P4&gt;::Type, MP4, typename CrossThreadCopier&lt;P5&gt;::Type, MP5, typename CrossThreadCopier&lt;P6&gt;::Type, MP6,
-        typename CrossThreadCopier&lt;P7&gt;::Type, MP7&gt;::create(
-            method,
-            CrossThreadCopier&lt;P1&gt;::copy(parameter1), CrossThreadCopier&lt;P2&gt;::copy(parameter2),
-            CrossThreadCopier&lt;P3&gt;::copy(parameter3), CrossThreadCopier&lt;P4&gt;::copy(parameter4),
-            CrossThreadCopier&lt;P5&gt;::copy(parameter5), CrossThreadCopier&lt;P6&gt;::copy(parameter6),
-            CrossThreadCopier&lt;P7&gt;::copy(parameter7)).leakPtr());
-}
-
-template&lt;typename P1, typename MP1, typename P2, typename MP2, typename P3, typename MP3, typename P4, typename MP4, typename P5, typename MP5, typename P6, typename MP6, typename P7, typename MP7, typename P8, typename MP8&gt;
-void callOnMainThread(
-    void (*method)(MP1, MP2, MP3, MP4, MP5, MP6, MP7, MP8),
-    const P1&amp; parameter1, const P2&amp; parameter2, const P3&amp; parameter3, const P4&amp; parameter4, const P5&amp; parameter5, const P6&amp; parameter6, const P7&amp; parameter7, const P8&amp; parameter8)
-{
-    WTF::callOnMainThread(executeMainThreadTask, MainThreadTask8&lt;typename CrossThreadCopier&lt;P1&gt;::Type, MP1, typename CrossThreadCopier&lt;P2&gt;::Type, MP2, typename CrossThreadCopier&lt;P3&gt;::Type, MP3,
-    typename CrossThreadCopier&lt;P4&gt;::Type, MP4, typename CrossThreadCopier&lt;P5&gt;::Type, MP5, typename CrossThreadCopier&lt;P6&gt;::Type, MP6,
-    typename CrossThreadCopier&lt;P7&gt;::Type, MP7, typename CrossThreadCopier&lt;P8&gt;::Type, MP8&gt;::create(
-                                                       method,
-                                                       CrossThreadCopier&lt;P1&gt;::copy(parameter1), CrossThreadCopier&lt;P2&gt;::copy(parameter2),
-                                                       CrossThreadCopier&lt;P3&gt;::copy(parameter3), CrossThreadCopier&lt;P4&gt;::copy(parameter4),
-                                                       CrossThreadCopier&lt;P5&gt;::copy(parameter5), CrossThreadCopier&lt;P6&gt;::copy(parameter6),
-                                                       CrossThreadCopier&lt;P7&gt;::copy(parameter7), CrossThreadCopier&lt;P8&gt;::copy(parameter8)).leakPtr());
-}
-
</del><span class="cx"> } // namespace WebCore
</span><span class="cx"> 
</span><span class="cx"> 
</span></span></pre>
</div>
</div>

</body>
</html>