[webkit-changes] [WebKit/WebKit] 39f36d: [CSS Container Queries] Queries with unknown featu...

Antti Koivisto noreply at github.com
Mon Feb 5 09:13:25 PST 2024


  Branch: refs/heads/main
  Home:   https://github.com/WebKit/WebKit
  Commit: 39f36da26b7671d55bc256f852cc652255d1328b
      https://github.com/WebKit/WebKit/commit/39f36da26b7671d55bc256f852cc652255d1328b
  Author: Antti Koivisto <antti at apple.com>
  Date:   2024-02-05 (Mon, 05 Feb 2024)

  Changed paths:
    M LayoutTests/imported/w3c/web-platform-tests/css/css-contain/container-queries/container-selection-unknown-features-expected.txt
    M LayoutTests/imported/w3c/web-platform-tests/css/css-contain/container-queries/query-evaluation-expected.txt
    M Source/WebCore/css/ContainerQuery.h
    M Source/WebCore/css/ContainerQueryParser.cpp
    M Source/WebCore/css/ContainerQueryParser.h
    M Source/WebCore/css/query/GenericMediaQueryTypes.h
    M Source/WebCore/style/ContainerQueryEvaluator.cpp

  Log Message:
  -----------
  [CSS Container Queries] Queries with unknown features should not select a container
https://bugs.webkit.org/show_bug.cgi?id=268741
rdar://122307175

Reviewed by Alan Baradlay.

https://github.com/w3c/csswg-drafts/issues/7551 changed the behavior for unknown features:

"If the <container-query> contains unknown or unsupported container features, no query container will be selected."

* LayoutTests/imported/w3c/web-platform-tests/css/css-contain/container-queries/container-selection-unknown-features-expected.txt:
* LayoutTests/imported/w3c/web-platform-tests/css/css-contain/container-queries/query-evaluation-expected.txt:
* Source/WebCore/css/ContainerQuery.h:
* Source/WebCore/css/ContainerQueryParser.cpp:
(WebCore::ContainerQueryParser::consumeContainerQuery):

Traverse the features and see if we have anything unknown along with collecting the axis requirements.

(WebCore::ContainerQueryParser::consumeFeature): Deleted.

Traverse after consuming instead.

* Source/WebCore/css/ContainerQueryParser.h:
(WebCore::ContainerQueryParser::ContainerQueryParser):
* Source/WebCore/css/query/GenericMediaQueryTypes.h:
(WebCore::MQ::traverseFeatures):

Also traverse GeneralEnclosed which is what unknown features turn into.

* Source/WebCore/style/ContainerQueryEvaluator.cpp:
(WebCore::Style::ContainerQueryEvaluator::featureEvaluationContextForQuery const):

Bail out for unknown features.

Canonical link: https://commits.webkit.org/274098@main




More information about the webkit-changes mailing list