forked from github/server
refactor resource callbacks into callbacks module
This commit is contained in:
parent
437c9c2d2e
commit
6b7dcadf84
4 changed files with 15 additions and 13 deletions
|
@ -311,8 +311,8 @@ void register_tolua_helpers(void)
|
|||
|
||||
callbacks.cast_spell = lua_callspell;
|
||||
callbacks.use_item = use_item_lua;
|
||||
res_produce_fun = produce_resource_lua;
|
||||
res_limit_fun = limit_resource_lua;
|
||||
callbacks.produce_resource = produce_resource_lua;
|
||||
callbacks.limit_resource = limit_resource_lua;
|
||||
|
||||
register_function((pf_generic)lua_changeresource, "lua_changeresource");
|
||||
register_item_give(lua_giveitem, "lua_giveitem");
|
||||
|
|
|
@ -26,13 +26,16 @@ extern "C" {
|
|||
struct castorder;
|
||||
struct order;
|
||||
struct unit;
|
||||
struct region;
|
||||
struct item_type;
|
||||
struct resource_type;
|
||||
|
||||
struct callback_struct {
|
||||
int (*cast_spell)(struct castorder *co, const char *fname);
|
||||
int (*use_item)(struct unit *u, const struct item_type *itype,
|
||||
int amount, struct order *ord);
|
||||
|
||||
void(*produce_resource)(struct region *, const struct resource_type *, int);
|
||||
int(*limit_resource)(const struct region *, const struct resource_type *);
|
||||
};
|
||||
|
||||
extern struct callback_struct callbacks;
|
||||
|
|
|
@ -11,10 +11,11 @@
|
|||
*/
|
||||
|
||||
#include <platform.h>
|
||||
#include <kernel/config.h>
|
||||
#include "resources.h"
|
||||
|
||||
/* kernel includes */
|
||||
#include <kernel/config.h>
|
||||
#include <kernel/callbacks.h>
|
||||
#include "build.h"
|
||||
#include "item.h"
|
||||
#include "region.h"
|
||||
|
@ -213,14 +214,11 @@ struct rawmaterial_type *rmt_create(struct resource_type *rtype)
|
|||
return rmtype;
|
||||
}
|
||||
|
||||
int(*res_limit_fun)(const struct region *, const struct resource_type *);
|
||||
void(*res_produce_fun)(struct region *, const struct resource_type *, int);
|
||||
|
||||
int limit_resource(const struct region *r, const resource_type *rtype)
|
||||
{
|
||||
assert(!rtype->raw);
|
||||
if (res_limit_fun) {
|
||||
return res_limit_fun(r, rtype);
|
||||
if (callbacks.limit_resource) {
|
||||
return callbacks.limit_resource(r, rtype);
|
||||
}
|
||||
return -1;
|
||||
}
|
||||
|
@ -228,7 +226,7 @@ int limit_resource(const struct region *r, const resource_type *rtype)
|
|||
void produce_resource(struct region *r, const struct resource_type *rtype, int amount)
|
||||
{
|
||||
assert(!rtype->raw);
|
||||
if (res_produce_fun) {
|
||||
res_produce_fun(r, rtype, amount);
|
||||
if (callbacks.produce_resource) {
|
||||
callbacks.produce_resource(r, rtype, amount);
|
||||
}
|
||||
}
|
||||
|
|
|
@ -15,8 +15,11 @@
|
|||
extern "C" {
|
||||
#endif
|
||||
|
||||
#include <util/variant.h>
|
||||
|
||||
struct building_type;
|
||||
struct race;
|
||||
struct region;
|
||||
|
||||
enum {
|
||||
RM_USED = 1 << 0, /* resource has been used */
|
||||
|
@ -71,8 +74,6 @@ extern "C" {
|
|||
int base, int divisor, const struct resource_type *rtype);
|
||||
struct rawmaterial_type *rmt_create(struct resource_type *rtype);
|
||||
|
||||
extern int(*res_limit_fun)(const struct region *, const struct resource_type *);
|
||||
extern void(*res_produce_fun)(struct region *, const struct resource_type *, int);
|
||||
int limit_resource(const struct region *r, const struct resource_type *rtype);
|
||||
void produce_resource(struct region *r, const struct resource_type *rtype, int amount);
|
||||
|
||||
|
|
Loading…
Reference in a new issue