forked from github/server
Binding CAST, ENTER, CONTACT to Lua
This commit is contained in:
parent
573d4c3e97
commit
648de4d36c
7 changed files with 109 additions and 59 deletions
|
@ -38,6 +38,9 @@ function test_process()
|
||||||
assert_equal("function", _G.type(eressea.process.restack))
|
assert_equal("function", _G.type(eressea.process.restack))
|
||||||
assert_equal("function", _G.type(eressea.process.set_spells))
|
assert_equal("function", _G.type(eressea.process.set_spells))
|
||||||
assert_equal("function", _G.type(eressea.process.set_help))
|
assert_equal("function", _G.type(eressea.process.set_help))
|
||||||
|
assert_equal("function", _G.type(eressea.process.contact))
|
||||||
|
assert_equal("function", _G.type(eressea.process.enter))
|
||||||
|
assert_equal("function", _G.type(eressea.process.magic))
|
||||||
end
|
end
|
||||||
|
|
||||||
function test_settings()
|
function test_settings()
|
||||||
|
|
|
@ -190,3 +190,29 @@ function test_process_renumber()
|
||||||
assert_equal(666, u.id)
|
assert_equal(666, u.id)
|
||||||
end
|
end
|
||||||
|
|
||||||
|
function test_process_enter()
|
||||||
|
b = _G.building.create(r, default_building)
|
||||||
|
u:add_order("BETRETEN GEBAEUDE " .. _G.itoa36(b.id))
|
||||||
|
eressea.process.enter(1)
|
||||||
|
assert_equal(b, u.building)
|
||||||
|
end
|
||||||
|
|
||||||
|
function test_process_restack()
|
||||||
|
eressea.process.restack()
|
||||||
|
end
|
||||||
|
|
||||||
|
function test_process_setspells()
|
||||||
|
eressea.process.set_spells()
|
||||||
|
end
|
||||||
|
|
||||||
|
function test_process_help()
|
||||||
|
eressea.process.set_help()
|
||||||
|
end
|
||||||
|
|
||||||
|
function test_process_contact()
|
||||||
|
eressea.process.contact()
|
||||||
|
end
|
||||||
|
|
||||||
|
function test_process_magic()
|
||||||
|
eressea.process.magic()
|
||||||
|
end
|
||||||
|
|
|
@ -2,6 +2,7 @@
|
||||||
|
|
||||||
#include <platform.h>
|
#include <platform.h>
|
||||||
#include <kernel/types.h>
|
#include <kernel/types.h>
|
||||||
|
#include <kernel/magic.h>
|
||||||
#include <kernel/order.h>
|
#include <kernel/order.h>
|
||||||
#include <kernel/battle.h>
|
#include <kernel/battle.h>
|
||||||
#include <kernel/region.h>
|
#include <kernel/region.h>
|
||||||
|
@ -198,6 +199,20 @@ void process_sethelp(void) {
|
||||||
process_cmd(K_ALLY, ally_cmd, 0);
|
process_cmd(K_ALLY, ally_cmd, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void process_contact(void) {
|
||||||
|
process_cmd(K_CONTACT, contact_cmd, 0);
|
||||||
|
}
|
||||||
|
|
||||||
|
void process_magic(void) {
|
||||||
|
magic();
|
||||||
|
}
|
||||||
|
|
||||||
|
void process_enter(int final) {
|
||||||
|
region * r;
|
||||||
|
for (r=regions; r; r=r->next) {
|
||||||
|
do_enter(r, final);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
void process_maintenance(void) {
|
void process_maintenance(void) {
|
||||||
region * r;
|
region * r;
|
||||||
|
|
|
@ -30,6 +30,9 @@ void process_renumber(void);
|
||||||
void process_restack(void);
|
void process_restack(void);
|
||||||
void process_setspells(void);
|
void process_setspells(void);
|
||||||
void process_sethelp(void);
|
void process_sethelp(void);
|
||||||
|
void process_contact(void);
|
||||||
|
void process_enter(int final);
|
||||||
|
void process_magic(void);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
|
|
@ -27,5 +27,8 @@ module eressea {
|
||||||
void process_restack @ restack(void); /* SORT */
|
void process_restack @ restack(void); /* SORT */
|
||||||
void process_setspells @ set_spells(void); /* COMBATSPELL */
|
void process_setspells @ set_spells(void); /* COMBATSPELL */
|
||||||
void process_sethelp @ set_help(void); /* HELP */
|
void process_sethelp @ set_help(void); /* HELP */
|
||||||
|
void process_contact @ contact(void); /* CONTACT */
|
||||||
|
void process_enter @ enter(int message); /* ENTER */
|
||||||
|
void process_magic @ magic(void); /* CAST */
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -135,8 +135,7 @@ static void checkorders(void)
|
||||||
{
|
{
|
||||||
faction *f;
|
faction *f;
|
||||||
|
|
||||||
if (verbosity >= 1)
|
log_info(" - Warne spaete Spieler...");
|
||||||
puts(" - Warne spaete Spieler...");
|
|
||||||
for (f = factions; f; f = f->next)
|
for (f = factions; f; f = f->next)
|
||||||
if (!is_monsters(f) && turn - f->lastorders == NMRTimeout() - 1)
|
if (!is_monsters(f) && turn - f->lastorders == NMRTimeout() - 1)
|
||||||
ADDMSG(&f->msgs, msg_message("turnreminder", ""));
|
ADDMSG(&f->msgs, msg_message("turnreminder", ""));
|
||||||
|
@ -966,8 +965,7 @@ void demographics(void)
|
||||||
|
|
||||||
remove_empty_units();
|
remove_empty_units();
|
||||||
|
|
||||||
if (verbosity >= 1)
|
log_info(" - Einwanderung...");
|
||||||
puts(" - Einwanderung...");
|
|
||||||
for (r = regions; r; r = r->next) {
|
for (r = regions; r; r = r->next) {
|
||||||
if (r->land && r->land->newpeasants) {
|
if (r->land && r->land->newpeasants) {
|
||||||
int rp = rpeasants(r) + r->land->newpeasants;
|
int rp = rpeasants(r) + r->land->newpeasants;
|
||||||
|
@ -1078,7 +1076,7 @@ int can_contact(const region * r, const unit * u, const unit * u2) {
|
||||||
return (alliedunit(u, u2->faction, HELP_GIVE));
|
return (alliedunit(u, u2->faction, HELP_GIVE));
|
||||||
}
|
}
|
||||||
|
|
||||||
void contact_cmd(unit * u, order * ord, int final)
|
int contact_cmd(unit * u, order * ord)
|
||||||
{
|
{
|
||||||
/* unit u kontaktiert unit u2. Dies setzt den contact einfach auf 1 -
|
/* unit u kontaktiert unit u2. Dies setzt den contact einfach auf 1 -
|
||||||
* ein richtiger toggle ist (noch?) nicht noetig. die region als
|
* ein richtiger toggle ist (noch?) nicht noetig. die region als
|
||||||
|
@ -1094,13 +1092,12 @@ void contact_cmd(unit * u, order * ord, int final)
|
||||||
|
|
||||||
if (u2 != NULL) {
|
if (u2 != NULL) {
|
||||||
if (!can_contact(r, u, u2)) {
|
if (!can_contact(r, u, u2)) {
|
||||||
if (final) {
|
cmistake(u, u->thisorder, 23, MSG_EVENT);
|
||||||
cmistake(u, u->thisorder, 23, MSG_EVENT);
|
return -1;
|
||||||
}
|
|
||||||
return;
|
|
||||||
}
|
}
|
||||||
usetcontact(u, u2);
|
usetcontact(u, u2);
|
||||||
}
|
}
|
||||||
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
int leave_cmd(unit * u, struct order *ord)
|
int leave_cmd(unit * u, struct order *ord)
|
||||||
|
@ -1316,19 +1313,23 @@ int enter_building(unit * u, order * ord, int id, int report)
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
static void do_misc(region * r, int is_final_attempt)
|
static void do_contact(region * r)
|
||||||
{
|
{
|
||||||
unit **uptr, *uc;
|
unit * u;
|
||||||
|
for (u = r->units; u; u = u->next) {
|
||||||
for (uc = r->units; uc; uc = uc->next) {
|
|
||||||
order *ord;
|
order *ord;
|
||||||
for (ord = uc->orders; ord; ord = ord->next) {
|
for (ord = u->orders; ord; ord = ord->next) {
|
||||||
keyword_t kwd = get_keyword(ord);
|
keyword_t kwd = get_keyword(ord);
|
||||||
if (kwd == K_CONTACT) {
|
if (kwd == K_CONTACT) {
|
||||||
contact_cmd(uc, ord, is_final_attempt);
|
contact_cmd(u, ord);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void do_enter(struct region *r, int is_final_attempt)
|
||||||
|
{
|
||||||
|
unit **uptr;
|
||||||
|
|
||||||
for (uptr = &r->units; *uptr;) {
|
for (uptr = &r->units; *uptr;) {
|
||||||
unit *u = *uptr;
|
unit *u = *uptr;
|
||||||
|
@ -1407,38 +1408,6 @@ static void do_misc(region * r, int is_final_attempt)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void quit(void)
|
|
||||||
{
|
|
||||||
faction **fptr = &factions;
|
|
||||||
while (*fptr) {
|
|
||||||
faction *f = *fptr;
|
|
||||||
if (f->flags & FFL_QUIT) {
|
|
||||||
if (EnhancedQuit()) {
|
|
||||||
/* this doesn't work well (use object_name()) */
|
|
||||||
attrib *a = a_find(f->attribs, &at_object);
|
|
||||||
if (a) {
|
|
||||||
variant var;
|
|
||||||
object_type type;
|
|
||||||
var.i = 0;
|
|
||||||
object_get(a, &type, &var);
|
|
||||||
assert(var.i && type == TINTEGER);
|
|
||||||
if (var.i) {
|
|
||||||
int f2_id = var.i;
|
|
||||||
faction *f2 = findfaction(f2_id);
|
|
||||||
|
|
||||||
assert(f2_id > 0);
|
|
||||||
assert(f2 != NULL);
|
|
||||||
transfer_faction(f, f2);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
}
|
|
||||||
destroyfaction(f);
|
|
||||||
}
|
|
||||||
if (*fptr == f)
|
|
||||||
fptr = &f->next;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
int dropouts[2];
|
int dropouts[2];
|
||||||
int *age = NULL;
|
int *age = NULL;
|
||||||
|
|
||||||
|
@ -1517,9 +1486,39 @@ static void remove_idle_players(void)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (verbosity >= 1)
|
void quit(void)
|
||||||
puts(" - beseitige leere Einheiten und leere Parteien...");
|
{
|
||||||
|
faction **fptr = &factions;
|
||||||
|
while (*fptr) {
|
||||||
|
faction *f = *fptr;
|
||||||
|
if (f->flags & FFL_QUIT) {
|
||||||
|
if (EnhancedQuit()) {
|
||||||
|
/* this doesn't work well (use object_name()) */
|
||||||
|
attrib *a = a_find(f->attribs, &at_object);
|
||||||
|
if (a) {
|
||||||
|
variant var;
|
||||||
|
object_type type;
|
||||||
|
var.i = 0;
|
||||||
|
object_get(a, &type, &var);
|
||||||
|
assert(var.i && type == TINTEGER);
|
||||||
|
if (var.i) {
|
||||||
|
int f2_id = var.i;
|
||||||
|
faction *f2 = findfaction(f2_id);
|
||||||
|
|
||||||
|
assert(f2_id > 0);
|
||||||
|
assert(f2 != NULL);
|
||||||
|
transfer_faction(f, f2);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
destroyfaction(f);
|
||||||
|
}
|
||||||
|
if (*fptr == f)
|
||||||
|
fptr = &f->next;
|
||||||
|
}
|
||||||
|
remove_idle_players();
|
||||||
remove_empty_units();
|
remove_empty_units();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -4416,12 +4415,12 @@ void do_siege(region * r)
|
||||||
|
|
||||||
static void enter_1(region * r)
|
static void enter_1(region * r)
|
||||||
{
|
{
|
||||||
do_misc(r, 0);
|
do_enter(r, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void enter_2(region * r)
|
static void enter_2(region * r)
|
||||||
{
|
{
|
||||||
do_misc(r, 1);
|
do_enter(r, 1);
|
||||||
}
|
}
|
||||||
|
|
||||||
static void maintain_buildings_1(region * r)
|
static void maintain_buildings_1(region * r)
|
||||||
|
@ -4492,9 +4491,10 @@ void init_processor(void)
|
||||||
p += 10;
|
p += 10;
|
||||||
add_proc_global(p, &age_factions, "Parteienalter++");
|
add_proc_global(p, &age_factions, "Parteienalter++");
|
||||||
add_proc_order(p, K_MAIL, &mail_cmd, 0, "Botschaften");
|
add_proc_order(p, K_MAIL, &mail_cmd, 0, "Botschaften");
|
||||||
|
add_proc_order(p, K_CONTACT, &contact_cmd, 0, "Kontaktieren");
|
||||||
|
|
||||||
p += 10; /* all claims must be done before we can USE */
|
p += 10; /* all claims must be done before we can USE */
|
||||||
add_proc_region(p, &enter_1, "Kontaktieren & Betreten (1. Versuch)");
|
add_proc_region(p, &enter_1, "Betreten (1. Versuch)");
|
||||||
add_proc_order(p, K_USE, &use_cmd, 0, "Benutzen");
|
add_proc_order(p, K_USE, &use_cmd, 0, "Benutzen");
|
||||||
|
|
||||||
if (!global.disabled[K_GM]) {
|
if (!global.disabled[K_GM]) {
|
||||||
|
@ -4515,7 +4515,7 @@ void init_processor(void)
|
||||||
}
|
}
|
||||||
|
|
||||||
p += 10; /* can't allow reserve before siege (weapons) */
|
p += 10; /* can't allow reserve before siege (weapons) */
|
||||||
add_proc_region(p, &enter_1, "Kontaktieren & Betreten (2. Versuch)");
|
add_proc_region(p, &enter_1, "Betreten (2. Versuch)");
|
||||||
add_proc_order(p, K_RESERVE, &reserve_cmd, 0, "Reservieren");
|
add_proc_order(p, K_RESERVE, &reserve_cmd, 0, "Reservieren");
|
||||||
add_proc_order(p, K_CLAIM, &claim_cmd, 0, NULL);
|
add_proc_order(p, K_CLAIM, &claim_cmd, 0, NULL);
|
||||||
add_proc_unit(p, &follow_unit, "Folge auf Einheiten setzen");
|
add_proc_unit(p, &follow_unit, "Folge auf Einheiten setzen");
|
||||||
|
@ -4532,7 +4532,6 @@ void init_processor(void)
|
||||||
|
|
||||||
p += 10; /* QUIT fuer sich alleine */
|
p += 10; /* QUIT fuer sich alleine */
|
||||||
add_proc_global(p, quit, "Sterben");
|
add_proc_global(p, quit, "Sterben");
|
||||||
add_proc_global(p, remove_idle_players, "remove idle players");
|
|
||||||
|
|
||||||
if (!global.disabled[K_CAST]) {
|
if (!global.disabled[K_CAST]) {
|
||||||
p += 10;
|
p += 10;
|
||||||
|
@ -4553,7 +4552,7 @@ void init_processor(void)
|
||||||
add_proc_postregion(p, &split_allocations, "Produktion II");
|
add_proc_postregion(p, &split_allocations, "Produktion II");
|
||||||
|
|
||||||
p += 10;
|
p += 10;
|
||||||
add_proc_region(p, &enter_2, "Kontaktieren & Betreten (3. Versuch)");
|
add_proc_region(p, &enter_2, "Betreten (3. Versuch)");
|
||||||
|
|
||||||
p += 10;
|
p += 10;
|
||||||
add_proc_region(p, &sinkships, "Schiffe sinken");
|
add_proc_region(p, &sinkships, "Schiffe sinken");
|
||||||
|
@ -4615,8 +4614,7 @@ void processorders(void)
|
||||||
do_markets();
|
do_markets();
|
||||||
}
|
}
|
||||||
|
|
||||||
if (verbosity >= 1)
|
log_info(" - Attribute altern");
|
||||||
puts(" - Attribute altern");
|
|
||||||
ageing();
|
ageing();
|
||||||
remove_empty_units();
|
remove_empty_units();
|
||||||
|
|
||||||
|
@ -4640,7 +4638,7 @@ int writepasswd(void)
|
||||||
F = cfopen(zText, "w");
|
F = cfopen(zText, "w");
|
||||||
if (F) {
|
if (F) {
|
||||||
faction *f;
|
faction *f;
|
||||||
puts("writing passwords...");
|
log_info("writing passwords...");
|
||||||
|
|
||||||
for (f = factions; f; f = f->next) {
|
for (f = factions; f; f = f->next) {
|
||||||
fprintf(F, "%s:%s:%s:%s:%u\n",
|
fprintf(F, "%s:%s:%s:%s:%u\n",
|
||||||
|
|
|
@ -48,7 +48,6 @@ extern "C" {
|
||||||
|
|
||||||
extern int enter_building(struct unit *u, struct order *ord, int id, int report);
|
extern int enter_building(struct unit *u, struct order *ord, int id, int report);
|
||||||
extern int enter_ship(struct unit *u, struct order *ord, int id, int report);
|
extern int enter_ship(struct unit *u, struct order *ord, int id, int report);
|
||||||
extern void contact_cmd(struct unit *u, struct order *ord, int final);
|
|
||||||
|
|
||||||
extern void new_units(void);
|
extern void new_units(void);
|
||||||
extern void quit(void);
|
extern void quit(void);
|
||||||
|
@ -56,6 +55,8 @@ extern "C" {
|
||||||
extern void restack_units(void);
|
extern void restack_units(void);
|
||||||
extern void update_long_order(struct unit *u);
|
extern void update_long_order(struct unit *u);
|
||||||
extern void sinkships(struct region * r);
|
extern void sinkships(struct region * r);
|
||||||
|
extern void do_enter(struct region *r, int is_final_attempt);
|
||||||
|
|
||||||
extern int password_cmd(struct unit *u, struct order *ord);
|
extern int password_cmd(struct unit *u, struct order *ord);
|
||||||
extern int banner_cmd(struct unit *u, struct order *ord);
|
extern int banner_cmd(struct unit *u, struct order *ord);
|
||||||
extern int email_cmd(struct unit *u, struct order *ord);
|
extern int email_cmd(struct unit *u, struct order *ord);
|
||||||
|
@ -76,6 +77,7 @@ extern "C" {
|
||||||
extern int promotion_cmd(struct unit *u, struct order *ord);
|
extern int promotion_cmd(struct unit *u, struct order *ord);
|
||||||
extern int renumber_cmd(struct unit *u, struct order *ord);
|
extern int renumber_cmd(struct unit *u, struct order *ord);
|
||||||
extern int combatspell_cmd(struct unit *u, struct order *ord);
|
extern int combatspell_cmd(struct unit *u, struct order *ord);
|
||||||
|
extern int contact_cmd(struct unit *u, struct order *ord);
|
||||||
|
|
||||||
#ifdef __cplusplus
|
#ifdef __cplusplus
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue