summaryrefslogtreecommitdiff
path: root/server/src/luaformatmapper.cc
diff options
context:
space:
mode:
Diffstat (limited to 'server/src/luaformatmapper.cc')
-rw-r--r--server/src/luaformatmapper.cc119
1 files changed, 119 insertions, 0 deletions
diff --git a/server/src/luaformatmapper.cc b/server/src/luaformatmapper.cc
new file mode 100644
index 0000000..b45c170
--- /dev/null
+++ b/server/src/luaformatmapper.cc
@@ -0,0 +1,119 @@
+/* -*- Mode: C++; tab-width: 2; indent-tabs-mode: nil; c-basic-offset: 2 -*- */
+/***************************************************************************
+ * luaformatmapper.cc
+ *
+ * Wed Oct 29 16:02:03 CET 2008
+ * Copyright 2008 Bent Bisballe Nyeng
+ * deva@aasimon.org
+ ****************************************************************************/
+
+/*
+ * This file is part of Pracro.
+ *
+ * Pracro is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or
+ * (at your option) any later version.
+ *
+ * Pracro is distributed in the hope that it will be useful,
+ * but WITHOUT ANY WARRANTY; without even the implied warranty of
+ * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
+ * GNU General Public License for more details.
+ *
+ * You should have received a copy of the GNU General Public License
+ * along with Pracro; if not, write to the Free Software
+ * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA.
+ */
+#include "luaformatmapper.h"
+
+#include <sstream>
+
+#include "exception.h"
+
+static std::string loadresultstring(Fields &fields)
+{
+ std::string s;
+
+ Fields::iterator v = fields.begin();
+ while(v != fields.end()) {
+ s += (*v).first + " = \"" + (*v).second + "\"\n";
+ v++;
+ }
+
+ return s;
+}
+
+LUAFormatMapper::LUAFormatMapper(Fields &fields)
+{
+ L = luaL_newstate();
+ if(L == NULL) {
+ error("Could not create LUA state.");
+ return;
+ }
+
+ luaL_openlibs(L);
+
+ std::string preload = loadresultstring(fields);
+
+ if(luaL_loadbuffer(L, preload.c_str(), preload.size(), "preload")) {
+ error(lua_tostring(L, lua_gettop(L)));
+ return;
+ }
+
+ // Run program (init)
+ if(lua_pcall(L, 0, LUA_MULTRET, 0)) {
+ error(lua_tostring(L, lua_gettop(L)));
+ return;
+ }
+
+ clean_top = lua_gettop(L);
+}
+
+LUAFormatMapper::~LUAFormatMapper()
+{
+ lua_close(L);
+}
+
+std::string LUAFormatMapper::map(const std::string &mapper)
+{
+ output = "";
+
+ if(L == NULL) {
+ error("LUA state not initialized!");
+ return output;
+ }
+
+ if(mapper == "") {
+ error("Empty LUA mapper detected in " + mapper);
+ return output;
+ }
+
+ // Load the mapper
+ if(luaL_loadbuffer(L, mapper.c_str(), mapper.size(), "mapper")) {
+ error(lua_tostring(L, lua_gettop(L)) + std::string(" in ") + mapper);
+ return output;
+ }
+
+ // Run the loaded code
+ if(lua_pcall(L, 0, LUA_MULTRET, 0)) {
+ error(lua_tostring(L, lua_gettop(L)) + std::string(" in ") + mapper);
+ return output;
+ }
+
+ // Check if app messed up the stack.
+ if(lua_gettop(L) != clean_top + 1) {
+ error("Wrong number of return values in " + mapper);
+ lua_pop(L, lua_gettop(L) - clean_top);
+ return output;
+ }
+
+ output = lua_tostring(L, lua_gettop(L));
+ lua_pop(L, 1);
+
+ return output;
+}
+
+void LUAFormatMapper::error(std::string message)
+{
+ throw Exception("ERROR in LUAFormatMapper: " + message);
+}