Binding CAST, ENTER, CONTACT to Lua

This commit is contained in:
Enno Rehling 2012-06-17 17:24:23 -07:00
parent 573d4c3e97
commit 648de4d36c
7 changed files with 109 additions and 59 deletions

View file

@ -38,6 +38,9 @@ function test_process()
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_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
function test_settings()

View file

@ -190,3 +190,29 @@ function test_process_renumber()
assert_equal(666, u.id)
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

View file

@ -2,6 +2,7 @@
#include <platform.h>
#include <kernel/types.h>
#include <kernel/magic.h>
#include <kernel/order.h>
#include <kernel/battle.h>
#include <kernel/region.h>
@ -198,6 +199,20 @@ void process_sethelp(void) {
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) {
region * r;

View file

@ -30,6 +30,9 @@ void process_renumber(void);
void process_restack(void);
void process_setspells(void);
void process_sethelp(void);
void process_contact(void);
void process_enter(int final);
void process_magic(void);
#ifdef __cplusplus
}

View file

@ -27,5 +27,8 @@ module eressea {
void process_restack @ restack(void); /* SORT */
void process_setspells @ set_spells(void); /* COMBATSPELL */
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 */
}
}

View file

@ -135,8 +135,7 @@ static void checkorders(void)
{
faction *f;
if (verbosity >= 1)
puts(" - Warne spaete Spieler...");
log_info(" - Warne spaete Spieler...");
for (f = factions; f; f = f->next)
if (!is_monsters(f) && turn - f->lastorders == NMRTimeout() - 1)
ADDMSG(&f->msgs, msg_message("turnreminder", ""));
@ -966,8 +965,7 @@ void demographics(void)
remove_empty_units();
if (verbosity >= 1)
puts(" - Einwanderung...");
log_info(" - Einwanderung...");
for (r = regions; r; r = r->next) {
if (r->land && 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));
}
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 -
* 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 (!can_contact(r, u, u2)) {
if (final) {
cmistake(u, u->thisorder, 23, MSG_EVENT);
}
return;
cmistake(u, u->thisorder, 23, MSG_EVENT);
return -1;
}
usetcontact(u, u2);
}
return 0;
}
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;
}
static void do_misc(region * r, int is_final_attempt)
static void do_contact(region * r)
{
unit **uptr, *uc;
for (uc = r->units; uc; uc = uc->next) {
unit * u;
for (u = r->units; u; u = u->next) {
order *ord;
for (ord = uc->orders; ord; ord = ord->next) {
for (ord = u->orders; ord; ord = ord->next) {
keyword_t kwd = get_keyword(ord);
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;) {
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 *age = NULL;
@ -1517,9 +1486,39 @@ static void remove_idle_players(void)
}
}
}
}
if (verbosity >= 1)
puts(" - beseitige leere Einheiten und leere Parteien...");
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;
}
remove_idle_players();
remove_empty_units();
}
@ -4416,12 +4415,12 @@ void do_siege(region * r)
static void enter_1(region * r)
{
do_misc(r, 0);
do_enter(r, 0);
}
static void enter_2(region * r)
{
do_misc(r, 1);
do_enter(r, 1);
}
static void maintain_buildings_1(region * r)
@ -4492,9 +4491,10 @@ void init_processor(void)
p += 10;
add_proc_global(p, &age_factions, "Parteienalter++");
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 */
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");
if (!global.disabled[K_GM]) {
@ -4515,7 +4515,7 @@ void init_processor(void)
}
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_CLAIM, &claim_cmd, 0, NULL);
add_proc_unit(p, &follow_unit, "Folge auf Einheiten setzen");
@ -4532,7 +4532,6 @@ void init_processor(void)
p += 10; /* QUIT fuer sich alleine */
add_proc_global(p, quit, "Sterben");
add_proc_global(p, remove_idle_players, "remove idle players");
if (!global.disabled[K_CAST]) {
p += 10;
@ -4553,7 +4552,7 @@ void init_processor(void)
add_proc_postregion(p, &split_allocations, "Produktion II");
p += 10;
add_proc_region(p, &enter_2, "Kontaktieren & Betreten (3. Versuch)");
add_proc_region(p, &enter_2, "Betreten (3. Versuch)");
p += 10;
add_proc_region(p, &sinkships, "Schiffe sinken");
@ -4615,8 +4614,7 @@ void processorders(void)
do_markets();
}
if (verbosity >= 1)
puts(" - Attribute altern");
log_info(" - Attribute altern");
ageing();
remove_empty_units();
@ -4640,7 +4638,7 @@ int writepasswd(void)
F = cfopen(zText, "w");
if (F) {
faction *f;
puts("writing passwords...");
log_info("writing passwords...");
for (f = factions; f; f = f->next) {
fprintf(F, "%s:%s:%s:%s:%u\n",

View file

@ -48,7 +48,6 @@ extern "C" {
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 void contact_cmd(struct unit *u, struct order *ord, int final);
extern void new_units(void);
extern void quit(void);
@ -56,6 +55,8 @@ extern "C" {
extern void restack_units(void);
extern void update_long_order(struct unit *u);
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 banner_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 renumber_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
}