<!-- Please describe your changes on the following line: --> I just changed the `prefix` parameters on the constructors of several HTML elements. The type now is `Option<Prefix>`. I also changed the sizes of the `sizeof.rs` unit test to match the new values. --- <!-- Thank you for contributing to Servo! Please replace each `[ ]` by `[X]` when the step is complete, and replace `__` with appropriate data: --> - [X] `./mach build -d` does not report any errors - [X] `./mach test-tidy` does not report any errors - [X] These changes fix #16700 (github issue number if applicable). <!-- Either: --> - [ ] There are tests for these changes OR - [X] These changes do not require tests because it should not affect anything else <!-- Also, please make sure that "Allow edits from maintainers" checkbox is checked, so that we can help you if you get stuck somewhere along the way.--> <!-- Pull requests that do not address these steps are welcome, but they will require additional verification as part of the review process. --> Source-Repo: https://github.com/servo/servo Source-Revision: ed7686b42c02c5c1d769be952ef58b285f35a7f6
60 lines
2.0 KiB
Rust
60 lines
2.0 KiB
Rust
/* This Source Code Form is subject to the terms of the Mozilla Public
|
|
* 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/. */
|
|
|
|
use dom::bindings::codegen::Bindings::HTMLLIElementBinding;
|
|
use dom::bindings::codegen::Bindings::HTMLLIElementBinding::HTMLLIElementMethods;
|
|
use dom::bindings::inheritance::Castable;
|
|
use dom::bindings::js::Root;
|
|
use dom::bindings::str::DOMString;
|
|
use dom::document::Document;
|
|
use dom::htmlelement::HTMLElement;
|
|
use dom::node::Node;
|
|
use dom::virtualmethods::VirtualMethods;
|
|
use dom_struct::dom_struct;
|
|
use html5ever::{LocalName, Prefix};
|
|
use style::attr::AttrValue;
|
|
|
|
#[dom_struct]
|
|
pub struct HTMLLIElement {
|
|
htmlelement: HTMLElement,
|
|
}
|
|
|
|
impl HTMLLIElement {
|
|
fn new_inherited(local_name: LocalName, prefix: Option<Prefix>, document: &Document) -> HTMLLIElement {
|
|
HTMLLIElement {
|
|
htmlelement: HTMLElement::new_inherited(local_name, prefix, document)
|
|
}
|
|
}
|
|
|
|
#[allow(unrooted_must_root)]
|
|
pub fn new(local_name: LocalName,
|
|
prefix: Option<Prefix>,
|
|
document: &Document) -> Root<HTMLLIElement> {
|
|
Node::reflect_node(box HTMLLIElement::new_inherited(local_name, prefix, document),
|
|
document,
|
|
HTMLLIElementBinding::Wrap)
|
|
}
|
|
}
|
|
|
|
impl HTMLLIElementMethods for HTMLLIElement {
|
|
// https://html.spec.whatwg.org/multipage/#dom-li-value
|
|
make_int_getter!(Value, "value");
|
|
|
|
// https://html.spec.whatwg.org/multipage/#dom-li-value
|
|
make_int_setter!(SetValue, "value");
|
|
}
|
|
|
|
impl VirtualMethods for HTMLLIElement {
|
|
fn super_type(&self) -> Option<&VirtualMethods> {
|
|
Some(self.upcast::<HTMLElement>() as &VirtualMethods)
|
|
}
|
|
|
|
fn parse_plain_attribute(&self, name: &LocalName, value: DOMString) -> AttrValue {
|
|
match name {
|
|
&local_name!("value") => AttrValue::from_i32(value.into(), 0),
|
|
_ => self.super_type().unwrap().parse_plain_attribute(name, value),
|
|
}
|
|
}
|
|
}
|