mirror of
https://github.com/servo/servo.git
synced 2025-08-03 12:40:06 +01:00
Make script origins sendable and immutable.
This commit is contained in:
parent
922aef9dd6
commit
555661ef1c
2 changed files with 12 additions and 64 deletions
|
@ -2,63 +2,53 @@
|
||||||
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
* License, v. 2.0. If a copy of the MPL was not distributed with this
|
||||||
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
||||||
|
|
||||||
use ref_filter_map::ref_filter_map;
|
use std::sync::Arc;
|
||||||
use std::cell::{RefCell, Ref};
|
|
||||||
use std::rc::Rc;
|
|
||||||
use url::Origin as UrlOrigin;
|
use url::Origin as UrlOrigin;
|
||||||
use url::{Url, Host};
|
use url::{Url, Host};
|
||||||
|
|
||||||
/// A representation of an [origin](https://html.spec.whatwg.org/multipage/#origin-2).
|
/// A representation of an [origin](https://html.spec.whatwg.org/multipage/#origin-2).
|
||||||
#[derive(HeapSizeOf)]
|
#[derive(HeapSizeOf, JSTraceable)]
|
||||||
pub struct Origin {
|
pub struct Origin {
|
||||||
#[ignore_heap_size_of = "Rc<T> has unclear ownership semantics"]
|
#[ignore_heap_size_of = "Arc<T> has unclear ownership semantics"]
|
||||||
inner: Rc<RefCell<UrlOrigin>>,
|
inner: Arc<UrlOrigin>,
|
||||||
}
|
}
|
||||||
|
|
||||||
// We can't use RefCell inside JSTraceable, but Origin doesn't contain JS values and
|
|
||||||
// DOMRefCell makes it much harder to write unit tests (due to setting up required TLS).
|
|
||||||
no_jsmanaged_fields!(Origin);
|
|
||||||
|
|
||||||
impl Origin {
|
impl Origin {
|
||||||
/// Create a new origin comprising a unique, opaque identifier.
|
/// Create a new origin comprising a unique, opaque identifier.
|
||||||
pub fn opaque_identifier() -> Origin {
|
pub fn opaque_identifier() -> Origin {
|
||||||
Origin {
|
Origin {
|
||||||
inner: Rc::new(RefCell::new(UrlOrigin::new_opaque())),
|
inner: Arc::new(UrlOrigin::new_opaque()),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Create a new origin for the given URL.
|
/// Create a new origin for the given URL.
|
||||||
pub fn new(url: &Url) -> Origin {
|
pub fn new(url: &Url) -> Origin {
|
||||||
Origin {
|
Origin {
|
||||||
inner: Rc::new(RefCell::new(url.origin())),
|
inner: Arc::new(url.origin()),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn set(&self, origin: UrlOrigin) {
|
|
||||||
*self.inner.borrow_mut() = origin;
|
|
||||||
}
|
|
||||||
|
|
||||||
/// Does this origin represent a host/scheme/port tuple?
|
/// Does this origin represent a host/scheme/port tuple?
|
||||||
pub fn is_scheme_host_port_tuple(&self) -> bool {
|
pub fn is_scheme_host_port_tuple(&self) -> bool {
|
||||||
self.inner.borrow().is_tuple()
|
self.inner.is_tuple()
|
||||||
}
|
}
|
||||||
|
|
||||||
/// Return the host associated with this origin.
|
/// Return the host associated with this origin.
|
||||||
pub fn host(&self) -> Option<Ref<Host<String>>> {
|
pub fn host(&self) -> Option<&Host<String>> {
|
||||||
ref_filter_map(self.inner.borrow(), |origin| match *origin {
|
match *self.inner {
|
||||||
UrlOrigin::Tuple(_, ref host, _) => Some(host),
|
UrlOrigin::Tuple(_, ref host, _) => Some(host),
|
||||||
UrlOrigin::Opaque(..) => None,
|
UrlOrigin::Opaque(..) => None,
|
||||||
})
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
/// https://html.spec.whatwg.org/multipage/#same-origin
|
/// https://html.spec.whatwg.org/multipage/#same-origin
|
||||||
pub fn same_origin(&self, other: &Origin) -> bool {
|
pub fn same_origin(&self, other: &Origin) -> bool {
|
||||||
*self.inner.borrow() == *other.inner.borrow()
|
self.inner == other.inner
|
||||||
}
|
}
|
||||||
|
|
||||||
pub fn copy(&self) -> Origin {
|
pub fn copy(&self) -> Origin {
|
||||||
Origin {
|
Origin {
|
||||||
inner: Rc::new(RefCell::new(self.inner.borrow().clone())),
|
inner: Arc::new((*self.inner).clone()),
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -47,48 +47,6 @@ fn alias_cross_origin() {
|
||||||
assert!(c.same_origin(&c));
|
assert!(c.same_origin(&c));
|
||||||
}
|
}
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn alias_update_same_origin() {
|
|
||||||
let a = Origin::new(&Url::parse("http://example.com/a.html").unwrap());
|
|
||||||
let b = Origin::new(&Url::parse("http://example.org/b.html").unwrap());
|
|
||||||
let c = b.alias();
|
|
||||||
b.set(Url::parse("http://example.com/c.html").unwrap().origin());
|
|
||||||
assert!(a.same_origin(&c));
|
|
||||||
assert!(b.same_origin(&c));
|
|
||||||
assert!(c.same_origin(&c));
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn alias_update_cross_origin() {
|
|
||||||
let a = Origin::new(&Url::parse("http://example.com/a.html").unwrap());
|
|
||||||
let b = Origin::new(&Url::parse("http://example.com/b.html").unwrap());
|
|
||||||
let c = b.alias();
|
|
||||||
b.set(Url::parse("http://example.org/c.html").unwrap().origin());
|
|
||||||
assert!(!a.same_origin(&c));
|
|
||||||
assert!(b.same_origin(&c));
|
|
||||||
assert!(c.same_origin(&c));
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
|
||||||
fn alias_chain() {
|
|
||||||
let a = Origin::new(&Url::parse("http://example.com/a.html").unwrap());
|
|
||||||
let b = Origin::new(&Url::parse("http://example.com/b.html").unwrap());
|
|
||||||
let c = b.copy();
|
|
||||||
let d = c.alias();
|
|
||||||
let e = d.alias();
|
|
||||||
assert!(a.same_origin(&e));
|
|
||||||
assert!(b.same_origin(&e));
|
|
||||||
assert!(c.same_origin(&e));
|
|
||||||
assert!(d.same_origin(&e));
|
|
||||||
assert!(e.same_origin(&e));
|
|
||||||
c.set(Url::parse("http://example.org/c.html").unwrap().origin());
|
|
||||||
assert!(a.same_origin(&b));
|
|
||||||
assert!(!b.same_origin(&c));
|
|
||||||
assert!(c.same_origin(&d));
|
|
||||||
assert!(d.same_origin(&e));
|
|
||||||
assert!(!e.same_origin(&a));
|
|
||||||
}
|
|
||||||
|
|
||||||
#[test]
|
#[test]
|
||||||
fn opaque() {
|
fn opaque() {
|
||||||
let a = Origin::opaque_identifier();
|
let a = Origin::opaque_identifier();
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue