Move some more assorted classes from ExceptionCode to Exception
[WebKit.git] / Source / WebCore / bindings / js / JSMessagePortCustom.h
index 4972908..a8339cf 100644 (file)
@@ -29,8 +29,7 @@
  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
  */
 
-#ifndef JSMessagePortCustom_h
-#define JSMessagePortCustom_h
+#pragma once
 
 #include "MessagePort.h"
 #include <runtime/Error.h>
 
 namespace WebCore {
 
-    typedef int ExceptionCode;
+void extractTransferables(JSC::ExecState&, JSC::JSValue, Vector<RefPtr<MessagePort>>&, Vector<RefPtr<JSC::ArrayBuffer>>&);
 
-    void extractTransferables(JSC::ExecState&, JSC::JSValue, Vector<RefPtr<MessagePort>>&, Vector<RefPtr<JSC::ArrayBuffer>>&);
+// Helper function to convert from JS postMessage arguments to WebCore postMessage arguments.
+template<typename T> inline JSC::JSValue handlePostMessage(JSC::ExecState& state, T& object)
+{
+    JSC::VM& vm = state.vm();
+    auto scope = DECLARE_THROW_SCOPE(vm);
 
-    // Helper function to convert from JS postMessage arguments to WebCore postMessage arguments.
-    template <typename T>
-    inline JSC::JSValue handlePostMessage(JSC::ExecState& state, T* impl)
-    {
-        JSC::VM& vm = state.vm();
-        auto scope = DECLARE_THROW_SCOPE(vm);
+    if (UNLIKELY(state.argumentCount() < 1))
+        return throwException(&state, scope, createNotEnoughArgumentsError(&state));
 
-        if (UNLIKELY(state.argumentCount() < 1))
-            return throwException(&state, scope, createNotEnoughArgumentsError(&state));
+    Vector<RefPtr<MessagePort>> messagePortArray;
+    Vector<RefPtr<JSC::ArrayBuffer>> arrayBufferArray;
+    extractTransferables(state, state.argument(1), messagePortArray, arrayBufferArray);
 
-        
-        Vector<RefPtr<MessagePort>> messagePortArray;
-        Vector<RefPtr<JSC::ArrayBuffer>> arrayBufferArray;
-        extractTransferables(state, state.argument(1), messagePortArray, arrayBufferArray);
-        
-        auto message = SerializedScriptValue::create(state, state.uncheckedArgument(0), messagePortArray, WTFMove(arrayBufferArray));
-        RETURN_IF_EXCEPTION(scope, JSC::JSValue());
+    auto message = SerializedScriptValue::create(state, state.uncheckedArgument(0), messagePortArray, WTFMove(arrayBufferArray));
+    RETURN_IF_EXCEPTION(scope, JSC::JSValue());
 
-        ExceptionCode ec = 0;
-        impl->postMessage(WTFMove(message), WTFMove(messagePortArray), ec);
-        setDOMException(&state, ec);
-        return JSC::jsUndefined();
-    }
+    propagateException(state, scope, object.postMessage(WTFMove(message), WTFMove(messagePortArray)));
+    return JSC::jsUndefined();
+}
 
 }
-#endif // JSMessagePortCustom_h