2012-06-07 04:29:36 +02:00
|
|
|
#include "bind_process.h"
|
|
|
|
|
|
|
|
#include <platform.h>
|
|
|
|
#include <kernel/types.h>
|
2012-06-07 18:47:02 +02:00
|
|
|
#include <kernel/order.h>
|
2012-06-17 04:14:23 +02:00
|
|
|
#include <kernel/battle.h>
|
2012-06-07 04:29:36 +02:00
|
|
|
#include <kernel/region.h>
|
2012-06-17 04:14:23 +02:00
|
|
|
#include <kernel/terrain.h>
|
2012-06-07 18:47:02 +02:00
|
|
|
#include <kernel/unit.h>
|
2012-06-13 07:36:29 +02:00
|
|
|
#include <kernel/move.h>
|
2012-06-07 04:29:36 +02:00
|
|
|
#include <gamecode/economy.h>
|
2012-06-07 18:47:02 +02:00
|
|
|
#include <gamecode/laws.h>
|
2012-06-07 04:29:36 +02:00
|
|
|
#include <gamecode/market.h>
|
2012-06-13 07:36:29 +02:00
|
|
|
#include <gamecode/study.h>
|
|
|
|
|
2012-06-17 04:14:23 +02:00
|
|
|
#define PROC_LAND_REGION 0x0001
|
|
|
|
#define PROC_LONG_ORDER 0x0002
|
|
|
|
|
|
|
|
static void process_cmd(keyword_t kwd, int (*callback)(unit *, order *), int flags)
|
2012-06-13 07:36:29 +02:00
|
|
|
{
|
|
|
|
region * r;
|
|
|
|
for (r=regions; r; r=r->next) {
|
|
|
|
unit * u;
|
2012-06-17 04:14:23 +02:00
|
|
|
|
|
|
|
/* look for shortcuts */
|
|
|
|
if (flags&PROC_LAND_REGION) {
|
|
|
|
/* only execute when we are on solid terrain */
|
|
|
|
while (r && (r->terrain->flags&LAND_REGION)==0) {
|
|
|
|
r = r->next;
|
2012-06-13 07:36:29 +02:00
|
|
|
}
|
2012-06-17 04:14:23 +02:00
|
|
|
if (!r) break;
|
2012-06-13 07:36:29 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
for (u=r->units; u; u=u->next) {
|
2012-06-17 04:14:23 +02:00
|
|
|
if (flags & PROC_LONG_ORDER) {
|
|
|
|
if (kwd == get_keyword(u->thisorder)) {
|
|
|
|
callback(u, u->thisorder);
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
order * ord;
|
|
|
|
for (ord=u->orders; ord; ord=ord->next) {
|
|
|
|
if (kwd == get_keyword(ord)) {
|
|
|
|
callback(u, ord);
|
|
|
|
}
|
|
|
|
}
|
2012-06-13 07:36:29 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2012-06-07 04:29:36 +02:00
|
|
|
|
|
|
|
void process_produce(void) {
|
|
|
|
struct region *r;
|
|
|
|
for (r = regions; r; r = r->next) {
|
2012-06-13 07:36:29 +02:00
|
|
|
unit * u;
|
|
|
|
for (u=r->units; u; u=u->next) {
|
|
|
|
order * ord;
|
|
|
|
for (ord=u->orders; ord; ord=ord->next) {
|
|
|
|
if (K_MAKE == get_keyword(ord)) {
|
|
|
|
make_cmd(u, ord);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2012-06-07 04:29:36 +02:00
|
|
|
produce(r);
|
2012-06-13 07:36:29 +02:00
|
|
|
split_allocations(r);
|
2012-06-07 04:29:36 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-06-17 04:14:23 +02:00
|
|
|
void process_battle(void) {
|
|
|
|
struct region *r;
|
|
|
|
for (r = regions; r; r = r->next) {
|
|
|
|
do_battle(r);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void process_siege(void) {
|
|
|
|
process_cmd(K_BESIEGE, siege_cmd, PROC_LAND_REGION);
|
|
|
|
}
|
|
|
|
|
2012-06-10 14:28:19 +02:00
|
|
|
void process_update_long_order(void) {
|
|
|
|
region * r;
|
|
|
|
for (r=regions; r; r=r->next) {
|
|
|
|
unit * u;
|
|
|
|
for (u=r->units; u; u=u->next) {
|
|
|
|
update_long_order(u);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-06-07 04:29:36 +02:00
|
|
|
void process_markets(void) {
|
|
|
|
do_markets();
|
|
|
|
}
|
2012-06-07 18:47:02 +02:00
|
|
|
|
|
|
|
void process_make_temp(void) {
|
|
|
|
new_units();
|
|
|
|
}
|
|
|
|
|
|
|
|
void process_settings(void) {
|
|
|
|
region * r;
|
|
|
|
for (r=regions; r; r=r->next) {
|
|
|
|
unit * u;
|
|
|
|
for (u=r->units; u; u=u->next) {
|
|
|
|
order * ord;
|
|
|
|
for (ord=u->orders; ord; ord=ord->next) {
|
|
|
|
keyword_t kwd = get_keyword(ord);
|
|
|
|
if (kwd==K_BANNER) {
|
|
|
|
banner_cmd(u, ord);
|
|
|
|
}
|
|
|
|
else if (kwd==K_EMAIL) {
|
|
|
|
email_cmd(u, ord);
|
|
|
|
}
|
|
|
|
else if (kwd==K_SEND) {
|
|
|
|
send_cmd(u, ord);
|
|
|
|
}
|
|
|
|
else if (kwd==K_PASSWORD) {
|
|
|
|
password_cmd(u, ord);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2012-06-10 14:28:19 +02:00
|
|
|
void process_ally(void) {
|
2012-06-17 04:14:23 +02:00
|
|
|
process_cmd(K_ALLY, ally_cmd, 0);
|
2012-06-10 14:28:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void process_prefix(void) {
|
2012-06-17 04:14:23 +02:00
|
|
|
process_cmd(K_PREFIX, prefix_cmd, 0);
|
2012-06-10 14:28:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void process_setstealth(void) {
|
2012-06-17 04:14:23 +02:00
|
|
|
process_cmd(K_SETSTEALTH, setstealth_cmd, 0);
|
2012-06-10 14:28:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void process_status(void) {
|
2012-06-17 04:14:23 +02:00
|
|
|
process_cmd(K_STATUS, status_cmd, 0);
|
2012-06-10 14:28:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void process_display(void) {
|
2012-06-17 04:14:23 +02:00
|
|
|
process_cmd(K_DISPLAY, display_cmd, 0);
|
2012-06-10 14:28:19 +02:00
|
|
|
}
|
|
|
|
|
2012-06-07 18:47:02 +02:00
|
|
|
void process_group(void) {
|
2012-06-17 04:14:23 +02:00
|
|
|
process_cmd(K_GROUP, group_cmd, 0);
|
2012-06-07 18:47:02 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void process_origin(void) {
|
2012-06-17 04:14:23 +02:00
|
|
|
process_cmd(K_URSPRUNG, origin_cmd, 0);
|
2012-06-07 18:47:02 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void process_quit(void) {
|
2012-06-17 04:14:23 +02:00
|
|
|
process_cmd(K_QUIT, quit_cmd, 0);
|
2012-06-07 18:47:02 +02:00
|
|
|
quit();
|
|
|
|
}
|
2012-06-13 07:36:29 +02:00
|
|
|
|
|
|
|
void process_study(void) {
|
2012-06-17 04:14:23 +02:00
|
|
|
process_cmd(K_TEACH, teach_cmd, PROC_LONG_ORDER);
|
|
|
|
process_cmd(K_STUDY, learn_cmd, PROC_LONG_ORDER);
|
2012-06-13 07:36:29 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
void process_movement(void) {
|
|
|
|
movement();
|
|
|
|
}
|
|
|
|
|
|
|
|
void process_use(void) {
|
2012-06-17 04:14:23 +02:00
|
|
|
process_cmd(K_USE, use_cmd, 0);
|
2012-06-13 07:36:29 +02:00
|
|
|
}
|
2012-06-14 08:28:56 +02:00
|
|
|
|
|
|
|
void process_leave(void) {
|
2012-06-17 04:14:23 +02:00
|
|
|
process_cmd(K_LEAVE, leave_cmd, 0);
|
2012-06-14 08:28:56 +02:00
|
|
|
}
|