archetype-recruiting can be limited by building-size

This commit is contained in:
Enno Rehling 2007-05-28 17:31:40 +00:00
parent bf89b256e5
commit c1ba34a268
3 changed files with 30 additions and 5 deletions

View file

@ -24,6 +24,10 @@
static struct archetype * archetypes; static struct archetype * archetypes;
struct attrib_type at_recruit = {
"recruit", NULL, NULL, NULL, NULL, NULL, ATF_UNIQUE
};
const struct archetype * const struct archetype *
find_archetype(const char * s, const struct locale * lang) find_archetype(const char * s, const struct locale * lang)
{ {
@ -102,7 +106,7 @@ parse_archetypes(xmlDocPtr doc)
xmlFree(property); xmlFree(property);
} }
arch->size = xml_ivalue(node, "cost", 1); arch->size = xml_ivalue(node, "cost", 0);
xpath->node = node; xpath->node = node;
sub = xmlXPathEvalExpression(BAD_CAST "construction", xpath); sub = xmlXPathEvalExpression(BAD_CAST "construction", xpath);

View file

@ -32,6 +32,7 @@ extern "C" {
extern void register_archetype(struct archetype * arch); extern void register_archetype(struct archetype * arch);
extern void register_archetypes(void); extern void register_archetypes(void);
extern struct attrib_type at_recruit;
#ifdef __cplusplus #ifdef __cplusplus
} }

View file

@ -1068,6 +1068,7 @@ recruit_archetype(unit * u, order * ord)
id = getid(); id = getid();
if (n>0 && s && s[0]) { if (n>0 && s && s[0]) {
const archetype * arch = find_archetype(s, u->faction->locale); const archetype * arch = find_archetype(s, u->faction->locale);
attrib * a = NULL;
if (u->number>0) { if (u->number>0) {
ADDMSG(&u->faction->msgs, msg_feedback(u, ord, "unit_must_be_new", "")); ADDMSG(&u->faction->msgs, msg_feedback(u, ord, "unit_must_be_new", ""));
@ -1080,16 +1081,35 @@ recruit_archetype(unit * u, order * ord)
/* TODO: error message */ /* TODO: error message */
return 0; return 0;
} }
if (arch->btype && u->building->type!=arch->btype) { if (arch->btype) {
ADDMSG(&u->faction->msgs, msg_feedback(u, ord, "unit_must_be_in_building", "type", arch->btype)); if (u->building==NULL || u->building->type!=arch->btype) {
/* TODO: error message */ ADDMSG(&u->faction->msgs, msg_feedback(u, ord, "unit_must_be_in_building", "type", arch->btype));
return 0; /* TODO: error message */
return 0;
}
if (arch->size) {
int maxsize = u->building->size;
attrib * a = a_find(u->building->attribs, &at_recruit);
if (a!=NULL) {
maxsize -= a->data.i;
}
n = max(maxsize/arch->size, n);
if (n<=0) {
ADDMSG(&u->faction->msgs, msg_feedback(u, ord, "recruit_capacity_exhausted", "building", u->building));
/* TODO: error message */
return 0;
}
}
} }
n = build(u, arch->ctype, 0, n); n = build(u, arch->ctype, 0, n);
if (n>0) { if (n>0) {
scale_number(u, n); scale_number(u, n);
equip_unit(u, arch->equip); equip_unit(u, arch->equip);
if (arch->size) {
if (a==NULL) a = a_add(&u->building->attribs, a_new(&at_recruit));
a->data.i += n*arch->size;
}
return n; return n;
} else switch(n) { } else switch(n) {
case ENOMATERIALS: case ENOMATERIALS: