neue lua-exporte:

- unit:tostring
- unit:operator==

mehrere wdw-parameter aus defines raus, und ins datenfile rein (traumziel ist, den gleichen server für alle spiele zu nehmen)
This commit is contained in:
Enno Rehling 2004-04-11 15:11:19 +00:00
parent 846f110268
commit 5d559840fa
8 changed files with 177 additions and 115 deletions

View file

@ -84,6 +84,28 @@ attrib_type at_reportspell = {
** TODO: separate castle-appearance from illusion-effects
**/
static double
MagicRegeneration(void)
{
static double value = -1.0;
if (value<0) {
const char * str = get_param(global.parameters, "magic.regeneration");
value = str?atof(str):1.0;
}
return value;
}
static double
MagicPower(void)
{
static double value = -1.0;
if (value<0) {
const char * str = get_param(global.parameters, "magic.power");
value = str?atof(str):1.0;
}
return value;
}
static ship *
findshipr(const region *r, int n)
/* Ein Schiff in einer bestimmten Region finden: */
@ -1009,9 +1031,7 @@ spellpower(region * r, unit * u, spell * sp, int cast_level)
cmistake(u, findorder(u, u->thisorder), 185, MSG_MAGIC);
}
#ifdef MAGICPOWER
force = force * MAGICPOWER;
#endif
force = force * MagicPower();
return max(force, 0);
}
@ -1254,84 +1274,86 @@ fumble(region * r, unit * u, spell * sp, int cast_grade)
static void
do_fumble(castorder *co)
{
curse * c;
region * r = co->rt;
unit * u = (unit*)co->magician;
spell * sp = co->sp;
int level = co->level;
int duration;
curse * c;
region * r = co->rt;
unit * u = (unit*)co->magician;
spell * sp = co->sp;
int level = co->level;
int duration;
const char * sp_name = spell_name(sp, u->faction->locale);
switch (rand() % 10) {
/* wenn vorhanden spezieller Patzer, ansonsten nix */
case 0:
sp->patzer(co);
break;
case 1:
/* Kröte */
duration = rand()%level/2;
if (duration<2) duration = 2;
{
/* one or two things will happen: the toad changes her race back,
* and may or may not get toadslime.
* The list of things to happen are attached to a timeout
* trigger and that's added to the triggerlit of the mage gone toad.
*/
trigger * trestore = trigger_changerace(u, u->race, u->irace);
if (rand()%10>2) t_add(&trestore, trigger_giveitem(u, olditemtype[I_TOADSLIME], 1));
add_trigger(&u->attribs, "timer", trigger_timeout(duration, trestore));
}
u->race = new_race[RC_TOAD];
u->irace = new_race[RC_TOAD];
sprintf(buf, "Eine Botschaft von %s: 'Ups! Quack, Quack!'", unitname(u));
addmessage(r, 0, buf, MSG_MAGIC, ML_MISTAKE);
break;
case 2:
/* temporärer Stufenverlust */
duration = max(rand()%level/2, 2);
c = create_curse(u, &u->attribs, ct_find("skil"), level, duration,
-(level/2), 1);
c->data = (void*)SK_MAGIC;
add_message(&u->faction->msgs,
new_message(u->faction, "patzer2%u:unit%r:region", u, r));
break;
case 3:
case 4:
/* Spruch schlägt fehl, alle Magiepunkte weg */
set_spellpoints(u, 0);
add_message(&u->faction->msgs, msg_message("patzer3",
"unit region command",
u, r, spell_name(sp, u->faction->locale)));
break;
ADDMSG(&u->faction->msgs, msg_message("patzer", "unit region spell",
u, r, sp_name));
switch (rand() % 10) {
case 0:
/* wenn vorhanden spezieller Patzer, ansonsten nix */
sp->patzer(co);
break;
case 5:
case 6:
/* Spruch gelingt, aber alle Magiepunkte weg */
((nspell_f)sp->sp_function)(co);
set_spellpoints(u, 0);
sprintf(buf, "Als %s versucht, '%s' zu zaubern erhebt sich "
"plötzlich ein dunkler Wind. Bizarre geisterhafte "
"Gestalten kreisen um den Magier und scheinen sich von "
"den magischen Energien des Zaubers zu ernähren. Mit letzter "
"Kraft gelingt es %s dennoch den Spruch zu zaubern.",
unitname(u), spell_name(sp, u->faction->locale), unitname(u));
addmessage(0, u->faction, buf, MSG_MAGIC, ML_WARN);
break;
case 1:
/* Kröte */
duration = rand()%level/2;
if (duration<2) duration = 2;
{
/* one or two things will happen: the toad changes her race back,
* and may or may not get toadslime.
* The list of things to happen are attached to a timeout
* trigger and that's added to the triggerlit of the mage gone toad.
*/
trigger * trestore = trigger_changerace(u, u->race, u->irace);
if (rand()%10>2) t_add(&trestore, trigger_giveitem(u, olditemtype[I_TOADSLIME], 1));
add_trigger(&u->attribs, "timer", trigger_timeout(duration, trestore));
}
u->race = new_race[RC_TOAD];
u->irace = new_race[RC_TOAD];
sprintf(buf, "Eine Botschaft von %s: 'Ups! Quack, Quack!'", unitname(u));
addmessage(r, 0, buf, MSG_MAGIC, ML_MISTAKE);
break;
case 7:
case 8:
case 9:
default:
/* Spruch gelingt, alle nachfolgenden Sprüche werden 2^4 so teuer */
((nspell_f)sp->sp_function)(co);
sprintf(buf, "%s fühlt sich nach dem Zaubern von %s viel erschöpfter "
"als sonst und hat das Gefühl, dass alle weiteren Zauber deutlich "
"mehr Kraft als normalerweise kosten werden.", unitname(u),
spell_name(sp, u->faction->locale));
addmessage(0, u->faction, buf, MSG_MAGIC, ML_WARN);
countspells(u,3);
}
case 2:
/* temporärer Stufenverlust */
duration = max(rand()%level/2, 2);
c = create_curse(u, &u->attribs, ct_find("skil"), level, duration,
-(level/2), 1);
c->data = (void*)SK_MAGIC;
ADDMSG(&u->faction->msgs, msg_message("patzer2", "unit region", u, r));
break;
case 3:
case 4:
/* Spruch schlägt fehl, alle Magiepunkte weg */
set_spellpoints(u, 0);
ADDMSG(&u->faction->msgs, msg_message("patzer3", "unit region command",
u, r, sp_name));
break;
return;
case 5:
case 6:
/* Spruch gelingt, aber alle Magiepunkte weg */
((nspell_f)sp->sp_function)(co);
set_spellpoints(u, 0);
sprintf(buf, "Als %s versucht, '%s' zu zaubern erhebt sich "
"plötzlich ein dunkler Wind. Bizarre geisterhafte "
"Gestalten kreisen um den Magier und scheinen sich von "
"den magischen Energien des Zaubers zu ernähren. Mit letzter "
"Kraft gelingt es %s dennoch den Spruch zu zaubern.",
unitname(u), sp_name, unitname(u));
addmessage(0, u->faction, buf, MSG_MAGIC, ML_WARN);
break;
case 7:
case 8:
case 9:
default:
/* Spruch gelingt, alle nachfolgenden Sprüche werden 2^4 so teuer */
((nspell_f)sp->sp_function)(co);
sprintf(buf, "%s fühlt sich nach dem Zaubern von %s viel erschöpfter "
"als sonst und hat das Gefühl, dass alle weiteren Zauber deutlich "
"mehr Kraft als normalerweise kosten werden.", unitname(u), sp_name);
addmessage(0, u->faction, buf, MSG_MAGIC, ML_WARN);
countspells(u, 3);
}
return;
}
/* ------------------------------------------------------------- */
@ -1361,9 +1383,7 @@ regeneration(unit * u)
/* Würfeln */
aura = (rand() % d + rand() % d)/2 + 1;
#ifdef MAGICREGEN
aura = (int)(aura * MAGICREGEN);
#endif
aura = (int)(aura * MagicRegeneration());
return aura;
}

