#ifndef PYTHON_PLUGIN_HH
#define PYTHON_PLUGIN_HH
#ifndef BOOST_PYTHON_MAX_ARITY
#define BOOST_PYTHON_MAX_ARITY 4
#endif
#include <boost/python/object.hpp>
#include <vector>
#include <string>
#include <sys/types.h>
extern std::string handle_pyerror();
enum pp_status {
PLUGIN_NO_SECTION = -1,
PLUGIN_NO_INIFILE = -2,
PLUGIN_BAD_INIFILE = -3,
PLUGIN_NO_TOPLEVEL = -4,
PLUGIN_BAD_PATH = -5,
PLUGIN_STAT_FAILED = -6,
PLUGIN_INITTAB_FAILED = -7 ,
PLUGIN_PYTHON_ALREADY_INITIALIZED = -8,
PLUGIN_EXCEPTION_DURING_PATH_PREPEND = -9,
PLUGIN_EXCEPTION_DURING_PATH_APPEND = -10,
PLUGIN_INIT_EXCEPTION = -11,
PLUGIN_PYTHON_NOT_INITIALIZED = -12,
PLUGIN_PATH_TOO_LONG = -13,
PLUGIN_OK = 0,
PLUGIN_NO_CALLABLE = 1,
PLUGIN_EXCEPTION = 2
};
class PythonPlugin {
public:
static PythonPlugin *instantiate(struct _inittab *inittab = NULL);
int configure(const char *iniFilename = NULL, const char *section = NULL);
bool is_callable(const char *module, const char *funcname);
int call(const char *module,const char *callable,
boost::python::object tupleargs, boost::python::object kwargs, boost::python::object &retval);
int run_string(const char *cmd, boost::python::object &retval, bool as_file = false);
int call_method(boost::python::object method, boost::python::object &retval);
int plugin_status() { return status; };
bool usable() { return (status >= PLUGIN_OK); }
int initialize();
std::string last_exception() { return exception_msg; };
std::string last_errmsg() { return error_msg; };
boost::python::object main_namespace;
private:
PythonPlugin(struct _inittab *inittab); PythonPlugin(const PythonPlugin &) {}; PythonPlugin & operator=(const PythonPlugin&) { return *this; }; ~PythonPlugin() {};
int reload();
std::vector<std::string> inittab_entries;
int status;
time_t module_mtime; bool reload_on_change; const char *toplevel; const char *abs_path; std::string exception_msg;
std::string error_msg;
int log_level;
};
#endif