aboutsummaryrefslogtreecommitdiffstats
path: root/components/script/dom
diff options
context:
space:
mode:
authorJitendra Jain <jsjain@ncsu.edu>2015-10-17 22:25:32 -0400
committerJitendra Jain <jsjain@ncsu.edu>2015-11-05 22:19:24 -0500
commited809a60bf9ca1ac5babb1ed6575fd1c0c4f6600 (patch)
treef16732ddbfb12a627feed1f3737c723a49f738de /components/script/dom
parent4067960ba5d309ec6c4c6aef6e7aa231aca0e5d5 (diff)
downloadservo-ed809a60bf9ca1ac5babb1ed6575fd1c0c4f6600.tar.gz
servo-ed809a60bf9ca1ac5babb1ed6575fd1c0c4f6600.zip
Implement the overrideMimeType method for XMLHttpRequest
Diffstat (limited to 'components/script/dom')
-rw-r--r--components/script/dom/bindings/trace.rs2
-rw-r--r--components/script/dom/webidls/XMLHttpRequest.webidl3
-rw-r--r--components/script/dom/xmlhttprequest.rs21
3 files changed, 25 insertions, 1 deletions
diff --git a/components/script/dom/bindings/trace.rs b/components/script/dom/bindings/trace.rs
index 6c2f9367350..df5c84d3778 100644
--- a/components/script/dom/bindings/trace.rs
+++ b/components/script/dom/bindings/trace.rs
@@ -45,6 +45,7 @@ use euclid::size::Size2D;
use html5ever::tree_builder::QuirksMode;
use hyper::header::Headers;
use hyper::method::Method;
+use hyper::mime::Mime;
use ipc_channel::ipc::{IpcReceiver, IpcSender};
use js::jsapi::JS_CallUnbarrieredObjectTracer;
use js::jsapi::{GCTraceKindToAscii, Heap, JSGCTraceKind, JSObject, JSTracer, JS_CallObjectTracer, JS_CallValueTracer};
@@ -286,6 +287,7 @@ no_jsmanaged_fields!(PseudoElement);
no_jsmanaged_fields!(Length);
no_jsmanaged_fields!(ElementState);
no_jsmanaged_fields!(DOMString);
+no_jsmanaged_fields!(Mime);
impl JSTraceable for Box<ScriptChan + Send> {
#[inline]
diff --git a/components/script/dom/webidls/XMLHttpRequest.webidl b/components/script/dom/webidls/XMLHttpRequest.webidl
index 3285e859691..aba1569957b 100644
--- a/components/script/dom/webidls/XMLHttpRequest.webidl
+++ b/components/script/dom/webidls/XMLHttpRequest.webidl
@@ -65,7 +65,8 @@ interface XMLHttpRequest : XMLHttpRequestEventTarget {
readonly attribute ByteString statusText;
ByteString? getResponseHeader(ByteString name);
ByteString getAllResponseHeaders();
- // void overrideMimeType(DOMString mime);
+ [Throws]
+ void overrideMimeType(DOMString mime);
[SetterThrows]
attribute XMLHttpRequestResponseType responseType;
readonly attribute any response;
diff --git a/components/script/dom/xmlhttprequest.rs b/components/script/dom/xmlhttprequest.rs
index 10bc4cd8d57..e8025880f2e 100644
--- a/components/script/dom/xmlhttprequest.rs
+++ b/components/script/dom/xmlhttprequest.rs
@@ -121,6 +121,9 @@ pub struct XMLHttpRequest {
response_xml: MutNullableHeap<JS<Document>>,
#[ignore_heap_size_of = "Defined in hyper"]
response_headers: DOMRefCell<Headers>,
+ override_mime_type: DOMRefCell<Option<Mime>>,
+ #[ignore_heap_size_of = "Defined in rust-encoding"]
+ override_charset: DOMRefCell<Option<EncodingRef>>,
// Associated concepts
request_method: DOMRefCell<Method>,
@@ -158,6 +161,8 @@ impl XMLHttpRequest {
response_type: Cell::new(_empty),
response_xml: Default::default(),
response_headers: DOMRefCell::new(Headers::new()),
+ override_mime_type: DOMRefCell::new(None),
+ override_charset: DOMRefCell::new(None),
request_method: DOMRefCell::new(Method::Get),
request_url: DOMRefCell::new(None),
@@ -644,6 +649,21 @@ impl XMLHttpRequestMethods for XMLHttpRequest {
ByteString::new(self.filter_response_headers().to_string().into_bytes())
}
+ // https://xhr.spec.whatwg.org/#the-overridemimetype()-method
+ fn OverrideMimeType(&self, mime: DOMString) -> ErrorResult {
+ match self.ready_state.get() {
+ XMLHttpRequestState::Loading | XMLHttpRequestState::Done => return Err(Error::InvalidState),
+ _ => {},
+ }
+ let override_mime = try!(mime.parse::<Mime>().map_err(|_| Error::Syntax));
+ *self.override_mime_type.borrow_mut() = Some(override_mime.clone());
+ let value = override_mime.get_param(mime::Attr::Charset);
+ *self.override_charset.borrow_mut() = value.and_then(|value| {
+ encoding_from_whatwg_label(value)
+ });
+ Ok(())
+ }
+
// https://xhr.spec.whatwg.org/#the-responsetype-attribute
fn ResponseType(&self) -> XMLHttpRequestResponseType {
self.response_type.get()
@@ -987,6 +1007,7 @@ impl XMLHttpRequest {
}
}
+ //FIXME: add support for override_mime_type and override_charset
fn text_response(&self) -> String {
let mut encoding = UTF_8 as EncodingRef;
match self.response_headers.borrow().get() {