View file

@ -25,18 +25,39 @@
#include <assert.h>
#include <string.h>
static double
ResourceFactor(void)
{
static double value = -1.0;
if (value<0) {
const char * str = get_param(global.parameters, "resource.factor");
value = str?atof(str):1.0;
}
return value;
}
void
update_resources(region * r)
{
struct rawmaterial * res = r->resources;
while (res) {
if (res->type->update) res->type->update(res, r);
res = res->next;
}
struct rawmaterial * res = r->resources;
while (res) {
if (res->type->update) res->type->update(res, r);
res = res->next;
}
}
extern int dice_rand(const char *s);
static void
update_resource(struct rawmaterial * res, double modifier)
{
double amount = 1 + (res->level-res->startlevel) * res->divisor/100.0;
amount = ResourceFactor() * res->base * amount * modifier;
if (amount<1.0) res->amount = 1;
else res->amount = (int)amount;
assert(res->amount>0);
}
void
terraform_resources(region * r)
{
@ -53,6 +74,7 @@ terraform_resources(region * r)
if (rand()%100 < tdata->rawmaterials[i].chance) {
struct rawmaterial * res = calloc(sizeof(struct rawmaterial), 1);
res->next = r->resources;
r->resources = res;
res->level = dice_rand(tdata->rawmaterials[i].startlevel);
@ -61,12 +83,7 @@ terraform_resources(region * r)
res->divisor = dice_rand(tdata->rawmaterials[i].divisor);
res->flags = 0;
res->type = tdata->rawmaterials[i].type;
res->amount = (int)(res->base * (1+(res->level-res->startlevel)*(res->divisor/100.0)));
#ifdef RESOURCE_FACTOR
res->amount = (int)(res->amount * RESOURCE_FACTOR);
if (res->amount == 0) res->amount = 1;
#endif
assert(res->amount>0);
update_resource(res, 1.0);
res->type->terraform(res, r);
}
}
@ -120,28 +137,25 @@ visible_default(const rawmaterial *res, int skilllevel)
return -1;
}
static void use_default(rawmaterial *res, const region * r, int amount)
static void
use_default(rawmaterial *res, const region * r, int amount)
{
const terraindata_t * tdata = &terrain[rterrain(r)];
assert(res->amount>0 && amount>=0 && amount <= res->amount);
res->amount-=amount;
while (res->amount==0) {
double modifier = 1.0 + ((rand() % (SHIFT*2+1)) - SHIFT) * ((rand() % (SHIFT*2+1)) - SHIFT) / 10000.0;
int i;
const terraindata_t * tdata = &terrain[rterrain(r)];
assert(res->amount>0 && amount>=0 && amount <= res->amount);
res->amount-=amount;
while (res->amount==0) {
double modifier = 1.0 + ((rand() % (SHIFT*2+1)) - SHIFT) * ((rand() % (SHIFT*2+1)) - SHIFT) / 10000.0;
int i;
for (i=0; i!=3; ++i) {
const rawmaterial_type * rmtype = tdata->rawmaterials[i].type;
assert(rmtype);
if (rmtype==res->type) break;
}
for (i=0; i!=3; ++i) {
const rawmaterial_type * rmtype = tdata->rawmaterials[i].type;
assert(rmtype);
if (rmtype==res->type) break;
}
++res->level;
res->amount = (int)(modifier * res->base * (1+(res->level-res->startlevel)*res->divisor/100.0));
/* random adjustment, +/- 91% */
#ifdef RESOURCE_QUANTITY
res->amount = (int)(res->amount * RESOURCE_QUANTITY);
#endif
}
++res->level;
update_resource(res, modifier);
}
}
struct rawmaterial *

