//Necessary for cerr
#include <iostream>
+#include <algorithm>
#ifdef WIN32
#include <windows.h>
+#pragma warning(disable : 4996) // for getenv
#else
#include <dlfcn.h>
#endif
: Config_XMLReader(PLUGIN_FILE),
myEventGenerated(theEventGenerated)
{
+ myHaveSalome = false;
+ char* anEnv = getenv("SALOME_ROOT_DIR");
+ std::string value = normalize(anEnv);
+ if (!value.empty()) {
+ myHaveSalome = true;
+ }
+
}
Config_ModuleReader::~Config_ModuleReader()
void Config_ModuleReader::processNode(xmlNodePtr theNode)
{
if (isNode(theNode, NODE_PLUGIN, NULL)) {
+ bool isAvailable = isAvaliableOnThisPlatform(getProperty(theNode, PLUGIN_PLATFORM));
+ if (!isAvailable)
+ return;
std::string aPluginConf = getProperty(theNode, PLUGIN_CONFIG);
std::string aPluginLibrary = getProperty(theNode, PLUGIN_LIBRARY);
std::string aPluginScript = getProperty(theNode, PLUGIN_SCRIPT);
}
if(!aPluginName.empty()) {
myPluginTypes[aPluginName] = aType;
-
}
+
return aPluginName;
}
}
}
+bool Config_ModuleReader::isAvaliableOnThisPlatform(const std::string& thePluginPlatform)
+{
+ bool result = true;
+ PluginPlatform aPlatform = All;
+ std::string aPlatformName = normalize(thePluginPlatform) ;
+ if (aPlatformName == PLUGIN_PLATFORM_SALOME) {
+ aPlatform = Salome;
+ } else if (aPlatformName == PLUGIN_PLATFORM_NEWGEOM) {
+ aPlatform = OpenParts;
+ } else if (!thePluginPlatform.empty()) {
+ Events_Error::send("Unknown platform: " + thePluginPlatform);
+ }
+ if (aPlatform == All) {
+ result = true;
+ } else if (myHaveSalome) {
+ result = aPlatform == Salome;
+ } else {
+ result = aPlatform == OpenParts;
+ }
+ return result;
+
+}
+
void Config_ModuleReader::loadScript(const std::string theFileName)
{
/* aquire python thread */
PyGILState_STATE gstate = PyGILState_Ensure();
- PyObject* module = PyImport_ImportModule(theFileName.c_str());
+ PyObject* module = PyImport_ImportModule(theFileName.c_str());
if (!module) {
std::string anErrorMsg = "An error occured while importing " + theFileName;
//Get detailed error message:
if (PyErr_Occurred()) {
- PyObject *ptype, *pvalue, *ptraceback;
+ PyObject *pstr, *ptype, *pvalue, *ptraceback;
PyErr_Fetch(&ptype, &pvalue, &ptraceback);
- std::string aPyError = std::string(PyString_AsString(pvalue));
+ PyErr_NormalizeException(&ptype, &pvalue, &ptraceback);
+ pstr = PyObject_Str(pvalue);
+ std::string aPyError = std::string(PyString_AsString(pstr));
if (!aPyError.empty()) {
anErrorMsg += ":\n" + aPyError;
}
+ Py_XDECREF(pstr);
Py_XDECREF(ptype);
Py_XDECREF(pvalue);
Py_XDECREF(ptraceback);