- Issue created by @Chris64
- Status changed to Needs workover 1 year ago 10:45pm 31 January 2024
- 🇬🇧United Kingdom longwave UKThanks for the suggestion. I assume there are many similar changes we could make across all of core, and ideally a coding standards sniff we could enable to prevent this code from creeping back in. Ideally we would change all instances of this across core in one go, please read the issue scoping guidelines for more info: https://www.drupal.org/docs/develop/issues/issue-procedures-and-etiquett... → If you can help expand the scope of this issue, please do! 
- 🇫🇷France Chris64 FranceIndeed, that is clear. Here the idea was to suggest the principle with a concrete case. The general purpose is necessary but more difficult. 
- 🇫🇷France Chris64 FranceAs first sniffer, 
 grep -Prn '^\s*([^\s]+)\s=\s\1\s\?\?\s.+$'
- Status changed to Closed: duplicateover 1 year ago 12:56pm 2 February 2024
- Status changed to Needs workover 1 year ago 12:58pm 2 February 2024
- Then again, maybe not. This issue may be about using one-line assignment statements instead of multi-line conditionals. Is it? 
- 🇫🇷France Chris64 FranceYes, reducing the number of instruction lines. When it is possible. 
- 🇫🇷France Chris64 FranceTwo files corresponding to patches giving an idea of what kind of code transformations the rule gives. One is small, A, grouping uniligne code, the other is bigger, B, grouping multiligne code. All the code changes here are produced automatically via a sed command (one command, one file). It is the moment for comments. Is it right? Is it complete? Is reasonable? 
- last updateover 1 year ago Patch Failed to Apply
- last updateover 1 year ago Patch Failed to Apply
- Status changed to Needs reviewover 1 year ago 3:18pm 20 February 2024
- Status changed to Needs workover 1 year ago 3:35pm 20 February 2024
- 🇺🇸United States smustgraveTitle and issue summary mention just layout_discovery.module but the patches appear to be entire drupal so tagging for those to be updated. Also recommended to use MRs 
- Status changed to Needs reviewover 1 year ago 4:56pm 20 February 2024
- 🇫🇷France Chris64 FranceAlso recommended to use MRs I thought about it, but the work needs a first general code review, and a patch file seems for me a simple means to do it. If it will be, look right try a MR now, or some things likes, to big must be cut, or, some rules look wrong. 
- Status changed to Needs workover 1 year ago 1:37pm 22 February 2024
- The Needs Review Queue Bot → tested this issue. - While you are making the above changes, we recommend that you convert this patch to a merge request → . Merge requests are preferred over patches. Be sure to hide the old patch files as well. (Converting an issue to a merge request without other contributions to the issue will not receive credit.) 
- First commit to issue fork.
- Status changed to Needs reviewover 1 year ago 2:01pm 22 February 2024
- 🇫🇷France Chris64 France@sakthi_dev your MR seems correspond with the patch 9A. Agree with this choice. Thank you for your MR. 
- 🇫🇷France Chris64 FranceMay be this issue would be more easy to manage with a parent issue with children corresponding to the different cases. Actually two. 
- 🇫🇷France Chris64 FranceIssue changed from general to the particular simpler case A corresponding to the MR. See the parent issue 📌 Use null coalescing assignment operator Active for the general purpose. 
- Status changed to Needs workover 1 year ago 12:43pm 25 February 2024
- 🇦🇺Australia dpi Perth, AustraliaCan we simply resolve to run rector with the result of the relevant rector rule: https://github.com/rectorphp/rector/blob/main/docs/rector_rules_overview... : Rector\Php74\Rector\Assign\NullCoalescingOperatorRector, instead ofsedper IS.That way we have an easily testable/reproducable set of changes. I'm seeing at least twice as many changes as the MR, compared to a local rector run. 
- 🇫🇷France Chris64 FranceYou are right @dpi! Rector is much better. Indeed, some cases was missed... 
- Status changed to Needs reviewover 1 year ago 10:58pm 26 February 2024
- 🇫🇷France Chris64 France13 missing files found, in core/lib. Got with rector.
- 🇦🇺Australia mstrelanAdded 📌 Require short ternary (Elvis operator) syntax Postponed as related. 
- 🇺🇸United States smustgraveShould we work on some checker to catch these before merging so they don't resurface? 
- 🇫🇷France Chris64 France@smustgrave, this particular case is efficiently managed by rector. As indicated by @dpi in #23 📌 Switch long-form single-line assign and null coalesce (= ??) to null coalesce assign operator (??=) Needs work . The general purpose is some thing else. I am in favour of dividing the general problem into different particular cases. 
- 🇫🇷France Chris64 France@smustgrave, for phpcs, a rule exists about this case, 
 slevomat/coding-standard/SlevomatCodingStandard/Sniffs/ControlStructures/RequireNullCoalesceEqualOperatorSniff
 but is missing indrupal/coder/coder_sniffer/Drupal/ruleset.xml,
 <rule ref="SlevomatCodingStandard.ControlStructures.RequireNullCoalesceEqualOperator" />
 I think this is this case since the rule message is,
 Use "??=" operator instead of "=" and "??
