33
2
mirror of https://github.com/joomla-extensions/jedchecker.git synced 2025-01-01 06:01:46 +00:00

Add descriptions for new checks

This commit is contained in:
Denis Ryabov 2021-04-04 14:54:06 +03:00
parent cfe16c16d0
commit 0c51f8a60b

View File

@ -104,15 +104,15 @@ class JedcheckerRulesLanguage extends JEDcheckerRule
$startLineno = $lineno + 1; $startLineno = $lineno + 1;
$line = trim($lines[$lineno]); $line = trim($lines[$lineno]);
// Check for BOM sequence // Check for BOM sequence
if ($lineno === 0 && strncmp($line, "\xEF\xBB\xBF", 3) === 0) if ($lineno === 0 && strncmp($line, "\xEF\xBB\xBF", 3) === 0)
{ {
// Report as an error if BOM is directly followed by key name (and become a part of the name)
if (isset($line[3]) && strpos(";\n\r", $line[3]) === false) if (isset($line[3]) && strpos(";\n\r", $line[3]) === false)
{ {
$this->report->addError($file, JText::_('COM_JEDCHECKER_LANG_BOM_FOUND'), $startLineno); $this->report->addError($file, JText::_('COM_JEDCHECKER_LANG_BOM_FOUND'), $startLineno);
} }
else else // Otherwise report a warning
{ {
$this->report->addWarning($file, JText::_('COM_JEDCHECKER_LANG_BOM_FOUND'), $startLineno); $this->report->addWarning($file, JText::_('COM_JEDCHECKER_LANG_BOM_FOUND'), $startLineno);
} }
@ -175,16 +175,19 @@ class JedcheckerRulesLanguage extends JEDcheckerRule
continue; continue;
} }
// Check key contains ASCII characters only
if (preg_match('/[\x00-\x1F\x80-\xFF]/', $key)) if (preg_match('/[\x00-\x1F\x80-\xFF]/', $key))
{ {
$this->report->addWarning($file, JText::_('COM_JEDCHECKER_LANG_KEY_NOT_ASCII'), $startLineno, $line); $this->report->addWarning($file, JText::_('COM_JEDCHECKER_LANG_KEY_NOT_ASCII'), $startLineno, $line);
} }
// Check key is uppercase
if ($key !== strtoupper($key)) if ($key !== strtoupper($key))
{ {
$this->report->addWarning($file, JText::_('COM_JEDCHECKER_LANG_KEY_NOT_UPPERCASE'), $startLineno, $line); $this->report->addWarning($file, JText::_('COM_JEDCHECKER_LANG_KEY_NOT_UPPERCASE'), $startLineno, $line);
} }
// Check for duplicated keys
if (isset($keys[$key])) if (isset($keys[$key]))
{ {
$this->report->addWarning($file, JText::sprintf('COM_JEDCHECKER_LANG_KEY_DUPLICATED', $keys[$key]), $startLineno, $line); $this->report->addWarning($file, JText::sprintf('COM_JEDCHECKER_LANG_KEY_DUPLICATED', $keys[$key]), $startLineno, $line);
@ -211,12 +214,14 @@ class JedcheckerRulesLanguage extends JEDcheckerRule
$value .= $chunk; $value .= $chunk;
} }
// The value doesn't match INI format
if (!isset($matches[0])) if (!isset($matches[0]))
{ {
$this->report->addWarning($file, JText::_('COM_JEDCHECKER_LANG_TRANSLATION_ERROR'), $startLineno, $line); $this->report->addWarning($file, JText::_('COM_JEDCHECKER_LANG_TRANSLATION_ERROR'), $startLineno, $line);
continue; continue;
} }
// Get value w/o comment
$value = trim($matches[1]); $value = trim($matches[1]);
// Check for empty value // Check for empty value
@ -255,22 +260,25 @@ class JedcheckerRulesLanguage extends JEDcheckerRule
continue; continue;
} }
// // Remove quotes around // Remove quotes around
$value = substr($value, 1, -1); $value = substr($value, 1, -1);
// Check for legacy "_QQ_" code (deprecated since Joomla! 3.9 if favor of escaped double quote \"; removed in Joomla! 4) // Check for legacy "_QQ_" code (deprecated since Joomla! 3.9 in favour of escaped double quote \"; removed in Joomla! 4)
if (strpos($value, '"_QQ_"') !== false) if (strpos($value, '"_QQ_"') !== false)
{ {
$this->report->addCompat($file, JText::_('COM_JEDCHECKER_LANG_QQ_DEPRECATED'), $startLineno, $line); $this->report->addCompat($file, JText::_('COM_JEDCHECKER_LANG_QQ_DEPRECATED'), $startLineno, $line);
} }
// Convert "_QQ_" to escaped quotes for further analysis
$value = str_replace('"_QQ_"', '\"', $value); $value = str_replace('"_QQ_"', '\"', $value);
// Check for unescaped quote
if (preg_match('/[^\\\\]"/', $value)) if (preg_match('/[^\\\\]"/', $value))
{ {
$this->report->addWarning($file, JText::_('COM_JEDCHECKER_LANG_UNESCAPED_QUOTE'), $startLineno, $line); $this->report->addWarning($file, JText::_('COM_JEDCHECKER_LANG_UNESCAPED_QUOTE'), $startLineno, $line);
} }
// Check for value interpolation (see https://www.php.net/manual/en/function.parse-ini-file.php for details)
if (strpos($value, '${') !== false) if (strpos($value, '${') !== false)
{ {
$this->report->addWarning($file, JText::_('COM_JEDCHECKER_LANG_VARIABLE_REF'), $startLineno, $line); $this->report->addWarning($file, JText::_('COM_JEDCHECKER_LANG_VARIABLE_REF'), $startLineno, $line);