Skip to content

Commit 8b45167

Browse files
committed
[REVERT] WP_Theme_JSON: Prevent implicit coercion in to_ruleset
Reverts r62347. The fix the patch proposes is destined for 7.1. There is a general block for such patches until the 7.0 general release. Props ramonopoly, andrewserong, westonruter. See #64848. git-svn-id: https://develop.svn.wordpress.org/trunk@62348 602fd350-edb4-49c9-b593-d223f7449a82
1 parent 8a4a40e commit 8b45167

2 files changed

Lines changed: 3 additions & 56 deletions

File tree

src/wp-includes/class-wp-theme-json.php

Lines changed: 1 addition & 13 deletions
Original file line numberDiff line numberDiff line change
@@ -1982,7 +1982,6 @@ protected function get_css_variables( $nodes, $origins ) {
19821982
* creates the corresponding ruleset.
19831983
*
19841984
* @since 5.8.0
1985-
* @since 7.1.0 Skip declarations whose value is not a plain string (booleans, arrays, objects, etc.).
19861985
*
19871986
* @param string $selector CSS selector.
19881987
* @param array $declarations List of declarations.
@@ -1996,18 +1995,7 @@ protected static function to_ruleset( $selector, $declarations ) {
19961995
$declaration_block = array_reduce(
19971996
$declarations,
19981997
static function ( $carry, $element ) {
1999-
$value = $element['value'];
2000-
2001-
if ( is_numeric( $value ) ) {
2002-
$value = (string) $value;
2003-
}
2004-
2005-
if ( ! is_string( $value ) ) {
2006-
return $carry;
2007-
}
2008-
2009-
return $carry .= $element['name'] . ': ' . $value . ';';
2010-
},
1998+
return $carry .= $element['name'] . ': ' . $element['value'] . ';'; },
20111999
''
20122000
);
20132001

tests/phpunit/tests/theme/wpThemeJson.php

Lines changed: 2 additions & 43 deletions
Original file line numberDiff line numberDiff line change
@@ -4138,7 +4138,6 @@ public function test_get_styles_with_content_width() {
41384138
* @ticket 60936
41394139
* @ticket 61165
41404140
* @ticket 61829
4141-
* @ticket 64848
41424141
*/
41434142
public function test_get_styles_with_appearance_tools() {
41444143
$theme_json = new WP_Theme_JSON(
@@ -4151,11 +4150,11 @@ public function test_get_styles_with_appearance_tools() {
41514150
);
41524151

41534152
$metadata = array(
4154-
'path' => array( 'styles' ),
4153+
'path' => array( 'settings' ),
41554154
'selector' => 'body',
41564155
);
41574156

4158-
$expected = ':where(body) { margin: 0; }.wp-site-blocks > .alignleft { float: left; margin-right: 2em; }.wp-site-blocks > .alignright { float: right; margin-left: 2em; }.wp-site-blocks > .aligncenter { justify-content: center; margin-left: auto; margin-right: auto; }:where(.wp-site-blocks) > * { margin-block-start: ; margin-block-end: 0; }:where(.wp-site-blocks) > :first-child { margin-block-start: 0; }:where(.wp-site-blocks) > :last-child { margin-block-end: 0; }:root { --wp--style--block-gap: ; }.is-layout-flow > .alignleft{float: left;margin-inline-start: 0;margin-inline-end: 2em;}.is-layout-flow > .alignright{float: right;margin-inline-start: 2em;margin-inline-end: 0;}.is-layout-flow > .aligncenter{margin-left: auto !important;margin-right: auto !important;}.is-layout-constrained > .alignleft{float: left;margin-inline-start: 0;margin-inline-end: 2em;}.is-layout-constrained > .alignright{float: right;margin-inline-start: 2em;margin-inline-end: 0;}.is-layout-constrained > .aligncenter{margin-left: auto !important;margin-right: auto !important;}.is-layout-constrained > :where(:not(.alignleft):not(.alignright):not(.alignfull)){margin-left: auto !important;margin-right: auto !important;}body .is-layout-flex{display: flex;}.is-layout-flex{flex-wrap: wrap;align-items: center;}.is-layout-flex > :is(*, div){margin: 0;}body .is-layout-grid{display: grid;}.is-layout-grid > :is(*, div){margin: 0;}';
4157+
$expected = ':where(body) { margin: 0; }.wp-site-blocks > .alignleft { float: left; margin-right: 2em; }.wp-site-blocks > .alignright { float: right; margin-left: 2em; }.wp-site-blocks > .aligncenter { justify-content: center; margin-left: auto; margin-right: auto; }:where(.wp-site-blocks) > * { margin-block-start: ; margin-block-end: 0; }:where(.wp-site-blocks) > :first-child { margin-block-start: 0; }:where(.wp-site-blocks) > :last-child { margin-block-end: 0; }:root { --wp--style--block-gap: ; }:root :where(.is-layout-flow) > :first-child{margin-block-start: 0;}:root :where(.is-layout-flow) > :last-child{margin-block-end: 0;}:root :where(.is-layout-flow) > *{margin-block-start: 1;margin-block-end: 0;}:root :where(.is-layout-constrained) > :first-child{margin-block-start: 0;}:root :where(.is-layout-constrained) > :last-child{margin-block-end: 0;}:root :where(.is-layout-constrained) > *{margin-block-start: 1;margin-block-end: 0;}:root :where(.is-layout-flex){gap: 1;}:root :where(.is-layout-grid){gap: 1;}.is-layout-flow > .alignleft{float: left;margin-inline-start: 0;margin-inline-end: 2em;}.is-layout-flow > .alignright{float: right;margin-inline-start: 2em;margin-inline-end: 0;}.is-layout-flow > .aligncenter{margin-left: auto !important;margin-right: auto !important;}.is-layout-constrained > .alignleft{float: left;margin-inline-start: 0;margin-inline-end: 2em;}.is-layout-constrained > .alignright{float: right;margin-inline-start: 2em;margin-inline-end: 0;}.is-layout-constrained > .aligncenter{margin-left: auto !important;margin-right: auto !important;}.is-layout-constrained > :where(:not(.alignleft):not(.alignright):not(.alignfull)){margin-left: auto !important;margin-right: auto !important;}body .is-layout-flex{display: flex;}.is-layout-flex{flex-wrap: wrap;align-items: center;}.is-layout-flex > :is(*, div){margin: 0;}body .is-layout-grid{display: grid;}.is-layout-grid > :is(*, div){margin: 0;}';
41594158
$this->assertSame( $expected, $theme_json->get_root_layout_rules( WP_Theme_JSON::ROOT_BLOCK_SELECTOR, $metadata ) );
41604159
}
41614160

@@ -7055,44 +7054,4 @@ public function test_sanitize_preserves_null_schema_behavior() {
70557054
$this->assertSame( 'string-value', $settings['appearanceTools'], 'Appearance tools should be string value' );
70567055
$this->assertSame( array( 'nested' => 'value' ), $settings['custom'], 'Custom should be array value' );
70577056
}
7058-
7059-
/**
7060-
* @covers WP_Theme_JSON::to_ruleset
7061-
*
7062-
* @ticket 64848
7063-
*/
7064-
public function test_to_ruleset_skips_non_scalar_values_and_casts_numerics() {
7065-
$reflection = new ReflectionMethod( WP_Theme_JSON::class, 'to_ruleset' );
7066-
if ( PHP_VERSION_ID < 80100 ) {
7067-
$reflection->setAccessible( true );
7068-
}
7069-
$declarations = array(
7070-
array(
7071-
'name' => 'color',
7072-
'value' => 'red',
7073-
),
7074-
array(
7075-
'name' => 'opacity',
7076-
'value' => true,
7077-
),
7078-
array(
7079-
'name' => 'margin',
7080-
'value' => 0,
7081-
),
7082-
array(
7083-
'name' => 'padding',
7084-
'value' => false,
7085-
),
7086-
array(
7087-
'name' => 'gap',
7088-
'value' => array(),
7089-
),
7090-
);
7091-
$result = $reflection->invoke( null, '.test', $declarations );
7092-
$this->assertStringContainsString( 'color: red;', $result, 'Color declaration should be included' );
7093-
$this->assertStringContainsString( 'margin: 0;', $result, 'Numeric value should be cast to string' );
7094-
$this->assertStringNotContainsString( 'opacity', $result, 'Boolean value should be skipped' );
7095-
$this->assertStringNotContainsString( 'padding', $result, 'Boolean value should be skipped' );
7096-
$this->assertStringNotContainsString( 'gap', $result, 'Array value should be skipped' );
7097-
}
70987057
}

0 commit comments

Comments
 (0)