- Status changed to Needs workover 1 year ago 12:21pm 15 March 2024
- The Needs Review Queue Bot → tested this issue. It no longer applies to Drupal core. Therefore, this issue status is now "Needs work". - This does not mean that the patch necessarily needs to be re-rolled or the MR rebased. Read the Issue Summary, the issue tags and the latest discussion here to determine what needs to be done. - Consult the Drupal Contributor Guide → to find step-by-step guides for working with issues. 
- 🇫🇷France Chris64 FranceUse phpcs with rule RequireNullCoalesceEqualOperator from SlevomatCodingStandard: 
 phpcs --standard=SlevomatCodingStandard --sniffs=SlevomatCodingStandard.ControlStructures.RequireNullCoalesceEqualOperator core
- 🇫🇷France Chris64 France1 test error occurs. Some thing wrong happen with, 
 Drupal\Tests\Composer\Plugin\Scaffold\Functional\ManageGitIgnoreTest::testUnmanagedGitIgnoreWhenGitNotAvailable
 incore/tests/Drupal/Tests/Composer/Plugin/Scaffold/Functional/ManageGitIgnoreTest.phpline 253,
 $this->assertEquals($expected, $output);
 The$expectedis not equal to the$output. In this latter an error message exists,
 Composer could not detect the root package (fixtures/drupal-composer-drupal-project) version, defaulting to '1.0.0'. See https://getcomposer.org/root-version
- 🇫🇷France Chris64 FranceThe test error message, Drupal.Tests.Composer.Plugin.Scaffold.Functional.ManageGitIgnoreTest Name testUnmanagedGitIgnoreWhenGitNotAvailable File core/tests/Drupal/Tests/Composer/Plugin/Scaffold/Functional/ManageGitIgnoreTest.php Execution time 448.86ms System output Drupal\Tests\Composer\Plugin\Scaffold\Functional\ManageGitIgnoreTest::testUnmanagedGitIgnoreWhenGitNotAvailable Failed asserting that two strings are equal. --- Expected +++ Actual @@ @@ -'Scaffolding files for fixtures/drupal-assets-fixture:\n +'Composer could not detect the root package (fixtures/drupal-composer-drupal-project) version, defaulting to '1.0.0'. See https://getcomposer.org/root-version\n +Scaffolding files for fixtures/drupal-assets-fixture:\n - Copy [web-root]/.csslintrc from assets/.csslintrc\n - Copy [web-root]/.editorconfig from assets/.editorconfig\n - Copy [web-root]/.eslintignore from assets/.eslintignore\n vendor/phpunit/phpunit/src/Framework/Constraint/Equality/IsEqual.php:94 core/tests/Drupal/Tests/Composer/Plugin/Scaffold/Functional/ManageGitIgnoreTest.php:253 vendor/phpunit/phpunit/src/Framework/TestResult.php:728 vendor/phpunit/phpunit/src/Framework/TestSuite.php:684 vendor/phpunit/phpunit/src/TextUI/TestRunner.php:651 vendor/phpunit/phpunit/src/TextUI/Command.php:144 vendor/phpunit/phpunit/src/TextUI/Command.php:97
- 🇳🇱Netherlands spokjeI don't see the relation with ??=. There is indeed no relation, HEAD was broken for a while 🐛 ManageGitIgnoreTest failing in HEAD RTBC . 
 Is fixed now, a rebase should make the error go away.
- 🇫🇷France Chris64 FranceThe $outputcomes from,// Confirm that 'git' is no longer available. $output = []; exec('git --help', $output, $status); $this->assertEquals(127, $status); // Run the scaffold command. $output = $this->mustExec('composer drupal:scaffold 2>&1', NULL);And the composer error comes from the latter line. From https://getcomposer.org/root-version the error message correspond to the case 4. The information can not come from case 3, since git is not available here. Therefore, to provide the information remain either case 1, through the version key in composer.json, or case 2, from theCOMPOSER_ROOT_VERSIONenvironment variable. Else the message is right, and the the$expectedis erroneous with this message missing.
- 🇫🇷France Chris64 FranceThank you @Spokje for the information. You mean #30 📌 Switch long-form single-line assign and null coalesce (= ??) to null coalesce assign operator (??=) Needs work ? Normally it is a new rebased version. 
- Status changed to Needs reviewover 1 year ago 4:58pm 18 March 2024
- 🇫🇷France Chris64 FranceMR Mergeable. Need review. Not a straight line, but seems okay now. Rebased on #3428032 to pass the test. 
- Status changed to Needs workover 1 year ago 4:32am 20 March 2024
- The Needs Review Queue Bot → tested this issue. It no longer applies to Drupal core. Therefore, this issue status is now "Needs work". - This does not mean that the patch necessarily needs to be re-rolled or the MR rebased. Read the Issue Summary, the issue tags and the latest discussion here to determine what needs to be done. - Consult the Drupal Contributor Guide → to find step-by-step guides for working with issues. 
- Status changed to Postponedover 1 year ago 11:31pm 26 March 2024
- 🇺🇸United States smustgraveOn the coding standard decision #3436307: Change !isset to the null coalescing assignment operator ??= →