forked from github/server
f8398db851
- eliminating a couple of warnings - fixed a crash bug or two in the -x option - fixed an endless loop in give_item
194 lines
4.2 KiB
C++
194 lines
4.2 KiB
C++
#include <config.h>
|
|
#include <eressea.h>
|
|
#include "message.h"
|
|
|
|
// kernel includes
|
|
#include <kernel/faction.h>
|
|
#include <kernel/item.h>
|
|
#include <kernel/region.h>
|
|
#include <kernel/unit.h>
|
|
|
|
// util includes
|
|
#include <util/message.h>
|
|
|
|
// lua includes
|
|
#pragma warning (push)
|
|
#pragma warning (disable: 4127)
|
|
#include <lua.hpp>
|
|
#include <luabind/luabind.hpp>
|
|
#include <luabind/iterator_policy.hpp>
|
|
#if LUABIND_BETA >= 7
|
|
# include <luabind/operator.hpp>
|
|
#endif
|
|
#pragma warning (pop)
|
|
|
|
#include <ostream>
|
|
|
|
using namespace luabind;
|
|
|
|
#define E_OK 0
|
|
#define E_INVALID_MESSAGE 1
|
|
#define E_INVALID_PARAMETER_NAME 2
|
|
#define E_INVALID_PARAMETER_TYPE 3
|
|
#define E_INVALID_PARAMETER_VALUE 4
|
|
|
|
class lua_message {
|
|
public:
|
|
lua_message(const char *type) : msg(0), args(0) {
|
|
mtype = mt_find(type);
|
|
if (mtype) {
|
|
args = (variant*)calloc(mtype->nparameters, sizeof(variant));
|
|
}
|
|
}
|
|
|
|
~lua_message() {
|
|
if (msg) msg_release(msg);
|
|
if (mtype) {
|
|
for (int i=0;i!=mtype->nparameters;++i) {
|
|
if (mtype->types[i]->release) {
|
|
mtype->types[i]->release(args[i]);
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
int set_resource(const char * param, const char * resname) {
|
|
if (mtype==0) return E_INVALID_MESSAGE;
|
|
|
|
int i = get_param(param);
|
|
if (i==mtype->nparameters) {
|
|
return E_INVALID_PARAMETER_NAME;
|
|
}
|
|
if (strcmp(mtype->types[i]->name, "resource")!=0) {
|
|
return E_INVALID_PARAMETER_TYPE;
|
|
}
|
|
|
|
args[i].v = (void*)rt_find(resname);
|
|
|
|
return E_OK;
|
|
}
|
|
|
|
int set_unit(const char * param, const unit& u) {
|
|
if (mtype==0) return E_INVALID_MESSAGE;
|
|
|
|
int i = get_param(param);
|
|
if (i==mtype->nparameters) {
|
|
return E_INVALID_PARAMETER_NAME;
|
|
}
|
|
if (strcmp(mtype->types[i]->name, "unit")!=0) {
|
|
return E_INVALID_PARAMETER_TYPE;
|
|
}
|
|
|
|
args[i].v = (void*)&u;
|
|
|
|
return E_OK;
|
|
}
|
|
|
|
int set_region(const char * param, const region& r) {
|
|
if (mtype==0) return E_INVALID_MESSAGE;
|
|
|
|
int i = get_param(param);
|
|
if (i==mtype->nparameters) {
|
|
return E_INVALID_PARAMETER_NAME;
|
|
}
|
|
if (strcmp(mtype->types[i]->name, "region")!=0) {
|
|
return E_INVALID_PARAMETER_TYPE;
|
|
}
|
|
|
|
args[i].v = (void*)&r;
|
|
|
|
return E_OK;
|
|
}
|
|
|
|
int set_string(const char * param, const char * value) {
|
|
if (mtype==0) return E_INVALID_MESSAGE;
|
|
|
|
int i = get_param(param);
|
|
if (i==mtype->nparameters) {
|
|
return E_INVALID_PARAMETER_NAME;
|
|
}
|
|
if (strcmp(mtype->types[i]->name, "string")!=0) {
|
|
return E_INVALID_PARAMETER_TYPE;
|
|
}
|
|
|
|
variant var;
|
|
var.v = (void*)value;
|
|
args[i] = mtype->types[i]->copy(var);
|
|
|
|
return E_OK;
|
|
}
|
|
|
|
int set_int(const char * param, int value) {
|
|
if (mtype==0) return E_INVALID_MESSAGE;
|
|
|
|
int i = get_param(param);
|
|
if (i==mtype->nparameters) {
|
|
return E_INVALID_PARAMETER_NAME;
|
|
}
|
|
if (strcmp(mtype->types[i]->name, "int")!=0) {
|
|
return E_INVALID_PARAMETER_TYPE;
|
|
}
|
|
|
|
args[i].i = value;
|
|
|
|
return E_OK;
|
|
}
|
|
|
|
int send_faction(faction& f) {
|
|
if (mtype==0) return E_INVALID_MESSAGE;
|
|
if (msg==NULL) {
|
|
msg = msg_create(mtype, args);
|
|
}
|
|
add_message(&f.msgs, msg);
|
|
return E_OK;
|
|
}
|
|
|
|
int send_region(region& r) {
|
|
if (mtype==0) return E_INVALID_MESSAGE;
|
|
if (msg==NULL) {
|
|
msg = msg_create(mtype, args);
|
|
}
|
|
add_message(&r.msgs, msg);
|
|
return E_OK;
|
|
}
|
|
|
|
protected:
|
|
int get_param(const char * param) {
|
|
for (int i=0;i!=mtype->nparameters;++i) {
|
|
if (strcmp(mtype->pnames[i], param)==0) {
|
|
return i;
|
|
}
|
|
}
|
|
return mtype->nparameters;
|
|
}
|
|
|
|
const message_type * mtype;
|
|
message * msg;
|
|
variant * args;
|
|
};
|
|
|
|
static std::ostream&
|
|
operator<<(std::ostream& stream, const lua_message& msg)
|
|
{
|
|
stream << "(message object)";
|
|
return stream;
|
|
}
|
|
|
|
|
|
void
|
|
bind_message(lua_State * L)
|
|
{
|
|
module(L)[
|
|
class_<lua_message>("message")
|
|
.def(constructor<const char *>())
|
|
.def(tostring(self))
|
|
|
|
.def("set_unit", &lua_message::set_unit)
|
|
.def("set_region", &lua_message::set_region)
|
|
.def("set_resource", &lua_message::set_resource)
|
|
.def("set_int", &lua_message::set_int)
|
|
.def("set_string", &lua_message::set_string)
|
|
.def("send_faction", &lua_message::send_faction)
|
|
.def("send_region", &lua_message::send_region)
|
|
];
|
|
}
|