mirror of
https://github.com/servo/servo.git
synced 2025-08-03 20:50:07 +01:00
Correctly initialize URL.searchParams
This commit is contained in:
parent
7932ab6ac2
commit
85de5ec743
3 changed files with 25 additions and 28 deletions
|
@ -42,6 +42,10 @@ impl URL {
|
|||
global, URLBinding::Wrap)
|
||||
}
|
||||
|
||||
pub fn query_pairs(&self) -> Vec<(String, String)> {
|
||||
self.url.borrow().query_pairs().into_owned().collect()
|
||||
}
|
||||
|
||||
pub fn set_query_pairs(&self, pairs: &[(String, String)]) {
|
||||
let mut url = self.url.borrow_mut();
|
||||
url.query_pairs_mut().clear().extend_pairs(pairs);
|
||||
|
|
|
@ -31,7 +31,7 @@ impl URLSearchParams {
|
|||
fn new_inherited(url: Option<&URL>) -> URLSearchParams {
|
||||
URLSearchParams {
|
||||
reflector_: Reflector::new(),
|
||||
list: DOMRefCell::new(vec![]),
|
||||
list: DOMRefCell::new(url.map_or(Vec::new(), |url| url.query_pairs())),
|
||||
url: MutableWeakRef::new(url),
|
||||
}
|
||||
}
|
||||
|
@ -111,6 +111,7 @@ impl URLSearchParamsMethods for URLSearchParams {
|
|||
|
||||
// https://url.spec.whatwg.org/#dom-urlsearchparams-set
|
||||
fn Set(&self, name: USVString, value: USVString) {
|
||||
{
|
||||
// Step 1.
|
||||
let mut list = self.list.borrow_mut();
|
||||
let mut index = None;
|
||||
|
@ -131,6 +132,7 @@ impl URLSearchParamsMethods for URLSearchParams {
|
|||
Some(index) => list[index].1 = value.0,
|
||||
None => list.push((name.0, value.0)), // Step 2.
|
||||
};
|
||||
} // Un-borrow self.list
|
||||
// Step 3.
|
||||
self.update_steps();
|
||||
}
|
||||
|
|
|
@ -75,15 +75,6 @@
|
|||
[Parsing: <h\tt\nt\rp://h\to\ns\rt:9\t0\n0\r0/p\ta\nt\rh?q\tu\ne\rry#f\tr\na\rg> against <about:blank>]
|
||||
expected: FAIL
|
||||
|
||||
[URL.searchParams updating, clearing]
|
||||
expected: FAIL
|
||||
|
||||
[URL.searchParams and URL.search setters, update propagation]
|
||||
expected: FAIL
|
||||
|
||||
[Parsing: <?a=b&c=d> against <http://example.org/foo/bar>]
|
||||
expected: FAIL
|
||||
|
||||
[Parsing: <??a=b&c=d> against <http://example.org/foo/bar>]
|
||||
expected: FAIL
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue