diff options
Diffstat (limited to 'components/style/selectors.rs')
-rw-r--r-- | components/style/selectors.rs | 66 |
1 files changed, 33 insertions, 33 deletions
diff --git a/components/style/selectors.rs b/components/style/selectors.rs index 55b2fc687d0..a4c4b0bea53 100644 --- a/components/style/selectors.rs +++ b/components/style/selectors.rs @@ -5,7 +5,7 @@ use std::cmp; use std::ascii::{AsciiExt, OwnedAsciiExt}; use std::sync::Arc; -use std::str::CowString; +use std::string::CowString; use cssparser::{Token, Parser, parse_nth}; use string_cache::{Atom, Namespace}; @@ -16,14 +16,14 @@ use namespaces::NamespaceMap; use stylesheets::Origin; -#[deriving(PartialEq, Clone, Show)] +#[derive(PartialEq, Clone, Show)] pub struct Selector { pub compound_selectors: Arc<CompoundSelector>, pub pseudo_element: Option<PseudoElement>, pub specificity: u32, } -#[deriving(Eq, PartialEq, Clone, Hash, Copy, Show)] +#[derive(Eq, PartialEq, Clone, Hash, Copy, Show)] pub enum PseudoElement { Before, After, @@ -31,13 +31,13 @@ pub enum PseudoElement { } -#[deriving(PartialEq, Clone, Show)] +#[derive(PartialEq, Clone, Show)] pub struct CompoundSelector { pub simple_selectors: Vec<SimpleSelector>, pub next: Option<(Box<CompoundSelector>, Combinator)>, // c.next is left of c } -#[deriving(PartialEq, Clone, Copy, Show)] +#[derive(PartialEq, Clone, Copy, Show)] pub enum Combinator { Child, // > Descendant, // space @@ -45,7 +45,7 @@ pub enum Combinator { LaterSibling, // ~ } -#[deriving(Eq, PartialEq, Clone, Hash, Show)] +#[derive(Eq, PartialEq, Clone, Hash, Show)] pub enum SimpleSelector { ID(Atom), Class(Atom), @@ -85,27 +85,27 @@ pub enum SimpleSelector { } -#[deriving(Eq, PartialEq, Clone, Hash, Copy, Show)] +#[derive(Eq, PartialEq, Clone, Hash, Copy, Show)] pub enum CaseSensitivity { CaseSensitive, // Selectors spec says language-defined, but HTML says sensitive. CaseInsensitive, } -#[deriving(Eq, PartialEq, Clone, Hash, Show)] +#[derive(Eq, PartialEq, Clone, Hash, Show)] pub struct LocalName { pub name: Atom, pub lower_name: Atom, } -#[deriving(Eq, PartialEq, Clone, Hash, Show)] +#[derive(Eq, PartialEq, Clone, Hash, Show)] pub struct AttrSelector { pub name: Atom, pub lower_name: Atom, pub namespace: NamespaceConstraint, } -#[deriving(Eq, PartialEq, Clone, Hash, Show)] +#[derive(Eq, PartialEq, Clone, Hash, Show)] pub enum NamespaceConstraint { Any, Specific(Namespace), @@ -288,7 +288,7 @@ fn parse_type_selector(context: &ParserContext, input: &mut Parser) Some(name) => { simple_selectors.push(SimpleSelector::LocalName(LocalName { name: Atom::from_slice(name.as_slice()), - lower_name: Atom::from_slice(name.into_owned().into_ascii_lower().as_slice()) + lower_name: Atom::from_slice(name.into_owned().into_ascii_lowercase().as_slice()) })) } None => (), @@ -299,7 +299,7 @@ fn parse_type_selector(context: &ParserContext, input: &mut Parser) } -#[deriving(Show)] +#[derive(Show)] enum SimpleSelectorParseResult { SimpleSelector(SimpleSelector), PseudoElement(PseudoElement), @@ -313,7 +313,7 @@ fn parse_qualified_name<'i, 't> (context: &ParserContext, input: &mut Parser<'i, 't>, in_attr_selector: bool) -> Result<Option<(NamespaceConstraint, Option<CowString<'i>>)>, ()> { - let default_namespace = |local_name| { + let default_namespace = |:local_name| { let namespace = match context.namespaces.default { Some(ref ns) => NamespaceConstraint::Specific(ns.clone()), None => NamespaceConstraint::Any, @@ -321,7 +321,7 @@ fn parse_qualified_name<'i, 't> Ok(Some((namespace, local_name))) }; - let explicit_namespace = |input: &mut Parser<'i, 't>, namespace| { + let explicit_namespace = |&: input: &mut Parser<'i, 't>, namespace| { match input.next_including_whitespace() { Ok(Token::Delim('*')) if !in_attr_selector => { Ok(Some((namespace, None))) @@ -383,7 +383,7 @@ fn parse_attribute_selector(context: &ParserContext, input: &mut Parser) Some((_, None)) => unreachable!(), Some((namespace, Some(local_name))) => AttrSelector { namespace: namespace, - lower_name: Atom::from_slice(local_name.as_slice().to_ascii_lower().as_slice()), + lower_name: Atom::from_slice(local_name.as_slice().to_ascii_lowercase().as_slice()), name: Atom::from_slice(local_name.as_slice()), }, }; @@ -408,7 +408,7 @@ fn parse_attribute_selector(context: &ParserContext, input: &mut Parser) // [foo|=bar] Ok(Token::DashMatch) => { let value = try!(parse_value(input)); - let dashing_value = format!("{}-", value); + let dashing_value = format!("{:?}-", value); Ok(SimpleSelector::AttrDashMatch(attr, value, dashing_value)) } // [foo^=bar] @@ -507,7 +507,7 @@ fn parse_functional_pseudo_class(context: &ParserContext, name: &str, inside_negation: bool) -> Result<SimpleSelector,()> { - match_ignore_ascii_case! { name: + match_ignore_ascii_case! { name, "nth-child" => parse_nth_pseudo_class(input, SimpleSelector::NthChild), "nth-of-type" => parse_nth_pseudo_class(input, SimpleSelector::NthOfType), "nth-last-child" => parse_nth_pseudo_class(input, SimpleSelector::NthLastChild), @@ -524,8 +524,8 @@ fn parse_functional_pseudo_class(context: &ParserContext, } -fn parse_nth_pseudo_class(input: &mut Parser, selector: |i32, i32| -> SimpleSelector) - -> Result<SimpleSelector, ()> { +fn parse_nth_pseudo_class<F>(input: &mut Parser, selector: F) -> Result<SimpleSelector, ()> +where F: FnOnce(i32, i32) -> SimpleSelector { let (a, b) = try!(parse_nth(input)); Ok(selector(a, b)) } @@ -566,7 +566,7 @@ fn parse_one_simple_selector(context: &ParserContext, Ok(Token::Ident(name)) => { match parse_simple_pseudo_class(context, name.as_slice()) { Err(()) => { - let pseudo_element = match_ignore_ascii_case! { name: + let pseudo_element = match_ignore_ascii_case! { name, // Supported CSS 2.1 pseudo-elements only. // ** Do not add to this list! ** "before" => PseudoElement::Before, @@ -607,7 +607,7 @@ fn parse_one_simple_selector(context: &ParserContext, } fn parse_simple_pseudo_class(context: &ParserContext, name: &str) -> Result<SimpleSelector,()> { - match_ignore_ascii_case! { name: + match_ignore_ascii_case! { name, "any-link" => Ok(SimpleSelector::AnyLink), "link" => Ok(SimpleSelector::Link), "visited" => Ok(SimpleSelector::Visited), @@ -635,7 +635,7 @@ fn parse_simple_pseudo_class(context: &ParserContext, name: &str) -> Result<Simp } fn parse_pseudo_element(name: &str) -> Result<PseudoElement, ()> { - match_ignore_ascii_case! { name: + match_ignore_ascii_case! { name, "before" => Ok(PseudoElement::Before), "after" => Ok(PseudoElement::After) _ => Err(()) @@ -673,7 +673,7 @@ mod tests { #[test] fn test_parsing() { - assert_eq!(parse(""), Err(())) + assert_eq!(parse(""), Err(())) ; assert_eq!(parse("EeÉ"), Ok(vec!(Selector { compound_selectors: Arc::new(CompoundSelector { simple_selectors: vec!(SimpleSelector::LocalName(LocalName { @@ -683,7 +683,7 @@ mod tests { }), pseudo_element: None, specificity: specificity(0, 0, 1), - }))) + }))); assert_eq!(parse(".foo"), Ok(vec!(Selector { compound_selectors: Arc::new(CompoundSelector { simple_selectors: vec!(SimpleSelector::Class(Atom::from_slice("foo"))), @@ -691,7 +691,7 @@ mod tests { }), pseudo_element: None, specificity: specificity(0, 1, 0), - }))) + }))); assert_eq!(parse("#bar"), Ok(vec!(Selector { compound_selectors: Arc::new(CompoundSelector { simple_selectors: vec!(SimpleSelector::ID(Atom::from_slice("bar"))), @@ -699,7 +699,7 @@ mod tests { }), pseudo_element: None, specificity: specificity(1, 0, 0), - }))) + }))); assert_eq!(parse("e.foo#bar"), Ok(vec!(Selector { compound_selectors: Arc::new(CompoundSelector { simple_selectors: vec!(SimpleSelector::LocalName(LocalName { @@ -711,7 +711,7 @@ mod tests { }), pseudo_element: None, specificity: specificity(1, 1, 1), - }))) + }))); assert_eq!(parse("e.foo #bar"), Ok(vec!(Selector { compound_selectors: Arc::new(CompoundSelector { simple_selectors: vec!(SimpleSelector::ID(Atom::from_slice("bar"))), @@ -725,7 +725,7 @@ mod tests { }), pseudo_element: None, specificity: specificity(1, 1, 1), - }))) + }))); // Default namespace does not apply to attribute selectors // https://github.com/mozilla/servo/pull/1652 let mut namespaces = NamespaceMap::new(); @@ -740,7 +740,7 @@ mod tests { }), pseudo_element: None, specificity: specificity(0, 1, 0), - }))) + }))); // Default namespace does not apply to attribute selectors // https://github.com/mozilla/servo/pull/1652 namespaces.default = Some(ns!(MathML)); @@ -755,7 +755,7 @@ mod tests { }), pseudo_element: None, specificity: specificity(0, 1, 0), - }))) + }))); // Default namespace does apply to type selectors assert_eq!(parse_ns("e", namespaces), Ok(vec!(Selector { compound_selectors: Arc::new(CompoundSelector { @@ -769,7 +769,7 @@ mod tests { }), pseudo_element: None, specificity: specificity(0, 0, 1), - }))) + }))); // https://github.com/mozilla/servo/issues/1723 assert_eq!(parse("::before"), Ok(vec!(Selector { compound_selectors: Arc::new(CompoundSelector { @@ -778,7 +778,7 @@ mod tests { }), pseudo_element: Some(PseudoElement::Before), specificity: specificity(0, 0, 1), - }))) + }))); assert_eq!(parse("div :after"), Ok(vec!(Selector { compound_selectors: Arc::new(CompoundSelector { simple_selectors: vec!(), @@ -791,7 +791,7 @@ mod tests { }), pseudo_element: Some(PseudoElement::After), specificity: specificity(0, 0, 2), - }))) + }))); assert_eq!(parse("#d1 > .ok"), Ok(vec![Selector { compound_selectors: Arc::new(CompoundSelector { simple_selectors: vec![ |