diff options
author | MyoungJune Park <mj2004.park@samsung.com> | 2016-11-09 18:20:36 -0800 |
---|---|---|
committer | Gerrit Code Review <gerrit@review.vlan103.tizen.org> | 2016-11-09 18:20:36 -0800 |
commit | 2212a42dc9bc8e6fea9d1dfaf7d2325c3a82b6ab (patch) | |
tree | 692e5f3fa6c597e6219766a393411e5a7b82be83 /libs/python/src/exec.cpp | |
parent | 19bc0ae04846b66e010064545c66a1b6f1a042ac (diff) | |
parent | dbcd53541404bc733ffbac7424388791190e1043 (diff) | |
download | boost-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.cpp | 15 |
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)); } |