All notable changes to this project will be documented in this file.
This projects adheres to Keep a CHANGELOG and uses Semantic Versioning.
Legend: :wrench: = Includes auto-fixer. :bar_chart: = Includes metrics. :books: = Includes CLI documentation.
Nothing yet.
1.5.0 - 2025-11-13
- 🔧 📊 📚 New
Universal.Attributes.BracketSpacingsniff to enforce a fixed number of spaces on the inside of attribute block brackets. #386, #406 The sniff offers the following properties to influence its behaviour:spacing(defaults to0).ignoreNewlines(defaults tofalse). When new lines are allowed (ignoreNewlines=true) and a new line is found, the sniff will verify that there are no superfluous blank lines at the start/end of an attribute block.
- 🔧 📊 📚 New
Universal.Attributes.DisallowAttributeParenthesessniff to forbid parentheses for attribute instantiations without arguments. #387, #409 - 🔧 📊 📚 New
Universal.Attributes.RequireAttributeParenthesessniff to demand that all attribute instantiations always use parentheses, even if no argument is passed. #387, #410 - 🔧 📊 📚 New
Universal.Attributes.TrailingCommasniff to demand a trailing comma for multi-line, multi-attribute attribute blocks and forbid trailing commas in single-line attribute blocks and in multi-line attributes containing only a single attribute. #397, #413 - 🔧 📊 📚 New
Universal.PHP.DisallowExitDieParenthesessniff to forbid invocations ofexit/diewith parentheses when no argument is passed. #399 - 🔧 📊 📚 New
Universal.PHP.RequireExitDieParenthesessniff to demand that invocations ofexit/diealways use parentheses, even if no argument is passed. #398 - 🔧 📚 New
Universal.WhiteSpace.FirstClassCallableSpacingsniff to enforce consistent spacing around the ellipses for first class callables. #385 The sniff offers the following property to influence its behaviour:spacing(defaults to0).
Universal.WhiteSpace.CommaSpacing: improved handling of commas in PHP attributes. #391, #412- The spacing after a trailing comma (after the last attribute in a block) will no longer be checked to prevent potential conflicts with attribute bracket spacing sniffs.
- Spacing errors for commas between attributes in an attribute block will now get an
*InAttributeBlockerror code suffix, so in-/excluding them selectively is more straight-forward. Note: spacing around commas between parameters passed to an attribute will still be reported with the*InFunctionCallerror code suffix, same as before. - Metrics for comma spacing in attribute blocks is now also measured and reported separately.
- Composer: The minimum
PHP_CodeSnifferrequirement has been updated to^3.13.5 || ^4.0.1(was^3.13.4 || ^4.0.0). #408 - Composer: The minimum
PHPCSUtilsrequirement has been updated to^1.2.0(was^1.1.2). #408 - Various housekeeping.
1.4.2 - 2025-10-28
- Various housekeeping.
Universal.OOStructures.AlphabeticExtendsImplementsincorrectly displayed the "expected" and "found" names. #378Universal.WhiteSpace.CommaSpacingcould accidentally cause a fatal error if the content adjacent to the comma was a text string containing percentage signs. Thanks @westonruter for reporting! #400, #401
1.4.1 - 2025-09-05
- Various housekeeping.
Universal.PHP.NoFQNTrueFalseNull: fix breakage due to upstream change in tokenization. #375
1.4.0 - 2025-06-14
- All sniffs: compatibility with the new PHP_CodeSniffer
4.xbranch in anticipation of the PHP_CodeSniffer 4.0 release. #367 PHPCSExtra should now be fully compatible with PHP_CodeSniffer 4.0. If you still find an issue, please report it.
- Composer: The minimum
PHP_CodeSnifferrequirement has been updated to^3.13.0(was^3.12.1). #361 - Composer: The minimum
PHPCSUtilsrequirement has been updated to^1.1.0(was^1.0.12). #361 - Various housekeeping.
Universal.WhiteSpace.PrecisionAlignment: support for scanning JS/CSS files via this sniff is now deprecated. #367
Universal.Arrays.DuplicateArrayKey: false positives for numeric strings with leading/trailing underscores. Fixed via the update to PHPCSUtils 1.1.0. #363Universal.Arrays.DuplicateArrayKey: false negatives for fully qualifiedtrue/false/nullarrays keys. Fixed via the update to PHPCSUtils 1.1.0. #363Universal.WhiteSpace.CommaSpacing: wrong errorcode for comma's in closure use statements after the update to PHPCSUtils 1.1.0. #362
1.3.1 - 2025-06-08
- Composer: The minimum
PHPCSUtilsrequirement has been updated to^1.0.12(was^1.0.9). #346 - Various housekeeping.
Universal.UseStatements.DisallowMixedGroupUse: the fixer could get confused when the "base" name for the group name contained a leading backslash, leading to parse errors in the fixed code. #350
1.3.0 - 2025-04-21
- 🔧 📚 New
Universal.PHP.NoFQNTrueFalseNullsniff to forbid usingtrue,falseandnullas fully qualified constants. Thanks @rodrigoprimo for reviewing. #327 Universal.Operators.TypeSeparatorSpacing: support for checking the spacing around the parentheses used in PHP 8.2+ DNF types. #329
- The
Universal.WhiteSpace.DisallowInlineTabssniff will now also check for inline tabs in heredoc/nowdoc openers and between theyieldandfromkeywords. #320
- Composer: The minimum
PHP_CodeSnifferrequirement has been updated to^3.12.1(was^3.8.0). #330 - Developer happiness: prevent creating a
composer.lockfile. Thanks @fredden! #307 - Various housekeeping, including improvements to the documentation and tests.
1.2.1 - 2023-12-08
- Composer: The minimum
PHP_CodeSnifferrequirement has been updated to^3.8.0(was^3.7.2). #298 - Composer: The minimum
PHPCSUtilsrequirement has been updated to^1.0.9(was^1.0.8). #298
Please ensure you run composer update phpcsstandards/phpcsextra --with-dependencies to benefit from this.
1.2.0 - 2023-12-02
- 🔧 📚 New
Universal.CodeAnalysis.NoDoubleNegativesniff to detect double negatives (!!) and advise to use a boolean cast instead. Thanks @diedexx for reviewing. #277 - 🔧 📚 New
Universal.Operators.ConcatPositionsniff to enforce that the concatenation operator for multi-line concatenations is in a preferred position, either always at the start of the next line or always at the end of the previous line. #294 - 🔧 📊 📚 New
Universal.PHP.LowercasePHPTagsniff to enforce that the "PHP" in a PHP open tag is lowercase. Thanks @fredden for reviewing. #276
NormalizedArrays.Arrays.CommaAfterLast: the sniff now has two extra error codes to distinguish between multi-line arrays with the last array item on the same line as the array closer vs the last array item being on a line before the array closer. Thanks @stronk7 for suggesting and patching this. #283, #284 These new error codes allow for selectively excluding that specific situation from triggering the sniff. The new error codes areFoundMultiLineCloserSameLine(formultiLine="forbid") andMissingMultiLineCloserSameLine(formultiLine="enforce"). The pre-existingFoundMultiLineandFoundSingleLineerror codes continue to be used for multi-line arrays with the last array item on a different line than the array closer.
- Various housekeeping.
1.1.2 - 2023-09-21
- Various housekeeping.
Universal.CodeAnalysis.ConstructorDestructorReturn: the sniff will now correctly ignore methods mirroring the class name (PHP-4 style constructors) in namespaced code. #207, #272
1.1.1 - 2023-08-26
Modernize.FunctionCalls.Dirname: the sniff will now respect a potentially setphp_versionconfiguration option and only report on modernizations which are possible on the configuredphp_version. #261 If thephp_versionis not set, the sniff will continue to report on all modernization options.
- Various documentation improvements. Props in part to @szepeviktor.
- Improved defensive coding in select places.
- Various housekeeping.
1.1.0 - 2023-07-19
- 🔧 📚 New
Universal.CodeAnalysis.NoEchoSprintfsniff to detect use of the inefficientecho [v]sprintf(...);combi and recommends using[v]printf()instead. #242 - 📊 📚 New
Universal.FunctionDeclarations.NoLongClosuressniff to detect "long" closures and recommend using a named function instead. #240 The sniff offers the following properties to influence its behaviour:recommendedLines(defaults to5),maxLines(defaults to8),ignoreCommentLines(defaults totrue) andignoreEmptyLines(defaults totrue). - 🔧 📊 📚 New
Universal.FunctionDeclarations.RequireFinalMethodsInTraitssniff to enforce non-private, non-abstract methods in traits to be declared asfinal. #243, #245 There is a separateNonFinalMagicMethodFounderror code for magic methods to allow those to be excluded from the check. - 🔧 📊 📚 New
Universal.UseStatements.DisallowMixedGroupUsesniff to disallow group use statements which import a combination of namespace/OO construct, functions and/or constants in one statement. #241, #246 Note: the fixer will use a semi-standardized format for group use statements. If there are more specific requirements for the formatting of group use statements, the ruleset configurator should ensure that additional sniffs are included in the ruleset to enforce the required format. - 🔧 📊 📚 New
Universal.UseStatements.KeywordSpacingsniff to enforce the use of a single space after theuse,function,constkeywords and both before and after theaskeyword in importusestatements. #247 The sniff has modular error codes to allow for disabling individual checks. - 🔧 📚 New
Universal.UseStatements.NoUselessAliasessniff to detect useless aliases (aliasing something to its original name) in import use statements. #244 Note: as OO and function names in PHP are case-insensitive, aliasing to the same name, using a different case is also considered useless. - 🔧 📊 📚 New
Universal.WhiteSpace.CommaSpacingsniff to enforce that there is no space before a comma and exactly one space, or a new line, after a comma. #254 Additionally, the sniff also enforces that the comma should follow the code and not be placed after a trailing comment. The sniff has modular error codes to allow for disabling individual checks and checks in certain contexts. The sniff will respect a potentially setphp_versionconfiguration option when deciding how to handle the spacing after a heredoc/nowdoc closer.
- Minor performance improvements for the
Universal.Arrays.DuplicateArrayKeyand theUniversal.CodeAnalysis.ConstructorDestructorReturnsniffs. #251, #252
- Composer: The minimum
PHPCSUtilsrequirement has been updated to^1.0.8(was^1.0.6). #249, #254 - Various housekeeping.
1.0.4 - 2023-06-18
- Composer: The minimum
PHPCSUtilsrequirement has been updated to^1.0.6(was^1.0.0). #237 - Various housekeeping.
Universal.Constants.LowercaseClassResolutionKeyword: prevent false positives for function calls to methods calledclass. #226
1.0.3 - 2023-03-28
- Various housekeeping.
Modernize.FunctionCalls.Dirname: prevent false positives for attribute classes calleddirname. #211, #213
1.0.2 - 2023-01-10
Universal.CodeAnalysis.ConstructorDestructorReturn: the sniff will now respect a potentially setphp_versionconfiguration option and only report on PHP4-style constructors when thephp_versionis below'80000'. Thanks @anomiex for reporting! #207, #208
1.0.1 - 2023-01-05
Universal.CodeAnalysis.ConstructorDestructorReturn: fixed false positive for return statements in nested functions/closures declared within constructor/destructor methods. Thanks @anomiex for reporting! #201, #202
1.0.0 - 2023-01-04
--with-[all-]dependencies when running composer update. ❗
For the full list of features, please see the changelogs of the alpha/rc releases:
- Updated various sniffs to take advantage of PHPCSUtils 1.0.0(-rc1). #193, #194, #195
- Minor documentation improvements.
- Various housekeeping.
Modernize.FunctionCalls.Dirname: the sniff will now correctly recognize magic constants in a case-insensitive manner. #187
1.0.0-RC1 - 2022-12-07
--with-[all-]dependencies when running composer update. ❗
- This is a new standard with one sniff to start with.
- 🔧 📚 New
Modernize.FunctionCalls.Dirnamesniff to detect and auto-fix two typical code modernizations which can be made related to thedirname()function. #172
- 🔧 📊 📚 New
Universal.Classes.DisallowAnonClassParenthesessniff to disallow the use of parentheses when declaring an anonymous class without passing parameters. #76, #162 - 🔧 📊 📚 New
Universal.Classes.RequireAnonClassParenthesessniff to require the use of parentheses when declaring an anonymous class, whether parameters are passed or not. #76, #166 - 🔧 📊 📚 New
Universal.Classes.DisallowFinalClasssniff to disallow classes being declaredfinal. #108, #114, #148, #163 - 🔧 📊 📚 New
Universal.Classes.RequireFinalClasssniff to require all non-abstractclasses to be declaredfinal. #109, #148, #164 Warning: the auto-fixer for this sniff may have unintended side-effects for applications and should be used with care! This is considered a risky fixer. - 🔧 📊 📚 New
Universal.Classes.ModifierKeywordOrdersniff to standardize the modifier keyword order for class declarations. #142 The sniff offers anorderproperty to specify the preferred order. - 🔧 📚 New
Universal.CodeAnalysis.ConstructorDestructorReturnsniff to verify that class constructor/destructor methods 1) do not have a return type declaration and 2) do not return a value. #137, #140, #146 Inspired by @derickr. - 🔧 📚 New
Universal.CodeAnalysis.ForeachUniqueAssignmentsniff to detectforeachcontrol structures which use the same variable for both the key as well as the value assignment as this will lead to unexpected - and most likely unintended - behaviour. #110, #175 The fixer will maintain the existing behaviour of the code. Mind: this may not be the intended behaviour. - 🔧 📚 New
Universal.CodeAnalysis.StaticInFinalClasssniff to detect usingstaticinstead ofselfin OO constructs which arefinal. #116, #180 The sniff has modular error codes to allow for making exceptions based on the type of use forstatic. - 🔧 📊 📚 New
Universal.Constants.LowercaseClassResolutionKeywordsniff to enforce that theclasskeyword when used for class name resolution, i.e.::class, is in lowercase. #72 - 🔧 📊 📚 New
Universal.Constants.ModifierKeywordOrdersniff to standardize the modifier keyword order for OO constant declarations. #143 The sniff offers anorderproperty to specify the preferred order. - 🔧 📚 New
Universal.ControlStructures.DisallowLonelyIfsniff to disallowifstatements as the only statement in anelseblock. #85, #168, #169 Inspired by the ESLint "no lonely if" rule. Note: This sniff will not fix the indentation of the "inner" code. It is strongly recommended to run this sniff together with theGeneric.WhiteSpace.ScopeIndentsniff to get the correct indentation. - 📊 📚 New
Universal.Files.SeparateFunctionsFromOOsniff to enforce that a file should either declare (global/namespaced) functions or declare OO structures, but not both. #95, #170, #171 Nested function declarations, i.e. functions declared within a function/method will be disregarded for the purposes of this sniff. The same goes for anonymous classes, closures and arrow functions. - 📚 New
Universal.NamingConventions.NoReservedKeywordParameterNamessniff to verify that function parameters do not use reserved keywords as names, as this can quickly become confusing when people use them in function calls using named parameters. #80, #81, #106, #107, #173 The sniff has modular error codes to allow for making exceptions for specific keywords. - 🔧 📊 📚 New
Universal.Operators.TypeSeparatorSpacingsniff to enforce no spaces around union type and intersection type separators. #117 - 🔧 📚 New
Universal.PHP.OneStatementInShortEchoTagsniff to disallow short open echo tags<?=containing more than one PHP statement. #89, #147, #165 - 🔧 📊 📚 New
Universal.WhiteSpace.AnonClassKeywordSpacingsniff to standardize the amount of spacing between theclasskeyword and the open parenthesis (if any) for anonymous class declarations. #120 The sniff offers aspacingproperty to set the amount of spaces the sniff should check for. - 🔧 📚 New
Universal.WhiteSpace.PrecisionAlignmentsniff to enforce indentation to always be a multiple of a tabstop, i.e. disallow precision alignment. #119, #122, #123, #124 Note:- This sniff does not concern itself with tabs versus spaces.
It is recommended to use the sniff in combination with the PHPCS native
Generic.WhiteSpace.DisallowTabIndentor theGeneric.WhiteSpace.DisallowSpaceIndentsniff. - When using this sniff with tab-based standards, please ensure that the
tab-widthis set and either don't set the$indentproperty or set it to the tab-width (or a multiple thereof). - The fixer works based on "best guess" and may not always result in the desired indentation. Combine this sniff with the
Generic.WhiteSpace.ScopeIndentsniff for more precise indentation fixes. - The behaviour of the sniff is customizable via the following properties:
indent: the indent used for the codebase.ignoreAlignmentBefore: allows for providing a list of token names for which (preceding) precision alignment should be ignored.ignoreBlankLines: whether or not potential trailing whitespace on otherwise blank lines should be examined or ignored.
- This sniff does not concern itself with tabs versus spaces.
It is recommended to use the sniff in combination with the PHPCS native
Universal.Arrays.DisallowShortArraySyntax: the sniff will now record metrics about long vs short array usage. #154Universal.Arrays.DuplicateArrayKey: where relevant, the sniff will now make a distinction between keys which will be duplicate in all PHP version and (numeric) keys which will only be a duplicate key in PHP < 8.0 or PHP >= 8.0. #177, #178 If aphp_versionconfiguration option has been passed to PHPCS, it will be respected by the sniff and only report duplicate keys for the configured PHP version.Universal.ControlStructures.DisallowAlternativeSyntax: the sniff will now also record a metric when single-line (no body) control structures are encountered. #158Universal.ControlStructures.DisallowAlternativeSyntax: the error message thrown by the sniff is now more descriptive. #159Universal.ControlStructures.DisallowAlternativeSyntax: metrics will no longer be recorded forelseifandelsekeywords, but only on theifkeyword as the type of syntax used has to be the same for the whole "chain". #161Universal.Lists.DisallowLongListSyntax: the sniff will no longer record (incomplete) metrics about long vs short list usage. #155Universal.Lists.DisallowShortListSyntax: the sniff will now record (complete) metrics about long vs short list usage. #155Universal.OOStructures.AlphabeticExtendsImplements: documented support forenum ... implements. #150Universal.UseStatements.DisallowUseClass: updated error message and metric name to take PHP 8.1enums into account. #149Universal.UseStatements.NoLeadingBackslash: the sniff will now also flag and auto-fix leading backslashes in group use statements. #167
- Updated the sniffs for compatibility with PHPCSUtils 1.0.0-alpha4. #134
- Updated the sniffs to correctly handle PHP 8.0/8.1/8.2 features whenever relevant.
- Readme: Updated installation instructions for compatibility with Composer 2.2+. #101
- Composer: The minimum
PHP_CodeSnifferrequirement has been updated to^3.7.1(was^3.3.1). #115, #130 - Composer: The package will now identify itself as a static analysis tool. Thanks @GaryJones! #126
- All non-
abstractclasses in this package are nowfinal. #121 - All XML documentation now has a schema annotation. #128
- Various housekeeping.
The upgrade to PHPCSUtils 1.0.0-alpha4 took care of a number of bugs, which potentially could have affected sniffs in this package.
NormalizedArrays.Arrays.ArrayBraceSpacing: the sniff now allows for trailing comments after the array opener in multi-line arrays. #118NormalizedArrays.Arrays.ArrayBraceSpacing: trailing comments at the end of an array, but before the closer, in multi-line arrays will no longer confuse the sniff. #135NormalizedArrays.Arrays.CommaAfterLast: the fixer will now recognize PHP 7.3+ flexible heredoc/nowdocs and in that case, will add the comma on the same line as the heredoc/nowdoc closer. #144
Universal.Arrays.DisallowShortArraySyntax: nested short arrays in short lists will now be detected and fixed correctly. #153Universal.ControlStructures.DisallowAlternativeSyntax: the sniff will no longer bow out indiscriminately when theallowWithInlineHTMLproperty is set totrue. #90, #161Universal.ControlStructures.DisallowAlternativeSyntax: when alternative control structure syntax is allowed in combination with inline HTML (allowWithInlineHTMLproperty set totrue), inline HTML in functions declared within the control structure body will no longer be taken into account for determining whether or not the control structure contains inline HTML. #160Universal.Lists.DisallowShortListSyntax: the sniff will work around a tokenizer bug in PHPCS 3.7.1, which previously could lead to false negatives. #151.Universal.Lists.DisallowShortListSyntax: nested short lists in short arrays will now be detected and fixed correctly. #152Universal.Operators.DisallowStandalonePostIncrementDecrement: the sniff will now correctly recognize stand-alone statements which end on a PHP close tag. #176
1.0.0-alpha3 - 2020-06-29
- 🔧 📚 New
Universal.Arrays.DisallowShortArraySyntaxsniff to disallow short array syntax. #40 In contrast to the PHPCS nativeGeneric.Arrays.DisallowShortArraySyntaxsniff, this sniff will ignore short list syntax and not cause parse errors when the fixer is used. - 🔧 📊 📚 New
Universal.Constants.UppercaseMagicConstantssniff to enforce that PHP native magic constants are in uppercase. #64 - 📊 📚 New
Universal.Namespaces.DisallowDeclarationWithoutNamesniff to disallow namespace declarations without a namespace name. #50 - 📊 📚 New
Universal.Operators.DisallowLogicalAndOrsniff to enforce the use of the boolean&&and||operators instead of the logicaland/oroperators. #52 Note: as the operator precedence of the logical operators is significantly lower than the operator precedence of boolean operators, this sniff does not contain an auto-fixer. - 📊 📚 New
Universal.Operators.DisallowShortTernarysniff to disallow the use of short ternaries?:. #42 While short ternaries are useful when used correctly, the principle of them is often misunderstood and they are more often than not used incorrectly, leading to hard to debug issues and/or PHP warnings/notices. - 🔧 📊 📚 New
Universal.Operators.DisallowStandalonePostIncrementDecrementsniff disallow the use of post-in/decrements in stand-alone statements and discourage the use of multiple increment/decrement operators in a stand-alone statement. #65 - 🔧 📊 📚 New
Universal.Operators.StrictComparisonssniff to enforce the use of strict comparisons. #48 Warning: the auto-fixer for this sniff may cause bugs in applications and should be used with care! This is considered a risky fixer. - 🔧 📊 📚 New
Universal.OOStructures.AlphabeticExtendsImplementssniff to verify that the names used in a class "implements" statement or an interface "extends" statement are listed in alphabetic order. #55- This sniff contains a public
orderbyproperty to determine the sort order to use for the statement. If all names used are unqualified, the sort order won't make a difference. However, if one or more of the names are partially or fully qualified, the chosen sort order will determine how the sorting between unqualified, partially and fully qualified names is handled. The sniff supports two sort order options:- 'name' : sort by the interface name only (default);
- 'full' : sort by the full name as used in the statement (without leading backslash). In both cases, the sorting will be done using natural sort, case-insensitive.
- The sniff has modular error codes to allow for selective inclusion/exclusion:
ImplementsWrongOrder- for "class implements" statements.ImplementsWrongOrderWithComments- for "class implements" statements interlaced with comments. These will not be auto-fixed.ExtendsWrongOrder- for "interface extends" statements.ExtendsWrongOrderWithComments- for "interface extends" statements interlaced with comments. These will not be auto-fixed.
- When fixing, the existing spacing between the names in an
implements/extendsstatement will not be maintained. The fixer will separate each name with a comma and one space. If alternative formatting is desired, a sniff which will check and fix the formatting should be added to the ruleset.
- This sniff contains a public
- 🔧 📊 📚 New
Universal.UseStatements.LowercaseFunctionConstsniff to enforce thatfunctionandconstkeywords when used in an importusestatement are always lowercase. #58 - 🔧 📊 📚 New
Universal.UseStatements.NoLeadingBackslashsniff to verify that a name being imported in an importusestatement does not start with a leading backslash. #46 Names in importusestatements should always be fully qualified, so a leading backslash is not needed and it is strongly recommended not to use one. This sniff handles all types of import use statements supported by PHP, in contrast to other sniffs for the same in, for instance, the PSR12 or the Slevomat standard, which are incomplete. - 🔧 📚 New
Universal.WhiteSpace.DisallowInlineTabssniff to enforce using spaces for mid-line alignment. #43
- The
masterbranch has been renamed tostable. - Composer: The version requirements for the Composer PHPCS plugin have been widened to allow for version 0.7.0 which supports Composer 2.0.0. #62
- Various housekeeping.
1.0.0-alpha2 - 2020-02-18
- 🔧 📊 📚 New
Universal.ControlStructures.DisallowAlternativeSyntaxsniff to disallow using the alternative syntax for control structures. #23- This sniff contains a
allowWithInlineHTMLproperty to allow alternative syntax when inline HTML is used within the control structure. In all other cases, the use of the alternative syntax will still be disallowed. - The sniff has modular error codes to allow for making exceptions based on specific control structures and/or specific control structures in combination with inline HTML.
- This sniff contains a
- 📊
Universal.UseStatements.DisallowUseClass/Function/Const: new, additional metrics about the import source will be shown in theinforeport. #25
- Readme: installation instructions and sniff list. #26
Universal.Arrays.DuplicateArrayKey: wording of the error message. #18Universal.UseStatements.DisallowUseClass/Function/Const: the error codes have been made more modular. #25 Each of these sniffs now has four additional error codes:FoundSameNamespace,FoundSameNamespaceWithAliasforusestatements importing from the same namespace;FoundGlobalNamespace,FoundGlobalNamespaceWithAliasforusestatements importing from the global namespace, like import statements for PHP native classes, functions and constants.
FoundWithAliasandFoundWithoutAliaswill continue to be used.
- Improved formatting of the CLI documentation which can be viewed using
--generator=text. #17 - Various housekeeping.
Universal.Arrays.DuplicateArrayKey: improved handling of parse errors. #34Universal.ControlStructures.IfElseDeclaration: the fixer will now respect tab indentation. #19Universal.UseStatements.DisallowUseClass/Function/Const: the determination of whether a import is aliased in now done in a case-insensitive manner. #25Universal.UseStatements.DisallowUseClass/Function/Const: an import from the global namespace would previously always be seen as non-aliased, even when it was aliased. #25Universal.UseStatements.DisallowUseClass/Function/Const: improved tolerance foruseimport statements with leading backslashes. #25
Initial alpha release containing:
- A
NormalizedArraysstandard which will contain a full set of sniffs to check the formatting of array declarations. - A
Universalstandard which will contain a collection of universally applicable sniffs. DO NOT INCLUDE THIS AS A STANDARD.Universal, like the upstream PHPCSGenericstandard, contains sniffs which contradict each other. Include individual sniffs from this standard in a custom project/company ruleset to use them.
This initial alpha release contains the following sniffs:
- 🔧 📊 📚
NormalizedArrays.Arrays.ArrayBraceSpacing: enforce consistent spacing for the open/close braces of array declarations. The sniff allows for having different settings for:- Space between the array keyword and the open parenthesis for long arrays via the
keywordSpacingproperty. Accepted values: (int) number of spaces orfalseto turn this check off. Defaults to0spaces. - Spaces on the inside of the braces for empty arrays via the
spacesWhenEmptyproperty. Accepted values: (string)newline, (int) number of spaces orfalseto turn this check off. Defaults to0spaces. - Spaces on the inside of the braces for single-line arrays via the
spacesSingleLineproperty; Accepted values: (int) number of spaces orfalseto turn this check off. Defaults to0spaces. - Spaces on the inside of the braces for multi-line arrays via the
spacesMultiLineproperty. Accepted values: (string)newline, (int) number of spaces orfalseto turn this check off. Defaults tonewline. Note: if any of the above properties are set tonewline, it is recommended to also include an array indentation sniff. This sniff will not handle the indentation.
- Space between the array keyword and the open parenthesis for long arrays via the
- 🔧 📊 📚
NormalizedArrays.Arrays.CommaAfterLast: enforce/forbid a comma after the last item in an array declaration. By default, this sniff will:- forbid a comma after the last array item for single-line arrays.
- enforce a comma after the last array item for multi-line arrays.
singleLineormultiLineproperties in a custom ruleset. The valid values are:enforce,forbidorskipto not check the comma after the last array item for a particular type of array.
- 📚
Universal.Arrays.DuplicateArrayKey: detects duplicate array keys in array declarations. - 📚
Universal.Arrays.MixedArrayKeyTypes: best practice sniff: don't use a mix of integer and numeric keys for array items. - 📚
Universal.Arrays.MixedKeyedUnkeyedArray: best practice sniff: don't use a mix of keyed and unkeyed array items. - 🔧 📊 📚
Universal.ControlStructures.IfElseDeclaration: verify that else(if) statements with braces are on a new line. - 🔧 📊 📚
Universal.Lists.DisallowLongListSyntax: disallow the use of longlists. - 🔧 📊 📚
Universal.Lists.DisallowShortListSyntax: disallow the use of short lists. - 📊 📚
Universal.Namespaces.DisallowCurlyBraceSyntax: disallow the use of the alternative namespace declaration syntax using curly braces. - 📊 📚
Universal.Namespaces.EnforceCurlyBraceSyntax: enforce the use of the alternative namespace syntax using curly braces. - 📚
Universal.Namespaces.OneDeclarationPerFile: disallow the use of multiple namespaces within a file. - 📊 📚
Universal.UseStatements.DisallowUseClass: forbid using import use statements for classes/traits/interfaces. Individual sub-types can be allowed by excluding specific error codes. - 📊 📚
Universal.UseStatements.DisallowUseConst: forbid using import use statements for constants. Individual sub-types can be allowed by excluding specific error codes. - 📊 📚
Universal.UseStatements.DisallowUseFunction: forbid using import use statements for functions. Individual sub-types can be allowed by excluding specific error codes.