WebKit Bugzilla
New
Browse
Log In
×
Sign in with GitHub
or
Remember my login
Create Account
·
Forgot Password
Forgotten password account recovery
RESOLVED FIXED
203592
Align CSS hsl() -> rgba() color conversion with the spec
https://bugs.webkit.org/show_bug.cgi?id=203592
Summary
Align CSS hsl() -> rgba() color conversion with the spec
Simon Fraser (smfr)
Reported
2019-10-29 15:19:36 PDT
Align CSS hsl() -> rgba() color conversion with the spec
Attachments
Patch
(536.31 KB, patch)
2019-10-29 15:21 PDT
,
Simon Fraser (smfr)
thorton
: review+
Details
Formatted Diff
Diff
Patch
(542.11 KB, patch)
2019-10-29 15:47 PDT
,
Simon Fraser (smfr)
no flags
Details
Formatted Diff
Diff
View All
Add attachment
proposed patch, testcase, etc.
Simon Fraser (smfr)
Comment 1
2019-10-29 15:21:07 PDT
Created
attachment 382233
[details]
Patch
Simon Fraser (smfr)
Comment 2
2019-10-29 15:47:14 PDT
Created
attachment 382241
[details]
Patch
Radar WebKit Bug Importer
Comment 3
2019-10-29 15:50:13 PDT
<
rdar://problem/56724731
>
Simon Fraser (smfr)
Comment 4
2019-10-29 17:55:54 PDT
https://trac.webkit.org/r251750
Truitt Savell
Comment 5
2019-10-30 07:59:20 PDT
The changes in
https://trac.webkit.org/changeset/251750/webkit
has broken http/wpt/css/css-images-4/conic-gradient-parsing.html History:
https://results.webkit.org/?suite=layout-tests&test=http%2Fwpt%2Fcss%2Fcss-images-4%2Fconic-gradient-parsing.html
Diff: --- /Volumes/Data/slave/mojave-release-tests-wk1/build/layout-test-results/http/wpt/css/css-images-4/conic-gradient-parsing-expected.txt +++ /Volumes/Data/slave/mojave-release-tests-wk1/build/layout-test-results/http/wpt/css/css-images-4/conic-gradient-parsing-actual.txt @@ -1,4 +1,4 @@ -PASS Test conic-gradient parsing +FAIL Test conic-gradient parsing assert_equals: Testing round trip of conic-gradient(hsl(0,0%,75%), hsl(0,0%,25%)) expected "conic-gradient(rgb(191, 191, 191), rgb(63, 63, 63))" but got "conic-gradient(rgb(191, 191, 191), rgb(64, 64, 64))" PASS Test repeating-conic-gradient parsing This is easily reproducible by running it in iterations.
Aakash Jain
Comment 6
2019-10-30 16:09:16 PDT
This probably also broke: fast/css/hsla-color.html and fast/css/hsl-color.html Flakiness dashboard:
https://results.webkit.org/?suite=layout-tests&suite=layout-tests&suite=layout-tests&test=fast%2Fcss%2Fhsl-color.html&test=fast%2Fcss%2Fhsla-color.html&test=http%2Fwpt%2Fcss%2Fcss-images-4%2Fconic-gradient-parsing.html
Simon Fraser (smfr)
Comment 7
2019-10-30 16:35:48 PDT
Already fixed.
Truitt Savell
Comment 8
2019-10-31 07:42:06 PDT
fast/css/hsl-color.html is still broken on Windows and is slowing down that EWS: History:
https://results.webkit.org/?suite=layout-tests&test=fast%2Fcss%2Fhsl-color.html&platform=win
Diff: --- /home/buildbot/worker/win10-release-tests/build/layout-test-results/fast/css/hsl-color-expected.txt +++ /home/buildbot/worker/win10-release-tests/build/layout-test-results/fast/css/hsl-color-actual.txt @@ -15,13 +15,13 @@ RenderBlock {H1} at (0,175) size 769x38 [color=#0000FF] RenderText {#text} at (0,0) size 570x37 text run at (0,0) width 570: "This should be blue: hsl(240, 100%, 50%)" - RenderBlock {H1} at (0,233) size 769x38 [color=#7FFF7F] + RenderBlock {H1} at (0,233) size 769x38 [color=#80FF80] RenderText {#text} at (0,0) size 658x37 text run at (0,0) width 658: "This should be light green: hsl(120, 100%, 75%)" - RenderBlock {H1} at (0,292) size 769x38 [color=#007F00] + RenderBlock {H1} at (0,292) size 769x38 [color=#008000] RenderText {#text} at (0,0) size 661x37 text run at (0,0) width 661: "This should be dark green: hsl(120, 100%, 25%)" - RenderBlock {H1} at (0,350) size 769x38 [color=#3FBF3F] + RenderBlock {H1} at (0,350) size 769x38 [color=#40BF40] RenderText {#text} at (0,0) size 659x37 text run at (0,0) width 659: "This should be pastel green: hsl(120, 50%, 50%)" RenderBlock (anonymous) at (0,409) size 769x37 @@ -40,32 +40,32 @@ RenderBlock (anonymous) at (0,583) size 769x19 RenderText {#text} at (0,0) size 470x18 text run at (0,0) width 470: "Check percentages less than 0% (negative values), should be limited to 0%" - RenderBlock {H1} at (0,622) size 769x38 [color=#7F7F7F] + RenderBlock {H1} at (0,622) size 769x38 [color=#808080] RenderText {#text} at (0,0) size 539x37 text run at (0,0) width 539: "This should be grey: hsl(120, 0%, 50%)" - RenderBlock {H1} at (0,681) size 769x38 [color=#7F7F7F] + RenderBlock {H1} at (0,681) size 769x38 [color=#808080] RenderText {#text} at (0,0) size 641x37 text run at (0,0) width 641: "This should be grey, too: hsl(120, -100%, 50%)" RenderBlock (anonymous) at (0,739) size 769x37 RenderText {#text} at (0,0) size 755x36 text run at (0,0) width 755: "Check Hue values that are larger than 360, should be normalized back to a value between 0 and 360. As Hue values are" text run at (0,18) width 451: "in degrees, there is no maximum like percentages, they are loop around." - RenderBlock {H1} at (0,797) size 769x38 [color=#007F00] + RenderBlock {H1} at (0,797) size 769x38 [color=#008000] RenderText {#text} at (0,0) size 661x37 text run at (0,0) width 661: "This should be dark green: hsl(120, 100%, 25%)" - RenderBlock {H1} at (0,855) size 769x38 [color=#007F00] + RenderBlock {H1} at (0,855) size 769x38 [color=#008000] RenderText {#text} at (0,0) size 720x37 text run at (0,0) width 720: "This should be dark green, too: hsl(480, 100%, 25%)" RenderBlock (anonymous) at (0,914) size 769x18 RenderText {#text} at (0,0) size 258x18 text run at (0,0) width 258: "Check Hue values with a negative angle." - RenderBlock {H1} at (0,953) size 769x38 [color=#7FFF7F] + RenderBlock {H1} at (0,953) size 769x38 [color=#80FF80] RenderText {#text} at (0,0) size 658x37 text run at (0,0) width 658: "This should be light green: hsl(120, 100%, 75%)" - RenderBlock {H1} at (0,1011) size 769x38 [color=#7FFF7F] + RenderBlock {H1} at (0,1011) size 769x38 [color=#80FF80] RenderText {#text} at (0,0) size 728x37 text run at (0,0) width 728: "This should be light green, too: hsl(-240, 100%, 75%)" - RenderBlock {H1} at (0,1070) size 769x38 [color=#7FFF7F] + RenderBlock {H1} at (0,1070) size 769x38 [color=#80FF80] RenderText {#text} at (0,0) size 728x37 text run at (0,0) width 728: "This should be light green, too: hsl(-600, 100%, 75%)" RenderBlock (anonymous) at (0,1128) size 769x19
Simon Fraser (smfr)
Comment 9
2019-10-31 10:59:27 PDT
Could you just land new Windows results?
Truitt Savell
Comment 10
2019-10-31 12:20:28 PDT
Updated test results in
https://trac.webkit.org/changeset/251865/webkit
Darin Adler
Comment 11
2019-11-02 19:57:54 PDT
Comment on
attachment 382241
[details]
Patch View in context:
https://bugs.webkit.org/attachment.cgi?id=382241&action=review
> Source/WebCore/platform/graphics/Color.cpp:108 > + return makeRGBA( > + round(floatResult.components[0] * scaleFactor), > + round(floatResult.components[1] * scaleFactor), > + round(floatResult.components[2] * scaleFactor), > + round(floatResult.components[3] * scaleFactor));
I think it would be better to use std::round. The ::round function used here takes and returns a double so we do "float * float -> double -> float". If we used std::round then it would stay a float.
Note
You need to
log in
before you can comment on or make changes to this bug.
Top of Page
Format For Printing
XML
Clone This Bug