summaryrefslogtreecommitdiff
path: root/libs/python/src/exec.cpp
diff options
context:
space:
mode:
authorMyoungJune Park <mj2004.park@samsung.com>2016-11-09 18:20:36 -0800
committerGerrit Code Review <gerrit@review.vlan103.tizen.org>2016-11-09 18:20:36 -0800
commit2212a42dc9bc8e6fea9d1dfaf7d2325c3a82b6ab (patch)
tree692e5f3fa6c597e6219766a393411e5a7b82be83 /libs/python/src/exec.cpp
parent19bc0ae04846b66e010064545c66a1b6f1a042ac (diff)
parentdbcd53541404bc733ffbac7424388791190e1043 (diff)
downloadboost-2212a42dc9bc8e6fea9d1dfaf7d2325c3a82b6ab.tar.gz
boost-2212a42dc9bc8e6fea9d1dfaf7d2325c3a82b6ab.tar.bz2
boost-2212a42dc9bc8e6fea9d1dfaf7d2325c3a82b6ab.zip
Merge "Rebase for boost 1.62.0" into tizen
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));
}