forked from github/server
it's beginning to look a lot like christmas
Conflicts: scripts/eressea/xmas.lua
This commit is contained in:
parent
80e0707cb2
commit
cf90f8cf93
3 changed files with 71 additions and 22 deletions
|
@ -1,5 +1,20 @@
|
|||
<?xml version="1.0" encoding="utf-8" ?>
|
||||
<messages>
|
||||
|
||||
<message name="santa_f" section="events">
|
||||
<type>
|
||||
<arg name="item" type="resource"/>
|
||||
</type>
|
||||
<text locale="de">'Ho ho ho!' Ein dicker Gnom fliegt auf einem von
|
||||
8 Jungdrachen gezogenen Schlitten durch die Nacht und vermacht Deiner
|
||||
Partei eine $resource($item,1). (Um diesen Gegenstand einer Einheit zu geben, gib
|
||||
ihr den Befehl 'BEANSPRUCHE 1 $resource($item,1)').</text>
|
||||
<text locale="en">'Ho ho ho!' A fat little gnome Gnom on a sled
|
||||
pulled by 8 young dragons flies through the stary night and presents
|
||||
your faction with a $resource($item,1).</text>
|
||||
</message>
|
||||
|
||||
|
||||
<message name="force_leave_ship" section="events">
|
||||
<type>
|
||||
<arg name="unit" type="unit"/>
|
||||
|
|
49
scripts/eressea/xmas.lua
Normal file
49
scripts/eressea/xmas.lua
Normal file
|
@ -0,0 +1,49 @@
|
|||
local gifts = {
|
||||
e2 = {
|
||||
{ year = 2015, turn = 959, item = 'snowglobe', msg='santa_f' },
|
||||
{ year = 2009, turn = 624, item = 'xmastree' },
|
||||
{ year = 2006, turn = 468, key = 'xm06', item = 'snowman' },
|
||||
{ year = 2005, turn = 416, key = 'xm05', item = 'stardust' },
|
||||
{ year = 2004, turn = 364, key = 'xm04', item = 'speedsail' }
|
||||
},
|
||||
e3 = {
|
||||
-- { year = 2015, turn = 338, item = 'snowglobe' },
|
||||
{ year = 2009, turn = 26, key = 'xm09', item = 'xmastree' }
|
||||
}
|
||||
}
|
||||
|
||||
local function give_gifts(gift)
|
||||
eressea.log.info("Es weihnachtet sehr (" .. gift.year .. ")")
|
||||
local msg = nil
|
||||
if gift.msg then
|
||||
msg = message.create(gift.msg)
|
||||
msg:set_resource("item", gift.item)
|
||||
end
|
||||
if gift.item then
|
||||
for f in factions() do
|
||||
f:add_item(gift.item, 1)
|
||||
if msg then
|
||||
msg:send_faction(f)
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
local self = {}
|
||||
|
||||
function self.init()
|
||||
local turn = get_turn()
|
||||
local tbl = gifts[config.rules]
|
||||
if tbl then
|
||||
for _, gift in ipairs(tbl) do
|
||||
if turn == gift.turn then
|
||||
give_gifts(gift)
|
||||
elseif gift.key and not get_key(gift.key) then
|
||||
give_gifts(gift)
|
||||
set_key(gift.key)
|
||||
end
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
return self
|
|
@ -57,22 +57,7 @@ static lua_message *msg_create_message(const char *type)
|
|||
return lmsg;
|
||||
}
|
||||
|
||||
/*
|
||||
static void
|
||||
msg_destroy_message(lua_message * msg)
|
||||
{
|
||||
if (msg->msg) msg_release(msg->msg);
|
||||
if (msg->mtype) {
|
||||
int i;
|
||||
for (i=0;i!=msg->mtype->nparameters;++i) {
|
||||
if (msg->mtype->types[i]->release) {
|
||||
msg->mtype->types[i]->release(msg->args[i]);
|
||||
}
|
||||
}
|
||||
}
|
||||
}
|
||||
*/
|
||||
int msg_set_resource(lua_message * msg, const char *param, const char *resname)
|
||||
static int msg_set_resource(lua_message * msg, const char *param, const char *resname)
|
||||
{
|
||||
if (msg->mtype) {
|
||||
int i = mtype_get_param(msg->mtype, param);
|
||||
|
@ -96,7 +81,7 @@ int msg_set_resource(lua_message * msg, const char *param, const char *resname)
|
|||
return E_INVALID_MESSAGE;
|
||||
}
|
||||
|
||||
int msg_set_unit(lua_message * msg, const char *param, const unit * u)
|
||||
static int msg_set_unit(lua_message * msg, const char *param, const unit * u)
|
||||
{
|
||||
if (msg->mtype) {
|
||||
int i = mtype_get_param(msg->mtype, param);
|
||||
|
@ -115,7 +100,7 @@ int msg_set_unit(lua_message * msg, const char *param, const unit * u)
|
|||
return E_INVALID_MESSAGE;
|
||||
}
|
||||
|
||||
int msg_set_region(lua_message * msg, const char *param, const region * r)
|
||||
static int msg_set_region(lua_message * msg, const char *param, const region * r)
|
||||
{
|
||||
if (msg->mtype) {
|
||||
int i = mtype_get_param(msg->mtype, param);
|
||||
|
@ -134,7 +119,7 @@ int msg_set_region(lua_message * msg, const char *param, const region * r)
|
|||
return E_INVALID_MESSAGE;
|
||||
}
|
||||
|
||||
int msg_set_string(lua_message * msg, const char *param, const char *value)
|
||||
static int msg_set_string(lua_message * msg, const char *param, const char *value)
|
||||
{
|
||||
if (msg->mtype) {
|
||||
int i = mtype_get_param(msg->mtype, param);
|
||||
|
@ -155,7 +140,7 @@ int msg_set_string(lua_message * msg, const char *param, const char *value)
|
|||
return E_INVALID_MESSAGE;
|
||||
}
|
||||
|
||||
int msg_set_int(lua_message * msg, const char *param, int value)
|
||||
static int msg_set_int(lua_message * msg, const char *param, int value)
|
||||
{
|
||||
if (msg->mtype) {
|
||||
int i = mtype_get_param(msg->mtype, param);
|
||||
|
@ -173,7 +158,7 @@ int msg_set_int(lua_message * msg, const char *param, int value)
|
|||
return E_INVALID_MESSAGE;
|
||||
}
|
||||
|
||||
int msg_send_faction(lua_message * msg, faction * f)
|
||||
static int msg_send_faction(lua_message * msg, faction * f)
|
||||
{
|
||||
assert(f);
|
||||
assert(msg);
|
||||
|
@ -188,7 +173,7 @@ int msg_send_faction(lua_message * msg, faction * f)
|
|||
return E_INVALID_MESSAGE;
|
||||
}
|
||||
|
||||
int msg_send_region(lua_message * lmsg, region * r)
|
||||
static int msg_send_region(lua_message * lmsg, region * r)
|
||||
{
|
||||
if (lmsg->mtype) {
|
||||
if (lmsg->msg == NULL) {
|
||||
|
|
Loading…
Reference in a new issue