View file

@ -35,10 +35,7 @@
#define PEASANTS_DO_NOT_STARVE 0
#define NEW_MIGRATION 1
#define MIGRANTS_CAN_LEARN_EXPENSIVE_SKILLS 1 /* vinyambar 3 only */
#define MAGICPOWER 0.5
#define MAGICREGEN 0.5
#define ASTRAL_HUNGER
#define RESOURCE_FACTOR 0.25
#if NEWATSROI == 1
#define ATSBONUS 2

View file

@ -88,6 +88,6 @@ bind_eressea(lua_State * L)
def("remove_empty_units", &remove_empty_units),
/* planes not really implemented */
def("find_plane_id", &find_plane_id)
def("get_plane_id", &find_plane_id)
];
}

View file

@ -15,11 +15,14 @@
#include <kernel/magic.h>
#include <kernel/spell.h>
#include <util/base36.h>
// lua includes
#include <lua.hpp>
#include <luabind/luabind.hpp>
#include <luabind/iterator_policy.hpp>
#include <ostream>
using namespace luabind;
class bind_spell_ptr {
@ -217,6 +220,19 @@ unit_setname(unit& u, const char * name)
set_string(&u.name, name);
}
static std::ostream&
operator<<(std::ostream& stream, unit& u)
{
stream << u.name << " (" << itoa36(u.no) << ")";
return stream;
}
static bool
operator==(const unit& a, const unit&b)
{
return a.no==b.no;
}
void
bind_unit(lua_State * L)
{
@ -226,6 +242,8 @@ bind_unit(lua_State * L)
class_<struct unit>("unit")
.property("name", &unit_getname, &unit_setname)
.def(tostring(self))
.def(self == unit())
.def_readonly("faction", &unit::faction)
.def_readonly("id", &unit::no)
.def_readwrite("hp", &unit::hp)

View file

@ -1267,6 +1267,15 @@
</type>
<text locale="de">"$unit($mage) erleidet einen Schock ${reason}."</text>
</message>
<message name="patzer" section="magic">
<type>
<arg name="unit" type="unit"></arg>
<arg name="region" type="region"></arg>
<arg name="spell" type="string"></arg>
</type>
<text locale="de">"$unit($unit) unterläuft in $region($region) beim Zaubern von $command ein Patzer:"</text>
<text locale="en">"$unit($unit) fumbles while casting $command in $region($region):"</text>
</message>
<message name="patzer3" section="magic">
<type>
<arg name="unit" type="unit"></arg>

View file

@ -28,6 +28,9 @@
<param name="allied.skilllimit" value="15"/>
<param name="atsroi.ats" value="2"/>
<param name="atsroi.roi" value="4"/>
<param name="magic.regeneration" value="0.5"/>
<param name="magic.power" value="0.5"/>
<param name="resource.factor" value="0.25"/>
</game>
<xi:include href="vinyambar/wdw-strings.xml"/>

View file

@ -19,9 +19,10 @@ end
function wyrm()
print("- running the wyrm quest")
local grave = get_region(-9995,4)
local plane = find_plane_id("arena")
local plane = get_plane_id("arena")
local map = {}
local mapsize = 0
local r
for r in regions() do
mapsize=mapsize+1
map[mapsize] = r