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;
|
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);
|
||||||
|
|
|
@ -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
|
||||||
}
|
}
|
||||||
|
|
|
@ -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:
|
||||||
|
|
Loading…
Reference in a new issue