[ticket/12527] Restore missing files and variables check

PHPBB3-12527
This commit is contained in:
Joas Schilling 2014-05-11 13:10:51 +02:00
parent c334d8431d
commit 63e195d7f0
3 changed files with 110 additions and 36 deletions

View file

@ -36,46 +36,32 @@
</fieldset> </fieldset>
</form> </form>
<br /><br /> <!-- IF .missing_files -->
<h3 class="error">{L_MISSING_FILES}</h3>
<!-- IF S_MISSING_FILES --> <fieldset>
<div class="errorbox"> <legend>{L_MISSING_LANG_FILES}</legend>
<h3>{L_MISSING_FILES}</h3> <!-- BEGIN missing_files -->
<p>{MISSING_FILES}</p> &raquo; {missing_files.FILE_NAME}<br />
</div> <!-- END missing_files -->
<br /><br /> </fieldset>
<!-- ENDIF --> <!-- ENDIF -->
<!-- IF S_MISSING_VARS --> <!-- IF .missing_varfile -->
<h1>{L_MISSING_LANG_VARIABLES}</h1> <h3 class="error">{L_MISSING_VARS_EXPLAIN}</h3>
<p>{L_MISSING_VARS_EXPLAIN}</p> <fieldset>
<legend>{L_MISSING_LANG_VARIABLES}</legend>
<form id="missing" method="post" action="{U_MISSING_ACTION}"> <!-- BEGIN missing_varfile -->
<dl>
<table class="table1"> <dt><label>{missing_varfile.FILE_NAME}</label></dt>
<thead> <!-- BEGIN variable -->
<tr> <dd>{missing_varfile.variable.VAR_NAME}</dd>
<th>{L_LANGUAGE_KEY}</th> <!-- END variable -->
<th>{L_LANGUAGE_VARIABLE}</th> </dl>
</tr> <!-- END missing_varfile -->
</thead> </fieldset>
<tbody>
<!-- BEGIN missing -->
<tr class="row4">
<td><strong>{missing.FILE}</strong></td>
<td style="text-align: right;"><input type="submit" name="missing_file[{missing.KEY}]" value="{L_SELECT}" class="button2" /></td>
</tr>
{missing.TPL}
<!-- END missing -->
</tbody>
</table>
<div>{S_FORM_TOKEN}</div>
</form>
<br /><br />
<!-- ENDIF --> <!-- ENDIF -->
<!-- ELSE --> <!-- ELSE -->
<h1>{L_ACP_LANGUAGE_PACKS}</h1> <h1>{L_ACP_LANGUAGE_PACKS}</h1>

View file

@ -110,6 +110,8 @@ class acp_language
$lang_entries = $db->sql_fetchrow($result); $lang_entries = $db->sql_fetchrow($result);
$db->sql_freeresult($result); $db->sql_freeresult($result);
$lang_iso = $lang_entries['lang_iso'];
$template->assign_vars(array( $template->assign_vars(array(
'S_DETAILS' => true, 'S_DETAILS' => true,
'U_ACTION' => $this->u_action . "&amp;action=details&amp;id=$lang_id", 'U_ACTION' => $this->u_action . "&amp;action=details&amp;id=$lang_id",
@ -117,10 +119,67 @@ class acp_language
'LANG_LOCAL_NAME' => $lang_entries['lang_local_name'], 'LANG_LOCAL_NAME' => $lang_entries['lang_local_name'],
'LANG_ENGLISH_NAME' => $lang_entries['lang_english_name'], 'LANG_ENGLISH_NAME' => $lang_entries['lang_english_name'],
'LANG_ISO' => $lang_entries['lang_iso'], 'LANG_ISO' => $lang_iso,
'LANG_AUTHOR' => $lang_entries['lang_author'], 'LANG_AUTHOR' => $lang_entries['lang_author'],
'L_MISSING_FILES' => $user->lang('THOSE_MISSING_LANG_FILES', $lang_entries['lang_local_name']),
'L_MISSING_VARS_EXPLAIN' => $user->lang('THOSE_MISSING_LANG_VARIABLES', $lang_entries['lang_local_name']),
)); ));
// If current lang is different from the default lang, then highlight missing files and variables
if ($lang_iso != $config['default_lang'])
{
try
{
$iterator = new \RecursiveIteratorIterator(
new \phpbb\recursive_dot_prefix_filter_iterator(
new \RecursiveDirectoryIterator(
$phpbb_root_path . 'language/' . $config['default_lang'] . '/',
\FilesystemIterator::SKIP_DOTS
)
),
\RecursiveIteratorIterator::LEAVES_ONLY
);
}
catch (\Exception $e)
{
return array();
}
foreach ($iterator as $file_info)
{
/** @var \RecursiveDirectoryIterator $file_info */
$relative_path = $iterator->getInnerIterator()->getSubPathname();
$relative_path = str_replace(DIRECTORY_SEPARATOR, '/', $relative_path);
if (file_exists($phpbb_root_path . 'language/' . $lang_iso . '/' . $relative_path))
{
if (substr($relative_path, 0 - strlen($phpEx)) === $phpEx)
{
$missing_vars = $this->compare_language_files($config['default_lang'], $lang_iso, $relative_path);
if (!empty($missing_vars))
{
$template->assign_block_vars('missing_varfile', array(
'FILE_NAME' => $relative_path,
));
foreach ($missing_vars as $var)
{
$template->assign_block_vars('missing_varfile.variable', array(
'VAR_NAME' => $var,
));
}
}
}
}
else
{
$template->assign_block_vars('missing_files', array(
'FILE_NAME' => $relative_path,
));
}
}
}
return; return;
break; break;
@ -362,4 +421,32 @@ class acp_language
unset($new_ary); unset($new_ary);
} }
/**
* Compare two language files
*/
function compare_language_files($source_lang, $dest_lang, $file)
{
global $phpbb_root_path;
$source_file = $phpbb_root_path . 'language/' . $source_lang . '/' . $file;
$dest_file = $phpbb_root_path . 'language/' . $dest_lang . '/' . $file;
if (!file_exists($dest_file))
{
return array();
}
$lang = array();
include($source_file);
$lang_entry_src = $lang;
$lang = array();
include($dest_file);
$lang_entry_dst = $lang;
unset($lang);
return array_diff(array_keys($lang_entry_src), array_keys($lang_entry_dst));
}
} }

View file

@ -71,6 +71,7 @@ $lang = array_merge($lang, array(
'LANG_LOCAL_NAME' => 'Local name', 'LANG_LOCAL_NAME' => 'Local name',
'MISSING_LANGUAGE_FILE' => 'Missing language file: <strong style="color:red">%s</strong>', 'MISSING_LANGUAGE_FILE' => 'Missing language file: <strong style="color:red">%s</strong>',
'MISSING_LANG_FILES' => 'Missing language files',
'MISSING_LANG_VARIABLES' => 'Missing language variables', 'MISSING_LANG_VARIABLES' => 'Missing language variables',
'MODS_FILES' => 'MODs language files', 'MODS_FILES' => 'MODs language files',