forked from github/server
GM KILL Kommando
Rundung Talentwochen
This commit is contained in:
parent
4e42cd7169
commit
be4b35d87f
7 changed files with 101 additions and 6 deletions
|
@ -972,7 +972,7 @@ drain_exp(const struct unit *u, int n)
|
||||||
* 30 points = 1 week
|
* 30 points = 1 week
|
||||||
*/
|
*/
|
||||||
void
|
void
|
||||||
drain_exp(const struct unit *u, int n)
|
drain_exp(struct unit *u, int n)
|
||||||
{
|
{
|
||||||
skill_t sk = (skill_t)(rand() % MAXSKILLS);
|
skill_t sk = (skill_t)(rand() % MAXSKILLS);
|
||||||
skill_t ssk;
|
skill_t ssk;
|
||||||
|
|
|
@ -236,6 +236,6 @@ extern boolean enemy (const struct side * a, const struct side * b);
|
||||||
extern struct troop select_corpse(struct battle * b, struct fighter * af);
|
extern struct troop select_corpse(struct battle * b, struct fighter * af);
|
||||||
extern fighter * make_fighter(struct battle * b, struct unit * u, boolean attack);
|
extern fighter * make_fighter(struct battle * b, struct unit * u, boolean attack);
|
||||||
void flee(const troop dt);
|
void flee(const troop dt);
|
||||||
void drain_exp(const struct unit *u, int d);
|
void drain_exp(struct unit *u, int d);
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -703,7 +703,7 @@ sp_shadowcall(fighter * fi, int level, int power, spell * sp)
|
||||||
unit *mage = fi->unit;
|
unit *mage = fi->unit;
|
||||||
attrib *a;
|
attrib *a;
|
||||||
int force = get_force(power, 3)/2;
|
int force = get_force(power, 3)/2;
|
||||||
const race *rc;
|
const race *rc = NULL;
|
||||||
int num;
|
int num;
|
||||||
unit *u;
|
unit *u;
|
||||||
|
|
||||||
|
|
|
@ -781,8 +781,17 @@ transfermen(unit * u, unit * u2, int n)
|
||||||
skill * sn = get_skill(u2, sv->id);
|
skill * sn = get_skill(u2, sv->id);
|
||||||
if (sn==NULL) sn = add_skill(u2, sv->id);
|
if (sn==NULL) sn = add_skill(u2, sv->id);
|
||||||
/* level abrunden, wochen aufrunden. */
|
/* level abrunden, wochen aufrunden. */
|
||||||
sn->level = (unsigned char)((sv->level*n+sn->level*u2->number)/(u2->number+n));
|
if (sn->level!=sv->level) {
|
||||||
sn->weeks = (unsigned char)((sv->weeks*n+sn->weeks*u2->number+u2->number+n-1)/(u2->number+n));
|
int level = (sv->level*n+sn->level*u2->number)/(u2->number+n);
|
||||||
|
int weeks = (sv->weeks*n*(level+1)/(sv->level+1)+sn->weeks*u2->number*(level+1)/(sn->level+1)+u2->number+n-1)/(u2->number+n);
|
||||||
|
sn->level = (unsigned char)level;
|
||||||
|
sn->weeks = (unsigned char)weeks;
|
||||||
|
} else {
|
||||||
|
/* aufgerundete wochenzahl */
|
||||||
|
int weeks = (sv->weeks*n+sn->weeks*u2->number+u2->number+n-1)/(u2->number+n);
|
||||||
|
sn->weeks = (unsigned char)weeks;
|
||||||
|
}
|
||||||
|
assert(sn->level>=0 && sn->weeks>=0 && sn->weeks<=sn->level*2+1);
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
a = a_find(u->attribs, &at_effect);
|
a = a_find(u->attribs, &at_effect);
|
||||||
|
|
|
@ -324,6 +324,72 @@ gm_messageregion(const char * str, void * data, const char * cmd)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
** GM: KILL UNIT <id> <string>
|
||||||
|
** requires: permission-key "gmkill"
|
||||||
|
**/
|
||||||
|
static void
|
||||||
|
gm_killunit(const char * str, void * data, const char * cmd)
|
||||||
|
{
|
||||||
|
unit * u = (unit*)data;
|
||||||
|
const struct plane * p = rplane(u->region);
|
||||||
|
unit * target = findunit(atoi36(igetstrtoken(str)));
|
||||||
|
const char * msg = getstrtoken();
|
||||||
|
region * r = target->region;
|
||||||
|
|
||||||
|
if (r==NULL || p!=rplane(r)) {
|
||||||
|
mistake(u, cmd, "In dieser Region kann niemand getötet werden.\n", 0);
|
||||||
|
} else {
|
||||||
|
/* checking permissions */
|
||||||
|
attrib * permissions = a_find(u->faction->attribs, &at_permissions);
|
||||||
|
if (!permissions || !has_permission(permissions, atoi36("gmkill"))) {
|
||||||
|
mistake(u, cmd, "Unzureichende Rechte für diesen Befehl.\n", 0);
|
||||||
|
}
|
||||||
|
else {
|
||||||
|
char * zmsg = (char*)gc_add(strdup(msg));
|
||||||
|
scale_number(target, 0);
|
||||||
|
ADDMSG(&target->faction->msgs, msg_message("killedbygm",
|
||||||
|
"region unit string", r, target, zmsg));
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
** GM: KILL FACTION <id> <string>
|
||||||
|
** requires: permission-key "gmmsgr"
|
||||||
|
**/
|
||||||
|
static void
|
||||||
|
gm_killfaction(const char * str, void * data, const char * cmd)
|
||||||
|
{
|
||||||
|
unit * u = (unit*)data;
|
||||||
|
int n = atoi36(igetstrtoken(str));
|
||||||
|
faction * f = findfaction(n);
|
||||||
|
const char * msg = getstrtoken();
|
||||||
|
plane * p = rplane(u->region);
|
||||||
|
attrib * permissions = a_find(u->faction->attribs, &at_permissions);
|
||||||
|
if (!permissions || !has_permission(permissions, atoi36("gmkill"))) {
|
||||||
|
mistake(u, cmd, "Unzureichende Rechte für diesen Befehl.\n", 0);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
if (f!=NULL) {
|
||||||
|
region * r;
|
||||||
|
for (r=regions;r;r=r->next) if (rplane(r)==p) {
|
||||||
|
unit * target;
|
||||||
|
for (target=r->units;target;target=target->next) {
|
||||||
|
if (target->faction==f) {
|
||||||
|
char * zmsg = (char*)gc_add(strdup(msg));
|
||||||
|
scale_number(target, 0);
|
||||||
|
ADDMSG(&target->faction->msgs, msg_message("killedbygm",
|
||||||
|
"region unit string", r, target, zmsg));
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
mistake(u, cmd, "Aus dieser Partei kann niemand gelöscht werden.\n", 0);
|
||||||
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
** GM: TELL <unit> <string>
|
** GM: TELL <unit> <string>
|
||||||
** requires: permission-key "gmmsgr"
|
** requires: permission-key "gmmsgr"
|
||||||
|
@ -463,6 +529,7 @@ gm_skill(const char * str, void * data, const char * cmd)
|
||||||
static tnode g_keys;
|
static tnode g_keys;
|
||||||
static tnode g_root;
|
static tnode g_root;
|
||||||
static tnode g_tell;
|
static tnode g_tell;
|
||||||
|
static tnode g_kill;
|
||||||
|
|
||||||
static void
|
static void
|
||||||
gm_command(const char * str, void * data, const char * cmd)
|
gm_command(const char * str, void * data, const char * cmd)
|
||||||
|
@ -476,6 +543,12 @@ gm_tell(const char * str, void * data, const char * cmd)
|
||||||
do_command(&g_tell, data, str);
|
do_command(&g_tell, data, str);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static void
|
||||||
|
gm_kill(const char * str, void * data, const char * cmd)
|
||||||
|
{
|
||||||
|
do_command(&g_kill, data, str);
|
||||||
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
init_gmcmd(void)
|
init_gmcmd(void)
|
||||||
{
|
{
|
||||||
|
@ -494,6 +567,9 @@ init_gmcmd(void)
|
||||||
add_command(&g_tell, "unit", &gm_messageunit);
|
add_command(&g_tell, "unit", &gm_messageunit);
|
||||||
add_command(&g_tell, "plane", &gm_messageplane);
|
add_command(&g_tell, "plane", &gm_messageplane);
|
||||||
add_command(&g_tell, "faction", &gm_messagefaction);
|
add_command(&g_tell, "faction", &gm_messagefaction);
|
||||||
|
add_command(&g_keys, "kill", &gm_kill);
|
||||||
|
add_command(&g_kill, "unit", &gm_killunit);
|
||||||
|
add_command(&g_kill, "faction", &gm_killfaction);
|
||||||
}
|
}
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -1058,7 +1058,7 @@ update_gms(void)
|
||||||
for (f=factions;f;f=f->next) {
|
for (f=factions;f;f=f->next) {
|
||||||
attrib * permissions = a_find(f->attribs, &at_permissions);
|
attrib * permissions = a_find(f->attribs, &at_permissions);
|
||||||
if (permissions) {
|
if (permissions) {
|
||||||
const char * keys[] = { "gmgate", "gmmsgr", "gmmsgu", NULL };
|
const char * keys[] = { "gmgate", "gmmsgr", "gmkill", "gmmsgu", NULL };
|
||||||
int k;
|
int k;
|
||||||
item_t i;
|
item_t i;
|
||||||
for (k=0;keys[k];++k) {
|
for (k=0;keys[k];++k) {
|
||||||
|
|
|
@ -7320,4 +7320,14 @@
|
||||||
<text locale="en">"$resource($item,1): $description"</text>
|
<text locale="en">"$resource($item,1): $description"</text>
|
||||||
</message>
|
</message>
|
||||||
|
|
||||||
|
<message name="killedbygm" section="events">
|
||||||
|
<type>
|
||||||
|
<arg name="unit" type="unit"></arg>
|
||||||
|
<arg name="string" type="string"></arg>
|
||||||
|
<arg name="region" type="region"></arg>
|
||||||
|
</type>
|
||||||
|
<text locale="de">"$unit($unit) wurde in $region($region) von einem GM gelöscht: \"$string\"."</text>
|
||||||
|
<text locale="en">"$unit($unit) in $region($region) was removed by a GM: \"$string\"."</text>
|
||||||
|
</message>
|
||||||
|
|
||||||
</messages>
|
</messages>
|
||||||
|
|
Loading…
Reference in a new issue