forked from github/server
verbesserte konvertierung (für die 'überflüssigen' Tage gibt es einen
Lernversuch) erste bugfixes mit skillpoints 1 (alte variante)
This commit is contained in:
parent
bb8ddf09d3
commit
d58fa96354
3 changed files with 50 additions and 20 deletions
|
@ -124,6 +124,7 @@ report_failure(unit * mage, const char * sa) {
|
||||||
void
|
void
|
||||||
do_shock(unit *u, char *reason)
|
do_shock(unit *u, char *reason)
|
||||||
{
|
{
|
||||||
|
skill_t sk;
|
||||||
if(u->number == 0) return;
|
if(u->number == 0) return;
|
||||||
|
|
||||||
/* HP - Verlust */
|
/* HP - Verlust */
|
||||||
|
@ -133,14 +134,23 @@ do_shock(unit *u, char *reason)
|
||||||
if(is_mage(u)) {
|
if(is_mage(u)) {
|
||||||
set_spellpoints(u, max_spellpoints(u->region,u)/10);
|
set_spellpoints(u, max_spellpoints(u->region,u)/10);
|
||||||
}
|
}
|
||||||
|
|
||||||
/* Evt. Talenttageverlust */
|
/* Evt. Talenttageverlust */
|
||||||
|
#if SKILLPOINTS
|
||||||
if(rand()%10 < 2) {
|
if(rand()%10 < 2) {
|
||||||
skill_t sk;
|
for (sk=0; sk < MAXSKILLS; sk++) {
|
||||||
int n;
|
int n = get_skill(u, sk);
|
||||||
for(sk=0; sk < MAXSKILLS; sk++) {
|
if (n!=0) set_skill(u, sk, (n*9)/10);
|
||||||
if((n = get_skill(u, sk))!=0) set_skill(u, sk, (n*9)/10);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
#else
|
||||||
|
for (sk=0; sk < MAXSKILLS; sk++) {
|
||||||
|
int n = get_skill(u, sk);
|
||||||
|
if (n!=0 && rand()%10 < 2) {
|
||||||
|
change_skill(u, sk, -1);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
#endif
|
||||||
|
|
||||||
/* Dies ist ein Hack, um das skillmod und familiar-Attribut beim Mage
|
/* Dies ist ein Hack, um das skillmod und familiar-Attribut beim Mage
|
||||||
* zu löschen wenn der Familiar getötet wird. Da sollten wir über eine
|
* zu löschen wenn der Familiar getötet wird. Da sollten wir über eine
|
||||||
|
@ -1457,8 +1467,8 @@ sp_create_irongolem(castorder *co)
|
||||||
u2 = create_unit(r, mage->faction, force*8, new_race[RC_IRONGOLEM], 0,
|
u2 = create_unit(r, mage->faction, force*8, new_race[RC_IRONGOLEM], 0,
|
||||||
LOC(mage->faction->locale, rc_name(new_race[RC_IRONGOLEM], 1)), mage);
|
LOC(mage->faction->locale, rc_name(new_race[RC_IRONGOLEM], 1)), mage);
|
||||||
|
|
||||||
set_skill(u2, SK_ARMORER, 30*u2->number);
|
set_skill(u2, SK_ARMORER, skill_level(1)*u2->number);
|
||||||
set_skill(u2, SK_WEAPONSMITH, 30*u2->number);
|
set_skill(u2, SK_WEAPONSMITH, skill_level(1)*u2->number);
|
||||||
|
|
||||||
a = a_new(&at_unitdissolve);
|
a = a_new(&at_unitdissolve);
|
||||||
a->data.ca[0] = 0;
|
a->data.ca[0] = 0;
|
||||||
|
@ -1517,8 +1527,8 @@ sp_create_stonegolem(castorder *co)
|
||||||
|
|
||||||
u2 = create_unit(r, mage->faction, force*5, new_race[RC_STONEGOLEM], 0,
|
u2 = create_unit(r, mage->faction, force*5, new_race[RC_STONEGOLEM], 0,
|
||||||
LOC(mage->faction->locale, rc_name(new_race[RC_STONEGOLEM], 1)), mage);
|
LOC(mage->faction->locale, rc_name(new_race[RC_STONEGOLEM], 1)), mage);
|
||||||
set_skill(u2, SK_ROAD_BUILDING, 30*u2->number);
|
set_skill(u2, SK_ROAD_BUILDING, skill_level(1)*u2->number);
|
||||||
set_skill(u2, SK_BUILDING, 30*u2->number);
|
set_skill(u2, SK_BUILDING, skill_level(1)*u2->number);
|
||||||
|
|
||||||
a = a_new(&at_unitdissolve);
|
a = a_new(&at_unitdissolve);
|
||||||
a->data.ca[0] = 0;
|
a->data.ca[0] = 0;
|
||||||
|
@ -3372,10 +3382,10 @@ sp_summonshadow(castorder *co)
|
||||||
fset(u, FL_PARTEITARNUNG);
|
fset(u, FL_PARTEITARNUNG);
|
||||||
|
|
||||||
/* Bekommen Tarnung = (Magie+Tarnung)/2 und Wahrnehmung 1. */
|
/* Bekommen Tarnung = (Magie+Tarnung)/2 und Wahrnehmung 1. */
|
||||||
val = (get_skill(mage, SK_MAGIC) + get_skill(mage, SK_STEALTH))/2;
|
val = (get_skill(mage, SK_MAGIC) + get_skill(mage, SK_STEALTH))/(2*mage->number);
|
||||||
|
|
||||||
set_skill(u, SK_STEALTH, u->number * val);
|
set_skill(u, SK_STEALTH, u->number * val);
|
||||||
set_skill(u, SK_OBSERVATION, u->number * 30);
|
set_skill(u, SK_OBSERVATION, u->number * skill_level(1));
|
||||||
|
|
||||||
sprintf(buf, "%s beschwört %d Dämonen aus dem Reich der Schatten.",
|
sprintf(buf, "%s beschwört %d Dämonen aus dem Reich der Schatten.",
|
||||||
unitname(mage), force*force);
|
unitname(mage), force*force);
|
||||||
|
@ -3419,9 +3429,12 @@ sp_summonshadowlords(castorder *co)
|
||||||
fset(u, FL_PARTEITARNUNG);
|
fset(u, FL_PARTEITARNUNG);
|
||||||
|
|
||||||
/* Bekommen Tarnung = Magie und Wahrnehmung 5. */
|
/* Bekommen Tarnung = Magie und Wahrnehmung 5. */
|
||||||
set_skill(u, SK_STEALTH, u->number * (get_skill(mage, SK_MAGIC)-1));
|
set_skill(u, SK_STEALTH, (u->number * get_skill(mage, SK_MAGIC)/mage->number));
|
||||||
set_skill(u, SK_OBSERVATION, u->number * 450);
|
#if SKILLPOINTS
|
||||||
|
set_skill(u, SK_OBSERVATION, u->number * level_days(5));
|
||||||
|
#else
|
||||||
|
set_skill(u, SK_OBSERVATION, u->number * 5);
|
||||||
|
#endif
|
||||||
sprintf(buf, "%s beschwört %d Schattenmeister.",
|
sprintf(buf, "%s beschwört %d Schattenmeister.",
|
||||||
unitname(mage), force*force);
|
unitname(mage), force*force);
|
||||||
addmessage(0, mage->faction, buf, MSG_MAGIC, ML_INFO);
|
addmessage(0, mage->faction, buf, MSG_MAGIC, ML_INFO);
|
||||||
|
@ -4706,6 +4719,7 @@ sp_headache(castorder *co)
|
||||||
|
|
||||||
target = pa->param[0]->data.u; /* Zieleinheit */
|
target = pa->param[0]->data.u; /* Zieleinheit */
|
||||||
|
|
||||||
|
/* finde das größte Talent: */
|
||||||
for(i=0;i<MAXSKILLS;i++){
|
for(i=0;i<MAXSKILLS;i++){
|
||||||
int t = get_skill(target, i);
|
int t = get_skill(target, i);
|
||||||
if (sk_val < t){
|
if (sk_val < t){
|
||||||
|
@ -4715,8 +4729,13 @@ sp_headache(castorder *co)
|
||||||
}
|
}
|
||||||
/* wirkt auf maximal 10 Personen */
|
/* wirkt auf maximal 10 Personen */
|
||||||
days = min(10,target->number) * lovar(60);
|
days = min(10,target->number) * lovar(60);
|
||||||
|
#if SKILLPOINTS
|
||||||
change_skill(target, sk, -days);
|
change_skill(target, sk, -days);
|
||||||
|
#else
|
||||||
|
if (learn_skill(target, sk, days)) {
|
||||||
|
change_skill(target, sk, -1);
|
||||||
|
}
|
||||||
|
#endif
|
||||||
set_string(&target->thisorder, "");
|
set_string(&target->thisorder, "");
|
||||||
|
|
||||||
sprintf(buf, "%s verschafft %s einige feuchtfröhliche Stunden mit heftigen "
|
sprintf(buf, "%s verschafft %s einige feuchtfröhliche Stunden mit heftigen "
|
||||||
|
|
|
@ -24,5 +24,7 @@
|
||||||
#define REDUCED_PEASANTGROWTH 1
|
#define REDUCED_PEASANTGROWTH 1
|
||||||
#define RACE_ADJUSTMENTS 1
|
#define RACE_ADJUSTMENTS 1
|
||||||
|
|
||||||
/* Einmalig! */
|
#define SKILLPOINTS 1
|
||||||
|
#define TEACHDIFFERENCE 1
|
||||||
|
|
||||||
#define PEASANT_ADJUSTMENT 1
|
#define PEASANT_ADJUSTMENT 1
|
||||||
|
|
|
@ -55,6 +55,7 @@
|
||||||
#include <spell.h>
|
#include <spell.h>
|
||||||
#include <alchemy.h>
|
#include <alchemy.h>
|
||||||
#include <study.h>
|
#include <study.h>
|
||||||
|
#include <unit.h>
|
||||||
|
|
||||||
/* util includes */
|
/* util includes */
|
||||||
#include <attrib.h>
|
#include <attrib.h>
|
||||||
|
@ -2644,8 +2645,15 @@ convert_skills(void)
|
||||||
if (val) {
|
if (val) {
|
||||||
int lvl = level(val/u->number);
|
int lvl = level(val/u->number);
|
||||||
int days = val-level_days(lvl)*u->number;
|
int days = val-level_days(lvl)*u->number;
|
||||||
int skip = level_days(lvl+1)-level_days(lvl);
|
set_skill(u, sk, lvl * u->number);
|
||||||
set_skill(u, sk, lvl * u->number + days/skip);
|
/* hat die Einheit mehr Lerntage als notwendig für den Skill,
|
||||||
|
* bekommt sie einen Bonus Lernversuch (die chance ist umso
|
||||||
|
* besser, je mehr tage sie hat) */
|
||||||
|
if (days) {
|
||||||
|
if (learn_skill(u, sk, days)){
|
||||||
|
change_skill(u,sk, u->number);
|
||||||
|
}
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -2704,9 +2712,6 @@ korrektur(void)
|
||||||
do_once("idlo", fix_idleout());
|
do_once("idlo", fix_idleout());
|
||||||
do_once("szip", set_zip());
|
do_once("szip", set_zip());
|
||||||
do_once("heal", heal_all());
|
do_once("heal", heal_all());
|
||||||
#if PEASANT_ADJUSTMENT == 1
|
|
||||||
do_once("peas", peasant_adjustment());
|
|
||||||
#endif
|
|
||||||
|
|
||||||
/* trade_orders(); */
|
/* trade_orders(); */
|
||||||
if (global.data_version < NEWROAD_VERSION) {
|
if (global.data_version < NEWROAD_VERSION) {
|
||||||
|
@ -2741,6 +2746,10 @@ korrektur_end(void)
|
||||||
#ifdef XMAS2001
|
#ifdef XMAS2001
|
||||||
do_once("2001", xmas2001());
|
do_once("2001", xmas2001());
|
||||||
#endif
|
#endif
|
||||||
|
#if PEASANT_ADJUSTMENT == 1
|
||||||
|
do_once("peas", peasant_adjustment());
|
||||||
|
#endif
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
|
Loading…
Reference in a new issue