2003-11-10 00:36:11 +01:00
|
|
|
|
/* vi: set ts=2:
|
2004-06-21 18:45:27 +02:00
|
|
|
|
+-------------------+ Christian Schlittchen <corwin@amber.kn-bremen.de>
|
|
|
|
|
| | Enno Rehling <enno@eressea-pbem.de>
|
|
|
|
|
| Eressea PBEM host | Katja Zedel <katze@felidae.kn-bremen.de>
|
|
|
|
|
| (c) 1998 - 2003 | Henning Peters <faroul@beyond.kn-bremen.de>
|
|
|
|
|
| | Ingo Wilken <Ingo.Wilken@informatik.uni-oldenburg.de>
|
|
|
|
|
+-------------------+ Stefan Reich <reich@halbling.de>
|
2003-11-10 00:36:11 +01:00
|
|
|
|
|
2004-06-21 18:45:27 +02:00
|
|
|
|
This program may not be used, modified or distributed
|
|
|
|
|
without prior permission by the authors of Eressea.
|
2003-11-10 00:36:11 +01:00
|
|
|
|
|
2004-06-21 18:45:27 +02:00
|
|
|
|
*/
|
2003-11-10 00:36:11 +01:00
|
|
|
|
#include <config.h>
|
|
|
|
|
#include "eressea.h"
|
|
|
|
|
#include "give.h"
|
|
|
|
|
|
2007-05-30 03:21:09 +02:00
|
|
|
|
#include "economy.h"
|
|
|
|
|
|
2003-11-10 00:36:11 +01:00
|
|
|
|
/* kernel includes */
|
2007-05-30 03:21:09 +02:00
|
|
|
|
#include <kernel/faction.h>
|
|
|
|
|
#include <kernel/item.h>
|
|
|
|
|
#include <kernel/magic.h>
|
|
|
|
|
#include <kernel/message.h>
|
|
|
|
|
#include <kernel/order.h>
|
|
|
|
|
#include <kernel/pool.h>
|
|
|
|
|
#include <kernel/race.h>
|
|
|
|
|
#include <kernel/region.h>
|
|
|
|
|
#include <kernel/reports.h>
|
|
|
|
|
#include <kernel/ship.h>
|
|
|
|
|
#include <kernel/skill.h>
|
|
|
|
|
#include <kernel/terrain.h>
|
|
|
|
|
#include <kernel/unit.h>
|
2003-11-10 00:36:11 +01:00
|
|
|
|
|
|
|
|
|
/* attributes includes */
|
|
|
|
|
#include <attributes/racename.h>
|
|
|
|
|
#include <attributes/orcification.h>
|
|
|
|
|
|
|
|
|
|
/* util includes */
|
|
|
|
|
#include <util/event.h>
|
2004-06-21 18:45:27 +02:00
|
|
|
|
#include <util/base36.h>
|
2003-11-10 00:36:11 +01:00
|
|
|
|
|
|
|
|
|
/* libc includes */
|
|
|
|
|
#include <limits.h>
|
|
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
|
|
|
|
/* Wieviel Fremde eine Partei pro Woche aufnehmen kann */
|
|
|
|
|
#define MAXNEWBIES 5
|
2004-07-06 18:08:49 +02:00
|
|
|
|
#define RESERVE_DONATIONS /* shall we reserve objects given to us by other factions? */
|
|
|
|
|
#define RESERVE_GIVE /* reserve anything that's given from one unit to another? */
|
|
|
|
|
|
2003-11-10 00:36:11 +01:00
|
|
|
|
|
|
|
|
|
static int
|
|
|
|
|
GiveRestriction(void) {
|
2004-06-21 18:45:27 +02:00
|
|
|
|
static int value = -1;
|
|
|
|
|
if (value<0) {
|
|
|
|
|
const char * str = get_param(global.parameters, "GiveRestriction");
|
|
|
|
|
value = str?atoi(str):0;
|
|
|
|
|
}
|
|
|
|
|
return value;
|
2003-11-10 00:36:11 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
add_give(unit * u, unit * u2, int n, const resource_type * rtype, struct order * ord, int error)
|
|
|
|
|
{
|
2004-06-21 18:45:27 +02:00
|
|
|
|
if (error) {
|
|
|
|
|
cmistake(u, ord, error, MSG_COMMERCE);
|
|
|
|
|
}
|
|
|
|
|
else if (!u2 || u2->faction!=u->faction) {
|
|
|
|
|
assert(rtype);
|
2006-01-29 02:55:36 +01:00
|
|
|
|
ADDMSG(&u->faction->msgs,
|
2004-06-21 18:45:27 +02:00
|
|
|
|
msg_message("give", "unit target resource amount",
|
|
|
|
|
u, u2?ucansee(u->faction, u2, u_unknown()):u_peasants(), rtype, n));
|
|
|
|
|
if (u2) {
|
2006-01-29 02:55:36 +01:00
|
|
|
|
ADDMSG(&u2->faction->msgs,
|
2004-06-21 18:45:27 +02:00
|
|
|
|
msg_message("give", "unit target resource amount",
|
|
|
|
|
ucansee(u2->faction, u, u_unknown()), u2, rtype, n));
|
|
|
|
|
}
|
|
|
|
|
}
|
2003-11-10 00:36:11 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static void
|
|
|
|
|
give_peasants(int n, const item_type * itype, unit * src)
|
|
|
|
|
{
|
2004-06-21 18:45:27 +02:00
|
|
|
|
region *r = src->region;
|
2003-11-10 00:36:11 +01:00
|
|
|
|
|
2004-06-21 18:45:27 +02:00
|
|
|
|
/* horses are given to the region via itype->give! */
|
2003-11-10 00:36:11 +01:00
|
|
|
|
|
2004-06-21 18:45:27 +02:00
|
|
|
|
if (itype->rtype==r_silver) {
|
|
|
|
|
rsetmoney(r, rmoney(r) + n);
|
|
|
|
|
}
|
2003-11-10 00:36:11 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
int
|
|
|
|
|
give_item(int want, const item_type * itype, unit * src, unit * dest, struct order * ord)
|
|
|
|
|
{
|
2004-06-21 18:45:27 +02:00
|
|
|
|
short error = 0;
|
|
|
|
|
int n;
|
2003-11-10 00:36:11 +01:00
|
|
|
|
|
2004-06-21 18:45:27 +02:00
|
|
|
|
assert(itype!=NULL);
|
2006-02-19 23:43:56 +01:00
|
|
|
|
n = get_pooled(src, item2resource(itype), GET_DEFAULT, want);
|
2004-06-21 18:45:27 +02:00
|
|
|
|
n = min(want, n);
|
|
|
|
|
if (dest && src->faction != dest->faction && src->faction->age < GiveRestriction()) {
|
2003-11-10 00:36:11 +01:00
|
|
|
|
if (ord!=NULL) {
|
2007-05-15 22:11:25 +02:00
|
|
|
|
ADDMSG(&src->faction->msgs, msg_feedback(src, ord, "giverestriction",
|
|
|
|
|
"turns", GiveRestriction()));
|
2003-11-10 00:36:11 +01:00
|
|
|
|
}
|
2004-06-21 18:45:27 +02:00
|
|
|
|
return -1;
|
|
|
|
|
} else if (n == 0) {
|
2007-05-15 22:11:25 +02:00
|
|
|
|
int reserve = get_reservation(src, itype->rtype);
|
|
|
|
|
if (reserve) {
|
|
|
|
|
msg_feedback(src, ord, "nogive_reserved", "resource reservation",
|
|
|
|
|
itype->rtype, reserve);
|
|
|
|
|
return -1;
|
|
|
|
|
}
|
2004-06-21 18:45:27 +02:00
|
|
|
|
error = 36;
|
|
|
|
|
} else if (itype->flags & ITF_CURSED) {
|
|
|
|
|
error = 25;
|
|
|
|
|
} else if (itype->give && !itype->give(src, dest, itype, n, ord)) {
|
|
|
|
|
return -1;
|
|
|
|
|
} else {
|
2005-10-30 16:42:15 +01:00
|
|
|
|
int use = use_pooled(src, item2resource(itype), GET_SLACK, n);
|
|
|
|
|
if (use<n) use += use_pooled(src, item2resource(itype), GET_RESERVE|GET_POOLED_SLACK, n-use);
|
2004-06-21 18:45:27 +02:00
|
|
|
|
if (dest) {
|
|
|
|
|
i_change(&dest->items, itype, n);
|
2004-07-06 18:08:49 +02:00
|
|
|
|
#ifdef RESERVE_GIVE
|
|
|
|
|
#ifdef RESERVE_DONATIONS
|
2005-10-29 14:25:53 +02:00
|
|
|
|
change_reservation(dest, item2resource(itype), n);
|
2004-07-06 18:08:49 +02:00
|
|
|
|
#else
|
2004-06-21 18:45:27 +02:00
|
|
|
|
if (src->faction==dest->faction) {
|
2005-10-29 14:25:53 +02:00
|
|
|
|
change_reservation(dest, item2resource(itype), n);
|
2004-06-21 18:45:27 +02:00
|
|
|
|
}
|
2004-07-06 18:08:49 +02:00
|
|
|
|
#endif
|
2003-11-10 00:36:11 +01:00
|
|
|
|
#endif
|
2006-08-12 21:15:16 +02:00
|
|
|
|
handle_event(src->attribs, "give", dest);
|
|
|
|
|
handle_event(dest->attribs, "receive", src);
|
2003-11-10 00:36:11 +01:00
|
|
|
|
#if defined(MUSEUM_MODULE) && defined(TODO)
|
2004-08-03 17:34:26 +02:00
|
|
|
|
/* TODO: Einen Trigger f<>r den museums-warden benutzen! */
|
2004-06-21 18:45:27 +02:00
|
|
|
|
if (a_find(dest->attribs, &at_warden)) {
|
|
|
|
|
/* warden_add_give(src, dest, itype, n); */
|
|
|
|
|
}
|
2003-11-10 00:36:11 +01:00
|
|
|
|
#endif
|
2007-05-15 22:11:25 +02:00
|
|
|
|
} else {
|
2004-06-21 18:45:27 +02:00
|
|
|
|
/* gib bauern */
|
|
|
|
|
give_peasants(use, itype, src);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
add_give(src, dest, n, item2resource(itype), ord, error);
|
|
|
|
|
if (error) return -1;
|
|
|
|
|
return 0;
|
2003-11-10 00:36:11 +01:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
2004-09-11 19:50:27 +02:00
|
|
|
|
give_men(int n, unit * u, unit * u2, struct order * ord)
|
2003-11-10 00:36:11 +01:00
|
|
|
|
{
|
2004-06-21 18:45:27 +02:00
|
|
|
|
ship *sh;
|
|
|
|
|
int k = 0;
|
|
|
|
|
int error = 0;
|
|
|
|
|
|
|
|
|
|
if (u2 && u->faction != u2->faction && u->faction->age < GiveRestriction()) {
|
|
|
|
|
ADDMSG(&u->faction->msgs, msg_feedback(u, ord, "giverestriction",
|
|
|
|
|
"turns", GiveRestriction()));
|
|
|
|
|
return;
|
|
|
|
|
} else if (u == u2) {
|
|
|
|
|
error = 10;
|
|
|
|
|
} else if (!u2 && u->race == new_race[RC_SNOTLING]) {
|
|
|
|
|
/* Snotlings k<>nnen nicht an Bauern <20>bergeben werden. */
|
|
|
|
|
error = 307;
|
2004-08-03 17:34:26 +02:00
|
|
|
|
#ifdef HEROES
|
2004-09-11 19:50:27 +02:00
|
|
|
|
} else if (u2 && u2->number>0 && fval(u, UFL_HERO)!=fval(u2, UFL_HERO)) {
|
2004-08-03 17:34:26 +02:00
|
|
|
|
error = 75;
|
2004-06-21 18:45:27 +02:00
|
|
|
|
#endif
|
|
|
|
|
} else if ((u && unit_has_cursed_item(u)) || (u2 && unit_has_cursed_item(u2))) {
|
|
|
|
|
error = 78;
|
2007-02-01 22:13:24 +01:00
|
|
|
|
} else if (fval(u, UFL_LOCKED) || is_cursed(u->attribs, C_SLAVE, 0)) {
|
2004-06-21 18:45:27 +02:00
|
|
|
|
error = 74;
|
2007-02-01 22:13:24 +01:00
|
|
|
|
} else if (u2 && fval(u, UFL_HUNGER)) {
|
2007-02-10 22:35:19 +01:00
|
|
|
|
error = 73;
|
2004-06-21 18:45:27 +02:00
|
|
|
|
} else if (u2 && (fval(u2, UFL_LOCKED)|| is_cursed(u2->attribs, C_SLAVE, 0))) {
|
|
|
|
|
error = 75;
|
2005-02-05 19:11:23 +01:00
|
|
|
|
} else if (u2 && u2->faction != u->faction && !alliedunit(u2, u->faction, HELP_GIVE) && !ucontact(u2, u)) {
|
2007-02-10 21:52:39 +01:00
|
|
|
|
ADDMSG(&u->faction->msgs, msg_feedback(u, ord, "feedback_no_contact", "target", u2));
|
|
|
|
|
error = -1;
|
2004-06-21 18:45:27 +02:00
|
|
|
|
} else if (u2 && (has_skill(u, SK_MAGIC) || has_skill(u2, SK_MAGIC))) {
|
|
|
|
|
error = 158;
|
|
|
|
|
} else if (u2 && fval(u, UFL_WERE) != fval(u2, UFL_WERE)) {
|
|
|
|
|
error = 312;
|
|
|
|
|
} else if (u2 && u2->number!=0 && u2->race != u->race) {
|
|
|
|
|
log_warning(("Partei %s versucht %s an %s zu <20>bergeben.\n",
|
|
|
|
|
itoa36(u->faction->no), u->race->_name[0],
|
|
|
|
|
u2->race->_name[1]));
|
|
|
|
|
error = 139;
|
2004-07-10 19:50:00 +02:00
|
|
|
|
} else if (u2!=NULL && (get_racename(u2->attribs) || get_racename(u->attribs))) {
|
|
|
|
|
error = 139;
|
2004-06-21 18:45:27 +02:00
|
|
|
|
} else {
|
|
|
|
|
if (n > u->number) n = u->number;
|
2006-10-29 13:45:42 +01:00
|
|
|
|
if (u2 && n+u2->number > UNIT_MAXSIZE) {
|
|
|
|
|
n = UNIT_MAXSIZE-u2->number;
|
|
|
|
|
ADDMSG(&u->faction->msgs, msg_feedback(u, ord, "error_unit_size", "maxsize", UNIT_MAXSIZE));
|
2006-10-29 14:04:18 +01:00
|
|
|
|
assert(n>=0);
|
2006-10-29 13:45:42 +01:00
|
|
|
|
}
|
2004-06-21 18:45:27 +02:00
|
|
|
|
if (n == 0) {
|
|
|
|
|
error = 96;
|
|
|
|
|
} else if (u2 && u->faction != u2->faction) {
|
|
|
|
|
if (u2->faction->newbies + n > MAXNEWBIES) {
|
|
|
|
|
error = 129;
|
|
|
|
|
} else if (u->race != u2->faction->race) {
|
|
|
|
|
if (u2->faction->race != new_race[RC_HUMAN]) {
|
|
|
|
|
error = 120;
|
|
|
|
|
} else if (count_migrants(u2->faction) + n > count_maxmigrants(u2->faction)) {
|
|
|
|
|
error = 128;
|
|
|
|
|
}
|
|
|
|
|
else if (teure_talente(u) || teure_talente(u2)) {
|
|
|
|
|
error = 154;
|
|
|
|
|
} else if (u2->number!=0) {
|
|
|
|
|
error = 139;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (u2 && (has_skill(u, SK_ALCHEMY) || has_skill(u2, SK_ALCHEMY))) {
|
|
|
|
|
k = count_skill(u2->faction, SK_ALCHEMY);
|
|
|
|
|
|
|
|
|
|
/* Falls die Zieleinheit keine Alchemisten sind, werden sie nun
|
|
|
|
|
* welche. */
|
|
|
|
|
if (!has_skill(u2, SK_ALCHEMY) && has_skill(u, SK_ALCHEMY))
|
|
|
|
|
k += u2->number;
|
|
|
|
|
|
|
|
|
|
/* Wenn in eine Alchemisteneinheit Personen verschoben werden */
|
|
|
|
|
if (has_skill(u2, SK_ALCHEMY) && !has_skill(u, SK_ALCHEMY))
|
|
|
|
|
k += n;
|
|
|
|
|
|
|
|
|
|
/* Wenn Parteigrenzen <20>berschritten werden */
|
|
|
|
|
if (u2->faction != u->faction)
|
|
|
|
|
k += n;
|
|
|
|
|
|
|
|
|
|
/* wird das Alchemistenmaximum ueberschritten ? */
|
|
|
|
|
|
|
|
|
|
if (k > max_skill(u2->faction, SK_ALCHEMY)) {
|
|
|
|
|
error = 156;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (error==0) {
|
|
|
|
|
if (u2 && u2->number == 0) {
|
|
|
|
|
set_racename(&u2->attribs, get_racename(u->attribs));
|
|
|
|
|
u2->race = u->race;
|
|
|
|
|
u2->irace = u->irace;
|
2004-09-25 12:26:30 +02:00
|
|
|
|
#ifdef HEROES
|
2004-09-11 19:50:27 +02:00
|
|
|
|
if (fval(u, UFL_HERO)) fset(u2, UFL_HERO);
|
|
|
|
|
else freset(u2, UFL_HERO);
|
2004-09-25 12:26:30 +02:00
|
|
|
|
#endif
|
2004-06-21 18:45:27 +02:00
|
|
|
|
}
|
2007-05-30 03:21:09 +02:00
|
|
|
|
|
2004-06-21 18:45:27 +02:00
|
|
|
|
if (u2) {
|
2007-05-30 03:21:09 +02:00
|
|
|
|
if (u2->number!=0 && recruit_archetypes()) {
|
|
|
|
|
/* must have same set of skills */
|
|
|
|
|
boolean okay = false;
|
|
|
|
|
if (u->skill_size==u2->skill_size) {
|
|
|
|
|
int i;
|
|
|
|
|
for (i=0;i!=u->skill_size;++i) {
|
|
|
|
|
int j;
|
|
|
|
|
for (j=0;j!=u2->skill_size;++j) {
|
|
|
|
|
if (u->skills[i].id==u2->skills[j].id) break;
|
|
|
|
|
}
|
|
|
|
|
if (j!=u2->skill_size) break;
|
|
|
|
|
}
|
|
|
|
|
if (i==u->skill_size) okay = true;
|
|
|
|
|
}
|
|
|
|
|
if (!okay) {
|
|
|
|
|
ADDMSG(&u->faction->msgs, msg_feedback(u, ord, "give_cannot_merge", ""));
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
2004-06-21 18:45:27 +02:00
|
|
|
|
/* Einheiten von Schiffen k<>nnen nicht NACH in von
|
|
|
|
|
* Nicht-alliierten bewachten Regionen ausf<EFBFBD>hren */
|
|
|
|
|
sh = leftship(u);
|
|
|
|
|
if (sh) set_leftship(u2, sh);
|
|
|
|
|
|
|
|
|
|
transfermen(u, u2, n);
|
|
|
|
|
if (u->faction != u2->faction) {
|
|
|
|
|
u2->faction->newbies += n;
|
|
|
|
|
}
|
|
|
|
|
} else {
|
|
|
|
|
if (getunitpeasants) {
|
2003-11-10 00:36:11 +01:00
|
|
|
|
#ifdef ORCIFICATION
|
2004-06-21 18:45:27 +02:00
|
|
|
|
if (u->race == new_race[RC_ORC] && !fval(u->region, RF_ORCIFIED)) {
|
|
|
|
|
attrib *a = a_find(u->region->attribs, &at_orcification);
|
|
|
|
|
if (!a) a = a_add(&u->region->attribs, a_new(&at_orcification));
|
|
|
|
|
a->data.i += n;
|
|
|
|
|
}
|
2003-11-10 00:36:11 +01:00
|
|
|
|
#endif
|
2004-06-21 18:45:27 +02:00
|
|
|
|
transfermen(u, NULL, n);
|
|
|
|
|
} else {
|
|
|
|
|
error = 159;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2007-02-10 21:52:39 +01:00
|
|
|
|
if (error>0) {
|
2004-07-03 10:55:41 +02:00
|
|
|
|
cmistake(u, ord, error, MSG_COMMERCE);
|
|
|
|
|
}
|
|
|
|
|
else if (!u2 || u2->faction!=u->faction) {
|
|
|
|
|
ADDMSG(&u->faction->msgs, msg_message("give_person", "unit target amount",
|
|
|
|
|
u, u2?ucansee(u->faction, u2, u_unknown()):u_peasants(), n));
|
|
|
|
|
if (u2) {
|
|
|
|
|
ADDMSG(&u2->faction->msgs, msg_message("give_person", "unit target amount",
|
|
|
|
|
ucansee(u2->faction, u, u_unknown()), u2, n));
|
|
|
|
|
}
|
|
|
|
|
}
|
2004-06-21 18:45:27 +02:00
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
void
|
2004-09-11 19:50:27 +02:00
|
|
|
|
give_unit(unit * u, unit * u2, order * ord)
|
2004-06-21 18:45:27 +02:00
|
|
|
|
{
|
|
|
|
|
region * r = u->region;
|
|
|
|
|
int n = u->number;
|
|
|
|
|
|
|
|
|
|
if (u && unit_has_cursed_item(u)) {
|
|
|
|
|
cmistake(u, ord, 78, MSG_COMMERCE);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
2004-08-03 17:34:26 +02:00
|
|
|
|
#ifdef HEROES
|
|
|
|
|
if (fval(u, UFL_HERO)) {
|
|
|
|
|
cmistake(u, ord, 75, MSG_COMMERCE);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
#endif
|
2004-06-21 18:45:27 +02:00
|
|
|
|
if (fval(u, UFL_LOCKED) || fval(u, UFL_HUNGER)) {
|
|
|
|
|
cmistake(u, ord, 74, MSG_COMMERCE);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
if (u2 == NULL) {
|
2005-10-25 14:38:01 +02:00
|
|
|
|
if (fval(r->terrain, SEA_REGION)) {
|
2004-06-21 18:45:27 +02:00
|
|
|
|
cmistake(u, ord, 152, MSG_COMMERCE);
|
|
|
|
|
} else if (getunitpeasants) {
|
|
|
|
|
unit *u3;
|
|
|
|
|
|
|
|
|
|
for(u3 = r->units; u3; u3 = u3->next)
|
|
|
|
|
if(u3->faction == u->faction && u != u3) break;
|
|
|
|
|
|
|
|
|
|
if(u3) {
|
|
|
|
|
while (u->items) {
|
|
|
|
|
item * iold = i_remove(&u->items, u->items);
|
|
|
|
|
item * inew = *i_find(&u3->items, iold->type);
|
|
|
|
|
if (inew==NULL) i_add(&u3->items, iold);
|
|
|
|
|
else {
|
|
|
|
|
inew->number += iold->number;
|
|
|
|
|
i_free(iold);
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
}
|
2004-09-11 19:50:27 +02:00
|
|
|
|
give_men(u->number, u, NULL, ord);
|
2004-06-21 18:45:27 +02:00
|
|
|
|
cmistake(u, ord, 153, MSG_COMMERCE);
|
|
|
|
|
} else {
|
2007-02-10 22:47:51 +01:00
|
|
|
|
ADDMSG(&u->faction->msgs, msg_feedback(u, ord, "feedback_unit_not_found", ""));
|
2004-06-21 18:45:27 +02:00
|
|
|
|
}
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
|
2005-02-05 19:11:23 +01:00
|
|
|
|
if (!alliedunit(u2, u->faction, HELP_GIVE) && ucontact(u2, u) == 0) {
|
2007-02-10 21:52:39 +01:00
|
|
|
|
ADDMSG(&u->faction->msgs, msg_feedback(u, ord, "feedback_no_contact", "target", u2));
|
2004-06-21 18:45:27 +02:00
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
if (u->number == 0) {
|
|
|
|
|
cmistake(u, ord, 105, MSG_COMMERCE);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
if (u2->faction->newbies + n > MAXNEWBIES) {
|
|
|
|
|
cmistake(u, ord, 129, MSG_COMMERCE);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
if (u->race != u2->faction->race) {
|
|
|
|
|
if (u2->faction->race != new_race[RC_HUMAN]) {
|
|
|
|
|
cmistake(u, ord, 120, MSG_COMMERCE);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
if (count_migrants(u2->faction) + u->number > count_maxmigrants(u2->faction)) {
|
|
|
|
|
cmistake(u, ord, 128, MSG_COMMERCE);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
if (teure_talente(u)) {
|
|
|
|
|
cmistake(u, ord, 154, MSG_COMMERCE);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if (has_skill(u, SK_MAGIC)) {
|
|
|
|
|
if (count_skill(u2->faction, SK_MAGIC) + u->number >
|
|
|
|
|
max_skill(u2->faction, SK_MAGIC))
|
|
|
|
|
{
|
|
|
|
|
cmistake(u, ord, 155, MSG_COMMERCE);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
if (u2->faction->magiegebiet != find_magetype(u)) {
|
|
|
|
|
cmistake(u, ord, 157, MSG_COMMERCE);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
if (has_skill(u, SK_ALCHEMY)
|
|
|
|
|
&& count_skill(u2->faction, SK_ALCHEMY) + u->number >
|
|
|
|
|
max_skill(u2->faction, SK_ALCHEMY))
|
|
|
|
|
{
|
|
|
|
|
cmistake(u, ord, 156, MSG_COMMERCE);
|
|
|
|
|
return;
|
|
|
|
|
}
|
|
|
|
|
add_give(u, u2, 1, r_unit, ord, 0);
|
|
|
|
|
u_setfaction(u, u2->faction);
|
|
|
|
|
u2->faction->newbies += n;
|
2003-11-10 00:36:11 +01:00
|
|
|
|
}
|