-
Notifications
You must be signed in to change notification settings - Fork 4
/
logger_methods.cpp
120 lines (101 loc) · 3.67 KB
/
logger_methods.cpp
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
#include "settings.h"
#include <stdexcept>
#include <boost/bind.hpp>
#include <boost/current_function.hpp>
#include <functional>
#include "xscript/logger.h"
#include "xscript/message_interface.h"
#include "xscript/request.h"
#include "lua_block.h"
#include "stack.h"
#include "exception.h"
#include "method_map.h"
#ifdef HAVE_DMALLOC_H
#include <dmalloc.h>
#endif
namespace xscript {
extern "C" int luaLoggerCrit(lua_State *state) throw ();
extern "C" int luaLoggerError(lua_State *state) throw ();
extern "C" int luaLoggerWarn(lua_State *state) throw ();
extern "C" int luaLoggerInfo(lua_State *state) throw ();
extern "C" int luaLoggerDebug(lua_State *state) throw ();
static const struct luaL_reg loggerlib [] = {
// {"crit", luaLoggerCrit},
{"error", luaLoggerError},
{"warn", luaLoggerWarn},
{"info", luaLoggerInfo},
// {"debug", luaLoggerDebug},
{NULL, NULL}
};
template<typename Func> int
luaLoggerFoo(lua_State *lua, Func func) {
try {
luaCheckStackSize(lua, 1);
log()->debug("%s: fetching argument", BOOST_CURRENT_FUNCTION);
std::string value = luaReadStack<std::string>(lua, 1);
func(log(), "%s", value.c_str());
//func(log(), "%s", value.c_str());
return 0;
}
catch (const LuaError &e) {
return e.translate(lua);
}
catch (const std::exception &e) {
return luaL_error(lua, "caught exception in args: %s", e.what());
}
}
#define METHOD_BODY(METHOD) \
try { \
luaCheckStackSize(lua, 1); \
log()->debug("%s: fetching argument", BOOST_CURRENT_FUNCTION); \
std::string value = luaReadStack<std::string>(lua, 1); \
log()->METHOD("%s", value.c_str()); \
return 0; \
} \
catch (const LuaError &e) { \
return e.translate(lua); \
} \
catch (const std::exception &e) { \
return luaL_error(lua, "caught exception in args: %s", e.what()); \
}
extern "C" int
luaLoggerCrit(lua_State *lua) throw () {
METHOD_BODY(crit);
}
extern "C" int
luaLoggerError(lua_State *lua) throw () {
METHOD_BODY(error);
}
extern "C" int
luaLoggerWarn(lua_State *lua) throw () {
METHOD_BODY(warn);
}
extern "C" int
luaLoggerInfo(lua_State *lua) throw () {
METHOD_BODY(info);
}
extern "C" int
luaLoggerDebug(lua_State *lua) throw () {
METHOD_BODY(debug);
}
class LuaLoggerRegisterHandler : public MessageHandler {
Result process(const MessageParams ¶ms, MessageResultBase &result) {
(void)result;
std::vector<LuaExtension::LuaRegisterFunc>* registerers =
params.getPtr<std::vector<LuaExtension::LuaRegisterFunc> >(0);
if (registerers) {
registerers->push_back(boost::bind(&LuaExtension::registerLib,
_1, "logger", false, (const luaL_Reg*)NULL, loggerlib));
}
return CONTINUE;
}
};
class LuaLoggerHandlerRegisterer {
public:
LuaLoggerHandlerRegisterer() {
MessageProcessor::instance()->registerBack("REGISTER_LUA_EXTENSION",
boost::shared_ptr<MessageHandler>(new LuaLoggerRegisterHandler()));
}
};
static LuaLoggerHandlerRegisterer reg_lua_logger_handlers;
}