auto merge of #3693 : ehsan/servo/3248, r=jdm

This fixes #3248.

r? @jdm.  Please review for mistakes mercilessly!  Also, I got a host of test failures when running the worker tests, not sure if these tests are expected to pass locally or not.
This commit is contained in:
bors-servo 2014-10-15 22:06:19 -06:00
commit a6001329b8
7 changed files with 27 additions and 18 deletions

View file

@ -34,7 +34,8 @@ pub enum Error {
Security, Security,
Network, Network,
Abort, Abort,
Timeout Timeout,
DataClone
} }
/// The return type for IDL operations that can throw DOM exceptions. /// The return type for IDL operations that can throw DOM exceptions.

View file

@ -7,6 +7,7 @@ use dom::bindings::codegen::Bindings::DedicatedWorkerGlobalScopeBinding::Dedicat
use dom::bindings::codegen::Bindings::EventHandlerBinding::EventHandlerNonNull; use dom::bindings::codegen::Bindings::EventHandlerBinding::EventHandlerNonNull;
use dom::bindings::codegen::InheritTypes::DedicatedWorkerGlobalScopeDerived; use dom::bindings::codegen::InheritTypes::DedicatedWorkerGlobalScopeDerived;
use dom::bindings::codegen::InheritTypes::{EventTargetCast, WorkerGlobalScopeCast}; use dom::bindings::codegen::InheritTypes::{EventTargetCast, WorkerGlobalScopeCast};
use dom::bindings::error::{ErrorResult, DataClone};
use dom::bindings::global; use dom::bindings::global;
use dom::bindings::js::{JSRef, Temporary, RootCollection}; use dom::bindings::js::{JSRef, Temporary, RootCollection};
use dom::bindings::utils::{Reflectable, Reflector}; use dom::bindings::utils::{Reflectable, Reflector};
@ -25,7 +26,7 @@ use script_task::StackRootTLS;
use servo_net::resource_task::{ResourceTask, load_whole_resource}; use servo_net::resource_task::{ResourceTask, load_whole_resource};
use js::glue::JS_STRUCTURED_CLONE_VERSION; use js::glue::JS_STRUCTURED_CLONE_VERSION;
use js::jsapi::{JSContext, JS_ReadStructuredClone, JS_WriteStructuredClone}; use js::jsapi::{JSContext, JS_ReadStructuredClone, JS_WriteStructuredClone, JS_ClearPendingException};
use js::jsval::{JSVal, UndefinedValue}; use js::jsval::{JSVal, UndefinedValue};
use js::rust::Cx; use js::rust::Cx;
@ -154,16 +155,21 @@ impl DedicatedWorkerGlobalScope {
} }
impl<'a> DedicatedWorkerGlobalScopeMethods for JSRef<'a, DedicatedWorkerGlobalScope> { impl<'a> DedicatedWorkerGlobalScopeMethods for JSRef<'a, DedicatedWorkerGlobalScope> {
fn PostMessage(self, cx: *mut JSContext, message: JSVal) { fn PostMessage(self, cx: *mut JSContext, message: JSVal) -> ErrorResult {
let mut data = ptr::null_mut(); let mut data = ptr::null_mut();
let mut nbytes = 0; let mut nbytes = 0;
unsafe { let result = unsafe {
assert!(JS_WriteStructuredClone(cx, message, &mut data, &mut nbytes, JS_WriteStructuredClone(cx, message, &mut data, &mut nbytes,
ptr::null(), ptr::null_mut()) != 0); ptr::null(), ptr::null_mut())
};
if result == 0 {
unsafe { JS_ClearPendingException(cx); }
return Err(DataClone);
} }
let ScriptChan(ref sender) = self.parent_sender; let ScriptChan(ref sender) = self.parent_sender;
sender.send(WorkerPostMessage(self.worker, data, nbytes)); sender.send(WorkerPostMessage(self.worker, data, nbytes));
Ok(())
} }
fn GetOnmessage(self) -> Option<EventHandlerNonNull> { fn GetOnmessage(self) -> Option<EventHandlerNonNull> {

View file

@ -55,6 +55,7 @@ impl DOMErrorName {
error::Network => NetworkError, error::Network => NetworkError,
error::Abort => AbortError, error::Abort => AbortError,
error::Timeout => TimeoutError, error::Timeout => TimeoutError,
error::DataClone => DataCloneError,
error::FailureUnknown => fail!(), error::FailureUnknown => fail!(),
} }
} }

View file

@ -5,6 +5,7 @@
// http://www.whatwg.org/html/#dedicatedworkerglobalscope // http://www.whatwg.org/html/#dedicatedworkerglobalscope
[Global/*=Worker,DedicatedWorker*/] [Global/*=Worker,DedicatedWorker*/]
/*sealed*/ interface DedicatedWorkerGlobalScope : WorkerGlobalScope { /*sealed*/ interface DedicatedWorkerGlobalScope : WorkerGlobalScope {
[Throws]
void postMessage(any message/*, optional sequence<Transferable> transfer*/); void postMessage(any message/*, optional sequence<Transferable> transfer*/);
attribute EventHandler onmessage; attribute EventHandler onmessage;
}; };

View file

@ -14,6 +14,7 @@ interface AbstractWorker {
interface Worker : EventTarget { interface Worker : EventTarget {
//void terminate(); //void terminate();
[Throws]
void postMessage(any message/*, optional sequence<Transferable> transfer*/); void postMessage(any message/*, optional sequence<Transferable> transfer*/);
attribute EventHandler onmessage; attribute EventHandler onmessage;
}; };

View file

@ -6,7 +6,7 @@ use dom::bindings::codegen::Bindings::WorkerBinding;
use dom::bindings::codegen::Bindings::WorkerBinding::WorkerMethods; use dom::bindings::codegen::Bindings::WorkerBinding::WorkerMethods;
use dom::bindings::codegen::Bindings::EventHandlerBinding::EventHandlerNonNull; use dom::bindings::codegen::Bindings::EventHandlerBinding::EventHandlerNonNull;
use dom::bindings::codegen::InheritTypes::EventTargetCast; use dom::bindings::codegen::InheritTypes::EventTargetCast;
use dom::bindings::error::{Fallible, Syntax}; use dom::bindings::error::{Fallible, Syntax, ErrorResult, DataClone};
use dom::bindings::global::{GlobalRef, GlobalField}; use dom::bindings::global::{GlobalRef, GlobalField};
use dom::bindings::js::{JS, JSRef, Temporary}; use dom::bindings::js::{JS, JSRef, Temporary};
use dom::bindings::trace::JSTraceable; use dom::bindings::trace::JSTraceable;
@ -20,7 +20,7 @@ use servo_util::str::DOMString;
use js::glue::JS_STRUCTURED_CLONE_VERSION; use js::glue::JS_STRUCTURED_CLONE_VERSION;
use js::jsapi::{JSContext, JS_AddObjectRoot, JS_RemoveObjectRoot, JSTracer}; use js::jsapi::{JSContext, JS_AddObjectRoot, JS_RemoveObjectRoot, JSTracer};
use js::jsapi::{JS_ReadStructuredClone, JS_WriteStructuredClone}; use js::jsapi::{JS_ReadStructuredClone, JS_WriteStructuredClone, JS_ClearPendingException};
use js::jsval::{JSVal, UndefinedValue}; use js::jsval::{JSVal, UndefinedValue};
use url::UrlParser; use url::UrlParser;
@ -133,17 +133,22 @@ impl Worker {
} }
impl<'a> WorkerMethods for JSRef<'a, Worker> { impl<'a> WorkerMethods for JSRef<'a, Worker> {
fn PostMessage(self, cx: *mut JSContext, message: JSVal) { fn PostMessage(self, cx: *mut JSContext, message: JSVal) -> ErrorResult {
let mut data = ptr::null_mut(); let mut data = ptr::null_mut();
let mut nbytes = 0; let mut nbytes = 0;
unsafe { let result = unsafe {
assert!(JS_WriteStructuredClone(cx, message, &mut data, &mut nbytes, JS_WriteStructuredClone(cx, message, &mut data, &mut nbytes,
ptr::null(), ptr::null_mut()) != 0); ptr::null(), ptr::null_mut())
};
if result == 0 {
unsafe { JS_ClearPendingException(cx); }
return Err(DataClone);
} }
self.addref(); self.addref();
let ScriptChan(ref sender) = self.sender; let ScriptChan(ref sender) = self.sender;
sender.send(DOMMessage(data, nbytes)); sender.send(DOMMessage(data, nbytes));
Ok(())
} }
fn GetOnmessage(self) -> Option<EventHandlerNonNull> { fn GetOnmessage(self) -> Option<EventHandlerNonNull> {

View file

@ -1,6 +0,0 @@
[postMessage_DataCloneErr.htm]
type: testharness
expected: TIMEOUT
[Test Description: Throw a DATA_CLONE_ERR exception when a host object (e.g. a DOM node) is used with postMessage.]
expected: NOTRUN