| 
									
										
										
										
											2012-02-22 09:19:53 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * ***** 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. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
										
											2012-02-23 05:20:09 +00:00
										 |  |  |  * The Original Code is Copyright (C) 2012 Blender Foundation. | 
					
						
							| 
									
										
										
										
											2012-02-22 09:19:53 +00:00
										 |  |  |  * All rights reserved. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * Contributor(s): Campbell Barton | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * ***** END GPL LICENSE BLOCK ***** | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-23 05:20:09 +00:00
										 |  |  | /** \file blender/python/bmesh/bmesh_py_api.c
 | 
					
						
							|  |  |  |  *  \ingroup pybmesh | 
					
						
							| 
									
										
										
										
											2012-02-22 09:19:53 +00:00
										 |  |  |  * | 
					
						
							| 
									
										
										
										
											2012-02-23 05:20:09 +00:00
										 |  |  |  * This file defines the 'bmesh' module. | 
					
						
							| 
									
										
										
										
											2012-02-22 09:19:53 +00:00
										 |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include <Python.h>
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-24 01:24:58 +00:00
										 |  |  | #include "BLI_utildefines.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-22 09:19:53 +00:00
										 |  |  | #include "bmesh.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "bmesh_py_types.h"
 | 
					
						
							| 
									
										
										
										
											2012-03-15 06:08:27 +00:00
										 |  |  | #include "bmesh_py_types_select.h"
 | 
					
						
							| 
									
										
										
										
											2012-03-16 05:03:13 +00:00
										 |  |  | #include "bmesh_py_types_customdata.h"
 | 
					
						
							| 
									
										
										
										
											2012-03-17 06:40:44 +00:00
										 |  |  | #include "bmesh_py_types_meshdata.h"
 | 
					
						
							| 
									
										
										
										
											2012-03-16 05:03:13 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-06-26 21:40:01 +00:00
										 |  |  | #include "bmesh_py_ops.h"
 | 
					
						
							| 
									
										
										
										
											2012-02-23 05:20:09 +00:00
										 |  |  | #include "bmesh_py_utils.h"
 | 
					
						
							| 
									
										
										
										
											2013-12-06 21:13:11 +11:00
										 |  |  | #include "bmesh_py_geometry.h"
 | 
					
						
							| 
									
										
										
										
											2012-02-22 09:19:53 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-04-13 20:31:52 +00:00
										 |  |  | #include "BKE_editmesh.h"
 | 
					
						
							| 
									
										
										
										
											2012-02-22 09:19:53 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include "DNA_mesh_types.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "../generic/py_capi_utils.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "bmesh_py_api.h" /* own include */
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-10 20:41:19 +00:00
										 |  |  | PyDoc_STRVAR(bpy_bm_new_doc, | 
					
						
							| 
									
										
										
										
											2016-07-01 19:07:11 +10:00
										 |  |  | ".. method:: new(use_operators=True)\n" | 
					
						
							| 
									
										
										
										
											2012-03-10 20:41:19 +00:00
										 |  |  | "\n" | 
					
						
							| 
									
										
										
										
											2016-07-01 19:07:11 +10:00
										 |  |  | "   :arg use_operators: Support calling operators in :mod:`bmesh.ops` (uses some extra memory per vert/edge/face).\n" | 
					
						
							|  |  |  | "   :type use_operators: bool\n" | 
					
						
							| 
									
										
										
										
											2012-03-11 04:07:22 +00:00
										 |  |  | "   :return: Return a new, empty BMesh.\n" | 
					
						
							|  |  |  | "   :rtype: :class:`bmesh.types.BMesh`\n" | 
					
						
							| 
									
										
										
										
											2012-03-10 20:41:19 +00:00
										 |  |  | ); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-01 19:07:11 +10:00
										 |  |  | static PyObject *bpy_bm_new(PyObject *UNUSED(self), PyObject *args, PyObject *kw) | 
					
						
							| 
									
										
										
										
											2012-03-10 20:41:19 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2016-07-01 19:07:11 +10:00
										 |  |  | 	static const char *kwlist[] = {"use_operators", NULL}; | 
					
						
							| 
									
										
										
										
											2012-03-10 20:41:19 +00:00
										 |  |  | 	BMesh *bm; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-01 19:07:11 +10:00
										 |  |  | 	bool use_operators = true; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (!PyArg_ParseTupleAndKeywords( | 
					
						
							|  |  |  | 	        args, kw, "|$O&:new", (char **)kwlist, | 
					
						
							|  |  |  | 	        PyC_ParseBool, &use_operators)) | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		return NULL; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	bm = BM_mesh_create( | 
					
						
							|  |  |  | 	        &bm_mesh_allocsize_default, | 
					
						
							|  |  |  | 	        &((struct BMeshCreateParams){.use_toolflags = use_operators,})); | 
					
						
							| 
									
										
										
										
											2012-03-10 20:41:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-11 05:58:22 +00:00
										 |  |  | 	return BPy_BMesh_CreatePyObject(bm, BPY_BMFLAG_NOP); | 
					
						
							| 
									
										
										
										
											2012-03-10 20:41:19 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-11 02:45:27 +00:00
										 |  |  | PyDoc_STRVAR(bpy_bm_from_edit_mesh_doc, | 
					
						
							|  |  |  | ".. method:: from_edit_mesh(mesh)\n" | 
					
						
							| 
									
										
										
										
											2012-02-22 09:19:53 +00:00
										 |  |  | "\n" | 
					
						
							| 
									
										
										
										
											2012-02-24 04:59:13 +00:00
										 |  |  | "   Return a BMesh from this mesh, currently the mesh must already be in editmode.\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							| 
									
										
										
										
											2012-11-29 05:02:06 +00:00
										 |  |  | "   :arg mesh: The editmode mesh.\n" | 
					
						
							|  |  |  | "   :type mesh: :class:`bpy.types.Mesh`\n" | 
					
						
							| 
									
										
										
										
											2012-07-04 15:04:38 +00:00
										 |  |  | "   :return: the BMesh associated with this mesh.\n" | 
					
						
							| 
									
										
										
										
											2012-02-24 04:59:13 +00:00
										 |  |  | "   :rtype: :class:`bmesh.types.BMesh`\n" | 
					
						
							| 
									
										
										
										
											2012-02-22 09:19:53 +00:00
										 |  |  | ); | 
					
						
							| 
									
										
										
										
											2012-03-11 02:45:27 +00:00
										 |  |  | static PyObject *bpy_bm_from_edit_mesh(PyObject *UNUSED(self), PyObject *value) | 
					
						
							| 
									
										
										
										
											2012-02-22 09:19:53 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-03-10 20:41:19 +00:00
										 |  |  | 	BMesh *bm; | 
					
						
							| 
									
										
										
										
											2012-02-22 09:19:53 +00:00
										 |  |  | 	Mesh *me = PyC_RNA_AsPointer(value, "Mesh"); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-10 20:41:19 +00:00
										 |  |  | 	if (me == NULL) { | 
					
						
							|  |  |  | 		return NULL; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2012-03-04 11:10:11 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-11 02:45:27 +00:00
										 |  |  | 	if (me->edit_btmesh == NULL) { | 
					
						
							|  |  |  | 		PyErr_SetString(PyExc_ValueError, | 
					
						
							|  |  |  | 		                "The mesh must be in editmode"); | 
					
						
							| 
									
										
										
										
											2012-03-10 20:41:19 +00:00
										 |  |  | 		return NULL; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-11 02:45:27 +00:00
										 |  |  | 	bm = me->edit_btmesh->bm; | 
					
						
							| 
									
										
										
										
											2012-03-10 20:41:19 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-11 05:58:22 +00:00
										 |  |  | 	return BPy_BMesh_CreatePyObject(bm, BPY_BMFLAG_IS_WRAPPED); | 
					
						
							| 
									
										
										
										
											2012-02-22 09:19:53 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-11-29 05:02:06 +00:00
										 |  |  | PyDoc_STRVAR(bpy_bm_update_edit_mesh_doc, | 
					
						
							| 
									
										
										
										
											2012-12-12 06:57:41 +00:00
										 |  |  | ".. method:: update_edit_mesh(mesh, tessface=True, destructive=True)\n" | 
					
						
							| 
									
										
										
										
											2012-11-29 05:02:06 +00:00
										 |  |  | "\n" | 
					
						
							|  |  |  | "   Update the mesh after changes to the BMesh in editmode, \n" | 
					
						
							|  |  |  | "   optionally recalculating n-gon tessellation.\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							|  |  |  | "   :arg mesh: The editmode mesh.\n" | 
					
						
							|  |  |  | "   :type mesh: :class:`bpy.types.Mesh`\n" | 
					
						
							|  |  |  | "   :arg tessface: Option to recalculate n-gon tessellation.\n" | 
					
						
							|  |  |  | "   :type tessface: boolean\n" | 
					
						
							| 
									
										
										
										
											2015-03-08 16:47:30 +09:00
										 |  |  | "   :arg destructive: Use when geometry has been added or removed.\n" | 
					
						
							| 
									
										
										
										
											2012-12-12 06:57:41 +00:00
										 |  |  | "   :type destructive: boolean\n" | 
					
						
							| 
									
										
										
										
											2012-11-29 05:02:06 +00:00
										 |  |  | ); | 
					
						
							| 
									
										
										
										
											2012-12-27 07:27:28 +00:00
										 |  |  | static PyObject *bpy_bm_update_edit_mesh(PyObject *UNUSED(self), PyObject *args, PyObject *kw) | 
					
						
							| 
									
										
										
										
											2012-11-29 05:02:06 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2012-12-27 07:27:28 +00:00
										 |  |  | 	static const char *kwlist[] = {"mesh", "tessface", "destructive", NULL}; | 
					
						
							| 
									
										
										
										
											2012-11-29 05:02:06 +00:00
										 |  |  | 	PyObject *py_me; | 
					
						
							|  |  |  | 	Mesh *me; | 
					
						
							| 
									
										
										
										
											2015-08-04 18:34:20 +10:00
										 |  |  | 	bool do_tessface = true; | 
					
						
							|  |  |  | 	bool is_destructive = true; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (!PyArg_ParseTupleAndKeywords( | 
					
						
							|  |  |  | 	        args, kw, "O|O&O&:update_edit_mesh", (char **)kwlist, | 
					
						
							|  |  |  | 	        &py_me, | 
					
						
							|  |  |  | 	        PyC_ParseBool, &do_tessface, | 
					
						
							|  |  |  | 	        PyC_ParseBool, &is_destructive)) | 
					
						
							| 
									
										
										
										
											2012-12-27 07:27:28 +00:00
										 |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2012-11-29 05:02:06 +00:00
										 |  |  | 		return NULL; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	me = PyC_RNA_AsPointer(py_me, "Mesh"); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (me == NULL) { | 
					
						
							|  |  |  | 		return NULL; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (me->edit_btmesh == NULL) { | 
					
						
							|  |  |  | 		PyErr_SetString(PyExc_ValueError, | 
					
						
							|  |  |  | 		                "The mesh must be in editmode"); | 
					
						
							|  |  |  | 		return NULL; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	{ | 
					
						
							| 
									
										
										
										
											2013-01-14 16:42:43 +00:00
										 |  |  | 		extern void EDBM_update_generic(BMEditMesh *em, const bool do_tessface, const bool is_destructive); | 
					
						
							| 
									
										
										
										
											2013-06-26 04:17:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-12-12 15:22:54 +00:00
										 |  |  | 		EDBM_update_generic(me->edit_btmesh, do_tessface, is_destructive); | 
					
						
							| 
									
										
										
										
											2012-11-29 05:02:06 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	Py_RETURN_NONE; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-22 09:19:53 +00:00
										 |  |  | static struct PyMethodDef BPy_BM_methods[] = { | 
					
						
							| 
									
										
										
										
											2016-07-01 19:07:11 +10:00
										 |  |  | 	{"new",            (PyCFunction)bpy_bm_new,            METH_VARARGS | METH_KEYWORDS,  bpy_bm_new_doc}, | 
					
						
							| 
									
										
										
										
											2012-08-26 11:35:43 +00:00
										 |  |  | 	{"from_edit_mesh", (PyCFunction)bpy_bm_from_edit_mesh, METH_O,       bpy_bm_from_edit_mesh_doc}, | 
					
						
							| 
									
										
										
										
											2012-12-27 07:27:28 +00:00
										 |  |  | 	{"update_edit_mesh", (PyCFunction)bpy_bm_update_edit_mesh, METH_VARARGS | METH_KEYWORDS, bpy_bm_update_edit_mesh_doc}, | 
					
						
							| 
									
										
										
										
											2012-08-26 11:35:43 +00:00
										 |  |  | 	{NULL, NULL, 0, NULL} | 
					
						
							| 
									
										
										
										
											2012-02-22 09:19:53 +00:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PyDoc_STRVAR(BPy_BM_doc, | 
					
						
							| 
									
										
										
										
											2012-03-09 21:23:15 +00:00
										 |  |  | "This module provides access to blenders bmesh data structures.\n" | 
					
						
							|  |  |  | "\n" | 
					
						
							| 
									
										
										
										
											2012-03-13 06:22:43 +00:00
										 |  |  | ".. include:: include__bmesh.rst\n" | 
					
						
							| 
									
										
										
										
											2012-02-22 09:19:53 +00:00
										 |  |  | ); | 
					
						
							|  |  |  | static struct PyModuleDef BPy_BM_module_def = { | 
					
						
							|  |  |  | 	PyModuleDef_HEAD_INIT, | 
					
						
							| 
									
										
										
										
											2012-02-22 10:41:07 +00:00
										 |  |  | 	"bmesh",  /* m_name */ | 
					
						
							| 
									
										
										
										
											2012-02-22 09:19:53 +00:00
										 |  |  | 	BPy_BM_doc,  /* m_doc */ | 
					
						
							|  |  |  | 	0,  /* m_size */ | 
					
						
							|  |  |  | 	BPy_BM_methods,  /* m_methods */ | 
					
						
							|  |  |  | 	NULL,  /* m_reload */ | 
					
						
							|  |  |  | 	NULL,  /* m_traverse */ | 
					
						
							|  |  |  | 	NULL,  /* m_clear */ | 
					
						
							|  |  |  | 	NULL,  /* m_free */ | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | PyObject *BPyInit_bmesh(void) | 
					
						
							|  |  |  | { | 
					
						
							| 
									
										
										
										
											2012-02-24 04:59:13 +00:00
										 |  |  | 	PyObject *mod; | 
					
						
							| 
									
										
										
										
											2012-02-22 09:19:53 +00:00
										 |  |  | 	PyObject *submodule; | 
					
						
							| 
									
										
										
										
											2012-04-15 14:54:15 +00:00
										 |  |  | 	PyObject *sys_modules = PyThreadState_GET()->interp->modules; | 
					
						
							| 
									
										
										
										
											2012-02-22 09:19:53 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	BPy_BM_init_types(); | 
					
						
							| 
									
										
										
										
											2012-03-16 05:03:13 +00:00
										 |  |  | 	BPy_BM_init_types_select(); | 
					
						
							|  |  |  | 	BPy_BM_init_types_customdata(); | 
					
						
							| 
									
										
										
										
											2012-03-17 06:40:44 +00:00
										 |  |  | 	BPy_BM_init_types_meshdata(); | 
					
						
							| 
									
										
										
										
											2012-02-29 14:05:03 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-24 04:59:13 +00:00
										 |  |  | 	mod = PyModule_Create(&BPy_BM_module_def); | 
					
						
							| 
									
										
										
										
											2012-02-22 09:19:53 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-23 05:20:09 +00:00
										 |  |  | 	/* bmesh.types */ | 
					
						
							| 
									
										
										
										
											2012-03-16 21:39:56 +00:00
										 |  |  | 	PyModule_AddObject(mod, "types", (submodule = BPyInit_bmesh_types())); | 
					
						
							| 
									
										
										
										
											2016-07-14 15:51:56 +10:00
										 |  |  | 	PyDict_SetItem(sys_modules, PyModule_GetNameObject(submodule), submodule); | 
					
						
							| 
									
										
										
										
											2012-02-24 04:59:13 +00:00
										 |  |  | 	Py_INCREF(submodule); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-14 15:51:56 +10:00
										 |  |  | 	/* bmesh.ops (not a real module, exposes module like access). */ | 
					
						
							| 
									
										
										
										
											2012-06-26 21:40:01 +00:00
										 |  |  | 	PyModule_AddObject(mod, "ops", (submodule = BPyInit_bmesh_ops())); | 
					
						
							| 
									
										
										
										
											2016-07-14 15:51:56 +10:00
										 |  |  | 	/* PyDict_SetItemString(sys_modules, PyModule_GetNameObject(submodule), submodule); */ | 
					
						
							| 
									
										
										
										
											2012-06-30 11:14:10 +00:00
										 |  |  | 	PyDict_SetItemString(sys_modules, "bmesh.ops", submodule); /* fake module */ | 
					
						
							| 
									
										
										
										
											2012-06-26 21:40:01 +00:00
										 |  |  | 	Py_INCREF(submodule); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-03-16 21:39:56 +00:00
										 |  |  | 	PyModule_AddObject(mod, "utils", (submodule = BPyInit_bmesh_utils())); | 
					
						
							| 
									
										
										
										
											2016-07-14 15:51:56 +10:00
										 |  |  | 	PyDict_SetItem(sys_modules, PyModule_GetNameObject(submodule), submodule); | 
					
						
							| 
									
										
										
										
											2012-02-24 04:59:13 +00:00
										 |  |  | 	Py_INCREF(submodule); | 
					
						
							| 
									
										
										
										
											2012-02-23 05:20:09 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2013-12-06 21:13:11 +11:00
										 |  |  | 	PyModule_AddObject(mod, "geometry", (submodule = BPyInit_bmesh_geometry())); | 
					
						
							| 
									
										
										
										
											2016-07-14 15:51:56 +10:00
										 |  |  | 	PyDict_SetItem(sys_modules, PyModule_GetNameObject(submodule), submodule); | 
					
						
							| 
									
										
										
										
											2013-12-06 21:13:11 +11:00
										 |  |  | 	Py_INCREF(submodule); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2012-02-24 04:59:13 +00:00
										 |  |  | 	return mod; | 
					
						
							| 
									
										
										
										
											2012-02-22 09:19:53 +00:00
										 |  |  | } |