Skip to content
Permalink
Branch: master
Find file Copy path
Find file Copy path
Fetching contributors…
Cannot retrieve contributors at this time
468 lines (444 sloc) 21.9 KB
<?php
// addnews ready
// mail ready
// translator ready
require_once("common.php");
require_once("lib/http.php");
require_once("lib/showform.php");
$op = httpget('op');
$id = httpget('id');
if ($op=="xml") {
header("Content-Type: text/xml");
$sql = "select name from " . db_prefix("accounts") . " where hashorse=$id";
$r = db_query($sql);
echo("<xml>");
while($row = db_fetch_assoc($r)) {
echo("<name name=\"");
echo(urlencode(appoencode("`0{$row['name']}")));
echo("\"/>");
}
if (db_num_rows($r) == 0) {
echo("<name name=\"" . translate_inline("NONE") . "\"/>");
}
echo("</xml>");
exit();
}
check_su_access(SU_EDIT_MOUNTS);
tlschema("mounts");
page_header("Mount Editor");
require_once("lib/superusernav.php");
superusernav();
addnav("Mount Editor");
addnav("Add a mount","mounts.php?op=add");
if ($op=="deactivate"){
$sql = "UPDATE " . db_prefix("mounts") . " SET mountactive=0 WHERE mountid='$id'";
db_query($sql);
$op="";
httpset("op", "");
invalidatedatacache("mountdata-$id");
} elseif ($op=="activate"){
$sql = "UPDATE " . db_prefix("mounts") . " SET mountactive=1 WHERE mountid='$id'";
db_query($sql);
$op="";
httpset("op", "");
invalidatedatacache("mountdata-$id");
} elseif ($op=="del") {
//refund for anyone who has a mount of this type.
$sql = "SELECT * FROM ".db_prefix("mounts")." WHERE mountid='$id'";
$result = db_query_cached($sql, "mountdata-$id", 3600);
$row = db_fetch_assoc($result);
$sql = "UPDATE ".db_prefix("accounts")." SET gems=gems+{$row['mountcostgems']}, goldinbank=goldinbank+{$row['mountcostgold']}, hashorse=0 WHERE hashorse={$row['mountid']}";
db_query($sql);
//drop the mount.
$sql = "DELETE FROM " . db_prefix("mounts") . " WHERE mountid='$id'";
db_query($sql);
module_delete_objprefs('mounts', $id);
$op = "";
httpset("op", "");
invalidatedatacache("mountdata-$id");
} elseif ($op=="give") {
$session['user']['hashorse'] = $id;
// changed to make use of the cached query
$sql = "SELECT * FROM ".db_prefix("mounts")." WHERE mountid='$id'";
$result = db_query_cached($sql, "mountdata-$id", 3600);
$row = db_fetch_assoc($result);
$buff = unserialize($row['mountbuff']);
if ($buff['schema'] == "") $buff['schema'] = "mounts";
apply_buff("mount",$buff);
$op="";
httpset("op", "");
}elseif ($op=="save"){
$subop = httpget("subop");
if ($subop == "") {
$buff = array();
$mount = httppost('mount');
if ($mount) {
reset($mount['mountbuff']);
while (list($key,$val)=each($mount['mountbuff'])){
if ($val>""){
$buff[$key]=stripslashes($val);
}
}
$buff['schema']="mounts";
httppostset('mount', $buff, 'mountbuff');
list($sql, $keys, $vals) = postparse(false, 'mount');
if ($id>""){
$sql="UPDATE " . db_prefix("mounts") .
" SET $sql WHERE mountid='$id'";
}else{
$sql="INSERT INTO " . db_prefix("mounts") .
" ($keys) VALUES ($vals)";
}
db_query($sql);
invalidatedatacache("mountdata-$id");
if (db_affected_rows()>0){
output("`^Mount saved!`0`n");
}else{
output("`^Mount `\$not`^ saved: `\$%s`0`n", $sql);
}
}
} elseif ($subop=="module") {
// Save modules settings
$module = httpget("module");
$post = httpallpost();
unset($post['showFormTabIndex']);
reset($post);
while(list($key, $val) = each($post)) {
set_module_objpref("mounts", $id, $key, $val, $module);
}
output("`^Saved!`0`n");
}
if ($id) {
$op="edit";
} else {
$op = "";
}
httpset("op", $op);
}
if ($op==""){
$sql = "SELECT count(acctid) AS c, hashorse FROM ".db_prefix("accounts")." GROUP BY hashorse";
$result = db_query($sql);
$mounts = array();
while ($row = db_fetch_assoc($result)){
$mounts[$row['hashorse']] = $row['c'];
}
rawoutput("<script language='JavaScript'>
function getUserInfo(id,divid){
var filename='mounts.php?op=xml&id='+id;
var xmldom;
if (document.implementation && document.implementation.createDocument){
// Mozilla
xmldom = document.implementation.createDocument('','',null);
} else if (window.ActiveXObject) {
// IE
xmldom = new ActiveXObject('Microsoft.XMLDOM');
}
xmldom.async=false;
xmldom.load(filename);
var output='';
for (var x=0; x<xmldom.documentElement.childNodes.length; x++) {
output = output + unescape(xmldom.documentElement.childNodes[x].getAttribute('name').replace(/\\+/g, ' ')) + '<br />';
}
document.getElementById('mountusers'+divid).innerHTML=output;
}
</script>");
$sql = "SELECT * FROM " . db_prefix("mounts") . " ORDER BY mountcategory, mountcostgems, mountcostgold";
$ops = translate_inline("Ops");
$name = translate_inline("Name");
$cost = translate_inline("Cost");
$feat = translate_inline("Features");
$owners = translate_inline("Owners");
$edit = translate_inline("Edit");
$give = translate_inline("Give");
$del = translate_inline("Del");
$deac = translate_inline("Deactivate");
$act = translate_inline("Activate");
$conf = translate_inline("There are %s user(s) who own this mount, are you sure you wish to delete it?");
rawoutput("<table border=0 cellpadding=2 cellspacing=1 bgcolor='#999999'>");
rawoutput("<tr class='trhead'><td nowrap>$ops</td><td>$name</td><td>$cost</td><td>$feat</td><td nowrap>$owners</td></tr>");
$result = db_query($sql);
$cat = "";
$count=0;
$number=db_num_rows($result);
for ($i=0;$i<$number;$i++){
$row = db_fetch_assoc($result);
if ($cat!=$row['mountcategory']){
rawoutput("<tr class='trlight'><td colspan='5'>");
output("Category: %s", $row['mountcategory']);
rawoutput("</td></tr>");
$cat = $row['mountcategory'];
$count=0;
}
if (isset($mounts[$row['mountid']])) {
$mounts[$row['mountid']] = (int)$mounts[$row['mountid']];
} else {
$mounts[$row['mountid']] = 0;
}
rawoutput("<tr class='".($count%2?"trlight":"trdark")."'>");
rawoutput("<td nowrap>[ <a href='mounts.php?op=edit&id={$row['mountid']}'>$edit</a> |");
addnav("","mounts.php?op=edit&id={$row['mountid']}");
rawoutput("<a href='mounts.php?op=give&id={$row['mountid']}'>$give</a> |",true);
addnav("","mounts.php?op=give&id={$row['mountid']}");
if ($row['mountactive']){
rawoutput("$del |");
}else{
$mconf = sprintf($conf, $mounts[$row['mountid']]);
rawoutput("<a href='mounts.php?op=del&id={$row['mountid']}' onClick=\"return confirm('$mconf');\">$del</a> |");
addnav("","mounts.php?op=del&id={$row['mountid']}");
}
if ($row['mountactive']) {
rawoutput("<a href='mounts.php?op=deactivate&id={$row['mountid']}'>$deac</a> ]</td>");
addnav("","mounts.php?op=deactivate&id={$row['mountid']}");
}else{
rawoutput("<a href='mounts.php?op=activate&id={$row['mountid']}'>$act</a> ]</td>");
addnav("","mounts.php?op=activate&id={$row['mountid']}");
}
rawoutput("<td>");
output_notl("`&%s`0", $row['mountname']);
rawoutput("</td><td>");
output("`%%s gems`0, `^%s gold`0",$row['mountcostgems'], $row['mountcostgold']);
rawoutput("</td><td>");
$features = array("FF"=>$row['mountforestfights'],"DKs"=>$row['mountdkcost']);
$args = array("id"=>$row['mountid'],"features"=>&$features);
$args = modulehook("mountfeatures", $args);
reset($features);
$mcount = 1;
$max = count($features);
foreach ($features as $fname=>$fval) {
$fname = translate_inline($fname);
output_notl("%s: %s%s", $fname, $fval, ($mcount==$max?"":", "));
$mcount++;
}
rawoutput("</td><td nowrap>");
$file = "mounts.php?op=xml&id=".$row['mountid'];
rawoutput("<div id='mountusers$i'><a href='$file' target='_blank' onClick=\"getUserInfo('".$row{'mountid'}."', $i); return false\">");
output_notl("`#%s`0", $mounts[$row['mountid']]);
addnav("", $file);
rawoutput("</a></div>");
rawoutput("</td></tr>");
$count++;
}
rawoutput("</table>");
output("`nIf you wish to delete a mount, you have to deactivate it first.");
output("If there are any owners of the mount when it is deleted, they will no longer have a mount, but they will get a FULL refund of the price of the mount at the time of deletion.");
}elseif ($op=="add"){
output("Add a mount:`n");
addnav("Mount Editor Home","mounts.php");
mountform(array());
}elseif ($op=="edit"){
addnav("Mount Editor Home","mounts.php");
$sql = "SELECT * FROM " . db_prefix("mounts") . " WHERE mountid='$id'";
$result = db_query_cached($sql, "mountdata-$id", 3600);
if (db_num_rows($result)<=0){
output("`iThis mount was not found.`i");
}else{
addnav("Mount properties", "mounts.php?op=edit&id=$id");
module_editor_navs("prefs-mounts", "mounts.php?op=edit&subop=module&id=$id&module=");
$subop=httpget("subop");
if ($subop=="module") {
$module = httpget("module");
rawoutput("<form action='mounts.php?op=save&subop=module&id=$id&module=$module' method='POST'>");
module_objpref_edit("mounts", $module, $id);
rawoutput("</form>");
addnav("", "mounts.php?op=save&subop=module&id=$id&module=$module");
} else {
output("Mount Editor:`n");
$row = db_fetch_assoc($result);
$row['mountbuff']=unserialize($row['mountbuff']);
mountform($row);
}
}
}
function mountform($mount){
// Let's sanitize the data
if (!isset($mount['mountname'])) $mount['mountname'] = "";
if (!isset($mount['mountid'])) $mount['mountid'] = "";
if (!isset($mount['mountdesc'])) $mount['mountdesc'] = "";
if (!isset($mount['mountcategory'])) $mount['mountcategory'] = "";
if (!isset($mount['mountlocation'])) $mount['mountlocation'] = 'all';
if (!isset($mount['mountdkcost'])) $mount['mountdkcost'] = 0;
if (!isset($mount['mountcostgems'])) $mount['mountcostgems'] = 0;
if (!isset($mount['mountcostgold'])) $mount['mountcostgold'] = 0;
if (!isset($mount['mountfeedcost'])) $mount['mountfeedcost'] = 0;
if (!isset($mount['mountforestfights'])) $mount['mountforestfights'] = 0;
if (!isset($mount['newday'])) $mount['newday'] = "";
if (!isset($mount['recharge'])) $mount['recharge'] = "";
if (!isset($mount['partrecharge'])) $mount['partrecharge'] = "";
if (!isset($mount['mountbuff'])) $mount['mountbuff'] = array();
if (!isset($mount['mountactive'])) $mount['mountactive']=0;
if (!isset($mount['mountbuff']['name']))
$mount['mountbuff']['name'] = "";
if (!isset($mount['mountbuff']['roundmsg']))
$mount['mountbuff']['roundmsg'] = "";
if (!isset($mount['mountbuff']['wearoff']))
$mount['mountbuff']['wearoff'] = "";
if (!isset($mount['mountbuff']['effectmsg']))
$mount['mountbuff']['effectmsg'] = "";
if (!isset($mount['mountbuff']['effectnodmgmsg']))
$mount['mountbuff']['effectnodmgmsg'] = "";
if (!isset($mount['mountbuff']['effectfailmsg']))
$mount['mountbuff']['effectfailmsg'] = "";
if (!isset($mount['mountbuff']['rounds']))
$mount['mountbuff']['rounds'] = 0;
if (!isset($mount['mountbuff']['atkmod']))
$mount['mountbuff']['atkmod'] = "";
if (!isset($mount['mountbuff']['defmod']))
$mount['mountbuff']['defmod'] = "";
if (!isset($mount['mountbuff']['invulnerable']))
$mount['mountbuff']['invulnerable'] = "";
if (!isset($mount['mountbuff']['regen']))
$mount['mountbuff']['regen'] = "";
if (!isset($mount['mountbuff']['minioncount']))
$mount['mountbuff']['minioncount'] = "";
if (!isset($mount['mountbuff']['minbadguydamage']))
$mount['mountbuff']['minbadguydamage'] = "";
if (!isset($mount['mountbuff']['maxbadguydamage']))
$mount['mountbuff']['maxbadguydamage'] = "";
if (!isset($mount['mountbuff']['mingoodguydamage']))
$mount['mountbuff']['mingoodguydamage'] = "";
if (!isset($mount['mountbuff']['maxgoodguydamage']))
$mount['mountbuff']['maxgoodguydamage'] = "";
if (!isset($mount['mountbuff']['lifetap']))
$mount['mountbuff']['lifetap'] = "";
if (!isset($mount['mountbuff']['damageshield']))
$mount['mountbuff']['damageshield'] = "";
if (!isset($mount['mountbuff']['badguydmgmod']))
$mount['mountbuff']['badguydmgmod'] = "";
if (!isset($mount['mountbuff']['badguyatkmod']))
$mount['mountbuff']['badguyatkmod'] = "";
if (!isset($mount['mountbuff']['badguydefmod']))
$mount['mountbuff']['badguydefmod'] = "";
rawoutput("<form action='mounts.php?op=save&id={$mount['mountid']}' method='POST'>");
rawoutput("<input type='hidden' name='mount[mountactive]' value=\"".$mount['mountactive']."\">");
addnav("","mounts.php?op=save&id={$mount['mountid']}");
rawoutput("<table>");
rawoutput("<tr><td nowrap>");
output("Mount Name:");
rawoutput("</td><td><input name='mount[mountname]' value=\"".htmlentities($mount['mountname'], ENT_COMPAT, getsetting("charset", "ISO-8859-1"))."\"></td></tr>");
rawoutput("<tr><td nowrap>");
output("Mount Description:");
rawoutput("</td><td><input name='mount[mountdesc]' value=\"".htmlentities($mount['mountdesc'], ENT_COMPAT, getsetting("charset", "ISO-8859-1"))."\"></td></tr>");
rawoutput("<tr><td nowrap>");
output("Mount Category:");
rawoutput("</td><td><input name='mount[mountcategory]' value=\"".htmlentities($mount['mountcategory'], ENT_COMPAT, getsetting("charset", "ISO-8859-1"))."\"></td></tr>");
rawoutput("<tr><td nowrap>");
output("Mount Availability:");
rawoutput("</td><td nowrap>");
// Run a modulehook to find out where stables are located. By default
// they are located in 'Degolburg' (ie, getgamesetting('villagename'));
// Some later module can remove them however.
$vname = getsetting('villagename', LOCATION_FIELDS);
$locs = array($vname => sprintf_translate("The Village of %s", $vname));
$locs = modulehook("stablelocs", $locs);
$locs['all'] = translate_inline("Everywhere");
ksort($locs);
reset($locs);
rawoutput("<select name='mount[mountlocation]'>");
foreach($locs as $loc=>$name) {
rawoutput("<option value='$loc'".($mount['mountlocation']==$loc?" selected":"").">$name</option>");
}
rawoutput("<tr><td nowrap>");
output("Mount Cost (DKs):");
rawoutput("</td><td><input name='mount[mountdkcost]' value=\"".htmlentities((int)$mount['mountdkcost'], ENT_COMPAT, getsetting("charset", "ISO-8859-1"))."\"></td></tr>");
rawoutput("<tr><td nowrap>");
output("Mount Cost (Gems):");
rawoutput("</td><td><input name='mount[mountcostgems]' value=\"".htmlentities((int)$mount['mountcostgems'], ENT_COMPAT, getsetting("charset", "ISO-8859-1"))."\"></td></tr>");
rawoutput("<tr><td nowrap>");
output("Mount Cost (Gold):");
rawoutput("</td><td><input name='mount[mountcostgold]' value=\"".htmlentities((int)$mount['mountcostgold'], ENT_COMPAT, getsetting("charset", "ISO-8859-1"))."\"></td></tr>");
rawoutput("<tr><td nowrap>");
output("Mount Feed Cost`n(Gold per level):");
rawoutput("</td><td><input name='mount[mountfeedcost]' value=\"".htmlentities((int)$mount['mountfeedcost'], ENT_COMPAT, getsetting("charset", "ISO-8859-1"))."\"></td></tr>");
rawoutput("<tr><td nowrap>");
output("Delta Forest Fights:");
rawoutput("</td><td><input name='mount[mountforestfights]' value=\"".htmlentities((int)$mount['mountforestfights'], ENT_COMPAT, getsetting("charset", "ISO-8859-1"))."\" size='5'></td></tr>");
rawoutput("<tr><td nowrap>");
output("`bMount Messages:`b");
rawoutput("</td><td></td></tr><tr><td nowrap>");
output("New Day:");
rawoutput("</td><td><input name='mount[newday]' value=\"".htmlentities($mount['newday'], ENT_COMPAT, getsetting("charset", "ISO-8859-1"))."\" size='40'></td></tr>");
rawoutput("<tr><td nowrap>");
output("Full Recharge:");
rawoutput("</td><td><input name='mount[recharge]' value=\"".htmlentities($mount['recharge'], ENT_COMPAT, getsetting("charset", "ISO-8859-1"))."\" size='40'></td></tr>");
rawoutput("<tr><td nowrap>");
output("Partial Recharge:");
rawoutput("</td><td><input name='mount[partrecharge]' value=\"".htmlentities($mount['partrecharge'], ENT_COMPAT, getsetting("charset", "ISO-8859-1"))."\" size='40'></td></tr>");
rawoutput("<tr><td valign='top' nowrap>");
output("Mount Buff:");
rawoutput("</td><td>");
output("Buff name:");
rawoutput("<input name='mount[mountbuff][name]' value=\"".htmlentities($mount['mountbuff']['name'], ENT_COMPAT, getsetting("charset", "ISO-8859-1"))."\" size='50'><br/>");
output("`bBuff Messages:`b`n");
output("Each round:");
rawoutput("<input name='mount[mountbuff][roundmsg]' value=\"".htmlentities($mount['mountbuff']['roundmsg'], ENT_COMPAT, getsetting("charset", "ISO-8859-1"))."\" size='50'><br/>");
output("Wear off:");
rawoutput("<input name='mount[mountbuff][wearoff]' value=\"".htmlentities($mount['mountbuff']['wearoff'], ENT_COMPAT, getsetting("charset", "ISO-8859-1"))."\" size='50'><br/>");
output("Effect:");
rawoutput("<input name='mount[mountbuff][effectmsg]' value=\"".htmlentities($mount['mountbuff']['effectmsg'], ENT_COMPAT, getsetting("charset", "ISO-8859-1"))."\" size='50'><br/>");
output("Effect No Damage:");
rawoutput("<input name='mount[mountbuff][effectnodmgmsg]' value=\"".htmlentities($mount['mountbuff']['effectnodmgmsg'], ENT_COMPAT, getsetting("charset", "ISO-8859-1"))."\" size='50'><br/>");
output("Effect Fail:");
rawoutput("<input name='mount[mountbuff][effectfailmsg]' value=\"".htmlentities($mount['mountbuff']['effectfailmsg'], ENT_COMPAT, getsetting("charset", "ISO-8859-1"))."\" size='50'><br/>");
output("(message replacements: {badguy}, {goodguy}, {weapon}, {armor}, {creatureweapon}, and where applicable {damage}.)`n");
output("`n`bEffects:`b`n");
output("Rounds to last (from new day):");
rawoutput("<input name='mount[mountbuff][rounds]' value=\"".htmlentities((int)$mount['mountbuff']['rounds'], ENT_COMPAT, getsetting("charset", "ISO-8859-1"))."\" size='50'><br/>");
output("Player Atk mod:");
rawoutput("<input name='mount[mountbuff][atkmod]' value=\"".htmlentities($mount['mountbuff']['atkmod'], ENT_COMPAT, getsetting("charset", "ISO-8859-1"))."\" size='50'>");
output("(multiplier)`n");
output("Player Def mod:");
rawoutput("<input name='mount[mountbuff][defmod]' value=\"".htmlentities($mount['mountbuff']['defmod'], ENT_COMPAT, getsetting("charset", "ISO-8859-1"))."\" size='50'>");
output("(multiplier)`n");
output("Player is invulnerable (1 = yes, 0 = no):");
rawoutput("<input name='mount[mountbuff][invulnerable]' value=\"".htmlentities($mount['mountbuff']['invulnerable'], ENT_COMPAT, getsetting("charset", "ISO-8859-1"))."\" size=50><br/>");
output("Regen:");
rawoutput("<input name='mount[mountbuff][regen]' value=\"".htmlentities($mount['mountbuff']['regen'], ENT_COMPAT, getsetting("charset", "ISO-8859-1"))."\" size='50'><br/>");
output("Minion Count:");
rawoutput("<input name='mount[mountbuff][minioncount]' value=\"".htmlentities($mount['mountbuff']['minioncount'], ENT_COMPAT, getsetting("charset", "ISO-8859-1"))."\" size='50'><br/>");
output("Min Badguy Damage:");
rawoutput("<input name='mount[mountbuff][minbadguydamage]' value=\"".htmlentities($mount['mountbuff']['minbadguydamage'], ENT_COMPAT, getsetting("charset", "ISO-8859-1"))."\" size='50'><br/>");
output("Max Badguy Damage:");
rawoutput("<input name='mount[mountbuff][maxbadguydamage]' value=\"".htmlentities($mount['mountbuff']['maxbadguydamage'], ENT_COMPAT, getsetting("charset", "ISO-8859-1"))."\" size='50'><br/>");
output("Min Goodguy Damage:");
rawoutput("<input name='mount[mountbuff][mingoodguydamage]' value=\"".htmlentities($mount['mountbuff']['mingoodguydamage'], ENT_COMPAT, getsetting("charset", "ISO-8859-1"))."\" size='50'><br/>");
output("Max Goodguy Damage:");
rawoutput("<input name='mount[mountbuff][maxgoodguydamage]' value=\"".htmlentities($mount['mountbuff']['maxgoodguydamage'], ENT_COMPAT, getsetting("charset", "ISO-8859-1"))."\" size='50'><br/>");
output("Lifetap:");
rawoutput("<input name='mount[mountbuff][lifetap]' value=\"".htmlentities($mount['mountbuff']['lifetap'], ENT_COMPAT, getsetting("charset", "ISO-8859-1"))."\" size='50'>");
output("(multiplier)`n");
output("Damage shield:");
rawoutput("<input name='mount[mountbuff][damageshield]' value=\"".htmlentities($mount['mountbuff']['damageshield'], ENT_COMPAT, getsetting("charset", "ISO-8859-1"))."\" size='50'>");
output("(multiplier)`n");
output("Badguy Damage mod:");
rawoutput("<input name='mount[mountbuff][badguydmgmod]' value=\"".htmlentities($mount['mountbuff']['badguydmgmod'], ENT_COMPAT, getsetting("charset", "ISO-8859-1"))."\" size='50'>");
output("(multiplier)`n");
output("Badguy Atk mod:");
rawoutput("<input name='mount[mountbuff][badguyatkmod]' value=\"".htmlentities($mount['mountbuff']['badguyatkmod'], ENT_COMPAT, getsetting("charset", "ISO-8859-1"))."\" size='50'>");
output("(multiplier)`n");
output("Badguy Def mod:");
rawoutput("<input name='mount[mountbuff][badguydefmod]' value=\"".htmlentities($mount['mountbuff']['badguydefmod'], ENT_COMPAT, getsetting("charset", "ISO-8859-1"))."\" size='50'>");
output("(multiplier)`n");
output("`bOn Dynamic Buffs`b`n");
output("`@In the above, for most fields, you can choose to enter valid PHP code, substituting <fieldname> for fields in the user's account table.`n");
output("Examples of code you might enter:`n");
output("`^<charm>`n");
output("round(<maxhitpoints>/10)`n");
output("round(<level>/max(<gems>,1))`n");
output("`@Fields you might be interested in for this: `n");
output_notl("`3name, sex `7(0=male 1=female)`3, specialty `7(DA=darkarts MP=mystical TS=thief)`3,`n");
output_notl("experience, gold, weapon `7(name)`3, armor `7(name)`3, level,`n");
output_notl("defense, attack, alive, goldinbank,`n");
output_notl("spirits `7(-2 to +2 or -6 for resurrection)`3, hitpoints, maxhitpoints, gems,`n");
output_notl("weaponvalue `7(gold value)`3, armorvalue `7(gold value)`3, turns, title, weapondmg, armordef,`n");
output_notl("age `7(days since last DK)`3, charm, playerfights, dragonkills, resurrections `7(times died since last DK)`3,`n");
output_notl("soulpoints, gravefights, deathpower `7(%s favor)`3,`n", getsetting("deathoverlord", '`$Ramius'));
output_notl("race, dragonage, bestdragonage`n`n");
output("You can also use module preferences by using <modulename|preference> (for instance '<specialtymystic|uses>' or '<drinks|drunkeness>'`n`n");
output("`@Finally, starting a field with 'debug:' will enable debug output for that field to help you locate errors in your implementation.");
output("While testing new buffs, you should be sure to debug fields before you release them on the world, as the PHP script will otherwise throw errors to the user if you have any, and this can break the site at various spots (as in places that redirects should happen).");
rawoutput("</td></tr></table>");
$save = translate_inline("Save");
rawoutput("<input type='submit' class='button' value='$save'></form>");
}
page_footer();
?>
You can’t perform that action at this time.