"fehlende Info bei OPTION TALENTVERSCHIEBUNG mit Dämonen"
Anzeige von Daemonentalenten mit OPTION TV, auch wenn sie auf 0 gefallen sind.
This commit is contained in:
Enno Rehling 2006-08-01 22:35:26 +00:00
parent 3b4a6dc262
commit b89721873c
4 changed files with 1358 additions and 1352 deletions

View file

@ -79,6 +79,7 @@ struct party;
struct unit; struct unit;
struct unit_list; struct unit_list;
struct item; struct item;
struct skill;
/* item */ /* item */
struct strlist; struct strlist;
struct resource_type; struct resource_type;

View file

@ -198,7 +198,6 @@ int
bufunit(const faction * f, const unit * u, int indent, int mode) bufunit(const faction * f, const unit * u, int indent, int mode)
{ {
int i, dh; int i, dh;
skill_t sk;
int getarnt = fval(u, UFL_PARTEITARNUNG); int getarnt = fval(u, UFL_PARTEITARNUNG);
const char *pzTmp; const char *pzTmp;
building * b; building * b;
@ -426,8 +425,9 @@ bufunit(const faction * f, const unit * u, int indent, int mode)
dh = 0; dh = 0;
if (u->faction == f || telepath_see) { if (u->faction == f || telepath_see) {
for (sk = 0; sk != MAXSKILLS; sk++) { skill * sv;
rsize = spskill(bufp, size, f->locale, u, sk, &dh, 1); for (sv = u->skills;sv!=u->skills+u->skill_size;++sv) {
rsize = spskill(bufp, size, f->locale, u, sv, &dh, 1);
if (rsize>size) rsize = size-1; if (rsize>size) rsize = size-1;
size -= rsize; size -= rsize;
bufp += rsize; bufp += rsize;
@ -640,7 +640,7 @@ bufunit(const faction * f, const unit * u, int indent, int mode)
*/ */
size_t size_t
spskill(char * buffer, size_t size, const struct locale * lang, const struct unit * u, skill_t sk, int *dh, int days) spskill(char * buffer, size_t size, const struct locale * lang, const struct unit * u, struct skill * sv, int *dh, int days)
{ {
char * bufp = buffer; char * bufp = buffer;
int i, effsk; int i, effsk;
@ -648,9 +648,12 @@ spskill(char * buffer, size_t size, const struct locale * lang, const struct uni
size_t tsize = 0; size_t tsize = 0;
if (!u->number) return 0; if (!u->number) return 0;
if (sv->level<=0) {
if (sv->old<=0 || (u->faction->options & want(O_SHOWSKCHANGE))==0) {
return 0;
}
}
if (!has_skill(u, sk)) return 0;
rsize = strlcpy(bufp, ", ", size); rsize = strlcpy(bufp, ", ", size);
tsize += rsize; tsize += rsize;
if (rsize>size) rsize = size-1; if (rsize>size) rsize = size-1;
@ -672,7 +675,7 @@ spskill(char * buffer, size_t size, const struct locale * lang, const struct uni
*dh = 1; *dh = 1;
} }
rsize = strlcpy(bufp, skillname(sk, lang), size); rsize = strlcpy(bufp, skillname(sv->id, lang), size);
tsize += rsize; tsize += rsize;
if (rsize>size) rsize = size-1; if (rsize>size) rsize = size-1;
size -= rsize; size -= rsize;
@ -684,7 +687,7 @@ spskill(char * buffer, size_t size, const struct locale * lang, const struct uni
size -= rsize; size -= rsize;
bufp += rsize; bufp += rsize;
if (sk == SK_MAGIC){ if (sv->id == SK_MAGIC){
if (find_magetype(u) != M_GRAU){ if (find_magetype(u) != M_GRAU){
rsize = strlcpy(bufp, LOC(lang, mkname("school", magietypen[find_magetype(u)])), size); rsize = strlcpy(bufp, LOC(lang, mkname("school", magietypen[find_magetype(u)])), size);
tsize += rsize; tsize += rsize;
@ -700,7 +703,7 @@ spskill(char * buffer, size_t size, const struct locale * lang, const struct uni
} }
} }
if (sk == SK_STEALTH && fval(u, UFL_STEALTH)) { if (sv->id == SK_STEALTH && fval(u, UFL_STEALTH)) {
i = u_geteffstealth(u); i = u_geteffstealth(u);
if (i>=0) { if (i>=0) {
rsize = slprintf(bufp, size, "%d/", i); rsize = slprintf(bufp, size, "%d/", i);
@ -711,7 +714,7 @@ spskill(char * buffer, size_t size, const struct locale * lang, const struct uni
} }
} }
effsk = effskill(u, sk); effsk = effskill(u, sv->id);
rsize = slprintf(bufp, size, "%d", effsk); rsize = slprintf(bufp, size, "%d", effsk);
tsize += rsize; tsize += rsize;
if (rsize>size) rsize = size-1; if (rsize>size) rsize = size-1;
@ -719,12 +722,11 @@ spskill(char * buffer, size_t size, const struct locale * lang, const struct uni
bufp += rsize; bufp += rsize;
if (u->faction->options & want(O_SHOWSKCHANGE)) { if (u->faction->options & want(O_SHOWSKCHANGE)) {
skill *skill = get_skill(u, sk);
int oldeff = 0; int oldeff = 0;
int diff; int diff;
if (skill->old > 0) { if (sv->old > 0) {
oldeff = skill->old + get_modifier(u, sk, skill->old, u->region, false); oldeff = sv->old + get_modifier(u, sv->id, sv->old, u->region, false);
} }
oldeff = max(0, oldeff); oldeff = max(0, oldeff);
@ -838,25 +840,24 @@ spy_message(int spy, unit *u, unit *target)
} }
} }
if (spy > 0){ if (spy > 0){
scat("Talente: "); int first = 1;
{ int found = 0;
int first = 1; skill * sv;
int found = 0;
skill_t sk; scat("Talente: ");
for (sv = u->skills;sv!=u->skills+u->skill_size;++sv) {
if (sv->level>0) {
found++;
if (first == 1) {
first = 0;
} else {
scat(", ");
}
scat(skillname(sv->id, u->faction->locale));
scat(" ");
icat(eff_skill(target, sv->id, target->region));
}
for (sk = 0; sk != MAXSKILLS; sk++) {
if (has_skill(target, sk)) {
found++;
if (first == 1) {
first = 0;
} else {
scat(", ");
}
scat(skillname(sk, u->faction->locale));
scat(" ");
icat(eff_skill(target, sk, target->region));
}
}
if (found == 0) { if (found == 0) {
scat("Keine"); scat("Keine");
} }

View file

@ -41,7 +41,7 @@ extern struct unit * can_find(struct faction *, struct faction *);
void sparagraph(struct strlist ** SP, const char *s, int indent, char mark); void sparagraph(struct strlist ** SP, const char *s, int indent, char mark);
void lparagraph(struct strlist ** SP, char *s, int indent, char mark); void lparagraph(struct strlist ** SP, char *s, int indent, char mark);
const char *hp_status(const struct unit * u); const char *hp_status(const struct unit * u);
extern size_t spskill(char * pbuf, size_t siz, const struct locale * lang, const struct unit * u, skill_t sk, int *dh, int days); /* mapper */ extern size_t spskill(char * pbuf, size_t siz, const struct locale * lang, const struct unit * u, struct skill * sv, int *dh, int days); /* mapper */
extern void spunit(struct strlist ** SP, const struct faction * f, const struct unit * u, int indent, int mode); extern void spunit(struct strlist ** SP, const struct faction * f, const struct unit * u, int indent, int mode);
extern int reports(void); extern int reports(void);

File diff suppressed because it is too large Load diff