forked from github/server
archetype-recruiting can be limited by building-size
This commit is contained in:
parent
bf89b256e5
commit
c1ba34a268
3 changed files with 30 additions and 5 deletions
|
@ -24,6 +24,10 @@
|
|||
|
||||
static struct archetype * archetypes;
|
||||
|
||||
struct attrib_type at_recruit = {
|
||||
"recruit", NULL, NULL, NULL, NULL, NULL, ATF_UNIQUE
|
||||
};
|
||||
|
||||
const struct archetype *
|
||||
find_archetype(const char * s, const struct locale * lang)
|
||||
{
|
||||
|
@ -102,7 +106,7 @@ parse_archetypes(xmlDocPtr doc)
|
|||
xmlFree(property);
|
||||
}
|
||||
|
||||
arch->size = xml_ivalue(node, "cost", 1);
|
||||
arch->size = xml_ivalue(node, "cost", 0);
|
||||
|
||||
xpath->node = node;
|
||||
sub = xmlXPathEvalExpression(BAD_CAST "construction", xpath);
|
||||
|
|
|
@ -32,6 +32,7 @@ extern "C" {
|
|||
extern void register_archetype(struct archetype * arch);
|
||||
extern void register_archetypes(void);
|
||||
|
||||
extern struct attrib_type at_recruit;
|
||||
|
||||
#ifdef __cplusplus
|
||||
}
|
||||
|
|
|
@ -1068,6 +1068,7 @@ recruit_archetype(unit * u, order * ord)
|
|||
id = getid();
|
||||
if (n>0 && s && s[0]) {
|
||||
const archetype * arch = find_archetype(s, u->faction->locale);
|
||||
attrib * a = NULL;
|
||||
|
||||
if (u->number>0) {
|
||||
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 */
|
||||
return 0;
|
||||
}
|
||||
if (arch->btype && u->building->type!=arch->btype) {
|
||||
ADDMSG(&u->faction->msgs, msg_feedback(u, ord, "unit_must_be_in_building", "type", arch->btype));
|
||||
/* TODO: error message */
|
||||
return 0;
|
||||
if (arch->btype) {
|
||||
if (u->building==NULL || u->building->type!=arch->btype) {
|
||||
ADDMSG(&u->faction->msgs, msg_feedback(u, ord, "unit_must_be_in_building", "type", arch->btype));
|
||||
/* 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);
|
||||
if (n>0) {
|
||||
scale_number(u, n);
|
||||
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;
|
||||
} else switch(n) {
|
||||
case ENOMATERIALS:
|
||||
|
|
Loading…
Reference in a new issue