mirror of
https://github.com/Sarjuuk/aowow.git
synced 2025-11-29 15:58:16 +08:00
113 lines
3.4 KiB
PHP
Executable File
113 lines
3.4 KiB
PHP
Executable File
<?php
|
|
|
|
if (!defined('AOWOW_REVISION'))
|
|
die('illegal access');
|
|
|
|
|
|
// Create 'glyphs'-file for available locales
|
|
// this script requires the following dbc-files to be parsed and available
|
|
// GlyphProperties, Spells, SkillLineAbility
|
|
|
|
/* Example
|
|
40896: {
|
|
"name":"Glyph of Frenzied Regeneration",
|
|
"description":"For 6 sec after activating Frenzied Regeneration, healing effects on you are 40% more powerful. However, your Frenzied Regeneration now always costs 60 Rage and no longer converts Rage into health.",
|
|
"icon":"ability_bullrush",
|
|
"type":1,
|
|
"classs":11,
|
|
"skill":798,
|
|
"level":25,
|
|
},
|
|
*/
|
|
|
|
$queryGlyphs = '
|
|
SELECT
|
|
i.entry as itemId,
|
|
i.name,
|
|
li.*,
|
|
IF (g.typeFlags & 0x1, 2, 1) as type,
|
|
i.subclass as classs,
|
|
i.requiredLevel as level,
|
|
s1.Id as glyphSpell,
|
|
s1.iconStringAlt as icon,
|
|
s1.skillLine1 as skillId,
|
|
s2.Id as glyphEffect,
|
|
s2.Id as ARRAY_KEY
|
|
FROM
|
|
item_template i
|
|
LEFT JOIN
|
|
locales_item li ON
|
|
i.entry = li.entry
|
|
LEFT JOIN
|
|
?_spell s1 ON
|
|
s1.Id = i.spellid_1
|
|
LEFT JOIN
|
|
?_glyphproperties g ON
|
|
g.Id = s1.effect1MiscValue
|
|
LEFT JOIN
|
|
?_spell s2 ON
|
|
s2.Id = g.spellId
|
|
WHERE
|
|
i.class = 16
|
|
;
|
|
';
|
|
|
|
$glyphList = DB::Aowow()->Select($queryGlyphs);
|
|
$locales = [LOCALE_EN, LOCALE_FR, LOCALE_DE, LOCALE_ES, LOCALE_RU];
|
|
|
|
// check directory-structure
|
|
foreach (Util::$localeStrings as $dir)
|
|
if (!is_dir('datasets\\'.$dir))
|
|
mkdir('datasets\\'.$dir, 0755, true);
|
|
|
|
echo "script set up in ".Util::execTime()."<br>\n";
|
|
|
|
$glyphSpells = new SpellList(array(['s.id', array_keys($glyphList)], 0));
|
|
|
|
foreach ($locales as $lId)
|
|
{
|
|
User::useLocale($lId);
|
|
|
|
$glyphsOut = [];
|
|
foreach ($glyphSpells->iterate() as $__)
|
|
{
|
|
$pop = $glyphList[$glyphSpells->id];
|
|
|
|
if (!$pop['glyphEffect'])
|
|
continue;
|
|
|
|
if ($glyphSpells->getField('effect1Id') != 6 && $glyphSpells->getField('effect2Id') != 6 && $glyphSpells->getField('effect3Id') != 6)
|
|
continue;
|
|
|
|
$glyphsOut[$pop['itemId']] = array(
|
|
'name' => Util::localizedString($pop, 'name'),
|
|
'description' => $glyphSpells->parseText()[0],
|
|
'icon' => $pop['icon'],
|
|
'type' => $pop['type'],
|
|
'classs' => $pop['classs'],
|
|
'skill' => $pop['skillId'],
|
|
'level' => $pop['level']
|
|
);
|
|
}
|
|
|
|
$toFile = "var g_glyphs = ";
|
|
$toFile .= json_encode($glyphsOut, JSON_PRETTY_PRINT | JSON_UNESCAPED_UNICODE | JSON_NUMERIC_CHECK);
|
|
$toFile .= ";";
|
|
$file = 'datasets\\'.User::$localeString.'\\glyphs';
|
|
|
|
$handle = fOpen($file, "w");
|
|
fWrite($handle, $toFile);
|
|
fClose($handle);
|
|
|
|
echo "done glyphs loc: ".$lId." in ".Util::execTime()."<br>\n";
|
|
}
|
|
|
|
echo "<br>\nall done";
|
|
|
|
User::useLocale(LOCALE_EN);
|
|
|
|
$stats = DB::Aowow()->getStatistics();
|
|
echo "<br>\n".$stats['count']." queries in: ".Util::formatTime($stats['time'] * 1000);
|
|
|
|
?>
|