123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155 |
- <?xml version="1.0"?>
- <ruleset
- xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
- xsi:noNamespaceSchemaLocation="vendor/squizlabs/php_codesniffer/phpcs.xsd"
- >
- <arg name="basepath" value="."/>
- <arg name="extensions" value="php"/>
- <arg name="parallel" value="80"/>
- <arg name="cache" value=".phpcs-cache"/>
- <arg name="colors"/>
- <!-- Show progress of the run and show sniff names -->
- <arg value="ps"/>
- <file>lib</file>
- <file>tests</file>
- <rule ref="Doctrine">
- <exclude name="SlevomatCodingStandard.TypeHints.ParameterTypeHint.MissingNativeTypeHint"/>
- <exclude name="SlevomatCodingStandard.TypeHints.ReturnTypeHint.MissingNativeTypeHint"/>
- <exclude name="SlevomatCodingStandard.TypeHints.DeclareStrictTypes"/>
- <exclude name="SlevomatCodingStandard.Classes.SuperfluousAbstractClassNaming"/>
- <exclude name="SlevomatCodingStandard.Classes.SuperfluousExceptionNaming"/>
- <exclude name="SlevomatCodingStandard.Classes.SuperfluousTraitNaming.SuperfluousSuffix"/>
- <exclude name="SlevomatCodingStandard.Classes.DisallowLateStaticBindingForConstants.DisallowedLateStaticBindingForConstant"/>
- <exclude name="SlevomatCodingStandard.ControlStructures.ControlStructureSpacing.IncorrectLinesCountAfterLastControlStructure"/>
- <exclude name="PSR2.Methods.MethodDeclaration.Underscore"/>
- <!-- https://github.com/slevomat/coding-standard/issues/867 -->
- <exclude name="SlevomatCodingStandard.ControlStructures.JumpStatementsSpacing.IncorrectLinesCountAfterLastControlStructure"/>
- <!-- See https://github.com/squizlabs/PHP_CodeSniffer/issues/2937 -->
- <exclude name="Squiz.Arrays.ArrayDeclaration.ValueNoNewline"/>
- <exclude name="Squiz.NamingConventions.ValidVariableName.PublicHasUnderscore"/>
- </rule>
- <!-- Disable the rules that will require PHP 7.4 -->
- <rule ref="SlevomatCodingStandard.TypeHints.PropertyTypeHint">
- <properties>
- <property name="enableNativeTypeHint" value="false"/>
- </properties>
- </rule>
- <rule ref="PSR1.Methods.CamelCapsMethodName.NotCamelCaps">
- <exclude-pattern>*/lib/Doctrine/Common/Annotations/DocParser.php</exclude-pattern>
- </rule>
- <rule ref="Squiz.Classes.ValidClassName.NotCamelCaps">
- <exclude-pattern>*/tests/Doctrine/Tests/Common/Annotations/Fixtures/ClassNoNamespaceNoComment.php</exclude-pattern>
- </rule>
- <rule ref="SlevomatCodingStandard.Namespaces.ReferenceUsedNamesOnly">
- <exclude-pattern>*/tests/Doctrine/Tests/Common/Annotations/Fixtures/*</exclude-pattern>
- </rule>
- <rule ref="SlevomatCodingStandard.Commenting.ForbiddenAnnotations.AnnotationForbidden">
- <exclude-pattern>*/tests/Doctrine/Tests/Common/Annotations/Fixtures/*</exclude-pattern>
- </rule>
- <rule ref="SlevomatCodingStandard.Namespaces.UseDoesNotStartWithBackslash.UseStartsWithBackslash">
- <exclude-pattern>*/tests/Doctrine/Tests/Common/Annotations/Fixtures/*</exclude-pattern>
- </rule>
- <rule ref="PSR12.Files.ImportStatement.LeadingSlash">
- <exclude-pattern>*/tests/Doctrine/Tests/Common/Annotations/Fixtures/*</exclude-pattern>
- </rule>
- <rule ref="SlevomatCodingStandard.TypeHints.LongTypeHints.UsedLongTypeHint">
- <exclude-pattern>*/tests/Doctrine/Tests/Common/Annotations/Fixtures/*</exclude-pattern>
- </rule>
- <rule ref="SlevomatCodingStandard.Namespaces.UseFromSameNamespace.UseFromSameNamespace">
- <exclude-pattern>*/tests/Doctrine/Tests/Common/Annotations/Fixtures/*</exclude-pattern>
- </rule>
- <rule ref="SlevomatCodingStandard.Namespaces.UseDoesNotStartWithBackslash.UseStartsWithBackslash">
- <exclude-pattern>*/tests/Doctrine/Tests/Common/Annotations/Fixtures/*</exclude-pattern>
- </rule>
- <rule ref="SlevomatCodingStandard.Namespaces.UnusedUses.UnusedUse">
- <exclude-pattern>*/tests/Doctrine/Tests/Common/Annotations/Fixtures/*</exclude-pattern>
- </rule>
- <rule ref="SlevomatCodingStandard.Namespaces.UseSpacing.IncorrectLinesCountBetweenSameTypeOfUse">
- <exclude-pattern>*/tests/Doctrine/Tests/Common/Annotations/Fixtures/*</exclude-pattern>
- </rule>
- <rule ref="SlevomatCodingStandard.Namespaces.MultipleUsesPerLine.MultipleUsesPerLine">
- <exclude-pattern>*/tests/Doctrine/Tests/Common/Annotations/Fixtures/*</exclude-pattern>
- </rule>
- <!-- https://github.com/slevomat/coding-standard/issues/1066 -->
- <rule ref="SlevomatCodingStandard.PHP.UselessParentheses">
- <exclude-pattern>*/lib/Doctrine/Common/Annotations/DocParser.php</exclude-pattern>
- </rule>
- <rule ref="SlevomatCodingStandard.Namespaces.ReferenceUsedNamesOnly.ReferenceViaFullyQualifiedName">
- <exclude-pattern>*/tests/Doctrine/Tests/Common/Annotations/PhpParserTest.php</exclude-pattern>
- </rule>
- <!-- It is easier to understand tests that involve annotations if you can
- declare several dummy classes with annotations in the same file -->
- <rule ref="PSR1.Classes.ClassDeclaration.MultipleClasses">
- <exclude-pattern>*/tests/*</exclude-pattern>
- </rule>
- <rule ref="Squiz.Classes.ClassFileName.NoMatch">
- <exclude-pattern>*/tests/*</exclude-pattern>
- </rule>
- <rule ref="PSR1.Files.SideEffects.FoundWithSymbols">
- <exclude-pattern>*/tests/Doctrine/Tests/Common/Annotations/Ticket/DCOM58Test.php</exclude-pattern>
- <exclude-pattern>*/tests/Doctrine/Tests/Common/Annotations/AbstractReaderTest.php</exclude-pattern>
- <exclude-pattern>*/tests/Doctrine/Tests/Common/Annotations/PhpParserTest.php</exclude-pattern>
- <exclude-pattern>*/tests/Doctrine/Tests/Common/Annotations/Fixtures/NamespaceWithClosureDeclaration.php</exclude-pattern>
- <exclude-pattern>*/tests/Doctrine/Tests/Common/Annotations/Fixtures/ClassWithRequire.php</exclude-pattern>
- </rule>
- <!-- these classes have unused properties, and is unused in a benchmark for the parser -->
- <rule ref="SlevomatCodingStandard.Classes.UnusedPrivateElements.UnusedProperty">
- <exclude-pattern>*/tests/Doctrine/Tests/Common/Annotations/Fixtures/SingleClassLOC1000.php</exclude-pattern>
- <exclude-pattern>*/tests/Doctrine/Tests/Common/Annotations/Fixtures/NamespacedSingleClassLOC1000.php</exclude-pattern>
- </rule>
- <rule ref="SlevomatCodingStandard.Classes.UnusedPrivateElements.UnusedMethod">
- <exclude-pattern>*/tests/Doctrine/Tests/Common/Annotations/Fixtures/Controller.php</exclude-pattern>
- </rule>
- <!-- these classes do not have a namespace on purpose -->
- <rule ref="PSR1.Classes.ClassDeclaration.MissingNamespace">
- <exclude-pattern>*/tests/Doctrine/Tests/Common/Annotations/Fixtures/SingleClassLOC1000.php</exclude-pattern>
- <exclude-pattern>*/tests/Doctrine/Tests/Common/Annotations/Fixtures/NonNamespacedClass.php</exclude-pattern>
- <exclude-pattern>*/tests/Doctrine/Tests/Common/Annotations/Ticket/DCOM58Entity.php</exclude-pattern>
- <exclude-pattern>*/tests/Doctrine/Tests/Common/Annotations/Fixtures/ClassNoNamespaceNoComment.php</exclude-pattern>
- <exclude-pattern>*/tests/Doctrine/Tests/Common/Annotations/TopLevelAnnotation.php</exclude-pattern>
- </rule>
- <rule ref="SlevomatCodingStandard.TypeHints.PropertyTypeHint.MissingAnyTypeHint">
- <!-- there is a class property with an empty var annotation on purpose -->
- <exclude-pattern>*/tests/Doctrine/Tests/Common/Annotations/AbstractReaderTest.php</exclude-pattern>
- <exclude-pattern>*/tests/Doctrine/Tests/Common/Annotations/Fixtures/ClassWithValidAnnotationTarget.php</exclude-pattern>
- </rule>
- <rule ref="SlevomatCodingStandard.Namespaces.DisallowGroupUse.DisallowedGroupUse">
- <!-- The name of the file alone explains this -->
- <exclude-pattern>*/tests/Doctrine/Tests/Common/Annotations/Fixtures/GroupUseStatement.php</exclude-pattern>
- </rule>
- <rule ref="SlevomatCodingStandard.TypeHints.PropertyTypeHint.MissingTraversableTypeHintSpecification">
- <exclude-pattern>*/tests/Doctrine/Tests/Common/Annotations/Fixtures/AnnotationWithVarType.php</exclude-pattern>
- </rule>
- <rule ref="SlevomatCodingStandard.Classes.SuperfluousInterfaceNaming.SuperfluousSuffix">
- <exclude-pattern>*/tests/Doctrine/Tests/Common/Annotations/Fixtures/EmptyInterface.php</exclude-pattern>
- <exclude-pattern>*/tests/Doctrine/Tests/Common/Annotations/Fixtures/InterfaceThatExtendsAnInterface.php</exclude-pattern>
- </rule>
- <rule ref="SlevomatCodingStandard.Classes.SuperfluousInterfaceNaming.SuperfluousPrefix">
- <exclude-pattern>*/tests/Doctrine/Tests/Common/Annotations/Fixtures/InterfaceThatExtendsAnInterface.php</exclude-pattern>
- <exclude-pattern>*/tests/Doctrine/Tests/Common/Annotations/Fixtures/InterfaceWithConstants.php</exclude-pattern>
- </rule>
- <rule ref="Generic.NamingConventions.UpperCaseConstantName.ClassConstantNotUpperCase">
- <!-- Usage of mixed case constants seems pretty deliberate here -->
- <exclude-pattern>*/lib/Doctrine/Common/Annotations/ImplicitlyIgnoredAnnotationNames.php</exclude-pattern>
- </rule>
- </ruleset>
|