mirror of
https://github.com/LadybirdBrowser/ladybird.git
synced 2025-10-16 13:09:41 +00:00
LibWeb: Use document's viewport when resolving lengths in media queries
Previously we would always use the window's viewport which was incorrect if we were within an iframe. This is likely applicable to all uses of `Length::ResolutionContext::for_window`.
This commit is contained in:
parent
c33be71df9
commit
05c336ea4e
Notes:
github-actions[bot]
2025-10-07 09:34:36 +00:00
Author: https://github.com/Calme1709
Commit: 05c336ea4e
Pull-request: https://github.com/LadybirdBrowser/ladybird/pull/6412
Reviewed-by: https://github.com/AtkinsSJ ✅
23 changed files with 198 additions and 83 deletions
|
@ -81,10 +81,10 @@ class BooleanExpression {
|
|||
public:
|
||||
virtual ~BooleanExpression() = default;
|
||||
|
||||
bool evaluate_to_boolean(HTML::Window const*) const;
|
||||
bool evaluate_to_boolean(DOM::Document const*) const;
|
||||
static void indent(StringBuilder& builder, int levels);
|
||||
|
||||
virtual MatchResult evaluate(HTML::Window const*) const = 0;
|
||||
virtual MatchResult evaluate(DOM::Document const*) const = 0;
|
||||
virtual String to_string() const = 0;
|
||||
virtual void dump(StringBuilder&, int indent_levels = 0) const = 0;
|
||||
};
|
||||
|
@ -98,7 +98,7 @@ public:
|
|||
}
|
||||
virtual ~GeneralEnclosed() override = default;
|
||||
|
||||
virtual MatchResult evaluate(HTML::Window const*) const override { return m_matches; }
|
||||
virtual MatchResult evaluate(DOM::Document const*) const override { return m_matches; }
|
||||
virtual String to_string() const override { return m_serialized_contents; }
|
||||
virtual void dump(StringBuilder&, int indent_levels = 0) const override;
|
||||
|
||||
|
@ -121,7 +121,7 @@ public:
|
|||
}
|
||||
virtual ~BooleanNotExpression() override = default;
|
||||
|
||||
virtual MatchResult evaluate(HTML::Window const*) const override;
|
||||
virtual MatchResult evaluate(DOM::Document const*) const override;
|
||||
virtual String to_string() const override;
|
||||
virtual void dump(StringBuilder&, int indent_levels = 0) const override;
|
||||
|
||||
|
@ -142,7 +142,7 @@ public:
|
|||
}
|
||||
virtual ~BooleanExpressionInParens() override = default;
|
||||
|
||||
virtual MatchResult evaluate(HTML::Window const*) const override;
|
||||
virtual MatchResult evaluate(DOM::Document const*) const override;
|
||||
virtual String to_string() const override;
|
||||
virtual void dump(StringBuilder&, int indent_levels = 0) const override;
|
||||
|
||||
|
@ -163,7 +163,7 @@ public:
|
|||
}
|
||||
virtual ~BooleanAndExpression() override = default;
|
||||
|
||||
virtual MatchResult evaluate(HTML::Window const*) const override;
|
||||
virtual MatchResult evaluate(DOM::Document const*) const override;
|
||||
virtual String to_string() const override;
|
||||
virtual void dump(StringBuilder&, int indent_levels = 0) const override;
|
||||
|
||||
|
@ -184,7 +184,7 @@ public:
|
|||
}
|
||||
virtual ~BooleanOrExpression() override = default;
|
||||
|
||||
virtual MatchResult evaluate(HTML::Window const*) const override;
|
||||
virtual MatchResult evaluate(DOM::Document const*) const override;
|
||||
virtual String to_string() const override;
|
||||
virtual void dump(StringBuilder&, int indent_levels = 0) const override;
|
||||
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue