From 3304604e5abdf635d189edb693f69b3a4fc1dd13 Mon Sep 17 00:00:00 2001 From: jrfnl Date: Tue, 25 Jul 2017 11:29:08 +0200 Subject: [PATCH] PrefixAllGlobals: Improve recognition of namespaced constants using `define()` Notes: * Checking for the existance of a namespace separator should be enough here. * Using `__NAMESPACE__` outside of a namespace will result in an empty string, however, the `\` in the string following it will be part of the namespace name, making the constant effectively unreachable (which is not our concern). Fixes 1056 --- .../NamingConventions/PrefixAllGlobalsSniff.php | 5 +++++ .../NamingConventions/PrefixAllGlobalsUnitTest.1.inc | 3 +++ .../NamingConventions/PrefixAllGlobalsUnitTest.inc | 12 ++++++++++++ .../NamingConventions/PrefixAllGlobalsUnitTest.php | 1 + 4 files changed, 21 insertions(+) diff --git a/WordPress/Sniffs/NamingConventions/PrefixAllGlobalsSniff.php b/WordPress/Sniffs/NamingConventions/PrefixAllGlobalsSniff.php index 887d0408c9..74191df878 100644 --- a/WordPress/Sniffs/NamingConventions/PrefixAllGlobalsSniff.php +++ b/WordPress/Sniffs/NamingConventions/PrefixAllGlobalsSniff.php @@ -626,6 +626,11 @@ public function process_parameters( $stackPtr, $group_name, $matched_content, $p return; } + if ( strpos( $raw_content, '\\' ) !== false ) { + // Namespaced or unreachable constant. + return; + } + $data = array( 'Global constants defined' ); $error_code = 'NonPrefixedConstantFound'; } else { diff --git a/WordPress/Tests/NamingConventions/PrefixAllGlobalsUnitTest.1.inc b/WordPress/Tests/NamingConventions/PrefixAllGlobalsUnitTest.1.inc index d8562e2eb3..2c9ca83f96 100644 --- a/WordPress/Tests/NamingConventions/PrefixAllGlobalsUnitTest.1.inc +++ b/WordPress/Tests/NamingConventions/PrefixAllGlobalsUnitTest.1.inc @@ -13,3 +13,6 @@ const SOME_CONSTANT = 'value'; class Example {} interface I_Example {} trait T_Example {} + +// Issue #1056. +define( __NAMESPACE__ . '\PLUGIN_FILE', __FILE__ ); diff --git a/WordPress/Tests/NamingConventions/PrefixAllGlobalsUnitTest.inc b/WordPress/Tests/NamingConventions/PrefixAllGlobalsUnitTest.inc index cc258a131a..44d8dbff69 100644 --- a/WordPress/Tests/NamingConventions/PrefixAllGlobalsUnitTest.inc +++ b/WordPress/Tests/NamingConventions/PrefixAllGlobalsUnitTest.inc @@ -306,3 +306,15 @@ do_action( 'acronym-action' ); // OK. apply_filters( 'acronym/filter', $var ); // OK. do_action( "acronym-action-{$acronym_filter_var}" ); // OK. apply_filters( 'acronym/filter-' . $acronym_filter_var ); // OK. + +// Issue #1056. +define( 'SomeNameSpace\PLUGIN_FILE', __FILE__ ); // OK. +define( '\OtherNameSpace\PLUGIN_FILE', __FILE__ ); // OK. +// OK: unreachable constants. +define( __NAMESPACE__ . '\PLUGIN_FILE', __FILE__ ); +define( '\PLUGIN_FILE', __FILE__ ); + +namespace Testing { + define( 'MY' . __NAMESPACE__, __FILE__ ); // Error, not actually namespaced. + define( 'MY\\' . __NAMESPACE__, __FILE__ ); // OK, even though strangely setup, the constant is in a namespace. +} diff --git a/WordPress/Tests/NamingConventions/PrefixAllGlobalsUnitTest.php b/WordPress/Tests/NamingConventions/PrefixAllGlobalsUnitTest.php index 108471574b..d23bc645e7 100644 --- a/WordPress/Tests/NamingConventions/PrefixAllGlobalsUnitTest.php +++ b/WordPress/Tests/NamingConventions/PrefixAllGlobalsUnitTest.php @@ -57,6 +57,7 @@ public function getErrorList( $testFile = 'PrefixAllGlobalsUnitTest.inc' ) { 230 => ( function_exists( '\array_column' ) ) ? 0 : 1, 234 => ( defined( '\E_DEPRECATED' ) ) ? 0 : 1, 238 => ( class_exists( '\IntlTimeZone' ) ) ? 0 : 1, + 318 => 1, ); case 'PrefixAllGlobalsUnitTest.1.inc':