mirror of
https://github.com/servo/servo.git
synced 2025-08-03 20:50:07 +01:00
Auto merge of #9054 - frewsxcv:parse-non-zero-dimension, r=eefriedman
Implement non-zero dimension attribute parsing Fixes #8445 The only attributes I found that we have implemented that uses non-zero dimenion attributes: * `width` for `<td>` and `<th>` (table cells) * `width` for `<table>` I updated these implementations to use the new non-zero dimension attribute parsing and added associated regression tests. <!-- Reviewable:start --> [<img src="https://reviewable.io/review_button.png" height=40 alt="Review on Reviewable"/>](https://reviewable.io/reviews/servo/servo/9054) <!-- Reviewable:end -->
This commit is contained in:
commit
0d52170f35
13 changed files with 227 additions and 291 deletions
|
@ -3,27 +3,25 @@
|
|||
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
|
||||
|
||||
use cssparser::RGBA;
|
||||
use dom::attr::{Attr, AttrValue};
|
||||
use dom::attr::AttrValue;
|
||||
use dom::bindings::codegen::Bindings::HTMLTableCellElementBinding::HTMLTableCellElementMethods;
|
||||
use dom::bindings::codegen::Bindings::NodeBinding::NodeMethods;
|
||||
use dom::bindings::inheritance::Castable;
|
||||
use dom::bindings::js::LayoutJS;
|
||||
use dom::document::Document;
|
||||
use dom::element::{AttributeMutation, Element, RawLayoutElementHelpers};
|
||||
use dom::element::{Element, RawLayoutElementHelpers};
|
||||
use dom::htmlelement::HTMLElement;
|
||||
use dom::htmltablerowelement::HTMLTableRowElement;
|
||||
use dom::node::Node;
|
||||
use dom::virtualmethods::VirtualMethods;
|
||||
use std::cell::Cell;
|
||||
use string_cache::Atom;
|
||||
use util::str::{self, DOMString, LengthOrPercentageOrAuto};
|
||||
use util::str::{DOMString, LengthOrPercentageOrAuto};
|
||||
|
||||
const DEFAULT_COLSPAN: u32 = 1;
|
||||
|
||||
#[dom_struct]
|
||||
pub struct HTMLTableCellElement {
|
||||
htmlelement: HTMLElement,
|
||||
width: Cell<LengthOrPercentageOrAuto>,
|
||||
}
|
||||
|
||||
impl HTMLTableCellElement {
|
||||
|
@ -33,7 +31,6 @@ impl HTMLTableCellElement {
|
|||
-> HTMLTableCellElement {
|
||||
HTMLTableCellElement {
|
||||
htmlelement: HTMLElement::new_inherited(tag_name, prefix, document),
|
||||
width: Cell::new(LengthOrPercentageOrAuto::Auto),
|
||||
}
|
||||
}
|
||||
|
||||
|
@ -56,6 +53,12 @@ impl HTMLTableCellElementMethods for HTMLTableCellElement {
|
|||
// https://html.spec.whatwg.org/multipage/#dom-tdth-bgcolor
|
||||
make_legacy_color_setter!(SetBgColor, "bgcolor");
|
||||
|
||||
// https://html.spec.whatwg.org/multipage/#dom-tdth-width
|
||||
make_getter!(Width, "width");
|
||||
|
||||
// https://html.spec.whatwg.org/multipage/#dom-tdth-width
|
||||
make_nonzero_dimension_setter!(SetWidth, "width");
|
||||
|
||||
// https://html.spec.whatwg.org/multipage/#dom-tdth-cellindex
|
||||
fn CellIndex(&self) -> i32 {
|
||||
let self_node = self.upcast::<Node>();
|
||||
|
@ -101,7 +104,11 @@ impl HTMLTableCellElementLayoutHelpers for LayoutJS<HTMLTableCellElement> {
|
|||
|
||||
fn get_width(&self) -> LengthOrPercentageOrAuto {
|
||||
unsafe {
|
||||
(*self.unsafe_get()).width.get()
|
||||
(&*self.upcast::<Element>().unsafe_get())
|
||||
.get_attr_for_layout(&ns!(), &atom!("width"))
|
||||
.map(AttrValue::as_dimension)
|
||||
.cloned()
|
||||
.unwrap_or(LengthOrPercentageOrAuto::Auto)
|
||||
}
|
||||
}
|
||||
}
|
||||
|
@ -111,23 +118,11 @@ impl VirtualMethods for HTMLTableCellElement {
|
|||
Some(self.upcast::<HTMLElement>() as &VirtualMethods)
|
||||
}
|
||||
|
||||
fn attribute_mutated(&self, attr: &Attr, mutation: AttributeMutation) {
|
||||
self.super_type().unwrap().attribute_mutated(attr, mutation);
|
||||
match *attr.local_name() {
|
||||
atom!("width") => {
|
||||
let width = mutation.new_value(attr).map(|value| {
|
||||
str::parse_length(&value)
|
||||
});
|
||||
self.width.set(width.unwrap_or(LengthOrPercentageOrAuto::Auto));
|
||||
},
|
||||
_ => {},
|
||||
}
|
||||
}
|
||||
|
||||
fn parse_plain_attribute(&self, local_name: &Atom, value: DOMString) -> AttrValue {
|
||||
match *local_name {
|
||||
atom!("colspan") => AttrValue::from_u32(value, DEFAULT_COLSPAN),
|
||||
atom!("bgcolor") => AttrValue::from_legacy_color(value),
|
||||
atom!("width") => AttrValue::from_nonzero_dimension(value),
|
||||
_ => self.super_type().unwrap().parse_plain_attribute(local_name, value),
|
||||
}
|
||||
}
|
||||
|
|
|
@ -120,7 +120,7 @@ impl HTMLTableElementMethods for HTMLTableElement {
|
|||
make_getter!(Width, "width");
|
||||
|
||||
// https://html.spec.whatwg.org/multipage/#dom-table-width
|
||||
make_dimension_setter!(SetWidth, "width");
|
||||
make_nonzero_dimension_setter!(SetWidth, "width");
|
||||
}
|
||||
|
||||
pub trait HTMLTableElementLayoutHelpers {
|
||||
|
@ -195,7 +195,7 @@ impl VirtualMethods for HTMLTableElement {
|
|||
fn parse_plain_attribute(&self, local_name: &Atom, value: DOMString) -> AttrValue {
|
||||
match *local_name {
|
||||
atom!("border") => AttrValue::from_u32(value, 1),
|
||||
atom!("width") => AttrValue::from_dimension(value),
|
||||
atom!("width") => AttrValue::from_nonzero_dimension(value),
|
||||
_ => self.super_type().unwrap().parse_plain_attribute(local_name, value),
|
||||
}
|
||||
}
|
||||
|
|
|
@ -236,6 +236,19 @@ macro_rules! make_dimension_setter(
|
|||
);
|
||||
);
|
||||
|
||||
#[macro_export]
|
||||
macro_rules! make_nonzero_dimension_setter(
|
||||
( $attr:ident, $htmlname:tt ) => (
|
||||
fn $attr(&self, value: DOMString) {
|
||||
use dom::bindings::inheritance::Castable;
|
||||
use dom::element::Element;
|
||||
let element = self.upcast::<Element>();
|
||||
let value = AttrValue::from_nonzero_dimension(value);
|
||||
element.set_attribute(&atom!($htmlname), value)
|
||||
}
|
||||
);
|
||||
);
|
||||
|
||||
/// For use on non-jsmanaged types
|
||||
/// Use #[derive(JSTraceable)] on JS managed types
|
||||
macro_rules! no_jsmanaged_fields(
|
||||
|
|
|
@ -19,7 +19,7 @@ partial interface HTMLTableCellElement {
|
|||
// attribute DOMString align;
|
||||
// attribute DOMString axis;
|
||||
// attribute DOMString height;
|
||||
// attribute DOMString width;
|
||||
attribute DOMString width;
|
||||
|
||||
// attribute DOMString ch;
|
||||
// attribute DOMString chOff;
|
||||
|
|
|
@ -6,7 +6,7 @@ use cssparser::RGBA;
|
|||
use std::ops::Deref;
|
||||
use string_cache::{Atom, Namespace};
|
||||
use util::str::{DOMString, LengthOrPercentageOrAuto, parse_unsigned_integer, parse_legacy_color, parse_length};
|
||||
use util::str::{split_html_space_chars, str_join, parse_integer};
|
||||
use util::str::{parse_nonzero_length, split_html_space_chars, str_join, parse_integer};
|
||||
use values::specified::{Length};
|
||||
|
||||
// Duplicated from script::dom::values.
|
||||
|
@ -96,6 +96,11 @@ impl AttrValue {
|
|||
AttrValue::Dimension(string, parsed)
|
||||
}
|
||||
|
||||
pub fn from_nonzero_dimension(string: DOMString) -> AttrValue {
|
||||
let parsed = parse_nonzero_length(&string);
|
||||
AttrValue::Dimension(string, parsed)
|
||||
}
|
||||
|
||||
/// Assumes the `AttrValue` is a `TokenList` and returns its tokens
|
||||
///
|
||||
/// ## Panics
|
||||
|
|
|
@ -4,6 +4,7 @@
|
|||
|
||||
use app_units::Au;
|
||||
use cssparser::{self, Color, RGBA};
|
||||
use euclid::num::Zero;
|
||||
use js::conversions::{FromJSValConvertible, ToJSValConvertible, latin1_to_string};
|
||||
use js::jsapi::{JSContext, JSString, HandleValue, MutableHandleValue};
|
||||
use js::jsapi::{JS_GetTwoByteStringCharsAndLength, JS_StringHasLatin1Chars};
|
||||
|
@ -372,6 +373,17 @@ pub fn parse_length(mut value: &str) -> LengthOrPercentageOrAuto {
|
|||
}
|
||||
}
|
||||
|
||||
/// HTML5 § 2.4.4.5.
|
||||
///
|
||||
/// https://html.spec.whatwg.org/multipage/#rules-for-parsing-non-zero-dimension-values
|
||||
pub fn parse_nonzero_length(value: &str) -> LengthOrPercentageOrAuto {
|
||||
match parse_length(value) {
|
||||
LengthOrPercentageOrAuto::Length(x) if x == Au::zero() => LengthOrPercentageOrAuto::Auto,
|
||||
LengthOrPercentageOrAuto::Percentage(0.) => LengthOrPercentageOrAuto::Auto,
|
||||
x => x,
|
||||
}
|
||||
}
|
||||
|
||||
/// https://html.spec.whatwg.org/multipage/#rules-for-parsing-a-legacy-font-size
|
||||
pub fn parse_legacy_font_size(mut input: &str) -> Option<&'static str> {
|
||||
// Steps 1 & 2 are not relevant
|
||||
|
|
|
@ -4589,6 +4589,16 @@
|
|||
],
|
||||
"url": "/html/rendering/non-replaced-elements/tables/table-border-2.html"
|
||||
},
|
||||
{
|
||||
"path": "html/rendering/non-replaced-elements/tables/table-cell-width.html",
|
||||
"references": [
|
||||
[
|
||||
"/html/rendering/non-replaced-elements/tables/table-cell-width-ref.html",
|
||||
"=="
|
||||
]
|
||||
],
|
||||
"url": "/html/rendering/non-replaced-elements/tables/table-cell-width.html"
|
||||
},
|
||||
{
|
||||
"path": "html/rendering/non-replaced-elements/tables/table-layout.html",
|
||||
"references": [
|
||||
|
@ -4609,6 +4619,16 @@
|
|||
],
|
||||
"url": "/html/rendering/non-replaced-elements/tables/table-width-150percent.html"
|
||||
},
|
||||
{
|
||||
"path": "html/rendering/non-replaced-elements/tables/table-width.html",
|
||||
"references": [
|
||||
[
|
||||
"/html/rendering/non-replaced-elements/tables/table-width-ref.html",
|
||||
"=="
|
||||
]
|
||||
],
|
||||
"url": "/html/rendering/non-replaced-elements/tables/table-width.html"
|
||||
},
|
||||
{
|
||||
"path": "html/rendering/non-replaced-elements/the-fieldset-element-0/min-width-not-important.html",
|
||||
"references": [
|
||||
|
@ -32277,6 +32297,18 @@
|
|||
"url": "/html/rendering/non-replaced-elements/tables/table-border-2.html"
|
||||
}
|
||||
],
|
||||
"html/rendering/non-replaced-elements/tables/table-cell-width.html": [
|
||||
{
|
||||
"path": "html/rendering/non-replaced-elements/tables/table-cell-width.html",
|
||||
"references": [
|
||||
[
|
||||
"/html/rendering/non-replaced-elements/tables/table-cell-width-ref.html",
|
||||
"=="
|
||||
]
|
||||
],
|
||||
"url": "/html/rendering/non-replaced-elements/tables/table-cell-width.html"
|
||||
}
|
||||
],
|
||||
"html/rendering/non-replaced-elements/tables/table-layout.html": [
|
||||
{
|
||||
"path": "html/rendering/non-replaced-elements/tables/table-layout.html",
|
||||
|
@ -32301,6 +32333,18 @@
|
|||
"url": "/html/rendering/non-replaced-elements/tables/table-width-150percent.html"
|
||||
}
|
||||
],
|
||||
"html/rendering/non-replaced-elements/tables/table-width.html": [
|
||||
{
|
||||
"path": "html/rendering/non-replaced-elements/tables/table-width.html",
|
||||
"references": [
|
||||
[
|
||||
"/html/rendering/non-replaced-elements/tables/table-width-ref.html",
|
||||
"=="
|
||||
]
|
||||
],
|
||||
"url": "/html/rendering/non-replaced-elements/tables/table-width.html"
|
||||
}
|
||||
],
|
||||
"html/rendering/non-replaced-elements/the-fieldset-element-0/min-width-not-important.html": [
|
||||
{
|
||||
"path": "html/rendering/non-replaced-elements/the-fieldset-element-0/min-width-not-important.html",
|
||||
|
|
|
@ -4683,9 +4683,6 @@
|
|||
[HTMLTableCellElement interface: document.createElement("td") must inherit property "height" with the proper type (6)]
|
||||
expected: FAIL
|
||||
|
||||
[HTMLTableCellElement interface: document.createElement("td") must inherit property "width" with the proper type (7)]
|
||||
expected: FAIL
|
||||
|
||||
[HTMLTableCellElement interface: document.createElement("td") must inherit property "ch" with the proper type (8)]
|
||||
expected: FAIL
|
||||
|
||||
|
@ -4740,9 +4737,6 @@
|
|||
[HTMLTableCellElement interface: document.createElement("th") must inherit property "height" with the proper type (6)]
|
||||
expected: FAIL
|
||||
|
||||
[HTMLTableCellElement interface: document.createElement("th") must inherit property "width" with the proper type (7)]
|
||||
expected: FAIL
|
||||
|
||||
[HTMLTableCellElement interface: document.createElement("th") must inherit property "ch" with the proper type (8)]
|
||||
expected: FAIL
|
||||
|
||||
|
@ -4773,9 +4767,6 @@
|
|||
[HTMLTableCellElement interface: attribute height]
|
||||
expected: FAIL
|
||||
|
||||
[HTMLTableCellElement interface: attribute width]
|
||||
expected: FAIL
|
||||
|
||||
[HTMLTableCellElement interface: attribute ch]
|
||||
expected: FAIL
|
||||
|
||||
|
|
|
@ -11721,135 +11721,6 @@
|
|||
[td.height: IDL set to object "test-valueOf" followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: typeof IDL attribute]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: IDL get with DOM attribute unset]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: setAttribute() to "" followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: setAttribute() to " \\0\\x01\\x02\\x03\\x04\\x05\\x06\\x07 \\b\\t\\n\\v\\f\\r\\x0e\\x0f \\x10\\x11\\x12\\x13\\x14\\x15\\x16\\x17 \\x18\\x19\\x1a\\x1b\\x1c\\x1d\\x1e\\x1f foo " followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: setAttribute() to undefined followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: setAttribute() to 7 followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: setAttribute() to 1.5 followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: setAttribute() to true followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: setAttribute() to false followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: setAttribute() to object "[object Object\]" followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: setAttribute() to NaN followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: setAttribute() to Infinity followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: setAttribute() to -Infinity followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: setAttribute() to "\\0" followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: setAttribute() to null followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: setAttribute() to object "test-toString" followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: setAttribute() to object "test-valueOf" followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: IDL set to "" followed by getAttribute()]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: IDL set to " \\0\\x01\\x02\\x03\\x04\\x05\\x06\\x07 \\b\\t\\n\\v\\f\\r\\x0e\\x0f \\x10\\x11\\x12\\x13\\x14\\x15\\x16\\x17 \\x18\\x19\\x1a\\x1b\\x1c\\x1d\\x1e\\x1f foo " followed by getAttribute()]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: IDL set to undefined followed by getAttribute()]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: IDL set to undefined followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: IDL set to 7 followed by getAttribute()]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: IDL set to 7 followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: IDL set to 1.5 followed by getAttribute()]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: IDL set to 1.5 followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: IDL set to true followed by getAttribute()]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: IDL set to true followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: IDL set to false followed by getAttribute()]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: IDL set to false followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: IDL set to object "[object Object\]" followed by getAttribute()]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: IDL set to object "[object Object\]" followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: IDL set to NaN followed by getAttribute()]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: IDL set to NaN followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: IDL set to Infinity followed by getAttribute()]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: IDL set to Infinity followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: IDL set to -Infinity followed by getAttribute()]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: IDL set to -Infinity followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: IDL set to "\\0" followed by getAttribute()]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: IDL set to null followed by getAttribute()]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: IDL set to null followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: IDL set to object "test-toString" followed by getAttribute()]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: IDL set to object "test-toString" followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[td.width: IDL set to object "test-valueOf" followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[td.ch (<td char>): typeof IDL attribute]
|
||||
expected: FAIL
|
||||
|
||||
|
@ -13776,135 +13647,6 @@
|
|||
[th.height: IDL set to object "test-valueOf" followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: typeof IDL attribute]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: IDL get with DOM attribute unset]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: setAttribute() to "" followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: setAttribute() to " \\0\\x01\\x02\\x03\\x04\\x05\\x06\\x07 \\b\\t\\n\\v\\f\\r\\x0e\\x0f \\x10\\x11\\x12\\x13\\x14\\x15\\x16\\x17 \\x18\\x19\\x1a\\x1b\\x1c\\x1d\\x1e\\x1f foo " followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: setAttribute() to undefined followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: setAttribute() to 7 followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: setAttribute() to 1.5 followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: setAttribute() to true followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: setAttribute() to false followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: setAttribute() to object "[object Object\]" followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: setAttribute() to NaN followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: setAttribute() to Infinity followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: setAttribute() to -Infinity followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: setAttribute() to "\\0" followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: setAttribute() to null followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: setAttribute() to object "test-toString" followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: setAttribute() to object "test-valueOf" followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: IDL set to "" followed by getAttribute()]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: IDL set to " \\0\\x01\\x02\\x03\\x04\\x05\\x06\\x07 \\b\\t\\n\\v\\f\\r\\x0e\\x0f \\x10\\x11\\x12\\x13\\x14\\x15\\x16\\x17 \\x18\\x19\\x1a\\x1b\\x1c\\x1d\\x1e\\x1f foo " followed by getAttribute()]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: IDL set to undefined followed by getAttribute()]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: IDL set to undefined followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: IDL set to 7 followed by getAttribute()]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: IDL set to 7 followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: IDL set to 1.5 followed by getAttribute()]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: IDL set to 1.5 followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: IDL set to true followed by getAttribute()]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: IDL set to true followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: IDL set to false followed by getAttribute()]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: IDL set to false followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: IDL set to object "[object Object\]" followed by getAttribute()]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: IDL set to object "[object Object\]" followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: IDL set to NaN followed by getAttribute()]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: IDL set to NaN followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: IDL set to Infinity followed by getAttribute()]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: IDL set to Infinity followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: IDL set to -Infinity followed by getAttribute()]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: IDL set to -Infinity followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: IDL set to "\\0" followed by getAttribute()]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: IDL set to null followed by getAttribute()]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: IDL set to null followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: IDL set to object "test-toString" followed by getAttribute()]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: IDL set to object "test-toString" followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[th.width: IDL set to object "test-valueOf" followed by IDL get]
|
||||
expected: FAIL
|
||||
|
||||
[th.ch (<th char>): typeof IDL attribute]
|
||||
expected: FAIL
|
||||
|
||||
|
|
|
@ -0,0 +1,37 @@
|
|||
<style>
|
||||
body {
|
||||
margin: 0;
|
||||
}
|
||||
|
||||
.row {
|
||||
clear: both;
|
||||
}
|
||||
|
||||
.row div {
|
||||
float: left;
|
||||
}
|
||||
|
||||
.red {
|
||||
background-color: red;
|
||||
}
|
||||
</style>
|
||||
|
||||
<div class="row">
|
||||
<div class="red" style="width: 200px">a</div>
|
||||
<div style="width: 200px">a</div>
|
||||
</div>
|
||||
|
||||
<div class="row">
|
||||
<div class="red" style="width: 200px">a</div>
|
||||
<div style="width: 200px">a</div>
|
||||
</div>
|
||||
|
||||
<div class="row">
|
||||
<div class="red" style="width: 100px">a</div>
|
||||
<div style="width: 300px">a</div>
|
||||
</div>
|
||||
|
||||
<div class="row">
|
||||
<div class="red" style="width: 100px">a</div>
|
||||
<div style="width: 300px">a</div>
|
||||
</div>
|
|
@ -0,0 +1,54 @@
|
|||
<link rel="match" href="table-cell-width-ref.html">
|
||||
<style>
|
||||
body {
|
||||
margin: 0;
|
||||
}
|
||||
|
||||
table {
|
||||
width: 400px;
|
||||
border-collapse: collapse;
|
||||
}
|
||||
|
||||
th {
|
||||
font-weight: normal;
|
||||
text-align: left;
|
||||
}
|
||||
|
||||
td, th {
|
||||
padding: 0;
|
||||
}
|
||||
|
||||
td:first-child, th:first-child {
|
||||
background-color: red;
|
||||
}
|
||||
</style>
|
||||
|
||||
<!-- width=0 should be treated as 'auto' -->
|
||||
<table>
|
||||
<tr>
|
||||
<th width=0>a</th>
|
||||
<th>a</th>
|
||||
</tr>
|
||||
</table>
|
||||
|
||||
<table>
|
||||
<tr>
|
||||
<td width=0>a</td>
|
||||
<td>a</td>
|
||||
</tr>
|
||||
</table>
|
||||
|
||||
<!-- test valid width attribute value-->
|
||||
<table>
|
||||
<tr>
|
||||
<th width=100>a</th>
|
||||
<th>a</th>
|
||||
</tr>
|
||||
</table>
|
||||
|
||||
<table>
|
||||
<tr>
|
||||
<td width=100>a</td>
|
||||
<td>a</td>
|
||||
</tr>
|
||||
</table>
|
|
@ -0,0 +1,13 @@
|
|||
<style>
|
||||
p {
|
||||
padding: 0;
|
||||
margin: 0;
|
||||
}
|
||||
</style>
|
||||
|
||||
<p>a b</p>
|
||||
|
||||
<hr>
|
||||
|
||||
<p>a</p>
|
||||
<p>b</p>
|
|
@ -0,0 +1,30 @@
|
|||
<link rel="match" href="table-width-ref.html">
|
||||
|
||||
<style>
|
||||
table {
|
||||
border-collapse: collapse;
|
||||
}
|
||||
|
||||
td {
|
||||
padding: 0;
|
||||
}
|
||||
</style>
|
||||
|
||||
<!-- width=0 should be treated as 'auto' -->
|
||||
<table width=0>
|
||||
<tr>
|
||||
<td>
|
||||
a b
|
||||
</td>
|
||||
</tr>
|
||||
</table>
|
||||
|
||||
<hr>
|
||||
|
||||
<table width=1>
|
||||
<tr>
|
||||
<td>
|
||||
a b
|
||||
</td>
|
||||
</tr>
|
||||
</table>
|
Loading…
Add table
Add a link
Reference in a new issue