mirror of
https://github.com/roytam1/palemoon27.git
synced 2026-05-26 14:30:27 +00:00
import changes from `dev' branch of rmottola/Arctic-Fox:
- bug 1212906 - don't handle windows messages while waiting for a sync a11y ipc message r=billm (c9297e58f4)
- Bug 1183431 - Tests for hypothetical box computation (to determine static position of abspos element) where orthogonal writing modes are involved. r=dholbert (87b22c5cf5)
- Bug 1221112: When checking for ::before/::after while sorting flex items by DOM order, dig past placeholder to out-of-flow frame. r=mats (b2e252fa86)
- Bug 1169420: add crashtests. (no review) (f7484702a2)
- Bug 1183431 - Ensure hypothetical box has a writing mode with the same block direction as the absolute containing block. r=dholbert (9106e022d1)
- Partial - No bug - Various crashtest manifest cleanups. (f2d0568f2d)
- Bug 1221874 - Crashtest for overzealous writing-mode check (currently asserts). r=smontagu (ef6685f606)
- Bug 1221874 - Ignore the sideways-orientation flag when logical-coordinate classes are checking writing-mode compatibility. r=smontagu (9617a761d6)
- Bug 1193488 - patch 2 - Update the writing-mode representation printed by debugging code such as DumpFrameTree to reflect the new property values. r=dholbert (b6b3fdda58)
- Bug 1208593 - Make the WritingMode::DebugString() method available even in non-DEBUG compilation (needed by --enable-dump-painting builds, for example). r=mchang (d6b46fde86)
- Bug 1122918 - Part 1 - Add parsing for logical inline-start/end keywords to the 'float' and 'clear' properties. r=heycam (20f9dc4d11)
- Bug 1122918 - Part 2 - Provide accessors that return logical 'float' and 'clear' values resolved to their physical equivalents. r=heycam (9380f050d6)
- Bug 1108055 - Part 1: Add ComputedTimingProperties dictionary. r=smaug (ac88430cfe)
- Bug 1108055 - Part 2: Refine ComputedTiming. r=birtles (3c25124b5f)
- Bug 1108055 - Part 3: Implement GetComputedTiming method. r=birtles (d9fe931cc5)
- Bug 1108055 - Part 4: Add ComputedTiming mochitests. r=birtles (1687824926)
- Bug 1195180 part 1 - Add Animation::NeedsTicks; r=heycam (9ac3bbda87)
- Bug 1195180 part 2 - Make DocumentTimeline inherit from nsARefreshObserver; r=heycam (292f9d154d)
- Bug 1195180 part 3 - Add flag to record if DocumentTimeline is observing the refresh driver; r=heycam (3d90d3f149)
- Bug 1195180 part 4 - Unregister from refresh observer when there are no animations needing ticks; r=heycam (ad76c3ddd5)
- Bug 1195180 part 5 - Synchronize refresh driver observing with presshell creation/teardown; r=heycam (94b7d9176f)
- Bug 1195180 part 6 - Lazily remove animations from timelines; r=heycam (bb3beaa264)
- Bug 1195180 part 7 - Store animations in an array; r=heycam (199756e7d6)
- Bug 1195180 part 8 - Tick animations from their timeline; r=heycam (12942bdc45)
- Bug 1195180 part 9 - Add test for seeking finished -> paused; r=heycam (0b42afcd26)
- Bug 1195180 part 10 - Remove refresh driver observing machinery from CommonAnimationManager; r=heycam (bf233d32ac)
- Bug 1208938 part 1 - Rename AnimationCollection::mNeedsRefreshes to mStyleChanging; r=heycam (679bdf0770)
- Bug 1208938 part 2 - Remove Animation::HasEndEventToQueue; r=heycam (c75bdb64b7)
- Bug 1208938 part 3 - Update pending finishing handling; r=heycam (c9f4c1aace)
- Bug 1196379 - Fix incorrect assertion checking for sorted arrays in nsDocumentRuleResultCacheKey::Matches. r=dbaron (a12db544ef)
- Bug 978833 patch 3 - Make css::Declaration implement nsIStyleRule. r=heycam (3b79410f06)
- Bug 978833 patch 4 - Add pointer back from css::Declaration to css::Rule. r=heycam (2f86331573)
- Bug 978833 patch 5 - Rename ImportantRule to ImportantStyleData. r=heycam (e8471fc026)
- Bug 978833 patch 6 - Move ImportantStyleData from StyleRule.{h,cpp} to Declaration.{h,cpp} r=heycam (612875a128)
- Bug 978833 patch 7 - Fuse allocation of ImportantStyleData with Declaration. r=heycam (a8e9e99a35)
- Bug 978833 patch 8 - Call SetImmutable for declarations of @page and keyframe rules. r=heycam (6b04b5a81e)
- Bug 978833 patch 9 - Move keyframe !important data assertion to where it will continue to happen. r=heycam (862c6df232)
- Bug 978833 patch 10 - Raise consistent exceptions so that the exception doesn't depend on rule destruction timing. r=bzbarsky (8bd58857e9)
- Bug 978833 patch 11 - Add missing #includes in preparation for nsRuleWalker.h #include change in following patch. r=heycam (25a6357983)
- Bug 1180118 - Part 6: Return eRestyle_SomeDescendants from HasAttributeDependentStyle where appropriate. r=bzbarsky (21d88cc938)
- Bug 1202512 - Part 2: Make SelectorMatchesTree take a flags argument. r=bzbarsky (b660a417f8)
- Bug 978833 patch 12 - Use the css::Declaration instead of the css::StyleRule as the matching rule. r=heycam (dd6a7914a6)
- Bug 978833 patch 13 - Remove important rule creation from css::StyleRule. r=heycam (4766c9a635)
- Bug 978833 patch 14 - Pass mozilla::css::Rule instead of nsIStyleRule to nsIDocument/nsIDocumentObserver style rule methods. r=heycam (a632b828b9)
- Bug 978833 patch 15 - Make css::Rule no longer inherit from nsIStyleRule. r=heycam (a975922671)
- Bug 978833 patch 16 - Always call Declaration::SetImmutable when we match a rule. r=heycam (0f0c89aede)
- Bug 978833 patch 17 - Remove Rule::mWasMatched. r=heycam (d0bb9bfef1)
- Bug 978833 patch 18 - Eliminate StyleRule::RuleMatched and call Declaration::SetImmutable directly for style rules (like for @page and keyframe rules). r=heycam (70d5e45a7c)
- Bug 978833 patch 19 - Fix ResolvedStyleCache to use Declaration rather than nsCSSKeyframeRule as keys. r=heycam (223cf85e8b)
- Bug 978833 patch 20 - Rev IIDs that I should have revised in Bug 978833 patch 14. (c6421cbca8)
- Bug 1214936 - Make the ArrayBuffer constructor throw if invoked without 'new'. (r=evilpie) (ec76f43c26)
- Bug 1198826 - Rename obj parameter to buffer to improve readability, r=terrence (3b1d280a76)
- pointer style (1f9d6a7d22)
- Bug 1218111 - Fix property enumeration order of unboxed objects with expando properties. r=bhackett (a7fdc9482d)
- Bug 980945 - Throw when invoking a typed array constructor without new. r=efaust (4f80026991)
- Bug 1192572 - Add id to each opcode section in SpiderMonkey Bytecode documentation. r=Waldo (bfd9d4c165)
- Bug 1219363 - Fix sort of indexed properties to not include properties already in the Vector. r=jorendorff (77edd4d779)
- Bug 1217593 - Fix compilation of LComputeThis now this can be undefined r=shu (d227ddf666)
- Bug 1212343 - Propagate OOM from SafepointWriter r=nbp (d5a79b7d61)
- remove core files (e008661015)
- Bug 1215937 - Remove use of expression closure from js/xpconnect/. r=bholley (e928296111)
- Bug 1196975 - part1: shimwaiver. r=billm (40bc720f37)
- Bug 1196975 - part2: shimwaiver applications. r=mossop (60cf9a9342)
- Bug 1196975 - part3: GetTabForContentWindowNoShim. r=billm (05d2af3c9a)
- Bug 1196975 - part4: waiveInterposition. r=billm (31ecb441b1)
- Bug 1196975 - part5: waiveInterposition for childloader. r=mossop (fe30dddc85)
- Bug 1196975 - part6: SDK Worker should not support CPOWs. r=mossop (7e59947069)
- Bug 1129662: sdk/page-worker should use a remote page. r=krizsa (ef63bafbe4)
- Bug 1216157 - Check for OOM when generating Ion RegExp stubs. r=jonco (690229c6d7)
- Bug 1221436 patch 5 - Stop generating new style rules in DeclarationChanged (and rename it to SetDeclaration), since we no longer need a new style rule for nsIStyleRule identity rules. r=heycam (98d860d06e)
- Bug 1220516 - Devirtualize CSSStyleSheet::GetOriginalURI. r=bzbarsky (6669f8ef70)
- Fix formatting of some macros; no bug. (fe337a3e91)
- Bug 1165538 part 1 - Use delegated constructor for nsStyleFont to simplify code and remove the need of nsStyleFont::Init. r=heycam (521e59852a)
- Bug 1165538 part 2 - Add -moz-min-font-size-ratio internal property. r=heycam (a16ef2d609)
- Bug 1165538 part 3 - Apply -moz-min-font-size-ratio to rt elements and add test. r=heycam (363684724b)
- Bug 1035091 part 1: change CSS parser and loader APIs to distinguish UA, user, and author sheets instead of just UA vs everyone else. r=heycam (01decf75df)
- Bug 1221436 patch 1 - Have a pointer back from the css::Declaration for style attributes to the nsHTMLCSSStyleSheet. r=heycam (308bf9701e)
- Bug 1221436 patch 2 - For style attributes, only store a css::Declaration instead of a css::StyleRule. r=heycam (f068adb5e9)
- Bug 1167588 - Mark Rule::mParentRule as MOZ_NON_OWNING_REF. r=dbaron (bdb2bfe4a7)
- Bug 1221436 patch 3 - Remove Rule::SetHTMLCSSStyleSheet and related code, now unused. r=heycam (d4fd6fca7c)
- Bug 1221436 patch 4 - Use the same pointer to store the owning rule and the nsHTMLCSSStyleSheet on css::Declaration, since we never need both. r=heycam (1a949ec7dc)
- Bug 1221436 patch 6 - Remove mechanism for replacing style rules. r=heycam (870539dcca)
- Bug 1221436 patch 7 - Remove ReplaceStyleRule/ReplaceRuleInGroup mechanism. r=heycam (a8a58186c1)
- Bug 1186768 patch 1 - Avoid setting different font-size conditions due to MathML font size adjustments. r=heycam (5b48d02031)
- Bug 1146101 - Test. r=dbaron a=abillings (b214ab1529)
- Bug 1161366 - Correctly set referrer when loading fonts with |new FontFace()|. r=dbaron (52a59ad6a4)
- Bug 1206105 - Use CheckedInt for an+b selector matching. r=bzbarsky (739875148c)
- Bug 1163446 - Drop reference to FontFace once a FontFaceBufferSource is loaded. r=jdaggett (9fd3a219c6)
- Bug 1164813 - Make nsAnimationManager update cached in-effect status even when there is no frame; r=dbaron (6f94c96764)
- Bug 1186768 patch 2 - Crashtest. r=heycam (a566cfef9b)
- Bug 1186768 patch 3 - Compute affectedByScriptMinSize sooner to avoid asserting or doing extra work. r=heycam (30dac96a78)
- Bug 1038663 (part 1) - Make nsStyleText::mWordSpacing an nsStyleCoord. r=heycam. (42a6a2398a)
- Bug 1038663 (part 2, attempt 2) - Move GetFirstFontMetrics() up. r=heycam. (5992325377)
- Bug 1038663 (part 3, attempt 2) - Factor out space width computation. r=heycam. (92281609f0)
- Bug 1038663 (part 4, attempt 2) - Inline StyleToCoord(). r=heycam. (f40476c105)
- Bug 1038663 (part 5, attempt 2) - Change GetSpacingFlags(). r=heycam (e1fe5ecdf0)
- Bug 1038663 (part 6, attempt 2) - Allow percentage values for 'word-spacing'. r=heycam. (433fee69f6)
- Bug 1038663 (part 7, attempt 3) - Add test for percentage values for 'word-spacing'. r=heycam. (72df555579)
- Bug 1216747 - Record dependency on writing mode in nsRuleNode::ComputeStylePosition. r=heycam (8604ceff20)
- Bug 1216747 followup - Use the correct value when calling SetWritingModeDependency. (b39a82cbf7)
- Bug 1216747 - Cleanup after test fix. r=heycam (e99ec5989a)
- Bug 1170781 - Patch 1: Implement CSS 'contain: paint'. r=dholbert (3b2f65288f)
- Bug 1170781 - Patch 2: Test CSS 'contain: paint'. r=dholbert (ee83c7c0fd)
This commit is contained in:
@@ -1561,8 +1561,11 @@ nthChildGenericMatches(Element* aElement,
|
||||
// Integer division in C does truncation (towards 0). So
|
||||
// check that the result is nonnegative, and that there was no
|
||||
// truncation.
|
||||
const int32_t n = (index - b) / a;
|
||||
return n >= 0 && (a * n == index - b);
|
||||
const CheckedInt<int32_t> indexMinusB = CheckedInt<int32_t>(index) - b;
|
||||
const CheckedInt<int32_t> n = indexMinusB / a;
|
||||
return n.isValid() &&
|
||||
n.value() >= 0 &&
|
||||
a * n == indexMinusB;
|
||||
}
|
||||
|
||||
static inline bool
|
||||
@@ -2389,10 +2392,20 @@ nsCSSRuleProcessor::RestrictedSelectorMatches(
|
||||
#define NS_IS_GREEDY_OPERATOR(ch) \
|
||||
((ch) == char16_t(' ') || (ch) == char16_t('~'))
|
||||
|
||||
static bool SelectorMatchesTree(Element* aPrevElement,
|
||||
nsCSSSelector* aSelector,
|
||||
TreeMatchContext& aTreeMatchContext,
|
||||
bool aLookForRelevantLink)
|
||||
/**
|
||||
* Flags for SelectorMatchesTree.
|
||||
*/
|
||||
enum SelectorMatchesTreeFlags {
|
||||
// Whether we still have not found the closest ancestor link element and
|
||||
// thus have to check the current element for it.
|
||||
eLookForRelevantLink = 0x1,
|
||||
};
|
||||
|
||||
static bool
|
||||
SelectorMatchesTree(Element* aPrevElement,
|
||||
nsCSSSelector* aSelector,
|
||||
TreeMatchContext& aTreeMatchContext,
|
||||
SelectorMatchesTreeFlags aFlags)
|
||||
{
|
||||
MOZ_ASSERT(!aSelector || !aSelector->IsPseudoElement());
|
||||
nsCSSSelector* selector = aSelector;
|
||||
@@ -2415,7 +2428,7 @@ static bool SelectorMatchesTree(Element* aPrevElement,
|
||||
if (char16_t('+') == selector->mOperator ||
|
||||
char16_t('~') == selector->mOperator) {
|
||||
// The relevant link must be an ancestor of the node being matched.
|
||||
aLookForRelevantLink = false;
|
||||
aFlags = SelectorMatchesTreeFlags(aFlags & ~eLookForRelevantLink);
|
||||
nsIContent* parent = prevElement->GetParent();
|
||||
if (parent) {
|
||||
if (aTreeMatchContext.mForStyling)
|
||||
@@ -2447,7 +2460,7 @@ static bool SelectorMatchesTree(Element* aPrevElement,
|
||||
if (selector->mOperator == '>' && element->IsActiveChildrenElement()) {
|
||||
Element* styleScope = aTreeMatchContext.mCurrentStyleScope;
|
||||
if (SelectorMatchesTree(element, selector, aTreeMatchContext,
|
||||
aLookForRelevantLink)) {
|
||||
aFlags)) {
|
||||
// It matched, don't try matching on the <xbl:children> element at
|
||||
// all.
|
||||
return true;
|
||||
@@ -2463,10 +2476,10 @@ static bool SelectorMatchesTree(Element* aPrevElement,
|
||||
if (!element) {
|
||||
return false;
|
||||
}
|
||||
NodeMatchContext nodeContext(EventStates(),
|
||||
aLookForRelevantLink &&
|
||||
nsCSSRuleProcessor::IsLink(element));
|
||||
if (nodeContext.mIsRelevantLink) {
|
||||
const bool isRelevantLink = (aFlags & eLookForRelevantLink) &&
|
||||
nsCSSRuleProcessor::IsLink(element);
|
||||
NodeMatchContext nodeContext(EventStates(), isRelevantLink);
|
||||
if (isRelevantLink) {
|
||||
// If we find an ancestor of the matched node that is a link
|
||||
// during the matching process, then it's the relevant link (see
|
||||
// constructor call above).
|
||||
@@ -2474,7 +2487,7 @@ static bool SelectorMatchesTree(Element* aPrevElement,
|
||||
// :visited (they'll just fail), we will always find such a node
|
||||
// during the selector matching process if there is a relevant
|
||||
// link that can influence selector matching.
|
||||
aLookForRelevantLink = false;
|
||||
aFlags = SelectorMatchesTreeFlags(aFlags & ~eLookForRelevantLink);
|
||||
aTreeMatchContext.SetHaveRelevantLink();
|
||||
}
|
||||
if (SelectorMatches(element, selector, nodeContext, aTreeMatchContext,
|
||||
@@ -2498,8 +2511,7 @@ static bool SelectorMatchesTree(Element* aPrevElement,
|
||||
// doesn't matter much for performance since most selectors
|
||||
// don't match. (If most did, it might be faster...)
|
||||
Element* styleScope = aTreeMatchContext.mCurrentStyleScope;
|
||||
if (SelectorMatchesTree(element, selector, aTreeMatchContext,
|
||||
aLookForRelevantLink)) {
|
||||
if (SelectorMatchesTree(element, selector, aTreeMatchContext, aFlags)) {
|
||||
return true;
|
||||
}
|
||||
// We want to reset mCurrentStyleScope on aTreeMatchContext
|
||||
@@ -2574,12 +2586,15 @@ void ContentEnumFunc(const RuleValue& value, nsCSSSelector* aSelector,
|
||||
if (SelectorMatches(data->mElement, selector, nodeContext,
|
||||
data->mTreeMatchContext, selectorFlags)) {
|
||||
nsCSSSelector *next = selector->mNext;
|
||||
if (!next || SelectorMatchesTree(data->mElement, next,
|
||||
data->mTreeMatchContext,
|
||||
!nodeContext.mIsRelevantLink)) {
|
||||
css::StyleRule *rule = value.mRule;
|
||||
rule->RuleMatched();
|
||||
data->mRuleWalker->Forward(rule);
|
||||
if (!next ||
|
||||
SelectorMatchesTree(data->mElement, next,
|
||||
data->mTreeMatchContext,
|
||||
nodeContext.mIsRelevantLink ?
|
||||
SelectorMatchesTreeFlags(0) :
|
||||
eLookForRelevantLink)) {
|
||||
css::Declaration* declaration = value.mRule->GetDeclaration();
|
||||
declaration->SetImmutable();
|
||||
data->mRuleWalker->Forward(declaration);
|
||||
// nsStyleSet will deal with the !important rule
|
||||
}
|
||||
}
|
||||
@@ -2624,8 +2639,9 @@ nsCSSRuleProcessor::RulesMatching(AnonBoxRuleProcessorData* aData)
|
||||
nsTArray<RuleValue>& rules = entry->mRules;
|
||||
for (RuleValue *value = rules.Elements(), *end = value + rules.Length();
|
||||
value != end; ++value) {
|
||||
value->mRule->RuleMatched();
|
||||
aData->mRuleWalker->Forward(value->mRule);
|
||||
css::Declaration* declaration = value->mRule->GetDeclaration();
|
||||
declaration->SetImmutable();
|
||||
aData->mRuleWalker->Forward(declaration);
|
||||
}
|
||||
}
|
||||
}
|
||||
@@ -2750,7 +2766,7 @@ nsCSSRuleProcessor::HasStateDependentStyle(ElementDependentRuleProcessorData* aD
|
||||
aData->mTreeMatchContext, selectorFlags) &&
|
||||
SelectorMatchesTree(aData->mElement, selector->mNext,
|
||||
aData->mTreeMatchContext,
|
||||
false))
|
||||
SelectorMatchesTreeFlags(0)))
|
||||
{
|
||||
hint = nsRestyleHint(hint | possibleChange);
|
||||
}
|
||||
@@ -2786,14 +2802,77 @@ nsCSSRuleProcessor::HasDocumentStateDependentStyle(StateRuleProcessorData* aData
|
||||
}
|
||||
|
||||
struct AttributeEnumData {
|
||||
explicit AttributeEnumData(AttributeRuleProcessorData *aData)
|
||||
: data(aData), change(nsRestyleHint(0)) {}
|
||||
AttributeEnumData(AttributeRuleProcessorData *aData,
|
||||
RestyleHintData& aRestyleHintData)
|
||||
: data(aData), change(nsRestyleHint(0)), hintData(aRestyleHintData) {}
|
||||
|
||||
AttributeRuleProcessorData *data;
|
||||
nsRestyleHint change;
|
||||
RestyleHintData& hintData;
|
||||
};
|
||||
|
||||
|
||||
static inline nsRestyleHint
|
||||
RestyleHintForSelectorWithAttributeChange(nsRestyleHint aCurrentHint,
|
||||
nsCSSSelector* aSelector,
|
||||
nsCSSSelector* aRightmostSelector)
|
||||
{
|
||||
MOZ_ASSERT(aSelector);
|
||||
|
||||
char16_t oper = aSelector->mOperator;
|
||||
|
||||
if (oper == char16_t('+') || oper == char16_t('~')) {
|
||||
return eRestyle_LaterSiblings;
|
||||
}
|
||||
|
||||
if (oper == char16_t(':')) {
|
||||
return eRestyle_Subtree;
|
||||
}
|
||||
|
||||
if (oper != char16_t(0)) {
|
||||
// Check whether the selector is in a form that supports
|
||||
// eRestyle_SomeDescendants. If it isn't, return eRestyle_Subtree.
|
||||
|
||||
if (aCurrentHint & eRestyle_Subtree) {
|
||||
// No point checking, since we'll end up restyling the whole
|
||||
// subtree anyway.
|
||||
return eRestyle_Subtree;
|
||||
}
|
||||
|
||||
if (!aRightmostSelector) {
|
||||
// aSelector wasn't a top-level selector, which means we were inside
|
||||
// a :not() or :-moz-any(). We don't support that.
|
||||
return eRestyle_Subtree;
|
||||
}
|
||||
|
||||
MOZ_ASSERT(aSelector != aRightmostSelector,
|
||||
"if aSelector == aRightmostSelector then we should have "
|
||||
"no operator");
|
||||
|
||||
// Check that aRightmostSelector can be passed to RestrictedSelectorMatches.
|
||||
if (!aRightmostSelector->IsRestrictedSelector()) {
|
||||
return eRestyle_Subtree;
|
||||
}
|
||||
|
||||
// We also don't support pseudo-elements on any of the selectors
|
||||
// between aRightmostSelector and aSelector.
|
||||
// XXX Can we lift this restriction, so that we don't have to loop
|
||||
// over all the selectors?
|
||||
for (nsCSSSelector* sel = aRightmostSelector->mNext;
|
||||
sel != aSelector;
|
||||
sel = sel->mNext) {
|
||||
MOZ_ASSERT(sel, "aSelector must be reachable from aRightmostSelector");
|
||||
if (sel->PseudoType() != nsCSSPseudoElements::ePseudo_NotPseudoElement) {
|
||||
return eRestyle_Subtree;
|
||||
}
|
||||
}
|
||||
|
||||
return eRestyle_SomeDescendants;
|
||||
}
|
||||
|
||||
return eRestyle_Self;
|
||||
}
|
||||
|
||||
static void
|
||||
AttributeEnumFunc(nsCSSSelector* aSelector,
|
||||
nsCSSSelector* aRightmostSelector,
|
||||
@@ -2808,18 +2887,27 @@ AttributeEnumFunc(nsCSSSelector* aSelector,
|
||||
return;
|
||||
}
|
||||
|
||||
nsRestyleHint possibleChange = RestyleHintForOp(aSelector->mOperator);
|
||||
nsRestyleHint possibleChange =
|
||||
RestyleHintForSelectorWithAttributeChange(aData->change,
|
||||
aSelector, aRightmostSelector);
|
||||
|
||||
// If enumData->change already includes all the bits of possibleChange, don't
|
||||
// bother calling SelectorMatches, since even if it returns false
|
||||
// enumData->change won't change.
|
||||
// If, ignoring eRestyle_SomeDescendants, enumData->change already includes
|
||||
// all the bits of possibleChange, don't bother calling SelectorMatches, since
|
||||
// even if it returns false enumData->change won't change. If possibleChange
|
||||
// has eRestyle_SomeDescendants, we need to call SelectorMatches(Tree)
|
||||
// regardless as it might give us new selectors to append to
|
||||
// mSelectorsForDescendants.
|
||||
NodeMatchContext nodeContext(EventStates(), false);
|
||||
if ((possibleChange & ~(aData->change)) &&
|
||||
if (((possibleChange & (~(aData->change) | eRestyle_SomeDescendants))) &&
|
||||
SelectorMatches(data->mElement, aSelector, nodeContext,
|
||||
data->mTreeMatchContext, SelectorMatchesFlags::UNKNOWN) &&
|
||||
SelectorMatchesTree(data->mElement, aSelector->mNext,
|
||||
data->mTreeMatchContext, false)) {
|
||||
data->mTreeMatchContext,
|
||||
SelectorMatchesTreeFlags(0))) {
|
||||
aData->change = nsRestyleHint(aData->change | possibleChange);
|
||||
if (possibleChange & eRestyle_SomeDescendants) {
|
||||
aData->hintData.mSelectorsForDescendants.AppendElement(aRightmostSelector);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -2851,7 +2939,7 @@ nsCSSRuleProcessor::HasAttributeDependentStyle(
|
||||
// We could try making use of aData->mModType, but :not rules make it a bit
|
||||
// of a pain to do so... So just ignore it for now.
|
||||
|
||||
AttributeEnumData data(aData);
|
||||
AttributeEnumData data(aData, aRestyleHintDataResult);
|
||||
|
||||
// Don't do our special handling of certain attributes if the attr
|
||||
// hasn't changed yet.
|
||||
@@ -3843,7 +3931,8 @@ nsCSSRuleProcessor::SelectorListMatches(Element* aElement,
|
||||
SelectorMatchesFlags::NONE)) {
|
||||
nsCSSSelector* next = sel->mNext;
|
||||
if (!next ||
|
||||
SelectorMatchesTree(aElement, next, aTreeMatchContext, false)) {
|
||||
SelectorMatchesTree(aElement, next, aTreeMatchContext,
|
||||
SelectorMatchesTreeFlags(0))) {
|
||||
return true;
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user