From 3cc7978f19f55a4f3ff7209d67bbb1b0ccb7c4ff Mon Sep 17 00:00:00 2001 From: Sergey Sharybin Date: Mon, 23 Dec 2013 22:48:20 +0600 Subject: Move python threading stuff to own file in bf_python_ext This way blender player can easily use BPY_thread_save/restore. Not so much important for master branch, but crucial to solve linking issues in threaded depsgraph branch. --- source/blender/python/generic/CMakeLists.txt | 1 + source/blender/python/generic/bpy_threads.c | 67 ++++++++++++++++++++++++++++ source/blender/python/intern/bpy_interface.c | 25 ----------- 3 files changed, 68 insertions(+), 25 deletions(-) create mode 100644 source/blender/python/generic/bpy_threads.c (limited to 'source/blender') diff --git a/source/blender/python/generic/CMakeLists.txt b/source/blender/python/generic/CMakeLists.txt index 2492de52588..aec2faa89e6 100644 --- a/source/blender/python/generic/CMakeLists.txt +++ b/source/blender/python/generic/CMakeLists.txt @@ -35,6 +35,7 @@ set(SRC bgl.c blf_py_api.c bpy_internal_import.c + bpy_threads.c idprop_py_api.c py_capi_utils.c diff --git a/source/blender/python/generic/bpy_threads.c b/source/blender/python/generic/bpy_threads.c new file mode 100644 index 00000000000..610c1846f56 --- /dev/null +++ b/source/blender/python/generic/bpy_threads.c @@ -0,0 +1,67 @@ +/* + * ***** BEGIN GPL LICENSE BLOCK ***** + * + * This program is free software; you can redistribute it and/or + * modify it under the terms of the GNU General Public License + * as published by the Free Software Foundation; either version 2 + * of the License, or (at your option) any later version. + * + * This program is distributed in the hope that it will be useful, + * but WITHOUT ANY WARRANTY; without even the implied warranty of + * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the + * GNU General Public License for more details. + * + * You should have received a copy of the GNU General Public License + * along with this program; if not, write to the Free Software Foundation, + * Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. + * + * Contributor(s): None yet + * + * ***** END GPL LICENSE BLOCK ***** + */ + +/** \file blender/python/generic/bpy_threads.c + * \ingroup pygen + * + * This file contains wrapper functions related to global interpreter lock. + * these functions are slightly different from the original Python API, + * don't throw SIGABRT even if the thread state is NULL. */ + +/** \file blender/python/intern/bpy_interface.c + * \ingroup pythonintern + * + * This file deals with embedding the python interpreter within blender, + * starting and stopping python and exposing blender/python modules so they can + * be accesses from scripts. + */ + +/* grr, python redefines */ +#ifdef _POSIX_C_SOURCE +# undef _POSIX_C_SOURCE +#endif + +#include + +#include "BLI_utildefines.h" +#include "../BPY_extern.h" + +/* analogue of PyEval_SaveThread() */ +BPy_ThreadStatePtr BPY_thread_save(void) +{ + PyThreadState *tstate = PyThreadState_Swap(NULL); + /* note: tstate can be NULL when quitting Blender */ + + if (tstate && PyEval_ThreadsInitialized()) { + PyEval_ReleaseLock(); + } + + return (BPy_ThreadStatePtr)tstate; +} + +/* analogue of PyEval_RestoreThread() */ +void BPY_thread_restore(BPy_ThreadStatePtr tstate) +{ + if (tstate) { + PyEval_RestoreThread((PyThreadState *)tstate); + } +} diff --git a/source/blender/python/intern/bpy_interface.c b/source/blender/python/intern/bpy_interface.c index 9fbad956d6d..7a3d56dc56d 100644 --- a/source/blender/python/intern/bpy_interface.c +++ b/source/blender/python/intern/bpy_interface.c @@ -408,31 +408,6 @@ void BPY_python_reset(bContext *C) BPY_modules_load_user(C); } -/* wrapper functions related to global interpreter lock. these functions - * are slightly different from the original Python API, don't throw - * SIGABRT even if the thread state is NULL. */ - -/* analogue of PyEval_SaveThread() */ -BPy_ThreadStatePtr BPY_thread_save(void) -{ - PyThreadState *tstate = PyThreadState_Swap(NULL); - /* note: tstate can be NULL when quitting Blender */ - - if (tstate && PyEval_ThreadsInitialized()) { - PyEval_ReleaseLock(); - } - - return (BPy_ThreadStatePtr)tstate; -} - -/* analogue of PyEval_RestoreThread() */ -void BPY_thread_restore(BPy_ThreadStatePtr tstate) -{ - if (tstate) { - PyEval_RestoreThread((PyThreadState *)tstate); - } -} - static void python_script_error_jump_text(struct Text *text) { int lineno; -- cgit v1.2.3