svn merge ^/trunk/blender -r40390:40394
This commit is contained in:
17
GNUmakefile
17
GNUmakefile
@@ -36,7 +36,7 @@ OS_NCASE:=$(shell uname -s | tr '[A-Z]' '[a-z]')
|
|||||||
BLENDER_DIR:=$(shell pwd -P)
|
BLENDER_DIR:=$(shell pwd -P)
|
||||||
BUILD_DIR:=$(shell dirname $(BLENDER_DIR))/build/$(OS_NCASE)
|
BUILD_DIR:=$(shell dirname $(BLENDER_DIR))/build/$(OS_NCASE)
|
||||||
BUILD_TYPE:=Release
|
BUILD_TYPE:=Release
|
||||||
BUILD_CMAKE_ARGS:=""
|
BUILD_CMAKE_ARGS:=
|
||||||
|
|
||||||
|
|
||||||
# -----------------------------------------------------------------------------
|
# -----------------------------------------------------------------------------
|
||||||
@@ -77,6 +77,16 @@ ifeq ($(OS), NetBSD)
|
|||||||
NPROCS:=$(shell sysctl -a | grep "hw.ncpu " | cut -d" " -f3 )
|
NPROCS:=$(shell sysctl -a | grep "hw.ncpu " | cut -d" " -f3 )
|
||||||
endif
|
endif
|
||||||
|
|
||||||
|
|
||||||
|
# -----------------------------------------------------------------------------
|
||||||
|
# Macro for configuring cmake
|
||||||
|
|
||||||
|
CMAKE_CONFIG = cmake $(BUILD_CMAKE_ARGS) \
|
||||||
|
-H$(BLENDER_DIR) \
|
||||||
|
-B$(BUILD_DIR) \
|
||||||
|
-DCMAKE_BUILD_TYPE:STRING=$(BUILD_TYPE)
|
||||||
|
|
||||||
|
|
||||||
# -----------------------------------------------------------------------------
|
# -----------------------------------------------------------------------------
|
||||||
# Build Blender
|
# Build Blender
|
||||||
all:
|
all:
|
||||||
@@ -84,7 +94,7 @@ all:
|
|||||||
@echo Configuring Blender ...
|
@echo Configuring Blender ...
|
||||||
|
|
||||||
if test ! -f $(BUILD_DIR)/CMakeCache.txt ; then \
|
if test ! -f $(BUILD_DIR)/CMakeCache.txt ; then \
|
||||||
cmake $(BUILD_CMAKE_ARGS) -H$(BLENDER_DIR) -B$(BUILD_DIR) -DCMAKE_BUILD_TYPE:STRING=$(BUILD_TYPE); \
|
$(CMAKE_CONFIG); \
|
||||||
fi
|
fi
|
||||||
|
|
||||||
@echo
|
@echo
|
||||||
@@ -186,12 +196,15 @@ project_eclipse:
|
|||||||
#
|
#
|
||||||
|
|
||||||
check_cppcheck:
|
check_cppcheck:
|
||||||
|
$(CMAKE_CONFIG)
|
||||||
cd $(BUILD_DIR) ; python3 $(BLENDER_DIR)/build_files/cmake/cmake_static_check_cppcheck.py
|
cd $(BUILD_DIR) ; python3 $(BLENDER_DIR)/build_files/cmake/cmake_static_check_cppcheck.py
|
||||||
|
|
||||||
check_splint:
|
check_splint:
|
||||||
|
$(CMAKE_CONFIG)
|
||||||
cd $(BUILD_DIR) ; python3 $(BLENDER_DIR)/build_files/cmake/cmake_static_check_splint.py
|
cd $(BUILD_DIR) ; python3 $(BLENDER_DIR)/build_files/cmake/cmake_static_check_splint.py
|
||||||
|
|
||||||
check_sparse:
|
check_sparse:
|
||||||
|
$(CMAKE_CONFIG)
|
||||||
cd $(BUILD_DIR) ; python3 $(BLENDER_DIR)/build_files/cmake/cmake_static_check_sparse.py
|
cd $(BUILD_DIR) ; python3 $(BLENDER_DIR)/build_files/cmake/cmake_static_check_sparse.py
|
||||||
|
|
||||||
|
|
||||||
|
|||||||
@@ -1816,7 +1816,7 @@ void flushTransParticles(TransInfo *t)
|
|||||||
/* ********************* mesh ****************** */
|
/* ********************* mesh ****************** */
|
||||||
|
|
||||||
/* proportional distance based on connectivity */
|
/* proportional distance based on connectivity */
|
||||||
#define THRESHOLD 0.000000000000001f
|
#define THRESHOLD 0.0001f
|
||||||
|
|
||||||
/*I did this wrong, it should be a breadth-first search
|
/*I did this wrong, it should be a breadth-first search
|
||||||
but instead it's a depth-first search, fudged
|
but instead it's a depth-first search, fudged
|
||||||
|
|||||||
@@ -47,6 +47,7 @@ set(SRC
|
|||||||
bpy_app_handlers.c
|
bpy_app_handlers.c
|
||||||
bpy_driver.c
|
bpy_driver.c
|
||||||
bpy_interface.c
|
bpy_interface.c
|
||||||
|
bpy_interface_atexit.c
|
||||||
bpy_intern_string.c
|
bpy_intern_string.c
|
||||||
bpy_library.c
|
bpy_library.c
|
||||||
bpy_operator.c
|
bpy_operator.c
|
||||||
|
|||||||
@@ -28,3 +28,6 @@
|
|||||||
|
|
||||||
void BPy_init_modules(void);
|
void BPy_init_modules(void);
|
||||||
extern PyObject *bpy_package_py;
|
extern PyObject *bpy_package_py;
|
||||||
|
|
||||||
|
/* bpy_interface_atexit.c */
|
||||||
|
void BPY_atexit_init(void);
|
||||||
|
|||||||
@@ -30,7 +30,7 @@
|
|||||||
|
|
||||||
/* grr, python redefines */
|
/* grr, python redefines */
|
||||||
#ifdef _POSIX_C_SOURCE
|
#ifdef _POSIX_C_SOURCE
|
||||||
#undef _POSIX_C_SOURCE
|
# undef _POSIX_C_SOURCE
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
#include <Python.h>
|
#include <Python.h>
|
||||||
@@ -241,6 +241,8 @@ void BPY_python_start(int argc, const char **argv)
|
|||||||
|
|
||||||
pyrna_alloc_types();
|
pyrna_alloc_types();
|
||||||
|
|
||||||
|
BPY_atexit_init(); /* this can init any time */
|
||||||
|
|
||||||
#ifndef WITH_PYTHON_MODULE
|
#ifndef WITH_PYTHON_MODULE
|
||||||
py_tstate= PyGILState_GetThisThreadState();
|
py_tstate= PyGILState_GetThisThreadState();
|
||||||
PyEval_ReleaseThread(py_tstate);
|
PyEval_ReleaseThread(py_tstate);
|
||||||
|
|||||||
76
source/blender/python/intern/bpy_interface_atexit.c
Normal file
76
source/blender/python/intern/bpy_interface_atexit.c
Normal file
@@ -0,0 +1,76 @@
|
|||||||
|
/*
|
||||||
|
* $Id:
|
||||||
|
*
|
||||||
|
* ***** 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): Campbell Barton
|
||||||
|
*
|
||||||
|
* ***** END GPL LICENSE BLOCK *****
|
||||||
|
*/
|
||||||
|
|
||||||
|
/** \file blender/python/intern/bpy_interface_atexit.c
|
||||||
|
* \ingroup pythonintern
|
||||||
|
*/
|
||||||
|
|
||||||
|
|
||||||
|
#include <Python.h>
|
||||||
|
|
||||||
|
#include "bpy_util.h"
|
||||||
|
|
||||||
|
#include "WM_api.h"
|
||||||
|
|
||||||
|
#include "BLI_utildefines.h"
|
||||||
|
|
||||||
|
static PyObject *bpy_atexit(PyObject *UNUSED(self), PyObject *UNUSED(args), PyObject *UNUSED(kw))
|
||||||
|
{
|
||||||
|
/* close down enough of blender at least not to crash */
|
||||||
|
struct bContext *C= BPy_GetContext();
|
||||||
|
|
||||||
|
WM_exit_ext(C, 0);
|
||||||
|
|
||||||
|
Py_RETURN_NONE;
|
||||||
|
}
|
||||||
|
|
||||||
|
static PyMethodDef meth_bpy_atexit= {"bpy_atexit", (PyCFunction)bpy_atexit, METH_NOARGS, NULL};
|
||||||
|
|
||||||
|
void BPY_atexit_init(void)
|
||||||
|
{
|
||||||
|
/* note - no error checking, if any of these fail we'll get a crash
|
||||||
|
* this is intended, but if its problematic it could be changed
|
||||||
|
* - campbell */
|
||||||
|
|
||||||
|
PyObject *atexit_mod= PyImport_ImportModuleLevel((char *)"atexit", NULL, NULL, NULL, 0);
|
||||||
|
PyObject *atexit_register= PyObject_GetAttrString(atexit_mod, "register");
|
||||||
|
PyObject *args= PyTuple_New(1);
|
||||||
|
PyObject *ret;
|
||||||
|
|
||||||
|
PyTuple_SET_ITEM(args, 0, (PyObject *)PyCFunction_New(&meth_bpy_atexit, NULL));
|
||||||
|
|
||||||
|
ret= PyObject_CallObject(atexit_register, args);
|
||||||
|
|
||||||
|
Py_DECREF(atexit_mod);
|
||||||
|
Py_DECREF(atexit_register);
|
||||||
|
Py_DECREF(args);
|
||||||
|
|
||||||
|
if(ret) {
|
||||||
|
Py_DECREF(ret);
|
||||||
|
}
|
||||||
|
else { /* should never happen */
|
||||||
|
PyErr_Print();
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
@@ -72,6 +72,7 @@ void WM_setinitialstate_fullscreen(void);
|
|||||||
void WM_setinitialstate_normal(void);
|
void WM_setinitialstate_normal(void);
|
||||||
|
|
||||||
void WM_init (struct bContext *C, int argc, const char **argv);
|
void WM_init (struct bContext *C, int argc, const char **argv);
|
||||||
|
void WM_exit_ext (struct bContext *C, const short do_python);
|
||||||
void WM_exit (struct bContext *C);
|
void WM_exit (struct bContext *C);
|
||||||
void WM_main (struct bContext *C);
|
void WM_main (struct bContext *C);
|
||||||
|
|
||||||
|
|||||||
@@ -343,7 +343,8 @@ extern void free_fmodifiers_copybuf(void);
|
|||||||
extern void free_posebuf(void);
|
extern void free_posebuf(void);
|
||||||
|
|
||||||
/* called in creator.c even... tsk, split this! */
|
/* called in creator.c even... tsk, split this! */
|
||||||
void WM_exit(bContext *C)
|
/* note, doesnt run exit() call WM_exit() for that */
|
||||||
|
void WM_exit_ext(bContext *C, const short do_python)
|
||||||
{
|
{
|
||||||
wmWindow *win;
|
wmWindow *win;
|
||||||
|
|
||||||
@@ -409,6 +410,8 @@ void WM_exit(bContext *C)
|
|||||||
|
|
||||||
|
|
||||||
#ifdef WITH_PYTHON
|
#ifdef WITH_PYTHON
|
||||||
|
/* option not to close python so we can use 'atexit' */
|
||||||
|
if(do_python) {
|
||||||
/* XXX - old note */
|
/* XXX - old note */
|
||||||
/* before free_blender so py's gc happens while library still exists */
|
/* before free_blender so py's gc happens while library still exists */
|
||||||
/* needed at least for a rare sigsegv that can happen in pydrivers */
|
/* needed at least for a rare sigsegv that can happen in pydrivers */
|
||||||
@@ -417,6 +420,7 @@ void WM_exit(bContext *C)
|
|||||||
* so decref'ing them after python ends causes bad problems every time
|
* so decref'ing them after python ends causes bad problems every time
|
||||||
* the pyDriver bug can be fixed if it happens again we can deal with it then */
|
* the pyDriver bug can be fixed if it happens again we can deal with it then */
|
||||||
BPY_python_end();
|
BPY_python_end();
|
||||||
|
}
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
GPU_global_buffer_pool_free();
|
GPU_global_buffer_pool_free();
|
||||||
@@ -463,6 +467,10 @@ void WM_exit(bContext *C)
|
|||||||
getchar();
|
getchar();
|
||||||
}
|
}
|
||||||
#endif
|
#endif
|
||||||
exit(G.afbreek==1);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void WM_exit(bContext *C)
|
||||||
|
{
|
||||||
|
WM_exit_ext(C, 1);
|
||||||
|
exit(G.afbreek==1);
|
||||||
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user