| Index: third_party/WebKit/Source/core/css/parser/CSSSelectorParser.cpp
|
| diff --git a/third_party/WebKit/Source/core/css/parser/CSSSelectorParser.cpp b/third_party/WebKit/Source/core/css/parser/CSSSelectorParser.cpp
|
| index 564b31d911422b116489cadc7ae64a29019c36c6..29d0b14ac16c16ded20b20671f15a0a94582320d 100644
|
| --- a/third_party/WebKit/Source/core/css/parser/CSSSelectorParser.cpp
|
| +++ b/third_party/WebKit/Source/core/css/parser/CSSSelectorParser.cpp
|
| @@ -24,6 +24,9 @@ static void recordSelectorStats(const CSSParserContext& context, const CSSSelect
|
| case CSSSelector::PseudoUnresolved:
|
| feature = UseCounter::CSSSelectorPseudoUnresolved;
|
| break;
|
| + case CSSSelector::PseudoSlotted:
|
| + feature = UseCounter::CSSSelectorPseudoSlotted;
|
| + break;
|
| case CSSSelector::PseudoContent:
|
| feature = UseCounter::CSSSelectorPseudoContent;
|
| break;
|
| @@ -360,6 +363,7 @@ PassOwnPtr<CSSParserSelector> CSSSelectorParser::consumePseudo(CSSParserTokenRan
|
| selector->setSelectorList(selectorList.release());
|
| return selector.release();
|
| }
|
| + case CSSSelector::PseudoSlotted:
|
| case CSSSelector::PseudoNot:
|
| {
|
| OwnPtr<CSSParserSelector> innerSelector = consumeCompoundSelector(block);
|
| @@ -369,6 +373,8 @@ PassOwnPtr<CSSParserSelector> CSSSelectorParser::consumePseudo(CSSParserTokenRan
|
| Vector<OwnPtr<CSSParserSelector>> selectorVector;
|
| selectorVector.append(innerSelector.release());
|
| selector->adoptSelectorVector(selectorVector);
|
| + if (selector->pseudoType() == CSSSelector::PseudoSlotted)
|
| + selector->setRelationIsAffectedByPseudoSlotted();
|
| return selector.release();
|
| }
|
| case CSSSelector::PseudoLang:
|
| @@ -576,8 +582,8 @@ void CSSSelectorParser::prependTypeSelectorIfNeeded(const AtomicString& namespac
|
| if (compoundSelector->crossesTreeScopes())
|
| return rewriteSpecifiersWithElementNameForCustomPseudoElement(tag, compoundSelector, elementName.isNull());
|
|
|
| - if (compoundSelector->pseudoType() == CSSSelector::PseudoContent)
|
| - return rewriteSpecifiersWithElementNameForContentPseudoElement(tag, compoundSelector, elementName.isNull());
|
| + if (compoundSelector->pseudoType() == CSSSelector::PseudoContent || compoundSelector->pseudoType() == CSSSelector::PseudoSlotted)
|
| + return rewriteSpecifiersWithElementNameForContentOrSlottedPseudoElement(tag, compoundSelector, elementName.isNull());
|
|
|
| // *:host never matches, so we can't discard the * otherwise we can't tell the
|
| // difference between *:host and just :host.
|
| @@ -609,13 +615,14 @@ void CSSSelectorParser::rewriteSpecifiersWithElementNameForCustomPseudoElement(c
|
| lastShadowPseudo->setRelation(CSSSelector::ShadowPseudo);
|
| }
|
|
|
| -void CSSSelectorParser::rewriteSpecifiersWithElementNameForContentPseudoElement(const QualifiedName& tag, CSSParserSelector* specifiers, bool tagIsImplicit)
|
| +void CSSSelectorParser::rewriteSpecifiersWithElementNameForContentOrSlottedPseudoElement(const QualifiedName& tag, CSSParserSelector* specifiers, bool tagIsImplicit)
|
| {
|
| CSSParserSelector* last = specifiers;
|
| CSSParserSelector* history = specifiers;
|
| while (history->tagHistory()) {
|
| history = history->tagHistory();
|
| - if (history->pseudoType() == CSSSelector::PseudoContent || history->relationIsAffectedByPseudoContent())
|
| + if (history->pseudoType() == CSSSelector::PseudoContent || history->relationIsAffectedByPseudoContent()
|
| + || history->pseudoType() == CSSSelector::PseudoSlotted || history->relationIsAffectedByPseudoSlotted())
|
| last = history;
|
| }
|
|
|
| @@ -625,10 +632,10 @@ void CSSSelectorParser::rewriteSpecifiersWithElementNameForContentPseudoElement(
|
| return;
|
| }
|
|
|
| - // For shadow-ID pseudo-elements to be correctly matched, the ShadowPseudo combinator has to be used.
|
| - // We therefore create a new Selector with that combinator here in any case, even if matching any (host) element in any namespace (i.e. '*').
|
| OwnPtr<CSSParserSelector> elementNameSelector = CSSParserSelector::create(tag);
|
| last->setTagHistory(elementNameSelector.release());
|
| + if (last->pseudoType() == CSSSelector::PseudoSlotted)
|
| + last->setRelation(CSSSelector::ShadowSlot);
|
| }
|
|
|
| PassOwnPtr<CSSParserSelector> CSSSelectorParser::addSimpleSelectorToCompound(PassOwnPtr<CSSParserSelector> compoundSelector, PassOwnPtr<CSSParserSelector> simpleSelector)
|
|
|