diff options
author | Ben Murdoch <benm@google.com> | 2010-06-15 19:36:43 +0100 |
---|---|---|
committer | Ben Murdoch <benm@google.com> | 2010-06-16 14:52:28 +0100 |
commit | 545e470e52f0ac6a3a072bf559c796b42c6066b6 (patch) | |
tree | c0c14763654d84d37577dde512c3d3b4699a9e86 /WebCore/bindings/js/JSWebSocketConstructor.cpp | |
parent | 719298a66237d38ea5c05f1547123ad8aacbc237 (diff) | |
download | external_webkit-545e470e52f0ac6a3a072bf559c796b42c6066b6.zip external_webkit-545e470e52f0ac6a3a072bf559c796b42c6066b6.tar.gz external_webkit-545e470e52f0ac6a3a072bf559c796b42c6066b6.tar.bz2 |
Merge webkit.org at r61121: Initial merge by git.
Change-Id: Icd6db395c62285be384d137164d95d7466c98760
Diffstat (limited to 'WebCore/bindings/js/JSWebSocketConstructor.cpp')
-rw-r--r-- | WebCore/bindings/js/JSWebSocketConstructor.cpp | 22 |
1 files changed, 11 insertions, 11 deletions
diff --git a/WebCore/bindings/js/JSWebSocketConstructor.cpp b/WebCore/bindings/js/JSWebSocketConstructor.cpp index 57b7477..2384c7b 100644 --- a/WebCore/bindings/js/JSWebSocketConstructor.cpp +++ b/WebCore/bindings/js/JSWebSocketConstructor.cpp @@ -54,32 +54,32 @@ JSWebSocketConstructor::JSWebSocketConstructor(ExecState* exec, JSDOMGlobalObjec putDirect(exec->propertyNames().length, jsNumber(exec, 1), ReadOnly | DontDelete | DontEnum); } -static JSObject* constructWebSocket(ExecState* exec, JSObject* constructor, const ArgList& args) +static EncodedJSValue JSC_HOST_CALL constructWebSocket(ExecState* exec) { - JSWebSocketConstructor* jsConstructor = static_cast<JSWebSocketConstructor*>(constructor); + JSWebSocketConstructor* jsConstructor = static_cast<JSWebSocketConstructor*>(exec->callee()); ScriptExecutionContext* context = jsConstructor->scriptExecutionContext(); if (!context) - return throwError(exec, ReferenceError, "WebSocket constructor associated document is unavailable"); + return throwVMError(exec, createReferenceError(exec, "WebSocket constructor associated document is unavailable")); - if (args.size() == 0) - return throwError(exec, SyntaxError, "Not enough arguments"); + if (!exec->argumentCount()) + return throwVMError(exec, createSyntaxError(exec, "Not enough arguments")); - const String& urlString = ustringToString(args.at(0).toString(exec)); + const String& urlString = ustringToString(exec->argument(0).toString(exec)); if (exec->hadException()) - return throwError(exec, SyntaxError, "wrong URL"); + return throwVMError(exec, createSyntaxError(exec, "wrong URL")); const KURL& url = context->completeURL(urlString); RefPtr<WebSocket> webSocket = WebSocket::create(context); ExceptionCode ec = 0; - if (args.size() < 2) + if (exec->argumentCount() < 2) webSocket->connect(url, ec); else { - const String& protocol = ustringToString(args.at(1).toString(exec)); + const String& protocol = ustringToString(exec->argument(1).toString(exec)); if (exec->hadException()) - return 0; + return JSValue::encode(JSValue()); webSocket->connect(url, protocol, ec); } setDOMException(exec, ec); - return CREATE_DOM_OBJECT_WRAPPER(exec, jsConstructor->globalObject(), WebSocket, webSocket.get()); + return JSValue::encode(CREATE_DOM_OBJECT_WRAPPER(exec, jsConstructor->globalObject(), WebSocket, webSocket.get())); } ConstructType JSWebSocketConstructor::getConstructData(ConstructData& constructData) |