summaryrefslogtreecommitdiff
path: root/libs/python/src/exec.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'libs/python/src/exec.cpp')
-rw-r--r--libs/python/src/exec.cpp15
1 files changed, 7 insertions, 8 deletions
diff --git a/libs/python/src/exec.cpp b/libs/python/src/exec.cpp
index 2910db7c85..fa2860e40e 100644
--- a/libs/python/src/exec.cpp
+++ b/libs/python/src/exec.cpp
@@ -84,24 +84,23 @@ object BOOST_PYTHON_DECL exec_file(str filename, object global, object local)
if (local.is_none()) local = global;
// should be 'char const *' but older python versions don't use 'const' yet.
char *f = python::extract<char *>(filename);
-
// Let python open the file to avoid potential binary incompatibilities.
-#if PY_VERSION_HEX >= 0x03000000
- // See http://www.codeproject.com/Articles/820116/Embedding-Python-program-in-a-C-Cplusplus-code
+#if PY_VERSION_HEX >= 0x03040000
FILE *fs = _Py_fopen(f, "r");
+#elif PY_VERSION_HEX >= 0x03000000
+ PyObject *fo = Py_BuildValue("s", f);
+ FILE *fs = _Py_fopen(fo, "r");
+ Py_DECREF(fo);
#else
PyObject *pyfile = PyFile_FromString(f, const_cast<char*>("r"));
if (!pyfile) throw std::invalid_argument(std::string(f) + " : no such file");
python::handle<> file(pyfile);
FILE *fs = PyFile_AsFile(file.get());
#endif
-
- int closeit = 1; // Close file before PyRun returns
- PyObject* result = PyRun_FileEx(fs,
+ PyObject* result = PyRun_File(fs,
f,
Py_file_input,
- global.ptr(), local.ptr(),
- closeit);
+ global.ptr(), local.ptr());
if (!result) throw_error_already_set();
return object(detail::new_reference(result));
}