mirror of
https://github.com/joomla-extensions/jedchecker.git
synced 2024-12-31 21:51:46 +00:00
Add descriptions for new checks
This commit is contained in:
parent
cfe16c16d0
commit
0c51f8a60b
@ -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);
|
||||||
|
Loading…
Reference in New Issue
Block a user