| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | /* 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  |  * $Id$ | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * ***** BEGIN GPL/BL DUAL 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. The Blender | 
					
						
							|  |  |  |  * Foundation also sells licenses for use in proprietary software under | 
					
						
							|  |  |  |  * the Blender License.  See http://www.blender.org/BL/ for information
 | 
					
						
							|  |  |  |  * about this. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * 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, | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  |  * Inc., 59 Temple Place - Suite 330, Boston, MA	02111-1307, USA. | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * The Original Code is Copyright (C) 2001-2002 by NaN Holding BV. | 
					
						
							|  |  |  |  * All rights reserved. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  * This is a new part of Blender. | 
					
						
							|  |  |  |  * | 
					
						
							| 
									
										
										
											
												BPython:
- tentative fix for scripts with CR/LF endings and split lines:
    in 2.32, the ac3d and vrml2 exporters, for example, had lines
    split with '\\\\' and so gave syntax errors when executed on Win
    platforms, because the scripts bundled with Win binaries had dos
    line endings.
- Chris Keith has written code to execute Python scripts from the
  command-line, with '-P ' switch: "blender -P filename":
    a Blender.Quit function was also added, so Blender can quit after
    running the script (end the script with Blender.Quit()), but there's
    still work to be done in this part, including adding more functions,
    to load / save .blend files and to run scripts.  More testing and
    discussions are necessary.
Thanks Chris, for both your contributions and your patience, since I
wasn't available to check / commit this for a while.
											
										 
											2004-03-31 04:18:39 +00:00
										 |  |  |  * Contributor(s): Michel Selten, Willian P. Germano, Stephen Swaney, | 
					
						
							| 
									
										
										
										
											2005-10-14 17:26:57 +00:00
										 |  |  |  * Chris Keith, Chris Want, Ken Hughes | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  |  * | 
					
						
							|  |  |  |  * ***** END GPL/BL DUAL LICENSE BLOCK ***** | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
										
										
											2003-05-13 01:54:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | #include <Python.h>
 | 
					
						
							| 
									
										
										
										
											2005-07-18 03:50:37 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | #include "compile.h"		/* for the PyCodeObject */
 | 
					
						
							|  |  |  | #include "eval.h"		/* for PyEval_EvalCode */
 | 
					
						
							| 
									
										
										
										
											2005-07-18 03:50:37 +00:00
										 |  |  | #include "BLI_blenlib.h"	/* for BLI_last_slash() */
 | 
					
						
							|  |  |  | #include "BIF_interface.h"	/* for pupmenu() */
 | 
					
						
							|  |  |  | #include "BIF_space.h"
 | 
					
						
							|  |  |  | #include "BIF_screen.h"
 | 
					
						
							|  |  |  | #include "BIF_toolbox.h"
 | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | #include "BKE_action.h" 	/* for get_pose_channel() */
 | 
					
						
							| 
									
										
										
										
											2005-07-18 03:50:37 +00:00
										 |  |  | #include "BKE_library.h"
 | 
					
						
							|  |  |  | #include "BKE_object.h"		/* during_scriptlink() */
 | 
					
						
							|  |  |  | #include "BKE_text.h"
 | 
					
						
							| 
									
										
										
										
											2007-08-18 06:17:50 +00:00
										 |  |  | #include "BKE_constraint.h" /* for bConstraintOb */
 | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | #include "BKE_idprop.h"
 | 
					
						
							| 
									
										
										
										
											2007-03-11 04:05:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-04-30 16:22:31 +00:00
										 |  |  | #include "DNA_curve_types.h" /* for struct IpoDriver */
 | 
					
						
							| 
									
										
										
										
											2007-03-11 04:05:45 +00:00
										 |  |  | #include "DNA_ID.h" /* ipo driver */
 | 
					
						
							|  |  |  | #include "DNA_object_types.h" /* ipo driver */
 | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | #include "DNA_constraint_types.h" /* for pyconstraint */
 | 
					
						
							| 
									
										
										
										
											2007-03-11 04:05:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-18 03:50:37 +00:00
										 |  |  | #include "DNA_screen_types.h"
 | 
					
						
							|  |  |  | #include "DNA_userdef_types.h"	/* for U.pythondir */
 | 
					
						
							|  |  |  | #include "MEM_guardedalloc.h"
 | 
					
						
							| 
									
										
										
										
											2003-03-19 18:57:23 +00:00
										 |  |  | #include "BPY_extern.h"
 | 
					
						
							| 
									
										
										
										
											2004-01-14 21:36:10 +00:00
										 |  |  | #include "BPY_menus.h"
 | 
					
						
							| 
									
										
										
										
											2005-07-18 03:50:37 +00:00
										 |  |  | #include "BPI_script.h"
 | 
					
						
							|  |  |  | #include "BKE_global.h"
 | 
					
						
							|  |  |  | #include "BKE_main.h"
 | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | #include "BKE_armature.h"
 | 
					
						
							| 
									
										
										
										
											2003-05-08 03:13:17 +00:00
										 |  |  | #include "api2_2x/EXPP_interface.h"
 | 
					
						
							| 
									
										
										
										
											2003-12-14 01:18:09 +00:00
										 |  |  | #include "api2_2x/constant.h"
 | 
					
						
							| 
									
										
											  
											
												BPython:
- Scripts:
    fixed error in "Save Current Theme" which prevented it from automatically updating script registration in menus.
    cosmetic changes in a couple of Campbell's sel_same.py script strings + more descriptive name for its new menu place (3d view, face mode -> select menu).
    small updates to help_browser.py script.
 The above changes are related to this:
- Added new script menu entries: Render (for exporters to renderers), Themes, FaceSelect (this already at the proper place).  Updated Scripts win->Scripts menu so it won't show all available entries, only  the ones we mean to see there.
- Updated menu registration so that scripts folders can become trees.  The release/scripts/ dir should be updated soon with subdirs like converters/, modifiers/, generators/ or whatever -- better discuss first (or is it? /me afraid of long irc discussions during meetings :) ).
- Modules:
    Blender: added 'udatadir' option to .Get() function and added var Blender.mode to tell if Blender is in bg or interactive mode.
    NMesh: added Campbell's nmesh.transform(matrix, recalc_normals = False) method (reworked, so my fault if it doesn't work).
- Bugs fixed:
    #2123: http://projects.blender.org/tracker/?func=detail&atid=125&aid=2123&group_id=9
    Reported by Ken Hughes (thanks!), who also found the exact problem later (it was in Text.Load, not with script links -- if only I had checked emails these days ... lost > 1 hour today to find the problem: passed filename to M_Text_Load was later being written over by a function called by add_text).  Also saw that Text.Load wasn't checking existence of passed filename (duh!), now it does.
    #1655: http://projects.blender.org/tracker/?func=detail&atid=125&aid=1655&group_id=9
    Reported by Chris Want (thanks!): command line "blender -P script" not working properly for bg mode ("blender -b blendfile -P script").
    Had to make some small updates to get it working (bg mode for scripts was never explicitely handled, it worked due to collateral effects, let's say), interested readers can check the report after I update it or the API_intro.py doc file.  After more testing we can make further updates.  Updated many places to not call redraws if in bg mode, now it is officially available.  Blender outputs its own info when rendering in bg mode, if that is considered a nuissance we'll have to add a few "if (during_script())" calls outside bpython.
- Removed a few warnings here and there and also updated docs.
											
										 
											2005-03-19 06:24:55 +00:00
										 |  |  | #include "api2_2x/gen_utils.h"
 | 
					
						
							| 
									
										
										
										
											2007-03-11 04:05:45 +00:00
										 |  |  | #include "api2_2x/gen_library.h" /* GetPyObjectFromID */
 | 
					
						
							| 
									
										
										
										
											2005-07-18 03:50:37 +00:00
										 |  |  | #include "api2_2x/BGL.h" 
 | 
					
						
							|  |  |  | #include "api2_2x/Blender.h"
 | 
					
						
							|  |  |  | #include "api2_2x/Camera.h"
 | 
					
						
							|  |  |  | #include "api2_2x/Draw.h"
 | 
					
						
							| 
									
										
										
										
											2007-03-30 00:57:07 +00:00
										 |  |  | #include "api2_2x/Object.h"
 | 
					
						
							| 
									
										
										
										
											2007-03-02 05:47:14 +00:00
										 |  |  | #include "api2_2x/Registry.h"
 | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | #include "api2_2x/Pose.h"
 | 
					
						
							| 
									
										
										
										
											2007-04-18 14:40:01 +00:00
										 |  |  | #include "api2_2x/bpy.h" /* for the new "bpy" module */
 | 
					
						
							| 
									
										
										
										
											2007-03-02 05:47:14 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | /*these next two are for pyconstraints*/ | 
					
						
							|  |  |  | #include "api2_2x/IDProp.h"
 | 
					
						
							|  |  |  | #include "api2_2x/matrix.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-03-11 04:05:45 +00:00
										 |  |  | /* for scriptlinks */ | 
					
						
							|  |  |  | #include "DNA_lamp_types.h"
 | 
					
						
							|  |  |  | #include "DNA_camera_types.h"
 | 
					
						
							|  |  |  | #include "DNA_world_types.h"
 | 
					
						
							|  |  |  | #include "DNA_scene_types.h"
 | 
					
						
							|  |  |  | #include "DNA_material_types.h"
 | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-09-03 04:13:08 +00:00
										 |  |  | /* bpy_registryDict is declared in api2_2x/Registry.h and defined
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  |  * in api2_2x/Registry.c | 
					
						
							|  |  |  |  * This Python dictionary will be used to store data that scripts | 
					
						
							| 
									
										
										
										
											2003-09-03 04:13:08 +00:00
										 |  |  |  * choose to preserve after they are executed, so user changes can be | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  |  * restored next time the script is used.  Check the Blender.Registry module.  | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2007-04-18 14:40:01 +00:00
										 |  |  | /*#include "api2_2x/Registry.h" */ | 
					
						
							| 
									
										
										
										
											2003-05-13 01:54:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-04-30 16:22:31 +00:00
										 |  |  | /* for pydrivers (ipo drivers defined by one-line Python expressions) */ | 
					
						
							|  |  |  | PyObject *bpy_pydriver_Dict = NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-01-31 03:12:26 +00:00
										 |  |  | /*
 | 
					
						
							|  |  |  |  * set up a weakref list for Armatures | 
					
						
							|  |  |  |  *    creates list in __main__ module dict  | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  |    | 
					
						
							|  |  |  | int setup_armature_weakrefs() | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	PyObject *maindict; | 
					
						
							|  |  |  | 	PyObject *main_module; | 
					
						
							|  |  |  | 	char *list_name = ARM_WEAKREF_LIST_NAME; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	main_module = PyImport_AddModule( "__main__"); | 
					
						
							|  |  |  | 	if(main_module){ | 
					
						
							| 
									
										
										
										
											2007-06-16 13:01:10 +00:00
										 |  |  | 		PyObject *weakreflink; | 
					
						
							| 
									
										
										
										
											2007-01-31 03:12:26 +00:00
										 |  |  | 		maindict= PyModule_GetDict(main_module); | 
					
						
							| 
									
										
										
										
											2007-06-16 13:01:10 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* check if there is already a dict entry for the armature weakrefs,
 | 
					
						
							|  |  |  | 		 * and delete if so before making another one */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		weakreflink= PyDict_GetItemString(maindict,list_name); | 
					
						
							|  |  |  | 		if( weakreflink != NULL ) { | 
					
						
							|  |  |  | 			PyDict_DelItemString(maindict,list_name); | 
					
						
							|  |  |  | 			Py_XDECREF( weakreflink ); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-01-31 03:12:26 +00:00
										 |  |  | 		if (PyDict_SetItemString(maindict,  | 
					
						
							|  |  |  | 								 list_name,  | 
					
						
							|  |  |  | 								 PyList_New(0)) == -1){ | 
					
						
							|  |  |  | 			printf("Oops - setup_armature_weakrefs()\n"); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			return 0; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return 1; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-03-28 03:18:21 +00:00
										 |  |  | /* Declares the modules and their initialization functions
 | 
					
						
							|  |  |  |  * These are TOP-LEVEL modules e.g. import `module` - there is no | 
					
						
							|  |  |  |  * support for packages here e.g. import `package.module` */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-08-17 14:26:00 +00:00
										 |  |  | static struct _inittab BPy_Inittab_Modules[] = { | 
					
						
							|  |  |  | 	{"Blender", M_Blender_Init}, | 
					
						
							| 
									
										
										
										
											2007-04-18 14:40:01 +00:00
										 |  |  | 	{"bpy", m_bpy_init}, | 
					
						
							| 
									
										
										
										
											2005-09-09 01:31:10 +00:00
										 |  |  | 	{NULL, NULL} | 
					
						
							| 
									
										
										
										
											2005-08-17 14:26:00 +00:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | /*************************************************************************
 | 
					
						
							|  |  |  | * Structure definitions	 | 
					
						
							|  |  |  | **************************************************************************/ | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | #define FILENAME_LENGTH 24
 | 
					
						
							| 
									
										
										
										
											2007-03-28 03:18:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | typedef struct _ScriptError { | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	char filename[FILENAME_LENGTH]; | 
					
						
							|  |  |  | 	int lineno; | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | } ScriptError; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | /****************************************************************************
 | 
					
						
							|  |  |  | * Global variables  | 
					
						
							|  |  |  | ****************************************************************************/ | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | ScriptError g_script_error; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | /***************************************************************************
 | 
					
						
							|  |  |  | * Function prototypes  | 
					
						
							|  |  |  | ***************************************************************************/ | 
					
						
							|  |  |  | PyObject *RunPython( Text * text, PyObject * globaldict ); | 
					
						
							|  |  |  | char *GetName( Text * text ); | 
					
						
							|  |  |  | PyObject *CreateGlobalDictionary( void ); | 
					
						
							|  |  |  | void ReleaseGlobalDictionary( PyObject * dict ); | 
					
						
							|  |  |  | void DoAllScriptsFromList( ListBase * list, short event ); | 
					
						
							|  |  |  | PyObject *importText( char *name ); | 
					
						
							|  |  |  | void init_ourImport( void ); | 
					
						
							| 
									
										
										
										
											2005-10-14 17:26:57 +00:00
										 |  |  | void init_ourReload( void ); | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | PyObject *blender_import( PyObject * self, PyObject * args ); | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | PyObject *RunPython2( Text * text, PyObject * globaldict, PyObject *localdict ); | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-04-11 19:05:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-03-09 19:45:59 +00:00
										 |  |  | void BPY_Err_Handle( char *script_name ); | 
					
						
							|  |  |  | PyObject *traceback_getFilename( PyObject * tb ); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | /****************************************************************************
 | 
					
						
							| 
									
										
										
										
											2005-08-17 14:26:00 +00:00
										 |  |  | * Description: This function will start the interpreter and load all modules | 
					
						
							|  |  |  | * as well as search for a python installation. | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | ****************************************************************************/ | 
					
						
							| 
									
										
											  
											
												BPython:
- Blender.Window: added function GetPerspMatrix() (Tom Musgrave's patch, thanks);
- added Chris Want's patch to tell argc, argv to the Python interpreter (thanks, Hos);
- Blender.Image: added image.glFree() to free textures bound by the recently added
  image.glLoad() (both suggested by Campbell Barton -- thanks, with these Blender can
  be used to load textures for scripts);
- Blender.Sound: removed for now at least a few get/set methods of vars that can't be
  accessed via interface;
- renamed Get/makeActive to Get/setCurrent in Blender.World (actually added alias for
  now), same in Blender.Sound: renamed makeActive to setCurrent.  Stephen Swaney
  pointed this some weeks ago, we should stick to one naming convention.
- added documentation for Sound and Window.Theme modules and the other added
  functions, made other small updates.
- Blender.Object: made 'worldspace' become the default output of .getMatrix and .mat/.matrix:
  after reading a discussion on blender.org's Python forum where eeshlo mentioned the
  pre 2.34 default was worldspace, I took a better look at Blender's relevant code,
  confirmed, talked to Theeth about this and as he suggested am changing the default
  back to 'worldspace'.
											
										 
											2004-10-20 05:51:24 +00:00
										 |  |  | void BPY_start_python( int argc, char **argv ) | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | { | 
					
						
							| 
									
										
											  
											
												BPython:
- Blender.Window: added function GetPerspMatrix() (Tom Musgrave's patch, thanks);
- added Chris Want's patch to tell argc, argv to the Python interpreter (thanks, Hos);
- Blender.Image: added image.glFree() to free textures bound by the recently added
  image.glLoad() (both suggested by Campbell Barton -- thanks, with these Blender can
  be used to load textures for scripts);
- Blender.Sound: removed for now at least a few get/set methods of vars that can't be
  accessed via interface;
- renamed Get/makeActive to Get/setCurrent in Blender.World (actually added alias for
  now), same in Blender.Sound: renamed makeActive to setCurrent.  Stephen Swaney
  pointed this some weeks ago, we should stick to one naming convention.
- added documentation for Sound and Window.Theme modules and the other added
  functions, made other small updates.
- Blender.Object: made 'worldspace' become the default output of .getMatrix and .mat/.matrix:
  after reading a discussion on blender.org's Python forum where eeshlo mentioned the
  pre 2.34 default was worldspace, I took a better look at Blender's relevant code,
  confirmed, talked to Theeth about this and as he suggested am changing the default
  back to 'worldspace'.
											
										 
											2004-10-20 05:51:24 +00:00
										 |  |  | 	static int argc_copy = 0; | 
					
						
							|  |  |  | 	static char **argv_copy = NULL; | 
					
						
							|  |  |  | 	int first_time = argc; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* we keep a copy of the values of argc and argv so that the game engine
 | 
					
						
							|  |  |  | 	 * can call BPY_start_python(0, NULL) whenever a game ends, without having | 
					
						
							|  |  |  | 	 * to know argc and argv there (in source/blender/src/space.c) */ | 
					
						
							|  |  |  | 	if( first_time ) { | 
					
						
							|  |  |  | 		argc_copy = argc; | 
					
						
							|  |  |  | 		argv_copy = argv; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-08-17 14:26:00 +00:00
										 |  |  | 	//stuff for Registry module
 | 
					
						
							| 
									
										
											  
											
												BPython:
- Blender.Window: added function GetPerspMatrix() (Tom Musgrave's patch, thanks);
- added Chris Want's patch to tell argc, argv to the Python interpreter (thanks, Hos);
- Blender.Image: added image.glFree() to free textures bound by the recently added
  image.glLoad() (both suggested by Campbell Barton -- thanks, with these Blender can
  be used to load textures for scripts);
- Blender.Sound: removed for now at least a few get/set methods of vars that can't be
  accessed via interface;
- renamed Get/makeActive to Get/setCurrent in Blender.World (actually added alias for
  now), same in Blender.Sound: renamed makeActive to setCurrent.  Stephen Swaney
  pointed this some weeks ago, we should stick to one naming convention.
- added documentation for Sound and Window.Theme modules and the other added
  functions, made other small updates.
- Blender.Object: made 'worldspace' become the default output of .getMatrix and .mat/.matrix:
  after reading a discussion on blender.org's Python forum where eeshlo mentioned the
  pre 2.34 default was worldspace, I took a better look at Blender's relevant code,
  confirmed, talked to Theeth about this and as he suggested am changing the default
  back to 'worldspace'.
											
										 
											2004-10-20 05:51:24 +00:00
										 |  |  | 	bpy_registryDict = PyDict_New(  );/* check comment at start of this file */ | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	if( !bpy_registryDict ) | 
					
						
							|  |  |  | 		printf( "Error: Couldn't create the Registry Python Dictionary!" ); | 
					
						
							|  |  |  | 	Py_SetProgramName( "blender" ); | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-08-17 14:26:00 +00:00
										 |  |  | 	/* Py_Initialize() will attempt to import the site module and
 | 
					
						
							| 
									
										
										
										
											2004-10-01 05:28:14 +00:00
										 |  |  | 	 * print an error if not found.  See init_syspath() for the | 
					
						
							|  |  |  | 	 * rest of our init msgs. | 
					
						
							|  |  |  | 	 */ | 
					
						
							| 
									
										
										
										
											2007-03-28 03:18:21 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* print Python version
 | 
					
						
							|  |  |  | 	 * Py_GetVersion() returns a ptr to a static string "9.9.9 (aaaa..."  | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	{ | 
					
						
							|  |  |  | 		int count = 3;  /* a nice default for major.minor.  example 2.5 */ | 
					
						
							|  |  |  | 		const char *version = Py_GetVersion(); | 
					
						
							|  |  |  | 		/* we know a blank is there somewhere! */ | 
					
						
							|  |  |  | 		char *blank_ptr = strchr( version, ' ');  | 
					
						
							|  |  |  | 		if(blank_ptr) | 
					
						
							|  |  |  | 			count = blank_ptr - version; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		printf( "Compiled with Python version %.*s.\n", count, version ); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-05-05 04:46:06 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-08-17 14:26:00 +00:00
										 |  |  | 	//Initialize the TOP-LEVEL modules
 | 
					
						
							|  |  |  | 	PyImport_ExtendInittab(BPy_Inittab_Modules); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	//Start the interpreter
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	Py_Initialize(  ); | 
					
						
							| 
									
										
											  
											
												BPython:
- Blender.Window: added function GetPerspMatrix() (Tom Musgrave's patch, thanks);
- added Chris Want's patch to tell argc, argv to the Python interpreter (thanks, Hos);
- Blender.Image: added image.glFree() to free textures bound by the recently added
  image.glLoad() (both suggested by Campbell Barton -- thanks, with these Blender can
  be used to load textures for scripts);
- Blender.Sound: removed for now at least a few get/set methods of vars that can't be
  accessed via interface;
- renamed Get/makeActive to Get/setCurrent in Blender.World (actually added alias for
  now), same in Blender.Sound: renamed makeActive to setCurrent.  Stephen Swaney
  pointed this some weeks ago, we should stick to one naming convention.
- added documentation for Sound and Window.Theme modules and the other added
  functions, made other small updates.
- Blender.Object: made 'worldspace' become the default output of .getMatrix and .mat/.matrix:
  after reading a discussion on blender.org's Python forum where eeshlo mentioned the
  pre 2.34 default was worldspace, I took a better look at Blender's relevant code,
  confirmed, talked to Theeth about this and as he suggested am changing the default
  back to 'worldspace'.
											
										 
											2004-10-20 05:51:24 +00:00
										 |  |  | 	PySys_SetArgv( argc_copy, argv_copy ); | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-08-17 14:26:00 +00:00
										 |  |  | 	//Overrides __import__
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	init_ourImport(  ); | 
					
						
							| 
									
										
										
										
											2005-10-14 17:26:57 +00:00
										 |  |  | 	init_ourReload(  ); | 
					
						
							| 
									
										
										
										
											2003-07-03 01:42:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-08-17 14:26:00 +00:00
										 |  |  | 	//init a global dictionary
 | 
					
						
							|  |  |  | 	g_blenderdict = NULL; | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-08-17 14:26:00 +00:00
										 |  |  | 	//Look for a python installation
 | 
					
						
							| 
									
										
											  
											
												BPython:
- Blender.Window: added function GetPerspMatrix() (Tom Musgrave's patch, thanks);
- added Chris Want's patch to tell argc, argv to the Python interpreter (thanks, Hos);
- Blender.Image: added image.glFree() to free textures bound by the recently added
  image.glLoad() (both suggested by Campbell Barton -- thanks, with these Blender can
  be used to load textures for scripts);
- Blender.Sound: removed for now at least a few get/set methods of vars that can't be
  accessed via interface;
- renamed Get/makeActive to Get/setCurrent in Blender.World (actually added alias for
  now), same in Blender.Sound: renamed makeActive to setCurrent.  Stephen Swaney
  pointed this some weeks ago, we should stick to one naming convention.
- added documentation for Sound and Window.Theme modules and the other added
  functions, made other small updates.
- Blender.Object: made 'worldspace' become the default output of .getMatrix and .mat/.matrix:
  after reading a discussion on blender.org's Python forum where eeshlo mentioned the
  pre 2.34 default was worldspace, I took a better look at Blender's relevant code,
  confirmed, talked to Theeth about this and as he suggested am changing the default
  back to 'worldspace'.
											
										 
											2004-10-20 05:51:24 +00:00
										 |  |  | 	init_syspath( first_time ); /* not first_time: some msgs are suppressed */ | 
					
						
							| 
									
										
										
										
											2003-06-28 07:38:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	return; | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-03-08 18:10:20 +00:00
										 |  |  | /*****************************************************************************/ | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | /* Description: This function will terminate the Python interpreter	     */ | 
					
						
							| 
									
										
										
										
											2003-03-08 18:10:20 +00:00
										 |  |  | /*****************************************************************************/ | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | void BPY_end_python( void ) | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2006-05-02 02:42:08 +00:00
										 |  |  | 	Script *script = NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	if( bpy_registryDict ) { | 
					
						
							|  |  |  | 		Py_DECREF( bpy_registryDict ); | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 		bpy_registryDict = NULL; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2003-09-03 04:13:08 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-04-30 16:22:31 +00:00
										 |  |  | 	if( bpy_pydriver_Dict ) { | 
					
						
							|  |  |  | 		Py_DECREF( bpy_pydriver_Dict ); | 
					
						
							|  |  |  | 		bpy_pydriver_Dict = NULL; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-05-02 02:42:08 +00:00
										 |  |  | 	/* Freeing all scripts here prevents problems with the order in which
 | 
					
						
							|  |  |  | 	 * Python is finalized and G.main is freed in exit_usiblender() */ | 
					
						
							|  |  |  | 	for (script = G.main->script.first; script; script = script->id.next) { | 
					
						
							|  |  |  | 		BPY_clear_script(script); | 
					
						
							|  |  |  | 		free_libblock( &G.main->script, script ); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	Py_Finalize(  ); | 
					
						
							| 
									
										
										
										
											2004-01-14 21:36:10 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	BPyMenu_RemoveAllEntries(  );	/* freeing bpymenu mem */ | 
					
						
							| 
									
										
										
										
											2004-01-14 21:36:10 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	/* a script might've opened a .blend file but didn't close it, so: */ | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	EXPP_Library_Close(  ); | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	return; | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | void syspath_append( char *dirname ) | 
					
						
							| 
									
										
										
										
											2003-06-28 07:38:21 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2007-09-17 04:46:58 +00:00
										 |  |  | 	PyObject *mod_sys= NULL, *dict= NULL, *path= NULL, *dir= NULL; | 
					
						
							|  |  |  | 	short ok=1; | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	PyErr_Clear(  ); | 
					
						
							| 
									
										
										
										
											2003-06-28 07:38:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	dir = Py_BuildValue( "s", dirname ); | 
					
						
							| 
									
										
										
										
											2004-01-23 19:24:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	mod_sys = PyImport_ImportModule( "sys" );	/* new ref */ | 
					
						
							| 
									
										
										
										
											2007-09-17 04:46:58 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	if (mod_sys) { | 
					
						
							|  |  |  | 		dict = PyModule_GetDict( mod_sys );	/* borrowed ref */ | 
					
						
							|  |  |  | 		path = PyDict_GetItemString( dict, "path" );	/* borrowed ref */ | 
					
						
							|  |  |  | 		if ( !PyList_Check( path ) ) { | 
					
						
							|  |  |  | 			ok = 0; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} else { | 
					
						
							|  |  |  | 		/* cant get the sys module */ | 
					
						
							|  |  |  | 		ok = 0; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2003-06-28 07:38:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-09-17 04:46:58 +00:00
										 |  |  | 	if (ok && PyList_Append( path, dir ) != 0) | 
					
						
							|  |  |  | 		ok = 0; /* append failed */ | 
					
						
							| 
									
										
										
										
											2003-06-28 07:38:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-09-17 04:46:58 +00:00
										 |  |  | 	if( (ok==0) || PyErr_Occurred(  ) ) | 
					
						
							|  |  |  | 		Py_FatalError( "could import or build sys.path, can't continue" ); | 
					
						
							| 
									
										
										
										
											2003-06-28 07:38:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-09-17 04:46:58 +00:00
										 |  |  | 	Py_XDECREF( mod_sys ); | 
					
						
							| 
									
										
										
										
											2003-06-28 07:38:21 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												BPython:
- Blender.Window: added function GetPerspMatrix() (Tom Musgrave's patch, thanks);
- added Chris Want's patch to tell argc, argv to the Python interpreter (thanks, Hos);
- Blender.Image: added image.glFree() to free textures bound by the recently added
  image.glLoad() (both suggested by Campbell Barton -- thanks, with these Blender can
  be used to load textures for scripts);
- Blender.Sound: removed for now at least a few get/set methods of vars that can't be
  accessed via interface;
- renamed Get/makeActive to Get/setCurrent in Blender.World (actually added alias for
  now), same in Blender.Sound: renamed makeActive to setCurrent.  Stephen Swaney
  pointed this some weeks ago, we should stick to one naming convention.
- added documentation for Sound and Window.Theme modules and the other added
  functions, made other small updates.
- Blender.Object: made 'worldspace' become the default output of .getMatrix and .mat/.matrix:
  after reading a discussion on blender.org's Python forum where eeshlo mentioned the
  pre 2.34 default was worldspace, I took a better look at Blender's relevant code,
  confirmed, talked to Theeth about this and as he suggested am changing the default
  back to 'worldspace'.
											
										 
											2004-10-20 05:51:24 +00:00
										 |  |  | void init_syspath( int first_time ) | 
					
						
							| 
									
										
										
										
											2003-06-28 07:38:21 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	PyObject *path; | 
					
						
							|  |  |  | 	PyObject *mod, *d; | 
					
						
							| 
									
										
										
										
											2005-10-30 18:27:24 +00:00
										 |  |  | 	char *progname; | 
					
						
							| 
									
										
										
										
											2005-03-21 05:26:52 +00:00
										 |  |  | 	char execdir[FILE_MAXDIR];	/*defines from DNA_space_types.h */ | 
					
						
							| 
									
										
										
										
											2003-06-28 07:38:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	int n; | 
					
						
							| 
									
										
										
										
											2003-06-28 07:38:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	path = Py_BuildValue( "s", bprogname ); | 
					
						
							| 
									
										
										
										
											2003-06-28 07:38:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	mod = PyImport_ImportModule( "Blender.sys" ); | 
					
						
							| 
									
										
										
										
											2003-06-28 07:38:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	if( mod ) { | 
					
						
							|  |  |  | 		d = PyModule_GetDict( mod ); | 
					
						
							| 
									
										
										
										
											2005-11-30 08:18:06 +00:00
										 |  |  | 		EXPP_dict_set_item_str( d, "progname", path ); | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		Py_DECREF( mod ); | 
					
						
							|  |  |  | 	} else | 
					
						
							|  |  |  | 		printf( "Warning: could not set Blender.sys.progname\n" ); | 
					
						
							| 
									
										
										
										
											2003-06-28 07:38:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	progname = BLI_last_slash( bprogname );	/* looks for the last dir separator */ | 
					
						
							| 
									
										
										
										
											2003-06-28 07:38:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	n = progname - bprogname; | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	if( n > 0 ) { | 
					
						
							|  |  |  | 		strncpy( execdir, bprogname, n ); | 
					
						
							|  |  |  | 		if( execdir[n - 1] == '.' ) | 
					
						
							|  |  |  | 			n--;	/*fix for when run as ./blender */ | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 		execdir[n] = '\0'; | 
					
						
							| 
									
										
										
										
											2003-06-28 07:38:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		syspath_append( execdir );	/* append to module search path */ | 
					
						
							|  |  |  | 	} else | 
					
						
							|  |  |  | 		printf( "Warning: could not determine argv[0] path\n" ); | 
					
						
							| 
									
										
										
										
											2003-06-28 07:38:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	/* 
 | 
					
						
							| 
									
										
										
										
											2006-04-11 19:05:58 +00:00
										 |  |  | 	   attempt to import 'site' module as a check for valid | 
					
						
							|  |  |  | 	   python install found. | 
					
						
							|  |  |  | 	*/ | 
					
						
							| 
									
										
										
										
											2003-10-19 06:26:32 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-07-08 20:40:41 +00:00
										 |  |  | 	printf("Checking for installed Python... "); /* appears after msg "Compiled with Python 2.x"  */ | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	mod = PyImport_ImportModule( "site" );	/* new ref */ | 
					
						
							| 
									
										
										
										
											2003-09-18 00:54:43 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	if( mod ) { | 
					
						
							| 
									
										
										
										
											2006-07-08 20:40:41 +00:00
										 |  |  | 		printf("got it!\n");   | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		Py_DECREF( mod ); | 
					
						
							|  |  |  | 	} else {		/* import 'site' failed */ | 
					
						
							|  |  |  | 		PyErr_Clear(  ); | 
					
						
							| 
									
										
											  
											
												BPython:
- Blender.Window: added function GetPerspMatrix() (Tom Musgrave's patch, thanks);
- added Chris Want's patch to tell argc, argv to the Python interpreter (thanks, Hos);
- Blender.Image: added image.glFree() to free textures bound by the recently added
  image.glLoad() (both suggested by Campbell Barton -- thanks, with these Blender can
  be used to load textures for scripts);
- Blender.Sound: removed for now at least a few get/set methods of vars that can't be
  accessed via interface;
- renamed Get/makeActive to Get/setCurrent in Blender.World (actually added alias for
  now), same in Blender.Sound: renamed makeActive to setCurrent.  Stephen Swaney
  pointed this some weeks ago, we should stick to one naming convention.
- added documentation for Sound and Window.Theme modules and the other added
  functions, made other small updates.
- Blender.Object: made 'worldspace' become the default output of .getMatrix and .mat/.matrix:
  after reading a discussion on blender.org's Python forum where eeshlo mentioned the
  pre 2.34 default was worldspace, I took a better look at Blender's relevant code,
  confirmed, talked to Theeth about this and as he suggested am changing the default
  back to 'worldspace'.
											
										 
											2004-10-20 05:51:24 +00:00
										 |  |  | 		if( first_time ) { | 
					
						
							|  |  |  | 			printf( "No installed Python found.\n" ); | 
					
						
							|  |  |  | 			printf( "Only built-in modules are available.  Some scripts may not run.\n" ); | 
					
						
							|  |  |  | 			printf( "Continuing happily.\n" ); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2006-04-11 19:05:58 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* 
 | 
					
						
							|  |  |  | 	 * initialize the sys module | 
					
						
							|  |  |  | 	 * set sys.executable to the Blender exe  | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	mod = PyImport_ImportModule( "sys" );	/* new ref */ | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	if( mod ) { | 
					
						
							|  |  |  | 		d = PyModule_GetDict( mod );	/* borrowed ref */ | 
					
						
							| 
									
										
										
										
											2005-11-30 08:18:06 +00:00
										 |  |  | 		EXPP_dict_set_item_str( d, "executable", | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 				      Py_BuildValue( "s", bprogname ) ); | 
					
						
							|  |  |  | 		Py_DECREF( mod ); | 
					
						
							| 
									
										
										
										
											2006-04-11 19:05:58 +00:00
										 |  |  | 	} else{ | 
					
						
							|  |  |  | 		printf("import of sys module failed\n"); | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2003-06-28 07:38:21 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | /****************************************************************************
 | 
					
						
							|  |  |  | * Description: This function finishes Python initialization in Blender.	  | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | Because U.pythondir (user defined dir for scripts) isn't	  | 
					
						
							|  |  |  | initialized when BPY_start_Python needs to be executed, we	  | 
					
						
							|  |  |  | postpone adding U.pythondir to sys.path and also BPyMenus	   | 
					
						
							|  |  |  | (mechanism to register scripts in Blender menus) for when   | 
					
						
							|  |  |  | that dir info is available.    | 
					
						
							|  |  |  | ****************************************************************************/ | 
					
						
							|  |  |  | void BPY_post_start_python( void ) | 
					
						
							| 
									
										
										
										
											2003-06-28 10:35:14 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2007-02-09 18:27:20 +00:00
										 |  |  | 	char dirpath[FILE_MAX]; | 
					
						
							| 
									
										
										
										
											2005-03-21 05:26:52 +00:00
										 |  |  | 	char *sdir = NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if(U.pythondir[0] != '\0' ) { | 
					
						
							| 
									
										
										
										
											2007-02-09 18:27:20 +00:00
										 |  |  | 		char modpath[FILE_MAX]; | 
					
						
							| 
									
										
										
										
											2005-03-22 04:28:36 +00:00
										 |  |  | 		int upyslen = strlen(U.pythondir); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* check if user pydir ends with a slash and, if so, remove the slash
 | 
					
						
							|  |  |  | 		 * (for eventual implementations of c library's stat function that might | 
					
						
							|  |  |  | 		 * not like it) */ | 
					
						
							|  |  |  | 		if (upyslen > 2) { /* avoids doing anything if dir == '//' */ | 
					
						
							|  |  |  | 			char ending = U.pythondir[upyslen - 1]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			if (ending == '/' || ending == '\\') | 
					
						
							|  |  |  | 				U.pythondir[upyslen - 1] = '\0'; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2005-03-21 05:26:52 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-02-09 18:27:20 +00:00
										 |  |  | 		BLI_strncpy(dirpath, U.pythondir, FILE_MAX); | 
					
						
							| 
									
										
										
										
											2005-03-21 05:26:52 +00:00
										 |  |  | 		BLI_convertstringcode(dirpath, G.sce, 0); | 
					
						
							|  |  |  | 		syspath_append(dirpath);	/* append to module search path */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-03-22 04:28:36 +00:00
										 |  |  | 		BLI_make_file_string("/", modpath, dirpath, "bpymodules"); | 
					
						
							| 
									
										
										
										
											2005-03-21 05:26:52 +00:00
										 |  |  | 		if (BLI_exists(modpath)) syspath_append(modpath); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	sdir = bpy_gethome(1); | 
					
						
							|  |  |  | 	if (sdir) { | 
					
						
							| 
									
										
										
										
											2004-06-10 03:27:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-03-21 05:26:52 +00:00
										 |  |  | 		syspath_append(sdir); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-03-22 04:28:36 +00:00
										 |  |  | 		BLI_make_file_string("/", dirpath, sdir, "bpymodules"); | 
					
						
							| 
									
										
										
										
											2005-03-21 05:26:52 +00:00
										 |  |  | 		if (BLI_exists(dirpath)) syspath_append(dirpath); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2004-01-23 19:24:45 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	BPyMenu_Init( 0 );	/* get dynamic menus (registered scripts) data */ | 
					
						
							| 
									
										
										
										
											2004-06-10 03:27:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-03-22 04:28:36 +00:00
										 |  |  | 	return; | 
					
						
							| 
									
										
										
										
											2003-06-28 10:35:14 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | /****************************************************************************
 | 
					
						
							|  |  |  | * Description: This function will return the linenumber on which an error   | 
					
						
							|  |  |  | *       	has occurred in the Python script.			 | 
					
						
							|  |  |  | ****************************************************************************/ | 
					
						
							|  |  |  | int BPY_Err_getLinenumber( void ) | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	return g_script_error.lineno; | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-03-08 18:10:20 +00:00
										 |  |  | /*****************************************************************************/ | 
					
						
							|  |  |  | /* Description: This function will return the filename of the python script. */ | 
					
						
							|  |  |  | /*****************************************************************************/ | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | const char *BPY_Err_getFilename( void ) | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	return g_script_error.filename; | 
					
						
							| 
									
										
										
										
											2003-05-13 01:54:28 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*****************************************************************************/ | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | /* Description: Return PyString filename from a traceback object	    */ | 
					
						
							| 
									
										
										
										
											2003-05-13 01:54:28 +00:00
										 |  |  | /*****************************************************************************/ | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | PyObject *traceback_getFilename( PyObject * tb ) | 
					
						
							| 
									
										
										
										
											2003-05-13 01:54:28 +00:00
										 |  |  | { | 
					
						
							| 
									
										
											  
											
												BPython:
- Scripts:
    fixed error in "Save Current Theme" which prevented it from automatically updating script registration in menus.
    cosmetic changes in a couple of Campbell's sel_same.py script strings + more descriptive name for its new menu place (3d view, face mode -> select menu).
    small updates to help_browser.py script.
 The above changes are related to this:
- Added new script menu entries: Render (for exporters to renderers), Themes, FaceSelect (this already at the proper place).  Updated Scripts win->Scripts menu so it won't show all available entries, only  the ones we mean to see there.
- Updated menu registration so that scripts folders can become trees.  The release/scripts/ dir should be updated soon with subdirs like converters/, modifiers/, generators/ or whatever -- better discuss first (or is it? /me afraid of long irc discussions during meetings :) ).
- Modules:
    Blender: added 'udatadir' option to .Get() function and added var Blender.mode to tell if Blender is in bg or interactive mode.
    NMesh: added Campbell's nmesh.transform(matrix, recalc_normals = False) method (reworked, so my fault if it doesn't work).
- Bugs fixed:
    #2123: http://projects.blender.org/tracker/?func=detail&atid=125&aid=2123&group_id=9
    Reported by Ken Hughes (thanks!), who also found the exact problem later (it was in Text.Load, not with script links -- if only I had checked emails these days ... lost > 1 hour today to find the problem: passed filename to M_Text_Load was later being written over by a function called by add_text).  Also saw that Text.Load wasn't checking existence of passed filename (duh!), now it does.
    #1655: http://projects.blender.org/tracker/?func=detail&atid=125&aid=1655&group_id=9
    Reported by Chris Want (thanks!): command line "blender -P script" not working properly for bg mode ("blender -b blendfile -P script").
    Had to make some small updates to get it working (bg mode for scripts was never explicitely handled, it worked due to collateral effects, let's say), interested readers can check the report after I update it or the API_intro.py doc file.  After more testing we can make further updates.  Updated many places to not call redraws if in bg mode, now it is officially available.  Blender outputs its own info when rendering in bg mode, if that is considered a nuissance we'll have to add a few "if (during_script())" calls outside bpython.
- Removed a few warnings here and there and also updated docs.
											
										 
											2005-03-19 06:24:55 +00:00
										 |  |  | 	PyObject *v = NULL; | 
					
						
							| 
									
										
										
										
											2003-05-13 01:54:28 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* co_filename is in f_code, which is in tb_frame, which is in tb */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	v = PyObject_GetAttrString( tb, "tb_frame" ); | 
					
						
							| 
									
										
											  
											
												BPython:
- Scripts:
    fixed error in "Save Current Theme" which prevented it from automatically updating script registration in menus.
    cosmetic changes in a couple of Campbell's sel_same.py script strings + more descriptive name for its new menu place (3d view, face mode -> select menu).
    small updates to help_browser.py script.
 The above changes are related to this:
- Added new script menu entries: Render (for exporters to renderers), Themes, FaceSelect (this already at the proper place).  Updated Scripts win->Scripts menu so it won't show all available entries, only  the ones we mean to see there.
- Updated menu registration so that scripts folders can become trees.  The release/scripts/ dir should be updated soon with subdirs like converters/, modifiers/, generators/ or whatever -- better discuss first (or is it? /me afraid of long irc discussions during meetings :) ).
- Modules:
    Blender: added 'udatadir' option to .Get() function and added var Blender.mode to tell if Blender is in bg or interactive mode.
    NMesh: added Campbell's nmesh.transform(matrix, recalc_normals = False) method (reworked, so my fault if it doesn't work).
- Bugs fixed:
    #2123: http://projects.blender.org/tracker/?func=detail&atid=125&aid=2123&group_id=9
    Reported by Ken Hughes (thanks!), who also found the exact problem later (it was in Text.Load, not with script links -- if only I had checked emails these days ... lost > 1 hour today to find the problem: passed filename to M_Text_Load was later being written over by a function called by add_text).  Also saw that Text.Load wasn't checking existence of passed filename (duh!), now it does.
    #1655: http://projects.blender.org/tracker/?func=detail&atid=125&aid=1655&group_id=9
    Reported by Chris Want (thanks!): command line "blender -P script" not working properly for bg mode ("blender -b blendfile -P script").
    Had to make some small updates to get it working (bg mode for scripts was never explicitely handled, it worked due to collateral effects, let's say), interested readers can check the report after I update it or the API_intro.py doc file.  After more testing we can make further updates.  Updated many places to not call redraws if in bg mode, now it is officially available.  Blender outputs its own info when rendering in bg mode, if that is considered a nuissance we'll have to add a few "if (during_script())" calls outside bpython.
- Removed a few warnings here and there and also updated docs.
											
										 
											2005-03-19 06:24:55 +00:00
										 |  |  | 	if (v) { | 
					
						
							|  |  |  | 		Py_DECREF( v ); | 
					
						
							|  |  |  | 		v = PyObject_GetAttrString( v, "f_code" ); | 
					
						
							|  |  |  | 		if (v) { | 
					
						
							|  |  |  | 			Py_DECREF( v ); | 
					
						
							|  |  |  | 			v = PyObject_GetAttrString( v, "co_filename" ); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2003-05-13 01:54:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												BPython:
- Scripts:
    fixed error in "Save Current Theme" which prevented it from automatically updating script registration in menus.
    cosmetic changes in a couple of Campbell's sel_same.py script strings + more descriptive name for its new menu place (3d view, face mode -> select menu).
    small updates to help_browser.py script.
 The above changes are related to this:
- Added new script menu entries: Render (for exporters to renderers), Themes, FaceSelect (this already at the proper place).  Updated Scripts win->Scripts menu so it won't show all available entries, only  the ones we mean to see there.
- Updated menu registration so that scripts folders can become trees.  The release/scripts/ dir should be updated soon with subdirs like converters/, modifiers/, generators/ or whatever -- better discuss first (or is it? /me afraid of long irc discussions during meetings :) ).
- Modules:
    Blender: added 'udatadir' option to .Get() function and added var Blender.mode to tell if Blender is in bg or interactive mode.
    NMesh: added Campbell's nmesh.transform(matrix, recalc_normals = False) method (reworked, so my fault if it doesn't work).
- Bugs fixed:
    #2123: http://projects.blender.org/tracker/?func=detail&atid=125&aid=2123&group_id=9
    Reported by Ken Hughes (thanks!), who also found the exact problem later (it was in Text.Load, not with script links -- if only I had checked emails these days ... lost > 1 hour today to find the problem: passed filename to M_Text_Load was later being written over by a function called by add_text).  Also saw that Text.Load wasn't checking existence of passed filename (duh!), now it does.
    #1655: http://projects.blender.org/tracker/?func=detail&atid=125&aid=1655&group_id=9
    Reported by Chris Want (thanks!): command line "blender -P script" not working properly for bg mode ("blender -b blendfile -P script").
    Had to make some small updates to get it working (bg mode for scripts was never explicitely handled, it worked due to collateral effects, let's say), interested readers can check the report after I update it or the API_intro.py doc file.  After more testing we can make further updates.  Updated many places to not call redraws if in bg mode, now it is officially available.  Blender outputs its own info when rendering in bg mode, if that is considered a nuissance we'll have to add a few "if (during_script())" calls outside bpython.
- Removed a few warnings here and there and also updated docs.
											
										 
											2005-03-19 06:24:55 +00:00
										 |  |  | 	if (v) return v; | 
					
						
							|  |  |  | 	else return PyString_FromString("unknown"); | 
					
						
							| 
									
										
										
										
											2003-05-13 01:54:28 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | /****************************************************************************
 | 
					
						
							|  |  |  | * Description: Blender Python error handler. This catches the error and	 | 
					
						
							|  |  |  | * stores filename and line number in a global   | 
					
						
							|  |  |  | *****************************************************************************/ | 
					
						
							|  |  |  | void BPY_Err_Handle( char *script_name ) | 
					
						
							| 
									
										
										
										
											2003-05-13 01:54:28 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	PyObject *exception, *err, *tb, *v; | 
					
						
							| 
									
										
										
										
											2003-05-13 01:54:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	if( !script_name ) { | 
					
						
							|  |  |  | 		printf( "Error: script has NULL name\n" ); | 
					
						
							| 
									
										
										
										
											2004-01-14 21:36:10 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	PyErr_Fetch( &exception, &err, &tb ); | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 	if (!script_name) script_name = "untitled"; | 
					
						
							|  |  |  | 	//if( !exception && !tb ) {
 | 
					
						
							|  |  |  | 	//	printf( "FATAL: spurious exception\n" );
 | 
					
						
							|  |  |  | 	//	return;
 | 
					
						
							|  |  |  | 	//}
 | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	strcpy( g_script_error.filename, script_name ); | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	if( exception | 
					
						
							|  |  |  | 	    && PyErr_GivenExceptionMatches( exception, PyExc_SyntaxError ) ) { | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 		/* no traceback available when SyntaxError */ | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		PyErr_Restore( exception, err, tb );	/* takes away reference! */ | 
					
						
							|  |  |  | 		PyErr_Print(  ); | 
					
						
							|  |  |  | 		v = PyObject_GetAttrString( err, "lineno" ); | 
					
						
							|  |  |  | 		if( v ) { | 
					
						
							|  |  |  | 			g_script_error.lineno = PyInt_AsLong( v ); | 
					
						
							|  |  |  | 			Py_DECREF( v ); | 
					
						
							| 
									
										
										
										
											2004-05-05 03:22:22 +00:00
										 |  |  | 		} else { | 
					
						
							|  |  |  | 			g_script_error.lineno = -1; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 		/* this avoids an abort in Python 2.3's garbage collecting: */ | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		PyErr_Clear(  ); | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} else { | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		PyErr_NormalizeException( &exception, &err, &tb ); | 
					
						
							|  |  |  | 		PyErr_Restore( exception, err, tb );	/* takes away reference! */ | 
					
						
							|  |  |  | 		PyErr_Print(  ); | 
					
						
							|  |  |  | 		tb = PySys_GetObject( "last_traceback" ); | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		if( !tb ) { | 
					
						
							|  |  |  | 			printf( "\nCan't get traceback\n" ); | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 			return; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		Py_INCREF( tb ); | 
					
						
							| 
									
										
										
										
											2003-05-13 01:54:28 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* From old bpython BPY_main.c:
 | 
					
						
							|  |  |  |  * 'check traceback objects and look for last traceback in the | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  |  *	same text file. This is used to jump to the line of where the | 
					
						
							|  |  |  |  *	error occured. "If the error occured in another text file or module, | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  |  *	the last frame in the current file is adressed."'  | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-18 03:50:37 +00:00
										 |  |  | 		for(;;) { | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 			v = PyObject_GetAttrString( tb, "tb_next" ); | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												BPython:
- Scripts:
    fixed error in "Save Current Theme" which prevented it from automatically updating script registration in menus.
    cosmetic changes in a couple of Campbell's sel_same.py script strings + more descriptive name for its new menu place (3d view, face mode -> select menu).
    small updates to help_browser.py script.
 The above changes are related to this:
- Added new script menu entries: Render (for exporters to renderers), Themes, FaceSelect (this already at the proper place).  Updated Scripts win->Scripts menu so it won't show all available entries, only  the ones we mean to see there.
- Updated menu registration so that scripts folders can become trees.  The release/scripts/ dir should be updated soon with subdirs like converters/, modifiers/, generators/ or whatever -- better discuss first (or is it? /me afraid of long irc discussions during meetings :) ).
- Modules:
    Blender: added 'udatadir' option to .Get() function and added var Blender.mode to tell if Blender is in bg or interactive mode.
    NMesh: added Campbell's nmesh.transform(matrix, recalc_normals = False) method (reworked, so my fault if it doesn't work).
- Bugs fixed:
    #2123: http://projects.blender.org/tracker/?func=detail&atid=125&aid=2123&group_id=9
    Reported by Ken Hughes (thanks!), who also found the exact problem later (it was in Text.Load, not with script links -- if only I had checked emails these days ... lost > 1 hour today to find the problem: passed filename to M_Text_Load was later being written over by a function called by add_text).  Also saw that Text.Load wasn't checking existence of passed filename (duh!), now it does.
    #1655: http://projects.blender.org/tracker/?func=detail&atid=125&aid=1655&group_id=9
    Reported by Chris Want (thanks!): command line "blender -P script" not working properly for bg mode ("blender -b blendfile -P script").
    Had to make some small updates to get it working (bg mode for scripts was never explicitely handled, it worked due to collateral effects, let's say), interested readers can check the report after I update it or the API_intro.py doc file.  After more testing we can make further updates.  Updated many places to not call redraws if in bg mode, now it is officially available.  Blender outputs its own info when rendering in bg mode, if that is considered a nuissance we'll have to add a few "if (during_script())" calls outside bpython.
- Removed a few warnings here and there and also updated docs.
											
										 
											2005-03-19 06:24:55 +00:00
										 |  |  | 			if( !v || v == Py_None || | 
					
						
							|  |  |  | 				strcmp(PyString_AsString(traceback_getFilename(v)), script_name)) { | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 				break; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 			Py_DECREF( tb ); | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 			tb = v; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		v = PyObject_GetAttrString( tb, "tb_lineno" ); | 
					
						
							| 
									
										
											  
											
												BPython:
- Scripts:
    fixed error in "Save Current Theme" which prevented it from automatically updating script registration in menus.
    cosmetic changes in a couple of Campbell's sel_same.py script strings + more descriptive name for its new menu place (3d view, face mode -> select menu).
    small updates to help_browser.py script.
 The above changes are related to this:
- Added new script menu entries: Render (for exporters to renderers), Themes, FaceSelect (this already at the proper place).  Updated Scripts win->Scripts menu so it won't show all available entries, only  the ones we mean to see there.
- Updated menu registration so that scripts folders can become trees.  The release/scripts/ dir should be updated soon with subdirs like converters/, modifiers/, generators/ or whatever -- better discuss first (or is it? /me afraid of long irc discussions during meetings :) ).
- Modules:
    Blender: added 'udatadir' option to .Get() function and added var Blender.mode to tell if Blender is in bg or interactive mode.
    NMesh: added Campbell's nmesh.transform(matrix, recalc_normals = False) method (reworked, so my fault if it doesn't work).
- Bugs fixed:
    #2123: http://projects.blender.org/tracker/?func=detail&atid=125&aid=2123&group_id=9
    Reported by Ken Hughes (thanks!), who also found the exact problem later (it was in Text.Load, not with script links -- if only I had checked emails these days ... lost > 1 hour today to find the problem: passed filename to M_Text_Load was later being written over by a function called by add_text).  Also saw that Text.Load wasn't checking existence of passed filename (duh!), now it does.
    #1655: http://projects.blender.org/tracker/?func=detail&atid=125&aid=1655&group_id=9
    Reported by Chris Want (thanks!): command line "blender -P script" not working properly for bg mode ("blender -b blendfile -P script").
    Had to make some small updates to get it working (bg mode for scripts was never explicitely handled, it worked due to collateral effects, let's say), interested readers can check the report after I update it or the API_intro.py doc file.  After more testing we can make further updates.  Updated many places to not call redraws if in bg mode, now it is officially available.  Blender outputs its own info when rendering in bg mode, if that is considered a nuissance we'll have to add a few "if (during_script())" calls outside bpython.
- Removed a few warnings here and there and also updated docs.
											
										 
											2005-03-19 06:24:55 +00:00
										 |  |  | 		if (v) { | 
					
						
							|  |  |  | 			g_script_error.lineno = PyInt_AsLong(v); | 
					
						
							|  |  |  | 			Py_DECREF(v); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		v = traceback_getFilename( tb ); | 
					
						
							| 
									
										
											  
											
												BPython:
- Scripts:
    fixed error in "Save Current Theme" which prevented it from automatically updating script registration in menus.
    cosmetic changes in a couple of Campbell's sel_same.py script strings + more descriptive name for its new menu place (3d view, face mode -> select menu).
    small updates to help_browser.py script.
 The above changes are related to this:
- Added new script menu entries: Render (for exporters to renderers), Themes, FaceSelect (this already at the proper place).  Updated Scripts win->Scripts menu so it won't show all available entries, only  the ones we mean to see there.
- Updated menu registration so that scripts folders can become trees.  The release/scripts/ dir should be updated soon with subdirs like converters/, modifiers/, generators/ or whatever -- better discuss first (or is it? /me afraid of long irc discussions during meetings :) ).
- Modules:
    Blender: added 'udatadir' option to .Get() function and added var Blender.mode to tell if Blender is in bg or interactive mode.
    NMesh: added Campbell's nmesh.transform(matrix, recalc_normals = False) method (reworked, so my fault if it doesn't work).
- Bugs fixed:
    #2123: http://projects.blender.org/tracker/?func=detail&atid=125&aid=2123&group_id=9
    Reported by Ken Hughes (thanks!), who also found the exact problem later (it was in Text.Load, not with script links -- if only I had checked emails these days ... lost > 1 hour today to find the problem: passed filename to M_Text_Load was later being written over by a function called by add_text).  Also saw that Text.Load wasn't checking existence of passed filename (duh!), now it does.
    #1655: http://projects.blender.org/tracker/?func=detail&atid=125&aid=1655&group_id=9
    Reported by Chris Want (thanks!): command line "blender -P script" not working properly for bg mode ("blender -b blendfile -P script").
    Had to make some small updates to get it working (bg mode for scripts was never explicitely handled, it worked due to collateral effects, let's say), interested readers can check the report after I update it or the API_intro.py doc file.  After more testing we can make further updates.  Updated many places to not call redraws if in bg mode, now it is officially available.  Blender outputs its own info when rendering in bg mode, if that is considered a nuissance we'll have to add a few "if (during_script())" calls outside bpython.
- Removed a few warnings here and there and also updated docs.
											
										 
											2005-03-19 06:24:55 +00:00
										 |  |  | 		if (v) { | 
					
						
							|  |  |  | 			strncpy( g_script_error.filename, PyString_AsString( v ), | 
					
						
							|  |  |  | 				FILENAME_LENGTH ); | 
					
						
							|  |  |  | 			Py_DECREF(v); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		Py_DECREF( tb ); | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return; | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | /****************************************************************************
 | 
					
						
							|  |  |  | * Description: This function executes the script passed by st.		 | 
					
						
							|  |  |  | * Notes:	It is called by blender/src/drawtext.c when a Blender user   | 
					
						
							|  |  |  | *		presses ALT+PKEY in the script's text window.  | 
					
						
							|  |  |  | *****************************************************************************/ | 
					
						
							|  |  |  | int BPY_txt_do_python_Text( struct Text *text ) | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	PyObject *py_dict, *py_result; | 
					
						
							| 
									
										
										
										
											2004-01-14 21:36:10 +00:00
										 |  |  | 	BPy_constant *info; | 
					
						
							| 
									
										
											  
											
												New scripts:
- hotkeys, obdatacopier and renameobjectbyblock, all from Jean-Michel Soler (jms);
- bevel_center by Loic Berthe, suggested for inclusion by jms;
- doc_browser, by Daniel Dunbar (Zr)
  Thanks to them for the new contributions!
  (I included doc_browser at 'Misc' because only users interested in script writing would actually use it, but it could also be under 'Help'.  Opinions?)
BPython related:
- Added scriptlink methods to object, lamp, camera and world.
- Object: added object.makeTrack and object.clearTrack (old track method).
- sys: made sys.exists(path) return 0 for not found; 1 for file, 2 for dir and -1 for neither.
- doc updates and fixes.
- made ONLOAD event work.  G.f's SCENESCRIPT bit was being zeroed in set_app_data.
- Blender: updated functions Load and Save to support the builtin importers and exporters besides .blend (dxf, videoscape, vrml 1.0, stl, ...)
- Draw: added mouse wheel events.
- Scene: added scene.play to play back animations (like ALT+A and SHIFT+ALT+A).  Makes a good counter, too, when the 'win' attribute is set to a space that doesn't "animate".
The scene.play() addition and the fix to ONLOAD scriptlinks is part of the work for a Blender demo mode.  It already works, but I'll still add support for Radiosity calculations and fix a thing in main(): it executes onload scripts too early (BIF_Init), giving funny results in alt+a animations and renderings when firing up Blender.  Loading after the program is up has no such problems.  When I finish I'll post examples of demo mode scripts.
											
										 
											2004-07-03 05:17:04 +00:00
										 |  |  | 	char textname[24]; | 
					
						
							| 
									
										
										
										
											2003-12-14 01:18:09 +00:00
										 |  |  | 	Script *script = G.main->script.first; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	if( !text ) | 
					
						
							|  |  |  | 		return 0; | 
					
						
							| 
									
										
										
										
											2003-12-14 01:18:09 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* check if this text is already running */ | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	while( script ) { | 
					
						
							|  |  |  | 		if( !strcmp( script->id.name + 2, text->id.name + 2 ) ) { | 
					
						
							|  |  |  | 			/* if this text is already a running script, 
 | 
					
						
							|  |  |  | 			 * just move to it: */ | 
					
						
							| 
									
										
										
										
											2003-12-15 18:18:09 +00:00
										 |  |  | 			SpaceScript *sc; | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 			newspace( curarea, SPACE_SCRIPT ); | 
					
						
							| 
									
										
										
										
											2003-12-15 18:18:09 +00:00
										 |  |  | 			sc = curarea->spacedata.first; | 
					
						
							|  |  |  | 			sc->script = script; | 
					
						
							| 
									
										
										
										
											2003-12-14 01:18:09 +00:00
										 |  |  | 			return 1; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		script = script->id.next; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* Create a new script structure and initialize it: */ | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	script = alloc_libblock( &G.main->script, ID_SCRIPT, GetName( text ) ); | 
					
						
							| 
									
										
										
										
											2003-12-14 01:18:09 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	if( !script ) { | 
					
						
							|  |  |  | 		printf( "couldn't allocate memory for Script struct!" ); | 
					
						
							| 
									
										
										
										
											2003-12-14 01:18:09 +00:00
										 |  |  | 		return 0; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												New scripts:
- hotkeys, obdatacopier and renameobjectbyblock, all from Jean-Michel Soler (jms);
- bevel_center by Loic Berthe, suggested for inclusion by jms;
- doc_browser, by Daniel Dunbar (Zr)
  Thanks to them for the new contributions!
  (I included doc_browser at 'Misc' because only users interested in script writing would actually use it, but it could also be under 'Help'.  Opinions?)
BPython related:
- Added scriptlink methods to object, lamp, camera and world.
- Object: added object.makeTrack and object.clearTrack (old track method).
- sys: made sys.exists(path) return 0 for not found; 1 for file, 2 for dir and -1 for neither.
- doc updates and fixes.
- made ONLOAD event work.  G.f's SCENESCRIPT bit was being zeroed in set_app_data.
- Blender: updated functions Load and Save to support the builtin importers and exporters besides .blend (dxf, videoscape, vrml 1.0, stl, ...)
- Draw: added mouse wheel events.
- Scene: added scene.play to play back animations (like ALT+A and SHIFT+ALT+A).  Makes a good counter, too, when the 'win' attribute is set to a space that doesn't "animate".
The scene.play() addition and the fix to ONLOAD scriptlinks is part of the work for a Blender demo mode.  It already works, but I'll still add support for Radiosity calculations and fix a thing in main(): it executes onload scripts too early (BIF_Init), giving funny results in alt+a animations and renderings when firing up Blender.  Loading after the program is up has no such problems.  When I finish I'll post examples of demo mode scripts.
											
										 
											2004-07-03 05:17:04 +00:00
										 |  |  | 	/* if in the script Blender.Load(blendfile) is not the last command,
 | 
					
						
							|  |  |  | 	 * an error after it will call BPY_Err_Handle below, but the text struct | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	 * will have been deallocated already, so we need to copy its name here. | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	BLI_strncpy( textname, GetName( text ), | 
					
						
							|  |  |  | 		     strlen( GetName( text ) ) + 1 ); | 
					
						
							| 
									
										
											  
											
												New scripts:
- hotkeys, obdatacopier and renameobjectbyblock, all from Jean-Michel Soler (jms);
- bevel_center by Loic Berthe, suggested for inclusion by jms;
- doc_browser, by Daniel Dunbar (Zr)
  Thanks to them for the new contributions!
  (I included doc_browser at 'Misc' because only users interested in script writing would actually use it, but it could also be under 'Help'.  Opinions?)
BPython related:
- Added scriptlink methods to object, lamp, camera and world.
- Object: added object.makeTrack and object.clearTrack (old track method).
- sys: made sys.exists(path) return 0 for not found; 1 for file, 2 for dir and -1 for neither.
- doc updates and fixes.
- made ONLOAD event work.  G.f's SCENESCRIPT bit was being zeroed in set_app_data.
- Blender: updated functions Load and Save to support the builtin importers and exporters besides .blend (dxf, videoscape, vrml 1.0, stl, ...)
- Draw: added mouse wheel events.
- Scene: added scene.play to play back animations (like ALT+A and SHIFT+ALT+A).  Makes a good counter, too, when the 'win' attribute is set to a space that doesn't "animate".
The scene.play() addition and the fix to ONLOAD scriptlinks is part of the work for a Blender demo mode.  It already works, but I'll still add support for Radiosity calculations and fix a thing in main(): it executes onload scripts too early (BIF_Init), giving funny results in alt+a animations and renderings when firing up Blender.  Loading after the program is up has no such problems.  When I finish I'll post examples of demo mode scripts.
											
										 
											2004-07-03 05:17:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-12-14 01:18:09 +00:00
										 |  |  | 	script->id.us = 1; | 
					
						
							|  |  |  | 	script->flags = SCRIPT_RUNNING; | 
					
						
							|  |  |  | 	script->py_draw = NULL; | 
					
						
							|  |  |  | 	script->py_event = NULL; | 
					
						
							|  |  |  | 	script->py_button = NULL; | 
					
						
							| 
									
										
											  
											
												BPython bug fixes:
- #2646 reported by Campbell: Python/Fileselector (moving from fileselector called by script to another space caused script to hang around open but not accessible)
http://projects.blender.org/tracker/?func=detail&atid=125&aid=2646&group_id=9
- #2676 reported by Wim Van Hoydonck: 2.37 python scripts gui: event 8 ignored (thanks Ton for discussing / pointing what to do, Ken Hughes for also working on a fix)
http://projects.blender.org/tracker/?func=detail&atid=125&aid=2676&group_id=9
- gui-less scripts with calls to progress bar inside fileselector callbacks didn't return to the previous space on exit (staying on Scripts win), requiring an event to do so (mouse movement, for example).  Quick fix for now, will rework a little after 2.37a for a better alternative, not needing to move to the Scripts win at all.
- added syntax colors access to Window.Theme module.
Scripts:
- updates by Jean-Michel Soler: svg2obj (svg paths import), tex2uvbaker, fixfromarmature;
- updates by Campbell Barton: obj import / export, console;
- tiny: converted vrml97 export to unix line endings;
- updates in ac3d exporter, help browser, save theme.
Thanks all mentioned above.
											
										 
											2005-06-11 05:30:14 +00:00
										 |  |  | 	script->py_browsercallback = NULL; | 
					
						
							| 
									
										
										
										
											2003-12-14 01:18:09 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	py_dict = CreateGlobalDictionary(  ); | 
					
						
							| 
									
										
										
										
											2003-12-14 01:18:09 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-01-31 03:12:26 +00:00
										 |  |  | 	if( !setup_armature_weakrefs()){ | 
					
						
							|  |  |  | 		printf("Oops - weakref dict\n"); | 
					
						
							| 
									
										
										
										
											2007-01-25 15:19:28 +00:00
										 |  |  | 		return 0; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-12-14 01:18:09 +00:00
										 |  |  | 	script->py_globaldict = py_dict; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-08-17 14:26:00 +00:00
										 |  |  | 	info = ( BPy_constant * ) PyConstant_New(  ); | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	if( info ) { | 
					
						
							| 
									
										
										
										
											2005-08-17 14:26:00 +00:00
										 |  |  | 		PyConstant_Insert( info, "name", | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 				 PyString_FromString( script->id.name + 2 ) ); | 
					
						
							|  |  |  | 		Py_INCREF( Py_None ); | 
					
						
							| 
									
										
										
										
											2005-08-17 14:26:00 +00:00
										 |  |  | 		PyConstant_Insert( info, "arg", Py_None ); | 
					
						
							| 
									
										
										
										
											2005-11-30 08:18:06 +00:00
										 |  |  | 		EXPP_dict_set_item_str( py_dict, "__script__", | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 				      ( PyObject * ) info ); | 
					
						
							| 
									
										
										
										
											2003-12-14 01:18:09 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	py_result = RunPython( text, py_dict );	/* Run the script */ | 
					
						
							| 
									
										
										
										
											2003-05-13 01:54:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	if( !py_result ) {	/* Failed execution of the script */ | 
					
						
							| 
									
										
										
										
											2003-05-13 01:54:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		BPY_Err_Handle( textname ); | 
					
						
							|  |  |  | 		ReleaseGlobalDictionary( py_dict ); | 
					
						
							| 
									
										
										
										
											2004-05-05 03:22:22 +00:00
										 |  |  | 		script->py_globaldict = NULL; | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		if( G.main->script.first ) | 
					
						
							|  |  |  | 			free_libblock( &G.main->script, script ); | 
					
						
							| 
									
										
										
										
											2004-01-14 21:36:10 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 		return 0; | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	} else { | 
					
						
							|  |  |  | 		Py_DECREF( py_result ); | 
					
						
							|  |  |  | 		script->flags &= ~SCRIPT_RUNNING; | 
					
						
							|  |  |  | 		if( !script->flags ) { | 
					
						
							|  |  |  | 			ReleaseGlobalDictionary( py_dict ); | 
					
						
							| 
									
										
										
										
											2004-01-14 21:36:10 +00:00
										 |  |  | 			script->py_globaldict = NULL; | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 			free_libblock( &G.main->script, script ); | 
					
						
							| 
									
										
										
										
											2004-01-14 21:36:10 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	return 1;		/* normal return */ | 
					
						
							| 
									
										
										
										
											2004-01-14 21:36:10 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | /****************************************************************************
 | 
					
						
							|  |  |  | * Description: Called from command line to run a Python script | 
					
						
							| 
									
										
											  
											
												BPython bug fixes:
- #2781, reported by Ed Blake: crash on undo when there were active space handlers. Space Handler script links belong to screen areas, which do not get saved on undo. Thanks Ton for pointing out the function that restores ui pointers gone bad.
- Applied patch #2822 by Ken Hughes for bug #2647 ("Setting a Face UV"), reported by Campbell Barton.
- #3022, reported by Timothy Wakeham: "Blender.BGL.glDrawPixels crashes when drawing more pixels then buffer size". Made glDrawPixels check buffer dimensions.
- #2882, reported by Campbell: crash in nmesh.getMaterials(arg == 0 or 1) when nmesh came from GetRawFromMesh(). Raw nmeshes are not linked to Blender meshes, so the method doesn't support these options (getting mat info from the actual mesh) for it.
- #2817, reported by Tod Koeckeritz: Dir_Depth var was not being decremented in BPY_Menus.c, causing dir depth limits to be reached prematurely.
- #2954, reported by Daniel Holtz: "Python scripts crash hard with valid windows paths". Blender.Load() was not meant for background mode, now it's been update to support it, using BKE_read_file instead of BIF_read_file in this case. Also found another issue with command line scripts using Blender.Load() that could crash Blender: trying to free the Text when it wasn't available anymore (loading a new .blend already removed it). There are still issues with one case, though, causing a crash on start or "Memoryblock winopen: double free" at end, when running a script that is already a Blender Text (only if the script calls Blender.Load, of course). Will investigate.
- #2897: reported by Timothy Wakeham: object.setMaterials was asking the length of a Python list w/o confirming first if the passed obj was really a list.
Thanks all for the help and for being patient (long delay, again).
											
										 
											2005-10-03 19:12:11 +00:00
										 |  |  | * automatically. The script can be a file or a Blender Text in the current  | 
					
						
							|  |  |  | * .blend. | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | ****************************************************************************/ | 
					
						
							|  |  |  | void BPY_run_python_script( char *fn ) | 
					
						
							| 
									
										
										
											
												BPython:
- tentative fix for scripts with CR/LF endings and split lines:
    in 2.32, the ac3d and vrml2 exporters, for example, had lines
    split with '\\\\' and so gave syntax errors when executed on Win
    platforms, because the scripts bundled with Win binaries had dos
    line endings.
- Chris Keith has written code to execute Python scripts from the
  command-line, with '-P ' switch: "blender -P filename":
    a Blender.Quit function was also added, so Blender can quit after
    running the script (end the script with Blender.Quit()), but there's
    still work to be done in this part, including adding more functions,
    to load / save .blend files and to run scripts.  More testing and
    discussions are necessary.
Thanks Chris, for both your contributions and your patience, since I
wasn't available to check / commit this for a while.
											
										 
											2004-03-31 04:18:39 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	Text *text = NULL; | 
					
						
							| 
									
										
											  
											
												BPython:
- Scripts:
    fixed error in "Save Current Theme" which prevented it from automatically updating script registration in menus.
    cosmetic changes in a couple of Campbell's sel_same.py script strings + more descriptive name for its new menu place (3d view, face mode -> select menu).
    small updates to help_browser.py script.
 The above changes are related to this:
- Added new script menu entries: Render (for exporters to renderers), Themes, FaceSelect (this already at the proper place).  Updated Scripts win->Scripts menu so it won't show all available entries, only  the ones we mean to see there.
- Updated menu registration so that scripts folders can become trees.  The release/scripts/ dir should be updated soon with subdirs like converters/, modifiers/, generators/ or whatever -- better discuss first (or is it? /me afraid of long irc discussions during meetings :) ).
- Modules:
    Blender: added 'udatadir' option to .Get() function and added var Blender.mode to tell if Blender is in bg or interactive mode.
    NMesh: added Campbell's nmesh.transform(matrix, recalc_normals = False) method (reworked, so my fault if it doesn't work).
- Bugs fixed:
    #2123: http://projects.blender.org/tracker/?func=detail&atid=125&aid=2123&group_id=9
    Reported by Ken Hughes (thanks!), who also found the exact problem later (it was in Text.Load, not with script links -- if only I had checked emails these days ... lost > 1 hour today to find the problem: passed filename to M_Text_Load was later being written over by a function called by add_text).  Also saw that Text.Load wasn't checking existence of passed filename (duh!), now it does.
    #1655: http://projects.blender.org/tracker/?func=detail&atid=125&aid=1655&group_id=9
    Reported by Chris Want (thanks!): command line "blender -P script" not working properly for bg mode ("blender -b blendfile -P script").
    Had to make some small updates to get it working (bg mode for scripts was never explicitely handled, it worked due to collateral effects, let's say), interested readers can check the report after I update it or the API_intro.py doc file.  After more testing we can make further updates.  Updated many places to not call redraws if in bg mode, now it is officially available.  Blender outputs its own info when rendering in bg mode, if that is considered a nuissance we'll have to add a few "if (during_script())" calls outside bpython.
- Removed a few warnings here and there and also updated docs.
											
										 
											2005-03-19 06:24:55 +00:00
										 |  |  | 	int is_blender_text = 0; | 
					
						
							| 
									
										
											  
											
												New scripts:
- hotkeys, obdatacopier and renameobjectbyblock, all from Jean-Michel Soler (jms);
- bevel_center by Loic Berthe, suggested for inclusion by jms;
- doc_browser, by Daniel Dunbar (Zr)
  Thanks to them for the new contributions!
  (I included doc_browser at 'Misc' because only users interested in script writing would actually use it, but it could also be under 'Help'.  Opinions?)
BPython related:
- Added scriptlink methods to object, lamp, camera and world.
- Object: added object.makeTrack and object.clearTrack (old track method).
- sys: made sys.exists(path) return 0 for not found; 1 for file, 2 for dir and -1 for neither.
- doc updates and fixes.
- made ONLOAD event work.  G.f's SCENESCRIPT bit was being zeroed in set_app_data.
- Blender: updated functions Load and Save to support the builtin importers and exporters besides .blend (dxf, videoscape, vrml 1.0, stl, ...)
- Draw: added mouse wheel events.
- Scene: added scene.play to play back animations (like ALT+A and SHIFT+ALT+A).  Makes a good counter, too, when the 'win' attribute is set to a space that doesn't "animate".
The scene.play() addition and the fix to ONLOAD scriptlinks is part of the work for a Blender demo mode.  It already works, but I'll still add support for Radiosity calculations and fix a thing in main(): it executes onload scripts too early (BIF_Init), giving funny results in alt+a animations and renderings when firing up Blender.  Loading after the program is up has no such problems.  When I finish I'll post examples of demo mode scripts.
											
										 
											2004-07-03 05:17:04 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												BPython:
- Scripts:
    fixed error in "Save Current Theme" which prevented it from automatically updating script registration in menus.
    cosmetic changes in a couple of Campbell's sel_same.py script strings + more descriptive name for its new menu place (3d view, face mode -> select menu).
    small updates to help_browser.py script.
 The above changes are related to this:
- Added new script menu entries: Render (for exporters to renderers), Themes, FaceSelect (this already at the proper place).  Updated Scripts win->Scripts menu so it won't show all available entries, only  the ones we mean to see there.
- Updated menu registration so that scripts folders can become trees.  The release/scripts/ dir should be updated soon with subdirs like converters/, modifiers/, generators/ or whatever -- better discuss first (or is it? /me afraid of long irc discussions during meetings :) ).
- Modules:
    Blender: added 'udatadir' option to .Get() function and added var Blender.mode to tell if Blender is in bg or interactive mode.
    NMesh: added Campbell's nmesh.transform(matrix, recalc_normals = False) method (reworked, so my fault if it doesn't work).
- Bugs fixed:
    #2123: http://projects.blender.org/tracker/?func=detail&atid=125&aid=2123&group_id=9
    Reported by Ken Hughes (thanks!), who also found the exact problem later (it was in Text.Load, not with script links -- if only I had checked emails these days ... lost > 1 hour today to find the problem: passed filename to M_Text_Load was later being written over by a function called by add_text).  Also saw that Text.Load wasn't checking existence of passed filename (duh!), now it does.
    #1655: http://projects.blender.org/tracker/?func=detail&atid=125&aid=1655&group_id=9
    Reported by Chris Want (thanks!): command line "blender -P script" not working properly for bg mode ("blender -b blendfile -P script").
    Had to make some small updates to get it working (bg mode for scripts was never explicitely handled, it worked due to collateral effects, let's say), interested readers can check the report after I update it or the API_intro.py doc file.  After more testing we can make further updates.  Updated many places to not call redraws if in bg mode, now it is officially available.  Blender outputs its own info when rendering in bg mode, if that is considered a nuissance we'll have to add a few "if (during_script())" calls outside bpython.
- Removed a few warnings here and there and also updated docs.
											
										 
											2005-03-19 06:24:55 +00:00
										 |  |  | 	if (!BLI_exists(fn)) {	/* if there's no such filename ... */ | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		text = G.main->text.first;	/* try an already existing Blender Text */ | 
					
						
							| 
									
										
											  
											
												BPython:
- Scripts:
    fixed error in "Save Current Theme" which prevented it from automatically updating script registration in menus.
    cosmetic changes in a couple of Campbell's sel_same.py script strings + more descriptive name for its new menu place (3d view, face mode -> select menu).
    small updates to help_browser.py script.
 The above changes are related to this:
- Added new script menu entries: Render (for exporters to renderers), Themes, FaceSelect (this already at the proper place).  Updated Scripts win->Scripts menu so it won't show all available entries, only  the ones we mean to see there.
- Updated menu registration so that scripts folders can become trees.  The release/scripts/ dir should be updated soon with subdirs like converters/, modifiers/, generators/ or whatever -- better discuss first (or is it? /me afraid of long irc discussions during meetings :) ).
- Modules:
    Blender: added 'udatadir' option to .Get() function and added var Blender.mode to tell if Blender is in bg or interactive mode.
    NMesh: added Campbell's nmesh.transform(matrix, recalc_normals = False) method (reworked, so my fault if it doesn't work).
- Bugs fixed:
    #2123: http://projects.blender.org/tracker/?func=detail&atid=125&aid=2123&group_id=9
    Reported by Ken Hughes (thanks!), who also found the exact problem later (it was in Text.Load, not with script links -- if only I had checked emails these days ... lost > 1 hour today to find the problem: passed filename to M_Text_Load was later being written over by a function called by add_text).  Also saw that Text.Load wasn't checking existence of passed filename (duh!), now it does.
    #1655: http://projects.blender.org/tracker/?func=detail&atid=125&aid=1655&group_id=9
    Reported by Chris Want (thanks!): command line "blender -P script" not working properly for bg mode ("blender -b blendfile -P script").
    Had to make some small updates to get it working (bg mode for scripts was never explicitely handled, it worked due to collateral effects, let's say), interested readers can check the report after I update it or the API_intro.py doc file.  After more testing we can make further updates.  Updated many places to not call redraws if in bg mode, now it is officially available.  Blender outputs its own info when rendering in bg mode, if that is considered a nuissance we'll have to add a few "if (during_script())" calls outside bpython.
- Removed a few warnings here and there and also updated docs.
											
										 
											2005-03-19 06:24:55 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		while (text) { | 
					
						
							|  |  |  | 			if (!strcmp(fn, text->id.name + 2)) break; | 
					
						
							| 
									
										
											  
											
												New scripts:
- hotkeys, obdatacopier and renameobjectbyblock, all from Jean-Michel Soler (jms);
- bevel_center by Loic Berthe, suggested for inclusion by jms;
- doc_browser, by Daniel Dunbar (Zr)
  Thanks to them for the new contributions!
  (I included doc_browser at 'Misc' because only users interested in script writing would actually use it, but it could also be under 'Help'.  Opinions?)
BPython related:
- Added scriptlink methods to object, lamp, camera and world.
- Object: added object.makeTrack and object.clearTrack (old track method).
- sys: made sys.exists(path) return 0 for not found; 1 for file, 2 for dir and -1 for neither.
- doc updates and fixes.
- made ONLOAD event work.  G.f's SCENESCRIPT bit was being zeroed in set_app_data.
- Blender: updated functions Load and Save to support the builtin importers and exporters besides .blend (dxf, videoscape, vrml 1.0, stl, ...)
- Draw: added mouse wheel events.
- Scene: added scene.play to play back animations (like ALT+A and SHIFT+ALT+A).  Makes a good counter, too, when the 'win' attribute is set to a space that doesn't "animate".
The scene.play() addition and the fix to ONLOAD scriptlinks is part of the work for a Blender demo mode.  It already works, but I'll still add support for Radiosity calculations and fix a thing in main(): it executes onload scripts too early (BIF_Init), giving funny results in alt+a animations and renderings when firing up Blender.  Loading after the program is up has no such problems.  When I finish I'll post examples of demo mode scripts.
											
										 
											2004-07-03 05:17:04 +00:00
										 |  |  | 			text = text->id.next; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
											
												BPython:
- tentative fix for scripts with CR/LF endings and split lines:
    in 2.32, the ac3d and vrml2 exporters, for example, had lines
    split with '\\\\' and so gave syntax errors when executed on Win
    platforms, because the scripts bundled with Win binaries had dos
    line endings.
- Chris Keith has written code to execute Python scripts from the
  command-line, with '-P ' switch: "blender -P filename":
    a Blender.Quit function was also added, so Blender can quit after
    running the script (end the script with Blender.Quit()), but there's
    still work to be done in this part, including adding more functions,
    to load / save .blend files and to run scripts.  More testing and
    discussions are necessary.
Thanks Chris, for both your contributions and your patience, since I
wasn't available to check / commit this for a while.
											
										 
											2004-03-31 04:18:39 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												BPython:
- Scripts:
    fixed error in "Save Current Theme" which prevented it from automatically updating script registration in menus.
    cosmetic changes in a couple of Campbell's sel_same.py script strings + more descriptive name for its new menu place (3d view, face mode -> select menu).
    small updates to help_browser.py script.
 The above changes are related to this:
- Added new script menu entries: Render (for exporters to renderers), Themes, FaceSelect (this already at the proper place).  Updated Scripts win->Scripts menu so it won't show all available entries, only  the ones we mean to see there.
- Updated menu registration so that scripts folders can become trees.  The release/scripts/ dir should be updated soon with subdirs like converters/, modifiers/, generators/ or whatever -- better discuss first (or is it? /me afraid of long irc discussions during meetings :) ).
- Modules:
    Blender: added 'udatadir' option to .Get() function and added var Blender.mode to tell if Blender is in bg or interactive mode.
    NMesh: added Campbell's nmesh.transform(matrix, recalc_normals = False) method (reworked, so my fault if it doesn't work).
- Bugs fixed:
    #2123: http://projects.blender.org/tracker/?func=detail&atid=125&aid=2123&group_id=9
    Reported by Ken Hughes (thanks!), who also found the exact problem later (it was in Text.Load, not with script links -- if only I had checked emails these days ... lost > 1 hour today to find the problem: passed filename to M_Text_Load was later being written over by a function called by add_text).  Also saw that Text.Load wasn't checking existence of passed filename (duh!), now it does.
    #1655: http://projects.blender.org/tracker/?func=detail&atid=125&aid=1655&group_id=9
    Reported by Chris Want (thanks!): command line "blender -P script" not working properly for bg mode ("blender -b blendfile -P script").
    Had to make some small updates to get it working (bg mode for scripts was never explicitely handled, it worked due to collateral effects, let's say), interested readers can check the report after I update it or the API_intro.py doc file.  After more testing we can make further updates.  Updated many places to not call redraws if in bg mode, now it is officially available.  Blender outputs its own info when rendering in bg mode, if that is considered a nuissance we'll have to add a few "if (during_script())" calls outside bpython.
- Removed a few warnings here and there and also updated docs.
											
										 
											2005-03-19 06:24:55 +00:00
										 |  |  | 		if (text == NULL) { | 
					
						
							|  |  |  | 			printf("\nError: no such file or Blender text -- %s.\n", fn); | 
					
						
							| 
									
										
											  
											
												New scripts:
- hotkeys, obdatacopier and renameobjectbyblock, all from Jean-Michel Soler (jms);
- bevel_center by Loic Berthe, suggested for inclusion by jms;
- doc_browser, by Daniel Dunbar (Zr)
  Thanks to them for the new contributions!
  (I included doc_browser at 'Misc' because only users interested in script writing would actually use it, but it could also be under 'Help'.  Opinions?)
BPython related:
- Added scriptlink methods to object, lamp, camera and world.
- Object: added object.makeTrack and object.clearTrack (old track method).
- sys: made sys.exists(path) return 0 for not found; 1 for file, 2 for dir and -1 for neither.
- doc updates and fixes.
- made ONLOAD event work.  G.f's SCENESCRIPT bit was being zeroed in set_app_data.
- Blender: updated functions Load and Save to support the builtin importers and exporters besides .blend (dxf, videoscape, vrml 1.0, stl, ...)
- Draw: added mouse wheel events.
- Scene: added scene.play to play back animations (like ALT+A and SHIFT+ALT+A).  Makes a good counter, too, when the 'win' attribute is set to a space that doesn't "animate".
The scene.play() addition and the fix to ONLOAD scriptlinks is part of the work for a Blender demo mode.  It already works, but I'll still add support for Radiosity calculations and fix a thing in main(): it executes onload scripts too early (BIF_Init), giving funny results in alt+a animations and renderings when firing up Blender.  Loading after the program is up has no such problems.  When I finish I'll post examples of demo mode scripts.
											
										 
											2004-07-03 05:17:04 +00:00
										 |  |  | 			return; | 
					
						
							| 
									
										
											  
											
												BPython:
- Scripts:
    fixed error in "Save Current Theme" which prevented it from automatically updating script registration in menus.
    cosmetic changes in a couple of Campbell's sel_same.py script strings + more descriptive name for its new menu place (3d view, face mode -> select menu).
    small updates to help_browser.py script.
 The above changes are related to this:
- Added new script menu entries: Render (for exporters to renderers), Themes, FaceSelect (this already at the proper place).  Updated Scripts win->Scripts menu so it won't show all available entries, only  the ones we mean to see there.
- Updated menu registration so that scripts folders can become trees.  The release/scripts/ dir should be updated soon with subdirs like converters/, modifiers/, generators/ or whatever -- better discuss first (or is it? /me afraid of long irc discussions during meetings :) ).
- Modules:
    Blender: added 'udatadir' option to .Get() function and added var Blender.mode to tell if Blender is in bg or interactive mode.
    NMesh: added Campbell's nmesh.transform(matrix, recalc_normals = False) method (reworked, so my fault if it doesn't work).
- Bugs fixed:
    #2123: http://projects.blender.org/tracker/?func=detail&atid=125&aid=2123&group_id=9
    Reported by Ken Hughes (thanks!), who also found the exact problem later (it was in Text.Load, not with script links -- if only I had checked emails these days ... lost > 1 hour today to find the problem: passed filename to M_Text_Load was later being written over by a function called by add_text).  Also saw that Text.Load wasn't checking existence of passed filename (duh!), now it does.
    #1655: http://projects.blender.org/tracker/?func=detail&atid=125&aid=1655&group_id=9
    Reported by Chris Want (thanks!): command line "blender -P script" not working properly for bg mode ("blender -b blendfile -P script").
    Had to make some small updates to get it working (bg mode for scripts was never explicitely handled, it worked due to collateral effects, let's say), interested readers can check the report after I update it or the API_intro.py doc file.  After more testing we can make further updates.  Updated many places to not call redraws if in bg mode, now it is officially available.  Blender outputs its own info when rendering in bg mode, if that is considered a nuissance we'll have to add a few "if (during_script())" calls outside bpython.
- Removed a few warnings here and there and also updated docs.
											
										 
											2005-03-19 06:24:55 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 		else is_blender_text = 1;	/* fn is already a Blender Text */ | 
					
						
							| 
									
										
										
											
												BPython:
- tentative fix for scripts with CR/LF endings and split lines:
    in 2.32, the ac3d and vrml2 exporters, for example, had lines
    split with '\\\\' and so gave syntax errors when executed on Win
    platforms, because the scripts bundled with Win binaries had dos
    line endings.
- Chris Keith has written code to execute Python scripts from the
  command-line, with '-P ' switch: "blender -P filename":
    a Blender.Quit function was also added, so Blender can quit after
    running the script (end the script with Blender.Quit()), but there's
    still work to be done in this part, including adding more functions,
    to load / save .blend files and to run scripts.  More testing and
    discussions are necessary.
Thanks Chris, for both your contributions and your patience, since I
wasn't available to check / commit this for a while.
											
										 
											2004-03-31 04:18:39 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												BPython:
- Scripts:
    fixed error in "Save Current Theme" which prevented it from automatically updating script registration in menus.
    cosmetic changes in a couple of Campbell's sel_same.py script strings + more descriptive name for its new menu place (3d view, face mode -> select menu).
    small updates to help_browser.py script.
 The above changes are related to this:
- Added new script menu entries: Render (for exporters to renderers), Themes, FaceSelect (this already at the proper place).  Updated Scripts win->Scripts menu so it won't show all available entries, only  the ones we mean to see there.
- Updated menu registration so that scripts folders can become trees.  The release/scripts/ dir should be updated soon with subdirs like converters/, modifiers/, generators/ or whatever -- better discuss first (or is it? /me afraid of long irc discussions during meetings :) ).
- Modules:
    Blender: added 'udatadir' option to .Get() function and added var Blender.mode to tell if Blender is in bg or interactive mode.
    NMesh: added Campbell's nmesh.transform(matrix, recalc_normals = False) method (reworked, so my fault if it doesn't work).
- Bugs fixed:
    #2123: http://projects.blender.org/tracker/?func=detail&atid=125&aid=2123&group_id=9
    Reported by Ken Hughes (thanks!), who also found the exact problem later (it was in Text.Load, not with script links -- if only I had checked emails these days ... lost > 1 hour today to find the problem: passed filename to M_Text_Load was later being written over by a function called by add_text).  Also saw that Text.Load wasn't checking existence of passed filename (duh!), now it does.
    #1655: http://projects.blender.org/tracker/?func=detail&atid=125&aid=1655&group_id=9
    Reported by Chris Want (thanks!): command line "blender -P script" not working properly for bg mode ("blender -b blendfile -P script").
    Had to make some small updates to get it working (bg mode for scripts was never explicitely handled, it worked due to collateral effects, let's say), interested readers can check the report after I update it or the API_intro.py doc file.  After more testing we can make further updates.  Updated many places to not call redraws if in bg mode, now it is officially available.  Blender outputs its own info when rendering in bg mode, if that is considered a nuissance we'll have to add a few "if (during_script())" calls outside bpython.
- Removed a few warnings here and there and also updated docs.
											
										 
											2005-03-19 06:24:55 +00:00
										 |  |  | 	else { | 
					
						
							|  |  |  | 		text = add_text(fn); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (text == NULL) { | 
					
						
							|  |  |  | 			printf("\nError in BPY_run_python_script:\n" | 
					
						
							|  |  |  | 				"couldn't create Blender text from %s\n", fn); | 
					
						
							|  |  |  | 		/* Chris: On Windows if I continue I just get a segmentation
 | 
					
						
							|  |  |  | 		 * violation.  To get a baseline file I exit here. */ | 
					
						
							|  |  |  | 		exit(2); | 
					
						
							|  |  |  | 		/* return; */ | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
											
												BPython:
- tentative fix for scripts with CR/LF endings and split lines:
    in 2.32, the ac3d and vrml2 exporters, for example, had lines
    split with '\\\\' and so gave syntax errors when executed on Win
    platforms, because the scripts bundled with Win binaries had dos
    line endings.
- Chris Keith has written code to execute Python scripts from the
  command-line, with '-P ' switch: "blender -P filename":
    a Blender.Quit function was also added, so Blender can quit after
    running the script (end the script with Blender.Quit()), but there's
    still work to be done in this part, including adding more functions,
    to load / save .blend files and to run scripts.  More testing and
    discussions are necessary.
Thanks Chris, for both your contributions and your patience, since I
wasn't available to check / commit this for a while.
											
										 
											2004-03-31 04:18:39 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												BPython:
- Scripts:
    fixed error in "Save Current Theme" which prevented it from automatically updating script registration in menus.
    cosmetic changes in a couple of Campbell's sel_same.py script strings + more descriptive name for its new menu place (3d view, face mode -> select menu).
    small updates to help_browser.py script.
 The above changes are related to this:
- Added new script menu entries: Render (for exporters to renderers), Themes, FaceSelect (this already at the proper place).  Updated Scripts win->Scripts menu so it won't show all available entries, only  the ones we mean to see there.
- Updated menu registration so that scripts folders can become trees.  The release/scripts/ dir should be updated soon with subdirs like converters/, modifiers/, generators/ or whatever -- better discuss first (or is it? /me afraid of long irc discussions during meetings :) ).
- Modules:
    Blender: added 'udatadir' option to .Get() function and added var Blender.mode to tell if Blender is in bg or interactive mode.
    NMesh: added Campbell's nmesh.transform(matrix, recalc_normals = False) method (reworked, so my fault if it doesn't work).
- Bugs fixed:
    #2123: http://projects.blender.org/tracker/?func=detail&atid=125&aid=2123&group_id=9
    Reported by Ken Hughes (thanks!), who also found the exact problem later (it was in Text.Load, not with script links -- if only I had checked emails these days ... lost > 1 hour today to find the problem: passed filename to M_Text_Load was later being written over by a function called by add_text).  Also saw that Text.Load wasn't checking existence of passed filename (duh!), now it does.
    #1655: http://projects.blender.org/tracker/?func=detail&atid=125&aid=1655&group_id=9
    Reported by Chris Want (thanks!): command line "blender -P script" not working properly for bg mode ("blender -b blendfile -P script").
    Had to make some small updates to get it working (bg mode for scripts was never explicitely handled, it worked due to collateral effects, let's say), interested readers can check the report after I update it or the API_intro.py doc file.  After more testing we can make further updates.  Updated many places to not call redraws if in bg mode, now it is officially available.  Blender outputs its own info when rendering in bg mode, if that is considered a nuissance we'll have to add a few "if (during_script())" calls outside bpython.
- Removed a few warnings here and there and also updated docs.
											
										 
											2005-03-19 06:24:55 +00:00
										 |  |  | 	if (BPY_txt_do_python_Text(text) != 1) { | 
					
						
							|  |  |  | 		printf("\nError executing Python script from command-line:\n" | 
					
						
							|  |  |  | 			"%s (at line %d).\n", fn, BPY_Err_getLinenumber()); | 
					
						
							| 
									
										
										
											
												BPython:
- tentative fix for scripts with CR/LF endings and split lines:
    in 2.32, the ac3d and vrml2 exporters, for example, had lines
    split with '\\\\' and so gave syntax errors when executed on Win
    platforms, because the scripts bundled with Win binaries had dos
    line endings.
- Chris Keith has written code to execute Python scripts from the
  command-line, with '-P ' switch: "blender -P filename":
    a Blender.Quit function was also added, so Blender can quit after
    running the script (end the script with Blender.Quit()), but there's
    still work to be done in this part, including adding more functions,
    to load / save .blend files and to run scripts.  More testing and
    discussions are necessary.
Thanks Chris, for both your contributions and your patience, since I
wasn't available to check / commit this for a while.
											
										 
											2004-03-31 04:18:39 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												BPython bug fixes:
- #2781, reported by Ed Blake: crash on undo when there were active space handlers. Space Handler script links belong to screen areas, which do not get saved on undo. Thanks Ton for pointing out the function that restores ui pointers gone bad.
- Applied patch #2822 by Ken Hughes for bug #2647 ("Setting a Face UV"), reported by Campbell Barton.
- #3022, reported by Timothy Wakeham: "Blender.BGL.glDrawPixels crashes when drawing more pixels then buffer size". Made glDrawPixels check buffer dimensions.
- #2882, reported by Campbell: crash in nmesh.getMaterials(arg == 0 or 1) when nmesh came from GetRawFromMesh(). Raw nmeshes are not linked to Blender meshes, so the method doesn't support these options (getting mat info from the actual mesh) for it.
- #2817, reported by Tod Koeckeritz: Dir_Depth var was not being decremented in BPY_Menus.c, causing dir depth limits to be reached prematurely.
- #2954, reported by Daniel Holtz: "Python scripts crash hard with valid windows paths". Blender.Load() was not meant for background mode, now it's been update to support it, using BKE_read_file instead of BIF_read_file in this case. Also found another issue with command line scripts using Blender.Load() that could crash Blender: trying to free the Text when it wasn't available anymore (loading a new .blend already removed it). There are still issues with one case, though, causing a crash on start or "Memoryblock winopen: double free" at end, when running a script that is already a Blender Text (only if the script calls Blender.Load, of course). Will investigate.
- #2897: reported by Timothy Wakeham: object.setMaterials was asking the length of a Python list w/o confirming first if the passed obj was really a list.
Thanks all for the help and for being patient (long delay, again).
											
										 
											2005-10-03 19:12:11 +00:00
										 |  |  | 	if (!is_blender_text) { | 
					
						
							|  |  |  | 		/* We can't simply free the text, since the script might have called
 | 
					
						
							|  |  |  | 		 * Blender.Load() to load a new .blend, freeing previous data. | 
					
						
							|  |  |  | 		 * So we check if the pointer is still valid. */ | 
					
						
							|  |  |  | 		Text *txtptr = G.main->text.first; | 
					
						
							|  |  |  | 		while (txtptr) { | 
					
						
							|  |  |  | 			if (txtptr == text) { | 
					
						
							|  |  |  | 				free_libblock(&G.main->text, text); | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			txtptr = txtptr->id.next; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
											
												BPython:
- tentative fix for scripts with CR/LF endings and split lines:
    in 2.32, the ac3d and vrml2 exporters, for example, had lines
    split with '\\\\' and so gave syntax errors when executed on Win
    platforms, because the scripts bundled with Win binaries had dos
    line endings.
- Chris Keith has written code to execute Python scripts from the
  command-line, with '-P ' switch: "blender -P filename":
    a Blender.Quit function was also added, so Blender can quit after
    running the script (end the script with Blender.Quit()), but there's
    still work to be done in this part, including adding more functions,
    to load / save .blend files and to run scripts.  More testing and
    discussions are necessary.
Thanks Chris, for both your contributions and your patience, since I
wasn't available to check / commit this for a while.
											
										 
											2004-03-31 04:18:39 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | /****************************************************************************
 | 
					
						
							|  |  |  | * Description: This function executes the script chosen from a menu. | 
					
						
							|  |  |  | * Notes:	It is called by the ui code in src/header_???.c when a user   | 
					
						
							|  |  |  | *		clicks on a menu entry that refers to a script. | 
					
						
							|  |  |  | *		Scripts are searched in the BPyMenuTable, using the given | 
					
						
							|  |  |  | *		menutype and event values to know which one was chosen.	 | 
					
						
							|  |  |  | *****************************************************************************/ | 
					
						
							|  |  |  | int BPY_menu_do_python( short menutype, int event ) | 
					
						
							| 
									
										
										
										
											2004-01-14 21:36:10 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	PyObject *py_dict, *py_res, *pyarg = NULL; | 
					
						
							| 
									
										
										
										
											2004-01-14 21:36:10 +00:00
										 |  |  | 	BPy_constant *info; | 
					
						
							|  |  |  | 	BPyMenu *pym; | 
					
						
							|  |  |  | 	BPySubMenu *pysm; | 
					
						
							|  |  |  | 	FILE *fp = NULL; | 
					
						
							| 
									
										
										
										
											2004-01-27 09:30:29 +00:00
										 |  |  | 	char *buffer, *s; | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	char filestr[FILE_MAXDIR + FILE_MAXFILE]; | 
					
						
							| 
									
										
										
										
											2004-11-09 14:07:25 +00:00
										 |  |  | 	char scriptname[21]; | 
					
						
							|  |  |  | 	Script *script = NULL; | 
					
						
							| 
									
										
										
										
											2004-01-18 15:08:02 +00:00
										 |  |  | 	int len; | 
					
						
							| 
									
										
										
										
											2004-01-14 21:36:10 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	pym = BPyMenu_GetEntry( menutype, ( short ) event ); | 
					
						
							| 
									
										
										
										
											2004-01-14 21:36:10 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	if( !pym ) | 
					
						
							|  |  |  | 		return 0; | 
					
						
							| 
									
										
										
										
											2004-08-04 06:16:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	if( pym->version > G.version ) | 
					
						
							|  |  |  | 		notice( "Version mismatch: script was written for Blender %d. " | 
					
						
							|  |  |  | 			"It may fail with yours: %d.", pym->version, | 
					
						
							|  |  |  | 			G.version ); | 
					
						
							| 
									
										
										
										
											2004-08-04 06:16:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-14 21:36:10 +00:00
										 |  |  | /* if there are submenus, let the user choose one from a pupmenu that we
 | 
					
						
							|  |  |  |  * create here.*/ | 
					
						
							|  |  |  | 	pysm = pym->submenus; | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	if( pysm ) { | 
					
						
							|  |  |  | 		char *pupstr; | 
					
						
							| 
									
										
										
										
											2004-01-14 21:36:10 +00:00
										 |  |  | 		int arg; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		pupstr = BPyMenu_CreatePupmenuStr( pym, menutype ); | 
					
						
							| 
									
										
										
										
											2004-01-14 21:36:10 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		if( pupstr ) { | 
					
						
							|  |  |  | 			arg = pupmenu( pupstr ); | 
					
						
							|  |  |  | 			MEM_freeN( pupstr ); | 
					
						
							| 
									
										
										
										
											2004-01-14 21:36:10 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 			if( arg >= 0 ) { | 
					
						
							|  |  |  | 				while( arg-- ) | 
					
						
							|  |  |  | 					pysm = pysm->next; | 
					
						
							|  |  |  | 				pyarg = PyString_FromString( pysm->arg ); | 
					
						
							|  |  |  | 			} else | 
					
						
							|  |  |  | 				return 0; | 
					
						
							| 
									
										
										
										
											2004-01-14 21:36:10 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-03-21 05:26:52 +00:00
										 |  |  | 	if( !pyarg ) { /* no submenus */ | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		Py_INCREF( Py_None ); | 
					
						
							| 
									
										
										
										
											2004-01-14 21:36:10 +00:00
										 |  |  | 		pyarg = Py_None; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-03-21 05:26:52 +00:00
										 |  |  | 	if( pym->dir ) { /* script is in U.pythondir */ | 
					
						
							|  |  |  | 		char upythondir[FILE_MAXDIR]; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* dirs in Blender can be "//", which has a special meaning */ | 
					
						
							|  |  |  | 		BLI_strncpy(upythondir, U.pythondir, FILE_MAXDIR); | 
					
						
							|  |  |  | 		BLI_convertstringcode(upythondir, G.sce, 0); /* if so, this expands it */ | 
					
						
							|  |  |  | 		BLI_make_file_string( "/", filestr, upythondir, pym->filename ); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { /* script is in default scripts dir */ | 
					
						
							|  |  |  | 		char *scriptsdir = bpy_gethome(1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if (!scriptsdir) { | 
					
						
							|  |  |  | 			printf("Error loading script: can't find default scripts dir!"); | 
					
						
							|  |  |  | 			return 0; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		BLI_make_file_string( "/", filestr, scriptsdir, pym->filename ); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2004-01-20 04:57:47 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	fp = fopen( filestr, "rb" ); | 
					
						
							|  |  |  | 	if( !fp ) { | 
					
						
							|  |  |  | 		printf( "Error loading script: couldn't open file %s\n", | 
					
						
							|  |  |  | 			filestr ); | 
					
						
							| 
									
										
										
										
											2004-01-14 21:36:10 +00:00
										 |  |  | 		return 0; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-11-09 14:07:25 +00:00
										 |  |  | 	BLI_strncpy(scriptname, pym->name, 21); | 
					
						
							|  |  |  | 	len = strlen(scriptname) - 1; | 
					
						
							|  |  |  | 	/* by convention, scripts that open the file browser or have submenus
 | 
					
						
							|  |  |  | 	 * display '...'.  Here we remove them from the datablock name */ | 
					
						
							|  |  |  | 	while ((len > 0) && scriptname[len] == '.') { | 
					
						
							|  |  |  | 		scriptname[len] = '\0'; | 
					
						
							|  |  |  | 		len--; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2004-01-14 21:36:10 +00:00
										 |  |  | 	/* Create a new script structure and initialize it: */ | 
					
						
							| 
									
										
										
										
											2004-11-09 14:07:25 +00:00
										 |  |  | 	script = alloc_libblock( &G.main->script, ID_SCRIPT, scriptname ); | 
					
						
							| 
									
										
										
										
											2004-01-14 21:36:10 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	if( !script ) { | 
					
						
							|  |  |  | 		printf( "couldn't allocate memory for Script struct!" ); | 
					
						
							|  |  |  | 		fclose( fp ); | 
					
						
							| 
									
										
										
										
											2004-01-14 21:36:10 +00:00
										 |  |  | 		return 0; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-06-10 03:27:46 +00:00
										 |  |  | 	/* let's find a proper area for an eventual script gui:
 | 
					
						
							| 
									
										
										
										
											2004-06-11 09:17:49 +00:00
										 |  |  | 	 * (still experimenting here, need definition on which win | 
					
						
							|  |  |  | 	 * each group will be put to code this properly) */ | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	switch ( menutype ) { | 
					
						
							| 
									
										
										
										
											2004-06-10 03:27:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												BPython:
- Scripts:
    fixed error in "Save Current Theme" which prevented it from automatically updating script registration in menus.
    cosmetic changes in a couple of Campbell's sel_same.py script strings + more descriptive name for its new menu place (3d view, face mode -> select menu).
    small updates to help_browser.py script.
 The above changes are related to this:
- Added new script menu entries: Render (for exporters to renderers), Themes, FaceSelect (this already at the proper place).  Updated Scripts win->Scripts menu so it won't show all available entries, only  the ones we mean to see there.
- Updated menu registration so that scripts folders can become trees.  The release/scripts/ dir should be updated soon with subdirs like converters/, modifiers/, generators/ or whatever -- better discuss first (or is it? /me afraid of long irc discussions during meetings :) ).
- Modules:
    Blender: added 'udatadir' option to .Get() function and added var Blender.mode to tell if Blender is in bg or interactive mode.
    NMesh: added Campbell's nmesh.transform(matrix, recalc_normals = False) method (reworked, so my fault if it doesn't work).
- Bugs fixed:
    #2123: http://projects.blender.org/tracker/?func=detail&atid=125&aid=2123&group_id=9
    Reported by Ken Hughes (thanks!), who also found the exact problem later (it was in Text.Load, not with script links -- if only I had checked emails these days ... lost > 1 hour today to find the problem: passed filename to M_Text_Load was later being written over by a function called by add_text).  Also saw that Text.Load wasn't checking existence of passed filename (duh!), now it does.
    #1655: http://projects.blender.org/tracker/?func=detail&atid=125&aid=1655&group_id=9
    Reported by Chris Want (thanks!): command line "blender -P script" not working properly for bg mode ("blender -b blendfile -P script").
    Had to make some small updates to get it working (bg mode for scripts was never explicitely handled, it worked due to collateral effects, let's say), interested readers can check the report after I update it or the API_intro.py doc file.  After more testing we can make further updates.  Updated many places to not call redraws if in bg mode, now it is officially available.  Blender outputs its own info when rendering in bg mode, if that is considered a nuissance we'll have to add a few "if (during_script())" calls outside bpython.
- Removed a few warnings here and there and also updated docs.
											
										 
											2005-03-19 06:24:55 +00:00
										 |  |  | 	case PYMENU_IMPORT:	/* first 4 were handled in header_info.c */ | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	case PYMENU_EXPORT: | 
					
						
							|  |  |  | 	case PYMENU_HELP: | 
					
						
							| 
									
										
											  
											
												BPython:
- Scripts:
    fixed error in "Save Current Theme" which prevented it from automatically updating script registration in menus.
    cosmetic changes in a couple of Campbell's sel_same.py script strings + more descriptive name for its new menu place (3d view, face mode -> select menu).
    small updates to help_browser.py script.
 The above changes are related to this:
- Added new script menu entries: Render (for exporters to renderers), Themes, FaceSelect (this already at the proper place).  Updated Scripts win->Scripts menu so it won't show all available entries, only  the ones we mean to see there.
- Updated menu registration so that scripts folders can become trees.  The release/scripts/ dir should be updated soon with subdirs like converters/, modifiers/, generators/ or whatever -- better discuss first (or is it? /me afraid of long irc discussions during meetings :) ).
- Modules:
    Blender: added 'udatadir' option to .Get() function and added var Blender.mode to tell if Blender is in bg or interactive mode.
    NMesh: added Campbell's nmesh.transform(matrix, recalc_normals = False) method (reworked, so my fault if it doesn't work).
- Bugs fixed:
    #2123: http://projects.blender.org/tracker/?func=detail&atid=125&aid=2123&group_id=9
    Reported by Ken Hughes (thanks!), who also found the exact problem later (it was in Text.Load, not with script links -- if only I had checked emails these days ... lost > 1 hour today to find the problem: passed filename to M_Text_Load was later being written over by a function called by add_text).  Also saw that Text.Load wasn't checking existence of passed filename (duh!), now it does.
    #1655: http://projects.blender.org/tracker/?func=detail&atid=125&aid=1655&group_id=9
    Reported by Chris Want (thanks!): command line "blender -P script" not working properly for bg mode ("blender -b blendfile -P script").
    Had to make some small updates to get it working (bg mode for scripts was never explicitely handled, it worked due to collateral effects, let's say), interested readers can check the report after I update it or the API_intro.py doc file.  After more testing we can make further updates.  Updated many places to not call redraws if in bg mode, now it is officially available.  Blender outputs its own info when rendering in bg mode, if that is considered a nuissance we'll have to add a few "if (during_script())" calls outside bpython.
- Removed a few warnings here and there and also updated docs.
											
										 
											2005-03-19 06:24:55 +00:00
										 |  |  | 	case PYMENU_RENDER: | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	case PYMENU_WIZARDS: | 
					
						
							| 
									
										
										
										
											2007-02-21 13:00:12 +00:00
										 |  |  | 	case PYMENU_SCRIPTTEMPLATE: | 
					
						
							| 
									
										
										
										
											2007-03-19 03:22:42 +00:00
										 |  |  | 	case PYMENU_MESHFACEKEY: | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		break; | 
					
						
							| 
									
										
										
										
											2004-06-11 09:17:49 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	default: | 
					
						
							|  |  |  | 		if( curarea->spacetype != SPACE_SCRIPT ) { | 
					
						
							|  |  |  | 			ScrArea *sa = NULL; | 
					
						
							| 
									
										
										
										
											2004-06-10 03:27:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 			sa = find_biggest_area_of_type( SPACE_BUTS ); | 
					
						
							|  |  |  | 			if( sa ) { | 
					
						
							|  |  |  | 				if( ( 1.5 * sa->winx ) < sa->winy ) | 
					
						
							|  |  |  | 					sa = NULL;	/* too narrow? */ | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2004-06-10 03:27:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 			if( !sa ) | 
					
						
							|  |  |  | 				sa = find_biggest_area_of_type( SPACE_SCRIPT ); | 
					
						
							|  |  |  | 			if( !sa ) | 
					
						
							|  |  |  | 				sa = find_biggest_area_of_type( SPACE_TEXT ); | 
					
						
							|  |  |  | 			if( !sa ) | 
					
						
							|  |  |  | 				sa = find_biggest_area_of_type( SPACE_IMAGE );	/* group UV */ | 
					
						
							|  |  |  | 			if( !sa ) | 
					
						
							|  |  |  | 				sa = find_biggest_area_of_type( SPACE_VIEW3D ); | 
					
						
							| 
									
										
										
										
											2004-06-10 03:27:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 			if( !sa ) | 
					
						
							|  |  |  | 				sa = find_biggest_area(  ); | 
					
						
							| 
									
										
										
										
											2004-06-10 03:27:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 			areawinset( sa->win ); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		break; | 
					
						
							| 
									
										
										
										
											2004-06-10 03:27:46 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-14 21:36:10 +00:00
										 |  |  | 	script->id.us = 1; | 
					
						
							|  |  |  | 	script->flags = SCRIPT_RUNNING; | 
					
						
							|  |  |  | 	script->py_draw = NULL; | 
					
						
							|  |  |  | 	script->py_event = NULL; | 
					
						
							|  |  |  | 	script->py_button = NULL; | 
					
						
							| 
									
										
											  
											
												BPython bug fixes:
- #2646 reported by Campbell: Python/Fileselector (moving from fileselector called by script to another space caused script to hang around open but not accessible)
http://projects.blender.org/tracker/?func=detail&atid=125&aid=2646&group_id=9
- #2676 reported by Wim Van Hoydonck: 2.37 python scripts gui: event 8 ignored (thanks Ton for discussing / pointing what to do, Ken Hughes for also working on a fix)
http://projects.blender.org/tracker/?func=detail&atid=125&aid=2676&group_id=9
- gui-less scripts with calls to progress bar inside fileselector callbacks didn't return to the previous space on exit (staying on Scripts win), requiring an event to do so (mouse movement, for example).  Quick fix for now, will rework a little after 2.37a for a better alternative, not needing to move to the Scripts win at all.
- added syntax colors access to Window.Theme module.
Scripts:
- updates by Jean-Michel Soler: svg2obj (svg paths import), tex2uvbaker, fixfromarmature;
- updates by Campbell Barton: obj import / export, console;
- tiny: converted vrml97 export to unix line endings;
- updates in ac3d exporter, help browser, save theme.
Thanks all mentioned above.
											
										 
											2005-06-11 05:30:14 +00:00
										 |  |  | 	script->py_browsercallback = NULL; | 
					
						
							| 
									
										
										
										
											2004-01-14 21:36:10 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	py_dict = CreateGlobalDictionary(  ); | 
					
						
							| 
									
										
										
										
											2004-01-14 21:36:10 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	script->py_globaldict = py_dict; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-08-17 14:26:00 +00:00
										 |  |  | 	info = ( BPy_constant * ) PyConstant_New(  ); | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	if( info ) { | 
					
						
							| 
									
										
										
										
											2005-08-17 14:26:00 +00:00
										 |  |  | 		PyConstant_Insert( info, "name", | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 				 PyString_FromString( script->id.name + 2 ) ); | 
					
						
							| 
									
										
										
										
											2005-08-17 14:26:00 +00:00
										 |  |  | 		PyConstant_Insert( info, "arg", pyarg ); | 
					
						
							| 
									
										
										
										
											2005-11-30 08:18:06 +00:00
										 |  |  | 		EXPP_dict_set_item_str( py_dict, "__script__", | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 				      ( PyObject * ) info ); | 
					
						
							| 
									
										
										
										
											2004-01-14 21:36:10 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	/* Previously we used PyRun_File to run directly the code on a FILE 
 | 
					
						
							|  |  |  | 	 * object, but as written in the Python/C API Ref Manual, chapter 2, | 
					
						
							|  |  |  | 	 * 'FILE structs for different C libraries can be different and  | 
					
						
							|  |  |  | 	 * incompatible'. | 
					
						
							| 
									
										
										
										
											2004-01-18 15:08:02 +00:00
										 |  |  | 	 * So now we load the script file data to a buffer */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	fseek( fp, 0L, SEEK_END ); | 
					
						
							|  |  |  | 	len = ftell( fp ); | 
					
						
							|  |  |  | 	fseek( fp, 0L, SEEK_SET ); | 
					
						
							| 
									
										
										
										
											2004-01-18 15:08:02 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	buffer = MEM_mallocN( len + 2, "pyfilebuf" );	/* len+2 to add '\n\0' */ | 
					
						
							|  |  |  | 	len = fread( buffer, 1, len, fp ); | 
					
						
							| 
									
										
										
										
											2004-01-18 15:08:02 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	buffer[len] = '\n';	/* fix syntax error in files w/o eol */ | 
					
						
							|  |  |  | 	buffer[len + 1] = '\0'; | 
					
						
							| 
									
										
										
										
											2004-01-14 21:36:10 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
											
												BPython:
- tentative fix for scripts with CR/LF endings and split lines:
    in 2.32, the ac3d and vrml2 exporters, for example, had lines
    split with '\\\\' and so gave syntax errors when executed on Win
    platforms, because the scripts bundled with Win binaries had dos
    line endings.
- Chris Keith has written code to execute Python scripts from the
  command-line, with '-P ' switch: "blender -P filename":
    a Blender.Quit function was also added, so Blender can quit after
    running the script (end the script with Blender.Quit()), but there's
    still work to be done in this part, including adding more functions,
    to load / save .blend files and to run scripts.  More testing and
    discussions are necessary.
Thanks Chris, for both your contributions and your patience, since I
wasn't available to check / commit this for a while.
											
										 
											2004-03-31 04:18:39 +00:00
										 |  |  | 	/* fast clean-up of dos cr/lf line endings: change '\r' to space */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* we also have to check for line splitters: '\\' */ | 
					
						
							|  |  |  | 	/* to avoid possible syntax errors on dos files on win */ | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	 /**/ | 
					
						
							|  |  |  | 		/* but first make sure we won't disturb memory below &buffer[0]: */ | 
					
						
							|  |  |  | 		if( *buffer == '\r' ) | 
					
						
							|  |  |  | 		*buffer = ' '; | 
					
						
							| 
									
										
										
											
												BPython:
- tentative fix for scripts with CR/LF endings and split lines:
    in 2.32, the ac3d and vrml2 exporters, for example, had lines
    split with '\\\\' and so gave syntax errors when executed on Win
    platforms, because the scripts bundled with Win binaries had dos
    line endings.
- Chris Keith has written code to execute Python scripts from the
  command-line, with '-P ' switch: "blender -P filename":
    a Blender.Quit function was also added, so Blender can quit after
    running the script (end the script with Blender.Quit()), but there's
    still work to be done in this part, including adding more functions,
    to load / save .blend files and to run scripts.  More testing and
    discussions are necessary.
Thanks Chris, for both your contributions and your patience, since I
wasn't available to check / commit this for a while.
											
										 
											2004-03-31 04:18:39 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* now handle the whole buffer */ | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	for( s = buffer + 1; *s != '\0'; s++ ) { | 
					
						
							|  |  |  | 		if( *s == '\r' ) { | 
					
						
							|  |  |  | 			if( *( s - 1 ) == '\\' ) {	/* special case: long lines split with '\': */ | 
					
						
							|  |  |  | 				*( s - 1 ) = ' ';	/* we write ' \', because '\ ' is a syntax error */ | 
					
						
							| 
									
										
										
											
												BPython:
- tentative fix for scripts with CR/LF endings and split lines:
    in 2.32, the ac3d and vrml2 exporters, for example, had lines
    split with '\\\\' and so gave syntax errors when executed on Win
    platforms, because the scripts bundled with Win binaries had dos
    line endings.
- Chris Keith has written code to execute Python scripts from the
  command-line, with '-P ' switch: "blender -P filename":
    a Blender.Quit function was also added, so Blender can quit after
    running the script (end the script with Blender.Quit()), but there's
    still work to be done in this part, including adding more functions,
    to load / save .blend files and to run scripts.  More testing and
    discussions are necessary.
Thanks Chris, for both your contributions and your patience, since I
wasn't available to check / commit this for a while.
											
										 
											2004-03-31 04:18:39 +00:00
										 |  |  | 				*s = '\\'; | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 			} else | 
					
						
							|  |  |  | 				*s = ' ';	/* not a split line, just replace '\r' with ' ' */ | 
					
						
							| 
									
										
										
											
												BPython:
- tentative fix for scripts with CR/LF endings and split lines:
    in 2.32, the ac3d and vrml2 exporters, for example, had lines
    split with '\\\\' and so gave syntax errors when executed on Win
    platforms, because the scripts bundled with Win binaries had dos
    line endings.
- Chris Keith has written code to execute Python scripts from the
  command-line, with '-P ' switch: "blender -P filename":
    a Blender.Quit function was also added, so Blender can quit after
    running the script (end the script with Blender.Quit()), but there's
    still work to be done in this part, including adding more functions,
    to load / save .blend files and to run scripts.  More testing and
    discussions are necessary.
Thanks Chris, for both your contributions and your patience, since I
wasn't available to check / commit this for a while.
											
										 
											2004-03-31 04:18:39 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2004-01-27 09:30:29 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	fclose( fp ); | 
					
						
							| 
									
										
										
										
											2004-01-14 21:36:10 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-01-31 03:12:26 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if( !setup_armature_weakrefs()){ | 
					
						
							|  |  |  | 		printf("Oops - weakref dict\n"); | 
					
						
							| 
									
										
										
										
											2007-05-25 16:43:25 +00:00
										 |  |  | 		MEM_freeN( buffer ); | 
					
						
							| 
									
										
										
										
											2007-01-31 03:12:26 +00:00
										 |  |  | 		return 0; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-01-18 15:08:02 +00:00
										 |  |  | 	/* run the string buffer */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	py_res = PyRun_String( buffer, Py_file_input, py_dict, py_dict ); | 
					
						
							| 
									
										
										
										
											2004-01-18 15:08:02 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	MEM_freeN( buffer ); | 
					
						
							| 
									
										
										
										
											2004-01-18 15:08:02 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	if( !py_res ) {		/* Failed execution of the script */ | 
					
						
							| 
									
										
										
										
											2004-01-14 21:36:10 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		BPY_Err_Handle( script->id.name + 2 ); | 
					
						
							|  |  |  | 		ReleaseGlobalDictionary( py_dict ); | 
					
						
							| 
									
										
										
										
											2005-03-21 05:26:52 +00:00
										 |  |  | 		script->py_globaldict = NULL; | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		if( G.main->script.first ) | 
					
						
							|  |  |  | 			free_libblock( &G.main->script, script ); | 
					
						
							|  |  |  | 		error( "Python script error: check console" ); | 
					
						
							| 
									
										
										
										
											2003-05-13 01:54:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 		return 0; | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	} else { | 
					
						
							|  |  |  | 		Py_DECREF( py_res ); | 
					
						
							|  |  |  | 		script->flags &= ~SCRIPT_RUNNING; | 
					
						
							| 
									
										
											  
											
												BPython: cleaning some bug tracker entries:
(excuse me for doing all in a single commit, but they are tiny
fixes and it's bpython, that dark corner ...)
#1025 - FileSelector SEGV on dynamic callback Category:
  Can't reproduce with current cvs, I'd say recent changes to fix
another crash related to FileSelector in gui-less scripts solved this
one, too.
#1028 - Reserved button event number:
  Menu choices generate two events, one extra related to the menu
itself, with value=4.  Made bpython ignore this extra event.
#1068 - FileSelector No file extension support:
  As Ton wrote there, Blender itself doesn't support this yet.  But the
requester also wanted Window.File/ImageSelector to accept a pathname.  Done.  Also updated doc.
#959 - Segfault on background rendering:
  This happened in bg mode (blender -b filename -a, for example) when
a script with the line "Blender.Redraw()" was linked to FRAMECHANGED events.  As reported in the bug page, it was because curarea is NULL in bg mode.  Made Redraw() check for this and not call functions that expected curarea in Redraw, like one to swap buffers.
#1072 - Blender.Redraw() Segfault:
  Good catch : ). Scripts called from the scripts win that called
Blender.Redraw() or Blender.Window.Redraw() would crash Blender because of a dirty pointer in Spacescript->script.  Fixed.
											
										 
											2004-04-11 04:41:33 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		if( !script->flags ) { | 
					
						
							|  |  |  | 			ReleaseGlobalDictionary( py_dict ); | 
					
						
							| 
									
										
										
										
											2003-12-14 01:18:09 +00:00
										 |  |  | 			script->py_globaldict = NULL; | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 			free_libblock( &G.main->script, script ); | 
					
						
							| 
									
										
											  
											
												BPython: cleaning some bug tracker entries:
(excuse me for doing all in a single commit, but they are tiny
fixes and it's bpython, that dark corner ...)
#1025 - FileSelector SEGV on dynamic callback Category:
  Can't reproduce with current cvs, I'd say recent changes to fix
another crash related to FileSelector in gui-less scripts solved this
one, too.
#1028 - Reserved button event number:
  Menu choices generate two events, one extra related to the menu
itself, with value=4.  Made bpython ignore this extra event.
#1068 - FileSelector No file extension support:
  As Ton wrote there, Blender itself doesn't support this yet.  But the
requester also wanted Window.File/ImageSelector to accept a pathname.  Done.  Also updated doc.
#959 - Segfault on background rendering:
  This happened in bg mode (blender -b filename -a, for example) when
a script with the line "Blender.Redraw()" was linked to FRAMECHANGED events.  As reported in the bug page, it was because curarea is NULL in bg mode.  Made Redraw() check for this and not call functions that expected curarea in Redraw, like one to swap buffers.
#1072 - Blender.Redraw() Segfault:
  Good catch : ). Scripts called from the scripts win that called
Blender.Redraw() or Blender.Window.Redraw() would crash Blender because of a dirty pointer in Spacescript->script.  Fixed.
											
										 
											2004-04-11 04:41:33 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 			/* special case: called from the menu in the Scripts window
 | 
					
						
							|  |  |  | 			 * we have to change sc->script pointer, since it'll be freed here.*/ | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 			if( curarea->spacetype == SPACE_SCRIPT ) { | 
					
						
							| 
									
										
											  
											
												BPython: cleaning some bug tracker entries:
(excuse me for doing all in a single commit, but they are tiny
fixes and it's bpython, that dark corner ...)
#1025 - FileSelector SEGV on dynamic callback Category:
  Can't reproduce with current cvs, I'd say recent changes to fix
another crash related to FileSelector in gui-less scripts solved this
one, too.
#1028 - Reserved button event number:
  Menu choices generate two events, one extra related to the menu
itself, with value=4.  Made bpython ignore this extra event.
#1068 - FileSelector No file extension support:
  As Ton wrote there, Blender itself doesn't support this yet.  But the
requester also wanted Window.File/ImageSelector to accept a pathname.  Done.  Also updated doc.
#959 - Segfault on background rendering:
  This happened in bg mode (blender -b filename -a, for example) when
a script with the line "Blender.Redraw()" was linked to FRAMECHANGED events.  As reported in the bug page, it was because curarea is NULL in bg mode.  Made Redraw() check for this and not call functions that expected curarea in Redraw, like one to swap buffers.
#1072 - Blender.Redraw() Segfault:
  Good catch : ). Scripts called from the scripts win that called
Blender.Redraw() or Blender.Window.Redraw() would crash Blender because of a dirty pointer in Spacescript->script.  Fixed.
											
										 
											2004-04-11 04:41:33 +00:00
										 |  |  | 				SpaceScript *sc = curarea->spacedata.first; | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 				sc->script = G.main->script.first;	/* can be null, which is ok ... */ | 
					
						
							| 
									
										
											  
											
												BPython: cleaning some bug tracker entries:
(excuse me for doing all in a single commit, but they are tiny
fixes and it's bpython, that dark corner ...)
#1025 - FileSelector SEGV on dynamic callback Category:
  Can't reproduce with current cvs, I'd say recent changes to fix
another crash related to FileSelector in gui-less scripts solved this
one, too.
#1028 - Reserved button event number:
  Menu choices generate two events, one extra related to the menu
itself, with value=4.  Made bpython ignore this extra event.
#1068 - FileSelector No file extension support:
  As Ton wrote there, Blender itself doesn't support this yet.  But the
requester also wanted Window.File/ImageSelector to accept a pathname.  Done.  Also updated doc.
#959 - Segfault on background rendering:
  This happened in bg mode (blender -b filename -a, for example) when
a script with the line "Blender.Redraw()" was linked to FRAMECHANGED events.  As reported in the bug page, it was because curarea is NULL in bg mode.  Made Redraw() check for this and not call functions that expected curarea in Redraw, like one to swap buffers.
#1072 - Blender.Redraw() Segfault:
  Good catch : ). Scripts called from the scripts win that called
Blender.Redraw() or Blender.Window.Redraw() would crash Blender because of a dirty pointer in Spacescript->script.  Fixed.
											
										 
											2004-04-11 04:41:33 +00:00
										 |  |  | 				/* ... meaning no other script is running right now. */ | 
					
						
							|  |  |  | 			} | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-12-14 01:18:09 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	return 1;		/* normal return */ | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | /*****************************************************************************
 | 
					
						
							|  |  |  | * Description:	 | 
					
						
							|  |  |  | * Notes: | 
					
						
							|  |  |  | *****************************************************************************/ | 
					
						
							|  |  |  | void BPY_free_compiled_text( struct Text *text ) | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	if( !text->compiled ) | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 	Py_DECREF( ( PyObject * ) text->compiled ); | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	text->compiled = NULL; | 
					
						
							| 
									
										
										
										
											2003-05-13 01:54:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	return; | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2003-12-15 18:18:09 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | /*****************************************************************************
 | 
					
						
							|  |  |  | * Description: This function frees a finished (flags == 0) script. | 
					
						
							|  |  |  | *****************************************************************************/ | 
					
						
							|  |  |  | void BPY_free_finished_script( Script * script ) | 
					
						
							| 
									
										
										
										
											2003-12-15 18:18:09 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	if( !script ) | 
					
						
							|  |  |  | 		return; | 
					
						
							| 
									
										
										
										
											2003-12-15 18:18:09 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	if( PyErr_Occurred(  ) ) {	/* if script ended after filesel */ | 
					
						
							|  |  |  | 		PyErr_Print(  );	/* eventual errors are handled now */ | 
					
						
							|  |  |  | 		error( "Python script error: check console" ); | 
					
						
							| 
									
										
										
										
											2004-01-28 19:16:50 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	free_libblock( &G.main->script, script ); | 
					
						
							| 
									
										
										
										
											2003-12-15 18:18:09 +00:00
										 |  |  | 	return; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-03-09 19:45:59 +00:00
										 |  |  | static void unlink_script( Script * script ) | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | {	/* copied from unlink_text in drawtext.c */ | 
					
						
							| 
									
										
										
										
											2003-12-15 18:18:09 +00:00
										 |  |  | 	bScreen *scr; | 
					
						
							|  |  |  | 	ScrArea *area; | 
					
						
							|  |  |  | 	SpaceLink *sl; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	for( scr = G.main->screen.first; scr; scr = scr->id.next ) { | 
					
						
							|  |  |  | 		for( area = scr->areabase.first; area; area = area->next ) { | 
					
						
							|  |  |  | 			for( sl = area->spacedata.first; sl; sl = sl->next ) { | 
					
						
							|  |  |  | 				if( sl->spacetype == SPACE_SCRIPT ) { | 
					
						
							|  |  |  | 					SpaceScript *sc = ( SpaceScript * ) sl; | 
					
						
							| 
									
										
										
										
											2003-12-15 18:18:09 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 					if( sc->script == script ) { | 
					
						
							|  |  |  | 						sc->script = NULL; | 
					
						
							| 
									
										
										
										
											2003-12-15 18:18:09 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 						if( sc == | 
					
						
							|  |  |  | 						    area->spacedata.first ) { | 
					
						
							|  |  |  | 							scrarea_queue_redraw | 
					
						
							|  |  |  | 								( area ); | 
					
						
							| 
									
										
										
										
											2003-12-15 18:18:09 +00:00
										 |  |  | 						} | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | void BPY_clear_script( Script * script ) | 
					
						
							| 
									
										
										
										
											2003-12-15 18:18:09 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	PyObject *dict; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	if( !script ) | 
					
						
							|  |  |  | 		return; | 
					
						
							| 
									
										
										
										
											2003-12-15 18:18:09 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-05-02 02:42:08 +00:00
										 |  |  | 	if (!Py_IsInitialized()) { | 
					
						
							|  |  |  | 		printf("\nError: trying to free script data after finalizing Python!"); | 
					
						
							|  |  |  | 		printf("\nScript name: %s\n", script->id.name+2); | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	Py_XDECREF( ( PyObject * ) script->py_draw ); | 
					
						
							|  |  |  | 	Py_XDECREF( ( PyObject * ) script->py_event ); | 
					
						
							|  |  |  | 	Py_XDECREF( ( PyObject * ) script->py_button ); | 
					
						
							| 
									
										
											  
											
												BPython bug fixes:
- #2646 reported by Campbell: Python/Fileselector (moving from fileselector called by script to another space caused script to hang around open but not accessible)
http://projects.blender.org/tracker/?func=detail&atid=125&aid=2646&group_id=9
- #2676 reported by Wim Van Hoydonck: 2.37 python scripts gui: event 8 ignored (thanks Ton for discussing / pointing what to do, Ken Hughes for also working on a fix)
http://projects.blender.org/tracker/?func=detail&atid=125&aid=2676&group_id=9
- gui-less scripts with calls to progress bar inside fileselector callbacks didn't return to the previous space on exit (staying on Scripts win), requiring an event to do so (mouse movement, for example).  Quick fix for now, will rework a little after 2.37a for a better alternative, not needing to move to the Scripts win at all.
- added syntax colors access to Window.Theme module.
Scripts:
- updates by Jean-Michel Soler: svg2obj (svg paths import), tex2uvbaker, fixfromarmature;
- updates by Campbell Barton: obj import / export, console;
- tiny: converted vrml97 export to unix line endings;
- updates in ac3d exporter, help browser, save theme.
Thanks all mentioned above.
											
										 
											2005-06-11 05:30:14 +00:00
										 |  |  | 	Py_XDECREF( ( PyObject * ) script->py_browsercallback ); | 
					
						
							| 
									
										
										
										
											2006-05-02 02:42:08 +00:00
										 |  |  | 	script->py_draw = NULL; | 
					
						
							|  |  |  | 	script->py_event = NULL; | 
					
						
							|  |  |  | 	script->py_button = NULL; | 
					
						
							|  |  |  | 	script->py_browsercallback = NULL; | 
					
						
							| 
									
										
										
										
											2003-12-15 18:18:09 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	dict = script->py_globaldict; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	if( dict ) { | 
					
						
							|  |  |  | 		PyDict_Clear( dict ); | 
					
						
							|  |  |  | 		Py_DECREF( dict );	/* Release dictionary. */ | 
					
						
							| 
									
										
										
										
											2003-12-15 18:18:09 +00:00
										 |  |  | 		script->py_globaldict = NULL; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	unlink_script( script ); | 
					
						
							| 
									
										
										
										
											2003-12-15 18:18:09 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-04-30 16:22:31 +00:00
										 |  |  | /* PyDrivers */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* PyDrivers are Ipo Drivers governed by expressions written in Python.
 | 
					
						
							|  |  |  |  * Expressions here are one-liners that evaluate to a float value. */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* For faster execution we keep a special dictionary for pydrivers, with
 | 
					
						
							|  |  |  |  * the needed modules and aliases. */ | 
					
						
							|  |  |  | static int bpy_pydriver_create_dict(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	PyObject *d, *mod; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (bpy_pydriver_Dict) return -1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	d = PyDict_New(); | 
					
						
							|  |  |  | 	if (!d) return -1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	bpy_pydriver_Dict = d; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* import some modules: builtins, Blender, math, Blender.noise */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	PyDict_SetItemString(d, "__builtins__", PyEval_GetBuiltins()); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	mod = PyImport_ImportModule("Blender"); | 
					
						
							|  |  |  | 	if (mod) { | 
					
						
							|  |  |  | 		PyDict_SetItemString(d, "Blender", mod); | 
					
						
							|  |  |  | 		PyDict_SetItemString(d, "b", mod); | 
					
						
							|  |  |  | 		Py_DECREF(mod); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	mod = PyImport_ImportModule("math"); | 
					
						
							|  |  |  | 	if (mod) { | 
					
						
							| 
									
										
										
										
											2007-12-03 16:43:58 +00:00
										 |  |  | 		PyDict_Merge(d, PyModule_GetDict(mod), 0); /* 0 - dont overwrite existing values */ | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* Only keep for backwards compat! - just import all math into root, they are standard */ | 
					
						
							| 
									
										
										
										
											2006-04-30 16:22:31 +00:00
										 |  |  | 		PyDict_SetItemString(d, "math", mod); | 
					
						
							|  |  |  | 		PyDict_SetItemString(d, "m", mod); | 
					
						
							|  |  |  | 		Py_DECREF(mod); | 
					
						
							| 
									
										
										
										
											2007-12-03 16:43:58 +00:00
										 |  |  | 	}  | 
					
						
							| 
									
										
										
										
											2006-04-30 16:22:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	mod = PyImport_ImportModule("Blender.Noise"); | 
					
						
							|  |  |  | 	if (mod) { | 
					
						
							|  |  |  | 		PyDict_SetItemString(d, "noise", mod); | 
					
						
							|  |  |  | 		PyDict_SetItemString(d, "n", mod); | 
					
						
							|  |  |  | 		Py_DECREF(mod); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* If there's a Blender text called pydrivers.py, import it.
 | 
					
						
							|  |  |  | 	 * Users can add their own functions to this module. */ | 
					
						
							|  |  |  | 	mod = importText("pydrivers"); /* can also use PyImport_Import() */ | 
					
						
							|  |  |  | 	if (mod) { | 
					
						
							|  |  |  | 		PyDict_SetItemString(d, "pydrivers", mod); | 
					
						
							|  |  |  | 		PyDict_SetItemString(d, "p", mod); | 
					
						
							|  |  |  | 		Py_DECREF(mod); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 		PyErr_Clear(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* short aliases for some Get() functions: */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* ob(obname) == Blender.Object.Get(obname) */ | 
					
						
							|  |  |  | 	mod = PyImport_ImportModule("Blender.Object"); | 
					
						
							|  |  |  | 	if (mod) { | 
					
						
							|  |  |  | 		PyObject *fcn = PyObject_GetAttrString(mod, "Get"); | 
					
						
							|  |  |  | 		Py_DECREF(mod); | 
					
						
							| 
									
										
										
										
											2007-03-30 00:57:07 +00:00
										 |  |  | 		if (fcn) { | 
					
						
							| 
									
										
										
										
											2006-04-30 16:22:31 +00:00
										 |  |  | 			PyDict_SetItemString(d, "ob", fcn); | 
					
						
							| 
									
										
										
										
											2007-03-30 00:57:07 +00:00
										 |  |  | 			Py_DECREF(fcn); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2006-04-30 16:22:31 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2007-12-07 09:51:02 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* TODO - change these */ | 
					
						
							| 
									
										
										
										
											2006-04-30 16:22:31 +00:00
										 |  |  | 	/* me(meshname) == Blender.Mesh.Get(meshname) */ | 
					
						
							|  |  |  | 	mod = PyImport_ImportModule("Blender.Mesh"); | 
					
						
							|  |  |  | 	if (mod) { | 
					
						
							|  |  |  | 		PyObject *fcn = PyObject_GetAttrString(mod, "Get"); | 
					
						
							|  |  |  | 		Py_DECREF(mod); | 
					
						
							| 
									
										
										
										
											2007-03-30 00:57:07 +00:00
										 |  |  | 		if (fcn) { | 
					
						
							| 
									
										
										
										
											2006-04-30 16:22:31 +00:00
										 |  |  | 			PyDict_SetItemString(d, "me", fcn); | 
					
						
							| 
									
										
										
										
											2007-03-30 00:57:07 +00:00
										 |  |  | 			Py_DECREF(fcn); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2006-04-30 16:22:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* ma(matname) == Blender.Material.Get(matname) */ | 
					
						
							|  |  |  | 	mod = PyImport_ImportModule("Blender.Material"); | 
					
						
							|  |  |  | 	if (mod) { | 
					
						
							|  |  |  | 		PyObject *fcn = PyObject_GetAttrString(mod, "Get"); | 
					
						
							|  |  |  | 		Py_DECREF(mod); | 
					
						
							| 
									
										
										
										
											2007-03-30 00:57:07 +00:00
										 |  |  | 		if (fcn) { | 
					
						
							| 
									
										
										
										
											2006-04-30 16:22:31 +00:00
										 |  |  | 			PyDict_SetItemString(d, "ma", fcn); | 
					
						
							| 
									
										
										
										
											2007-03-30 00:57:07 +00:00
										 |  |  | 			Py_DECREF(fcn); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2006-04-30 16:22:31 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* error return function for BPY_eval_pydriver */ | 
					
						
							|  |  |  | static float pydriver_error(IpoDriver *driver) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (bpy_pydriver_oblist) | 
					
						
							|  |  |  | 		bpy_pydriver_freeList(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (bpy_pydriver_Dict) { /* free the global dict used by pydrivers */ | 
					
						
							| 
									
										
										
										
											2006-04-30 22:10:39 +00:00
										 |  |  | 		PyDict_Clear(bpy_pydriver_Dict); | 
					
						
							| 
									
										
										
										
											2006-04-30 16:22:31 +00:00
										 |  |  | 		Py_DECREF(bpy_pydriver_Dict); | 
					
						
							|  |  |  | 		bpy_pydriver_Dict = NULL; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	driver->flag |= IPO_DRIVER_FLAG_INVALID; /* py expression failed */ | 
					
						
							| 
									
										
										
										
											2006-12-25 10:44:28 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	if (driver->ob) | 
					
						
							|  |  |  | 		fprintf(stderr, "\nError in Ipo Driver: Object %s\nThis is the failed Python expression:\n'%s'\n\n", driver->ob->id.name+2, driver->name); | 
					
						
							|  |  |  | 	else | 
					
						
							|  |  |  | 		fprintf(stderr, "\nError in Ipo Driver: No Object\nThis is the failed Python expression:\n'%s'\n\n", driver->name); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2006-04-30 16:22:31 +00:00
										 |  |  | 	PyErr_Print(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return 0.0f; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /********PyConstraints*********/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | /* This function checks whether a text-buffer is a PyConstraint candidate.
 | 
					
						
							|  |  |  |  * It uses simple text parsing that could be easily confused! | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | int BPY_is_pyconstraint(Text *text) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	TextLine *tline = text->lines.first; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (tline && (tline->len > 10)) { | 
					
						
							|  |  |  | 		char *line = tline->line; | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 		/* Expected format: #BPYCONSTRAINT
 | 
					
						
							|  |  |  | 		 * The actual checks are forgiving, so slight variations also work. */ | 
					
						
							|  |  |  | 		if (line && line[0] == '#' && strstr(line, "BPYCONSTRAINT")) return 1; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | /* This function is called to update PyConstraint data so that it is compatible with the script. 
 | 
					
						
							|  |  |  |  * Some of the allocating/freeing of memory for constraint targets occurs here, espcially | 
					
						
							|  |  |  |  * if the number of targets changes. | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | void BPY_pyconstraint_update(Object *owner, bConstraint *con) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	bPythonConstraint *data= con->data; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if (data->text) {	 | 
					
						
							|  |  |  | 		/* script does exist. it is assumed that this is a valid pyconstraint script */ | 
					
						
							|  |  |  | 		PyObject *globals; | 
					
						
							|  |  |  | 		PyObject *retval, *gval; | 
					
						
							| 
									
										
										
										
											2007-10-23 08:23:57 +00:00
										 |  |  | 		int num, i; | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2007-10-23 08:23:57 +00:00
										 |  |  | 		/* clear the relevant flags first */ | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 		data->flag = 0; | 
					
						
							| 
									
										
										
										
											2007-10-23 08:23:57 +00:00
										 |  |  | 				 | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 		/* populate globals dictionary */ | 
					
						
							|  |  |  | 		globals = CreateGlobalDictionary(); | 
					
						
							|  |  |  | 		retval = RunPython(data->text, globals); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		if (retval == NULL) { | 
					
						
							|  |  |  | 			BPY_Err_Handle(data->text->id.name); | 
					
						
							|  |  |  | 			ReleaseGlobalDictionary(globals); | 
					
						
							|  |  |  | 			data->flag |= PYCON_SCRIPTERROR; | 
					
						
							|  |  |  | 			return; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		Py_XDECREF(retval); | 
					
						
							|  |  |  | 		retval = NULL; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* try to find NUM_TARGETS */ | 
					
						
							|  |  |  | 		gval = PyDict_GetItemString(globals, "NUM_TARGETS"); | 
					
						
							|  |  |  | 		if ( (gval) && (num= PyInt_AsLong(gval)) ) { | 
					
						
							|  |  |  | 			/* NUM_TARGETS is defined... and non-zero */ | 
					
						
							|  |  |  | 			bConstraintTarget *ct; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* check if it is valid (just make sure it is not negative)
 | 
					
						
							|  |  |  | 			 *	TODO: PyInt_AsLong may return -1 as sign of invalid input...  | 
					
						
							|  |  |  | 			 */ | 
					
						
							|  |  |  | 			num = abs(num); | 
					
						
							|  |  |  | 			data->flag |= PYCON_USETARGETS; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* check if the number of targets has changed */ | 
					
						
							|  |  |  | 			if (num < data->tarnum) { | 
					
						
							|  |  |  | 				/* free a few targets */ | 
					
						
							| 
									
										
										
										
											2007-10-23 08:23:57 +00:00
										 |  |  | 				num= data->tarnum - num; | 
					
						
							|  |  |  | 				for (i = 0; i < num; i++, data->tarnum--) { | 
					
						
							|  |  |  | 					ct= data->targets.last; | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 					BLI_freelinkN(&data->targets, ct); | 
					
						
							| 
									
										
										
										
											2007-10-23 08:23:57 +00:00
										 |  |  | 				} | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 			else if (num > data->tarnum) { | 
					
						
							|  |  |  | 				/* add a few targets */ | 
					
						
							| 
									
										
										
										
											2007-10-23 08:23:57 +00:00
										 |  |  | 				num = num - data->tarnum; | 
					
						
							|  |  |  | 				for (i = 0; i < num; i++, data->tarnum++) { | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 					ct= MEM_callocN(sizeof(bConstraintTarget), "PyConTarget"); | 
					
						
							|  |  |  | 					BLI_addtail(&data->targets, ct); | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* validate targets */ | 
					
						
							| 
									
										
										
										
											2007-10-23 08:23:57 +00:00
										 |  |  | 			con->flag &= ~CONSTRAINT_DISABLE; | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 			for (ct= data->targets.first; ct; ct= ct->next) { | 
					
						
							|  |  |  | 				if (!exist_object(ct->tar)) { | 
					
						
							|  |  |  | 					ct->tar = NULL; | 
					
						
							|  |  |  | 					con->flag |= CONSTRAINT_DISABLE; | 
					
						
							|  |  |  | 					break; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 				 | 
					
						
							| 
									
										
										
										
											2007-10-23 08:23:57 +00:00
										 |  |  | 				if ((ct->tar == owner) && (ct->subtarget[0] != 0)) { | 
					
						
							|  |  |  | 					if (get_named_bone(get_armature(owner), ct->subtarget) == NULL) { | 
					
						
							|  |  |  | 						con->flag |= CONSTRAINT_DISABLE; | 
					
						
							|  |  |  | 						break; | 
					
						
							|  |  |  | 					} | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* clear globals */ | 
					
						
							|  |  |  | 			ReleaseGlobalDictionary(globals); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		else { | 
					
						
							|  |  |  | 			/* NUM_TARGETS is not defined or equals 0 */ | 
					
						
							|  |  |  | 			ReleaseGlobalDictionary(globals); | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			/* free all targets */ | 
					
						
							|  |  |  | 			BLI_freelistN(&data->targets); | 
					
						
							|  |  |  | 			data->tarnum = 0; | 
					
						
							|  |  |  | 			data->flag &= ~PYCON_USETARGETS; | 
					
						
							|  |  |  | 			 | 
					
						
							|  |  |  | 			return; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		/* no script, so clear any settings/data now */ | 
					
						
							|  |  |  | 		data->tarnum = 0; | 
					
						
							|  |  |  | 		data->flag = 0; | 
					
						
							| 
									
										
										
										
											2007-10-23 08:23:57 +00:00
										 |  |  | 		con->flag &= ~CONSTRAINT_DISABLE; | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		BLI_freelistN(&data->targets); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* supposedly this should still leave the base struct... */ | 
					
						
							|  |  |  | 		IDP_FreeProperty(data->prop); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-08-18 06:17:50 +00:00
										 |  |  | /* PyConstraints Evaluation Function (only called from evaluate_constraint)
 | 
					
						
							|  |  |  |  * This function is responsible for modifying the ownermat that it is passed.  | 
					
						
							|  |  |  |  */ | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | void BPY_pyconstraint_eval(bPythonConstraint *con, bConstraintOb *cob, ListBase *targets) | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | { | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 	PyObject *srcmat, *tarmat, *tarmats, *idprop; | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 	PyObject *globals; | 
					
						
							|  |  |  | 	PyObject *gval; | 
					
						
							|  |  |  | 	PyObject *pyargs, *retval; | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 	bConstraintTarget *ct; | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 	MatrixObject *retmat; | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 	int row, col, index; | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 	if (!con->text) return; | 
					
						
							|  |  |  | 	if (con->flag & PYCON_SCRIPTERROR) return; | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	globals = CreateGlobalDictionary(); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 	/* wrap blender-data as PyObjects for evaluation 
 | 
					
						
							|  |  |  | 	 * 	- we expose the owner's matrix as pymatrix | 
					
						
							|  |  |  | 	 *	- id-properties are wrapped using the id-properties pyapi | 
					
						
							|  |  |  | 	 *	- targets are presented as a list of matrices | 
					
						
							|  |  |  | 	 */ | 
					
						
							|  |  |  | 	srcmat = newMatrixObject((float *)cob->matrix, 4, 4, Py_NEW); | 
					
						
							|  |  |  | 	idprop = BPy_Wrap_IDProperty(NULL, con->prop, NULL); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	tarmats= PyList_New(con->tarnum);  | 
					
						
							|  |  |  | 	for (ct=targets->first, index=0; ct; ct=ct->next, index++) { | 
					
						
							|  |  |  | 		tarmat = newMatrixObject((float *)ct->matrix, 4, 4, Py_NEW); | 
					
						
							| 
									
										
										
										
											2007-12-07 09:51:02 +00:00
										 |  |  | 		PyList_SET_ITEM(tarmats, index, tarmat); | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | /*  since I can't remember what the armature weakrefs do, I'll just leave this here
 | 
					
						
							|  |  |  |     commented out.  This function was based on pydrivers, and it might still be relevent. | 
					
						
							|  |  |  | 	if( !setup_armature_weakrefs()){ | 
					
						
							|  |  |  | 		fprintf( stderr, "Oops - weakref dict setup\n"); | 
					
						
							|  |  |  | 		return result; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	retval = RunPython(con->text, globals); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if (retval == NULL) { | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 		BPY_Err_Handle(con->text->id.name); | 
					
						
							|  |  |  | 		con->flag |= PYCON_SCRIPTERROR; | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 		/* free temp objects */ | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 		Py_XDECREF(idprop); | 
					
						
							|  |  |  | 		Py_XDECREF(srcmat); | 
					
						
							|  |  |  | 		Py_XDECREF(tarmats); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		ReleaseGlobalDictionary(globals); | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (retval) {Py_XDECREF( retval );} | 
					
						
							|  |  |  | 	retval = NULL; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	gval = PyDict_GetItemString(globals, "doConstraint"); | 
					
						
							|  |  |  | 	if (!gval) { | 
					
						
							|  |  |  | 		printf("ERROR: no doConstraint function in constraint!\n"); | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		/* free temp objects */ | 
					
						
							|  |  |  | 		Py_XDECREF(idprop); | 
					
						
							|  |  |  | 		Py_XDECREF(srcmat); | 
					
						
							|  |  |  | 		Py_XDECREF(tarmats); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		ReleaseGlobalDictionary(globals); | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* Now for the fun part! Try and find the functions we need. */ | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 	if (PyFunction_Check(gval)) { | 
					
						
							|  |  |  | 		pyargs = Py_BuildValue("OOO", srcmat, tarmats, idprop); | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 		retval = PyObject_CallObject(gval, pyargs); | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 		Py_XDECREF(pyargs); | 
					
						
							|  |  |  | 	}  | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 		printf("ERROR: doConstraint is supposed to be a function!\n"); | 
					
						
							|  |  |  | 		con->flag |= PYCON_SCRIPTERROR; | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 		Py_XDECREF(idprop); | 
					
						
							|  |  |  | 		Py_XDECREF(srcmat); | 
					
						
							|  |  |  | 		Py_XDECREF(tarmats); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		ReleaseGlobalDictionary(globals); | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if (!retval) { | 
					
						
							|  |  |  | 		BPY_Err_Handle(con->text->id.name); | 
					
						
							|  |  |  | 		con->flag |= PYCON_SCRIPTERROR; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* free temp objects */ | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 		Py_XDECREF(idprop); | 
					
						
							|  |  |  | 		Py_XDECREF(srcmat); | 
					
						
							|  |  |  | 		Py_XDECREF(tarmats); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		ReleaseGlobalDictionary(globals); | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if (!PyObject_TypeCheck(retval, &matrix_Type)) { | 
					
						
							|  |  |  | 		printf("Error in PyConstraint - doConstraint: Function not returning a matrix!\n"); | 
					
						
							|  |  |  | 		con->flag |= PYCON_SCRIPTERROR; | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 		Py_XDECREF(idprop); | 
					
						
							|  |  |  | 		Py_XDECREF(srcmat); | 
					
						
							|  |  |  | 		Py_XDECREF(tarmats); | 
					
						
							|  |  |  | 		Py_XDECREF(retval); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		ReleaseGlobalDictionary(globals); | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 	retmat = (MatrixObject *)retval; | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 	if (retmat->rowSize != 4 || retmat->colSize != 4) { | 
					
						
							|  |  |  | 		printf("Error in PyConstraint - doConstraint: Matrix returned is the wrong size!\n"); | 
					
						
							|  |  |  | 		con->flag |= PYCON_SCRIPTERROR; | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 		Py_XDECREF(idprop); | 
					
						
							|  |  |  | 		Py_XDECREF(srcmat); | 
					
						
							|  |  |  | 		Py_XDECREF(tarmats); | 
					
						
							|  |  |  | 		Py_XDECREF(retval); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		ReleaseGlobalDictionary(globals); | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	}	 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* this is the reverse of code taken from newMatrix() */ | 
					
						
							|  |  |  | 	for(row = 0; row < 4; row++) { | 
					
						
							|  |  |  | 		for(col = 0; col < 4; col++) { | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 			cob->matrix[row][col] = retmat->contigPtr[row*4+col]; | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* free temp objects */ | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 	Py_XDECREF(idprop); | 
					
						
							|  |  |  | 	Py_XDECREF(srcmat); | 
					
						
							|  |  |  | 	Py_XDECREF(tarmats); | 
					
						
							|  |  |  | 	Py_XDECREF(retval); | 
					
						
							| 
									
										
										
										
											2007-08-18 06:17:50 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	/* clear globals */ | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 	ReleaseGlobalDictionary(globals); | 
					
						
							| 
									
										
										
										
											2007-08-18 06:17:50 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | /* This evaluates the target matrix for each target the PyConstraint uses.
 | 
					
						
							|  |  |  |  * NOTE: it only does one target at a time! | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  |  */ | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | void BPY_pyconstraint_target(bPythonConstraint *con, bConstraintTarget *ct) | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	PyObject *tar, *subtar; | 
					
						
							|  |  |  | 	PyObject *tarmat, *idprop; | 
					
						
							|  |  |  | 	PyObject *globals; | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 	PyObject *gval; | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 	PyObject *pyargs, *retval; | 
					
						
							|  |  |  | 	MatrixObject *retmat; | 
					
						
							|  |  |  | 	int row, col; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 	if (!con->text) return; | 
					
						
							|  |  |  | 	if (con->flag & PYCON_SCRIPTERROR) return; | 
					
						
							|  |  |  | 	if (!ct) return; | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	globals = CreateGlobalDictionary(); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 	tar = Object_CreatePyObject(ct->tar); | 
					
						
							|  |  |  | 	if ((ct->tar) && (ct->tar->type==OB_ARMATURE)) { | 
					
						
							| 
									
										
										
										
											2007-08-18 06:17:50 +00:00
										 |  |  | 		bPoseChannel *pchan; | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 		pchan = get_pose_channel(ct->tar->pose, ct->subtarget); | 
					
						
							|  |  |  | 		subtar = PyPoseBone_FromPosechannel(pchan); | 
					
						
							| 
									
										
										
										
											2007-08-18 06:17:50 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 	else | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 		subtar = PyString_FromString(ct->subtarget); | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 	tarmat = newMatrixObject((float *)ct->matrix, 4, 4, Py_NEW); | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 	idprop = BPy_Wrap_IDProperty( NULL, con->prop, NULL); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | /*  since I can't remember what the armature weakrefs do, I'll just leave this here
 | 
					
						
							|  |  |  |     commented out.  This function was based on pydrivers, and it might still be relevent. | 
					
						
							|  |  |  | 	if( !setup_armature_weakrefs()){ | 
					
						
							|  |  |  | 		fprintf( stderr, "Oops - weakref dict setup\n"); | 
					
						
							|  |  |  | 		return result; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | */ | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 	retval = RunPython(con->text, globals); | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 	if (retval == NULL) { | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 		BPY_Err_Handle(con->text->id.name); | 
					
						
							|  |  |  | 		con->flag |= PYCON_SCRIPTERROR; | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 		/* free temp objects */ | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 		Py_XDECREF(tar); | 
					
						
							|  |  |  | 		Py_XDECREF(subtar); | 
					
						
							|  |  |  | 		Py_XDECREF(idprop); | 
					
						
							|  |  |  | 		Py_XDECREF(tarmat); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		ReleaseGlobalDictionary(globals); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		return; | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 	Py_XDECREF(retval); | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 	retval = NULL; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* try to find doTarget function to set the target matrix */ | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 	gval = PyDict_GetItemString(globals, "doTarget"); | 
					
						
							|  |  |  | 	if (!gval) { | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 		/* free temp objects */ | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 		Py_XDECREF(tar); | 
					
						
							|  |  |  | 		Py_XDECREF(subtar); | 
					
						
							|  |  |  | 		Py_XDECREF(idprop); | 
					
						
							|  |  |  | 		Py_XDECREF(tarmat); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		ReleaseGlobalDictionary(globals); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		return; | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* Now for the fun part! Try and find the functions we need.*/ | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 	if (PyFunction_Check(gval)) { | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 		pyargs = Py_BuildValue("OOOO", tar, subtar, tarmat, idprop); | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 		retval = PyObject_CallObject(gval, pyargs); | 
					
						
							|  |  |  | 		Py_XDECREF(pyargs); | 
					
						
							|  |  |  | 	}  | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 		printf("ERROR: doTarget is supposed to be a function!\n"); | 
					
						
							|  |  |  | 		con->flag |= PYCON_SCRIPTERROR; | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 		Py_XDECREF(tar); | 
					
						
							|  |  |  | 		Py_XDECREF(subtar); | 
					
						
							|  |  |  | 		Py_XDECREF(idprop); | 
					
						
							|  |  |  | 		Py_XDECREF(tarmat); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		ReleaseGlobalDictionary(globals); | 
					
						
							|  |  |  | 		return; | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if (!retval) { | 
					
						
							|  |  |  | 		BPY_Err_Handle(con->text->id.name); | 
					
						
							|  |  |  | 		con->flag |= PYCON_SCRIPTERROR; | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 		/* free temp objects */ | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 		Py_XDECREF(tar); | 
					
						
							|  |  |  | 		Py_XDECREF(subtar); | 
					
						
							|  |  |  | 		Py_XDECREF(idprop); | 
					
						
							|  |  |  | 		Py_XDECREF(tarmat); | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 		ReleaseGlobalDictionary(globals); | 
					
						
							|  |  |  | 		return; | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if (!PyObject_TypeCheck(retval, &matrix_Type)) { | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 		con->flag |= PYCON_SCRIPTERROR; | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 		 | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 		Py_XDECREF(tar); | 
					
						
							|  |  |  | 		Py_XDECREF(subtar); | 
					
						
							|  |  |  | 		Py_XDECREF(idprop); | 
					
						
							|  |  |  | 		Py_XDECREF(tarmat); | 
					
						
							|  |  |  | 		Py_XDECREF(retval); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		ReleaseGlobalDictionary(globals); | 
					
						
							|  |  |  | 		return; | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 	retmat = (MatrixObject *)retval; | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 	if (retmat->rowSize != 4 || retmat->colSize != 4) { | 
					
						
							|  |  |  | 		printf("Error in PyConstraint - doTarget: Matrix returned is the wrong size!\n"); | 
					
						
							|  |  |  | 		con->flag |= PYCON_SCRIPTERROR; | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 		Py_XDECREF(tar); | 
					
						
							|  |  |  | 		Py_XDECREF(subtar); | 
					
						
							|  |  |  | 		Py_XDECREF(idprop); | 
					
						
							|  |  |  | 		Py_XDECREF(tarmat); | 
					
						
							|  |  |  | 		Py_XDECREF(retval); | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		ReleaseGlobalDictionary(globals); | 
					
						
							|  |  |  | 		return; | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 	}	 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* this is the reverse of code taken from newMatrix() */ | 
					
						
							|  |  |  | 	for(row = 0; row < 4; row++) { | 
					
						
							|  |  |  | 		for(col = 0; col < 4; col++) { | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 			ct->matrix[row][col] = retmat->contigPtr[row*4+col]; | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* free temp objects */ | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 	Py_XDECREF(tar); | 
					
						
							|  |  |  | 	Py_XDECREF(subtar); | 
					
						
							|  |  |  | 	Py_XDECREF(idprop); | 
					
						
							|  |  |  | 	Py_XDECREF(tarmat); | 
					
						
							|  |  |  | 	Py_XDECREF(retval); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* clear globals */ | 
					
						
							|  |  |  | 	ReleaseGlobalDictionary(globals); | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* This draws+handles the user-defined interface for editing pyconstraints idprops */ | 
					
						
							|  |  |  | void BPY_pyconstraint_settings(void *arg1, void *arg2) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	bPythonConstraint *con= (bPythonConstraint *)arg1; | 
					
						
							|  |  |  | 	PyObject *idprop; | 
					
						
							|  |  |  | 	PyObject *globals; | 
					
						
							|  |  |  | 	PyObject *gval; | 
					
						
							|  |  |  | 	PyObject *retval; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 	if (!con->text) return; | 
					
						
							|  |  |  | 	if (con->flag & PYCON_SCRIPTERROR) return; | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	globals = CreateGlobalDictionary(); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	idprop = BPy_Wrap_IDProperty( NULL, con->prop, NULL); | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 	retval = RunPython(con->text, globals); | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 	if (retval == NULL) { | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 		BPY_Err_Handle(con->text->id.name); | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 		ReleaseGlobalDictionary(globals); | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 		con->flag |= PYCON_SCRIPTERROR; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 		/* free temp objects */ | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 		Py_XDECREF(idprop); | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (retval) {Py_XDECREF( retval );} | 
					
						
							|  |  |  | 	retval = NULL; | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	gval = PyDict_GetItemString(globals, "getSettings"); | 
					
						
							|  |  |  | 	if (!gval) { | 
					
						
							| 
									
										
										
										
											2007-06-20 09:58:16 +00:00
										 |  |  | 		printf("ERROR: no getSettings function in constraint!\n"); | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		/* free temp objects */ | 
					
						
							|  |  |  | 		ReleaseGlobalDictionary( globals ); | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 		Py_XDECREF(idprop); | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* Now for the fun part! Try and find the functions we need. */ | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 	if (PyFunction_Check(gval)) { | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 		retval = PyObject_CallFunction(gval, "O", idprop); | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 	}  | 
					
						
							|  |  |  | 	else { | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 		printf("ERROR: getSettings is supposed to be a function!\n"); | 
					
						
							|  |  |  | 		ReleaseGlobalDictionary( globals ); | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 		Py_XDECREF(idprop); | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if (!retval) { | 
					
						
							|  |  |  | 		BPY_Err_Handle(con->text->id.name); | 
					
						
							|  |  |  | 		con->flag |= PYCON_SCRIPTERROR; | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		/* free temp objects */ | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 		ReleaseGlobalDictionary(globals); | 
					
						
							|  |  |  | 		Py_XDECREF(idprop); | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		/* clear globals */ | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 		ReleaseGlobalDictionary(globals); | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		/* free temp objects */ | 
					
						
							| 
									
										
											  
											
												== Constraints System - Recode 2 ==
Once again, I've recoded the constraints system. This time, the goals were:
* To make it more future-proof by 'modernising' the coding style. The long functions filled with switch statements, have given way to function-pointers with smaller functions for specific purposes.
* To make it support constraints which use multiple targets more readily that it did. In the past, it was assumed that constraints could only have at most one target.
As a result, a lot of code has been shuffled around, and modified. Also, the subversion number has been bumped up.
Known issues:
* PyConstraints, which were the main motivation for supporting multiple-targets, are currently broken. There are some bimport() error that keeps causing problems. I've also temporarily removed the doDriver support, although it may return in another form soon. 
* Constraints BPy-API is currently has a few features which currently don't work yet
* Outliner currently only displays the names of the constraints instead of the fancy subtarget/target/constraint-name display it used to do. What gets displayed here needs further investigation, as the old way was certainly not that great (and is not compatible with the new system too) 
											
										 
											2007-10-21 23:00:29 +00:00
										 |  |  | 		Py_XDECREF(idprop); | 
					
						
							|  |  |  | 		Py_DECREF(retval); | 
					
						
							| 
									
										
										
										
											2007-06-18 07:41:21 +00:00
										 |  |  | 		return; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-04-30 22:10:39 +00:00
										 |  |  | /* Update function, it gets rid of pydrivers global dictionary, forcing
 | 
					
						
							|  |  |  |  * BPY_pydriver_eval to recreate it. This function is used to force | 
					
						
							|  |  |  |  * reloading the Blender text module "pydrivers.py", if available, so | 
					
						
							|  |  |  |  * updates in it reach pydriver evaluation. */ | 
					
						
							|  |  |  | void BPY_pydriver_update(void) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	if (bpy_pydriver_Dict) { /* free the global dict used by pydrivers */ | 
					
						
							|  |  |  | 		PyDict_Clear(bpy_pydriver_Dict); | 
					
						
							|  |  |  | 		Py_DECREF(bpy_pydriver_Dict); | 
					
						
							|  |  |  | 		bpy_pydriver_Dict = NULL; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-04-30 16:22:31 +00:00
										 |  |  | /* for depsgraph.c, runs py expr once to collect all refs. made
 | 
					
						
							|  |  |  |  * to objects (self refs. to the object that owns the py driver | 
					
						
							|  |  |  |  * are not allowed). */ | 
					
						
							|  |  |  | struct Object **BPY_pydriver_get_objects(IpoDriver *driver) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	/*if (!driver || !driver->ob || driver->name[0] == '\0')
 | 
					
						
							|  |  |  | 		return NULL;*/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/*PyErr_Clear();*/ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* clear the flag that marks invalid python expressions */ | 
					
						
							|  |  |  | 	driver->flag &= ~IPO_DRIVER_FLAG_INVALID; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* tell we're running a pydriver, so Get() functions know they need
 | 
					
						
							|  |  |  | 	 * to add the requested obj to our list */ | 
					
						
							|  |  |  | 	bpy_pydriver_running(1); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* append driver owner object as the 1st ob in the list;
 | 
					
						
							|  |  |  | 	 * we put it there to make sure it is not itself referenced in | 
					
						
							|  |  |  | 	 * its pydriver expression */ | 
					
						
							|  |  |  | 	bpy_pydriver_appendToList(driver->ob); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* this will append any other ob referenced in expr (driver->name)
 | 
					
						
							|  |  |  | 	 * or set the driver's error flag if driver's py expression fails */ | 
					
						
							|  |  |  | 	BPY_pydriver_eval(driver); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	bpy_pydriver_running(0); /* ok, we're done */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return bpy_pydriver_obArrayFromList(); /* NULL if eval failed */ | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* This evals py driver expressions, 'expr' is a Python expression that
 | 
					
						
							|  |  |  |  * should evaluate to a float number, which is returned. */ | 
					
						
							|  |  |  | float BPY_pydriver_eval(IpoDriver *driver) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	char *expr = NULL; | 
					
						
							| 
									
										
										
										
											2007-12-07 09:51:02 +00:00
										 |  |  | 	PyObject *retval, *bpy_ob = NULL; | 
					
						
							| 
									
										
										
										
											2006-04-30 16:22:31 +00:00
										 |  |  | 	float result = 0.0f; /* default return */ | 
					
						
							| 
									
										
										
										
											2007-03-30 00:57:07 +00:00
										 |  |  | 	int setitem_retval; | 
					
						
							| 
									
										
										
										
											2006-04-30 16:22:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (!driver) return result; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	expr = driver->name; /* the py expression to be evaluated */ | 
					
						
							|  |  |  | 	if (!expr || expr[0]=='\0') return result; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (!bpy_pydriver_Dict) { | 
					
						
							|  |  |  | 		if (bpy_pydriver_create_dict() != 0) { | 
					
						
							|  |  |  | 			fprintf(stderr, "Pydriver error: couldn't create Python dictionary"); | 
					
						
							|  |  |  | 			return result; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-03-30 00:57:07 +00:00
										 |  |  | 	if (driver->ob) | 
					
						
							|  |  |  | 		bpy_ob = Object_CreatePyObject(driver->ob); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (!bpy_ob) { | 
					
						
							|  |  |  | 		Py_INCREF(Py_None); | 
					
						
							|  |  |  | 		bpy_ob = Py_None; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	setitem_retval = EXPP_dict_set_item_str(bpy_pydriver_Dict, "self", bpy_ob); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-01-31 03:12:26 +00:00
										 |  |  | 	if( !setup_armature_weakrefs()){ | 
					
						
							|  |  |  | 		fprintf( stderr, "Oops - weakref dict setup\n"); | 
					
						
							|  |  |  | 		return result; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-04-30 16:22:31 +00:00
										 |  |  | 	retval = PyRun_String(expr, Py_eval_input, bpy_pydriver_Dict, | 
					
						
							|  |  |  | 		bpy_pydriver_Dict); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (retval == NULL) { | 
					
						
							|  |  |  | 		return pydriver_error(driver); | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2007-03-30 00:57:07 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-12-07 09:51:02 +00:00
										 |  |  | 	result = ( float )PyFloat_AsDouble( retval ); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	if (result == -1 && PyErr_Occurred())  | 
					
						
							| 
									
										
										
										
											2006-04-30 16:22:31 +00:00
										 |  |  | 		return pydriver_error(driver); | 
					
						
							| 
									
										
										
										
											2007-03-30 00:57:07 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* remove 'self', since this dict is also used by py buttons */ | 
					
						
							|  |  |  | 	if (setitem_retval == 0) PyDict_DelItemString(bpy_pydriver_Dict, "self"); | 
					
						
							| 
									
										
										
										
											2006-04-30 16:22:31 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* all fine, make sure the "invalid expression" flag is cleared */ | 
					
						
							|  |  |  | 	driver->flag &= ~IPO_DRIVER_FLAG_INVALID; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return result; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-06-12 00:10:00 +00:00
										 |  |  | /* Button Python Evaluation */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* Python evaluation for gui buttons:
 | 
					
						
							|  |  |  |  *	users can write any valid Python expression (that evals to an int or float) | 
					
						
							|  |  |  |  *	inside Blender's gui number buttons and have them evaluated to their | 
					
						
							|  |  |  |  *	actual int or float value. | 
					
						
							|  |  |  |  * | 
					
						
							|  |  |  |  *	The global dict used for pydrivers is also used here, so all imported | 
					
						
							|  |  |  |  *	modules for pydrivers (including the pydrivers.py Blender text) are | 
					
						
							|  |  |  |  *	available for button py eval, too. */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static int bpy_button_eval_error(char *expr) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (bpy_pydriver_oblist) | 
					
						
							|  |  |  | 		bpy_pydriver_freeList(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (bpy_pydriver_Dict) { /* free the persistent global dict */ | 
					
						
							|  |  |  | 		/* it's the same dict used by pydrivers */ | 
					
						
							|  |  |  | 		PyDict_Clear(bpy_pydriver_Dict); | 
					
						
							|  |  |  | 		Py_DECREF(bpy_pydriver_Dict); | 
					
						
							|  |  |  | 		bpy_pydriver_Dict = NULL; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	fprintf(stderr, "\nError in button evaluation:\nThis is the failed Python expression:\n'%s'\n\n", expr); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	PyErr_Print(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return -1; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int BPY_button_eval(char *expr, double *value) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	PyObject *retval, *floatval; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (!value || !expr || expr[0]=='\0') return -1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	*value = 0.0; /* default value */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (!bpy_pydriver_Dict) { | 
					
						
							|  |  |  | 		if (bpy_pydriver_create_dict() != 0) { | 
					
						
							|  |  |  | 			fprintf(stderr, | 
					
						
							|  |  |  | 				"Button Python Eval error: couldn't create Python dictionary"); | 
					
						
							|  |  |  | 			return -1; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-03-28 03:18:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-01-31 03:12:26 +00:00
										 |  |  | 	if( !setup_armature_weakrefs()){ | 
					
						
							|  |  |  | 		fprintf(stderr, "Oops - weakref dict\n"); | 
					
						
							|  |  |  | 		return -1; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-06-12 00:10:00 +00:00
										 |  |  | 	retval = PyRun_String(expr, Py_eval_input, bpy_pydriver_Dict, | 
					
						
							|  |  |  | 		bpy_pydriver_Dict); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (retval == NULL) { | 
					
						
							|  |  |  | 		return bpy_button_eval_error(expr); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		floatval = PyNumber_Float(retval); | 
					
						
							|  |  |  | 		Py_DECREF(retval); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (floatval == NULL)  | 
					
						
							|  |  |  | 		return bpy_button_eval_error(expr); | 
					
						
							|  |  |  | 	else { | 
					
						
							|  |  |  | 		*value = (float)PyFloat_AsDouble(floatval); | 
					
						
							|  |  |  | 		Py_DECREF(floatval); | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return 0; /* successful exit */ | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-05-13 01:54:28 +00:00
										 |  |  | /*****************************************************************************/ | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | /* ScriptLinks                                                        */ | 
					
						
							| 
									
										
										
										
											2003-05-13 01:54:28 +00:00
										 |  |  | /*****************************************************************************/ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2003-03-08 18:10:20 +00:00
										 |  |  | /*****************************************************************************/ | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | /* Description:								 */ | 
					
						
							|  |  |  | /* Notes:				Not implemented yet	 */ | 
					
						
							| 
									
										
										
										
											2003-03-08 18:10:20 +00:00
										 |  |  | /*****************************************************************************/ | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | void BPY_clear_bad_scriptlinks( struct Text *byebye ) | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2003-05-13 01:54:28 +00:00
										 |  |  | /*
 | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	BPY_clear_bad_scriptlist(getObjectList(), byebye); | 
					
						
							|  |  |  | 	BPY_clear_bad_scriptlist(getLampList(), byebye); | 
					
						
							|  |  |  | 	BPY_clear_bad_scriptlist(getCameraList(), byebye); | 
					
						
							|  |  |  | 	BPY_clear_bad_scriptlist(getMaterialList(), byebye); | 
					
						
							|  |  |  | 	BPY_clear_bad_scriptlist(getWorldList(),	byebye); | 
					
						
							|  |  |  | 	BPY_clear_bad_scriptlink(&scene_getCurrent()->id, byebye); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	allqueue(REDRAWBUTSSCRIPT, 0); | 
					
						
							| 
									
										
										
										
											2003-05-13 01:54:28 +00:00
										 |  |  | */ | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	return; | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | /*****************************************************************************
 | 
					
						
							|  |  |  | * Description: Loop through all scripts of a list of object types, and  | 
					
						
							|  |  |  | *	execute these scripts.	 | 
					
						
							|  |  |  | *	For the scene, only the current active scene the scripts are  | 
					
						
							|  |  |  | *	executed (if any). | 
					
						
							|  |  |  | *****************************************************************************/ | 
					
						
							|  |  |  | void BPY_do_all_scripts( short event ) | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	DoAllScriptsFromList( &( G.main->object ), event ); | 
					
						
							|  |  |  | 	DoAllScriptsFromList( &( G.main->lamp ), event ); | 
					
						
							|  |  |  | 	DoAllScriptsFromList( &( G.main->camera ), event ); | 
					
						
							|  |  |  | 	DoAllScriptsFromList( &( G.main->mat ), event ); | 
					
						
							|  |  |  | 	DoAllScriptsFromList( &( G.main->world ), event ); | 
					
						
							| 
									
										
										
										
											2003-03-19 18:57:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	BPY_do_pyscript( &( G.scene->id ), event ); | 
					
						
							| 
									
										
										
										
											2003-03-19 18:57:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	return; | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | /*****************************************************************************
 | 
					
						
							|  |  |  | * Description: Execute a Python script when an event occurs. The following   | 
					
						
							|  |  |  | *		events are possible: frame changed, load script and redraw.   | 
					
						
							|  |  |  | *		Only events happening to one of the following object types    | 
					
						
							|  |  |  | *		are handled: Object, Lamp, Camera, Material, World and	     | 
					
						
							|  |  |  | *		Scene.			 | 
					
						
							|  |  |  | *****************************************************************************/ | 
					
						
							| 
									
										
										
										
											2004-05-04 14:27:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | static ScriptLink *ID_getScriptlink( ID * id ) | 
					
						
							| 
									
										
										
										
											2004-05-04 14:27:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	switch ( MAKE_ID2( id->name[0], id->name[1] ) ) { | 
					
						
							| 
									
										
										
										
											2004-05-04 14:27:41 +00:00
										 |  |  | 	case ID_OB: | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		return &( ( Object * ) id )->scriptlink; | 
					
						
							| 
									
										
										
										
											2004-05-04 14:27:41 +00:00
										 |  |  | 	case ID_LA: | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		return &( ( Lamp * ) id )->scriptlink; | 
					
						
							| 
									
										
										
										
											2004-05-04 14:27:41 +00:00
										 |  |  | 	case ID_CA: | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		return &( ( Camera * ) id )->scriptlink; | 
					
						
							| 
									
										
										
										
											2004-05-04 14:27:41 +00:00
										 |  |  | 	case ID_MA: | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		return &( ( Material * ) id )->scriptlink; | 
					
						
							| 
									
										
										
										
											2004-05-04 14:27:41 +00:00
										 |  |  | 	case ID_WO: | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		return &( ( World * ) id )->scriptlink; | 
					
						
							| 
									
										
										
										
											2004-05-04 14:27:41 +00:00
										 |  |  | 	case ID_SCE: | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		return &( ( Scene * ) id )->scriptlink; | 
					
						
							| 
									
										
										
										
											2004-05-04 14:27:41 +00:00
										 |  |  | 	default: | 
					
						
							|  |  |  | 		return NULL; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | int BPY_has_onload_script( void ) | 
					
						
							| 
									
										
										
										
											2004-07-20 08:16:46 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	ScriptLink *slink = &G.scene->scriptlink; | 
					
						
							|  |  |  | 	int i; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	if( !slink || !slink->totscript ) | 
					
						
							|  |  |  | 		return 0; | 
					
						
							| 
									
										
										
										
											2004-07-20 08:16:46 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	for( i = 0; i < slink->totscript; i++ ) { | 
					
						
							|  |  |  | 		if( ( slink->flag[i] == SCRIPT_ONLOAD ) | 
					
						
							|  |  |  | 		    && ( slink->scripts[i] != NULL ) ) | 
					
						
							|  |  |  | 			return 1; | 
					
						
							| 
									
										
										
										
											2004-07-20 08:16:46 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | void BPY_do_pyscript( ID * id, short event ) | 
					
						
							| 
									
										
										
										
											2004-05-04 14:27:41 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2004-11-07 15:05:35 +00:00
										 |  |  | 	ScriptLink *scriptlink; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if( !id ) return; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	scriptlink = ID_getScriptlink( id ); | 
					
						
							| 
									
										
										
										
											2004-05-04 14:27:41 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	if( scriptlink && scriptlink->totscript ) { | 
					
						
							| 
									
										
										
										
											2007-11-06 13:44:26 +00:00
										 |  |  | 		PyObject *value; | 
					
						
							| 
									
										
										
										
											2004-05-04 14:27:41 +00:00
										 |  |  | 		PyObject *dict; | 
					
						
							|  |  |  | 		PyObject *ret; | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		int index, during_slink = during_scriptlink(  ); | 
					
						
							| 
									
										
										
										
											2004-07-16 03:08:43 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* invalid scriptlinks (new .blend was just loaded), return */ | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		if( during_slink < 0 ) | 
					
						
							|  |  |  | 			return; | 
					
						
							| 
									
										
										
										
											2007-09-23 22:02:18 +00:00
										 |  |  | 		 | 
					
						
							|  |  |  | 		if( !setup_armature_weakrefs()){ | 
					
						
							| 
									
										
										
										
											2007-11-06 13:44:26 +00:00
										 |  |  | 			printf("Oops - weakref dict, this is a bug\n"); | 
					
						
							|  |  |  | 			return; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		 | 
					
						
							|  |  |  | 		value = GetPyObjectFromID( id ); | 
					
						
							|  |  |  | 		if( !value){ | 
					
						
							|  |  |  | 			printf("Oops - could not get a valid python object for Blender.link, this is a bug\n"); | 
					
						
							| 
									
										
										
										
											2007-09-23 22:02:18 +00:00
										 |  |  | 			return; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
										
										
											2004-07-16 03:08:43 +00:00
										 |  |  | 		/* tell we're running a scriptlink.  The sum also tells if this script
 | 
					
						
							|  |  |  | 		 * is running nested inside another.  Blender.Load needs this info to | 
					
						
							|  |  |  | 		 * avoid trouble with invalid slink pointers. */ | 
					
						
							|  |  |  | 		during_slink++; | 
					
						
							| 
									
										
										
										
											2005-07-18 03:50:37 +00:00
										 |  |  | 		disable_where_scriptlink( (short)during_slink ); | 
					
						
							| 
									
										
										
										
											2004-07-16 03:08:43 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* set globals in Blender module to identify scriptlink */ | 
					
						
							| 
									
										
										
										
											2007-12-07 09:51:02 +00:00
										 |  |  | 		PyDict_SetItemString(	g_blenderdict, "bylink", Py_True); | 
					
						
							| 
									
										
										
										
											2007-11-06 13:44:26 +00:00
										 |  |  | 		EXPP_dict_set_item_str( g_blenderdict, "link", value ); | 
					
						
							| 
									
										
										
										
											2005-11-30 08:18:06 +00:00
										 |  |  | 		EXPP_dict_set_item_str( g_blenderdict, "event", | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 				      PyString_FromString( event_to_name | 
					
						
							|  |  |  | 							   ( event ) ) ); | 
					
						
							| 
									
										
											  
											
												BPython:
- Made Blender.event var (previously only used by script links) hold ascii value -- where it applies -- of current event during events callback registered with Draw.Register(gui, events, button_events).  Useful for gui scripts like Campbell's Python console. No problem using this var to hold the value, since in gui scripts it was not used (always None).
- Updated Window and Window.Theme with new theme vars and the Time space.
- Script links:
-- Added "Render" event for script links (runs twice, second time as "PostEvent", for clean-up actions). Now FrameChanged links don't run when a single pic is rendered.
-- Added "Enable Script Links" button in the script buttons tab.  Now this bit gets saved in .blends along with the rest of G.f, so users can define per .blend if they are on or off by default.  "blender -y" also disables all slinks as happened before with OnLoad ones only.
-- Other small changes in the script buttons tab:
  When a link is added (button "new"), it becomes the active one for the window, no need to press a button to reach it.
  Also, a pupmenu showing all available texts is shown when "new" is pressed, so users can choose a text w/o having to type.  Cancel the popup to leave the string button empty (link exists, but has no script assigned).  A pulldown would be better UI-wise, but it's kinda weird to show both scripts and normal texts (Blender doesn't differentiate them) in a script links pulldown.  With a popup we can show only texts ending in ".py" (not done in this commit, need opinions) and if the script has no or another extension, case of many in old and current .blend's, there's still the string box for writing its name.
-- Implemented Ton's space handler script links:
Right now only for the 3d View,  but it's trivial to add for others.  There are two types: EVENT, to receive 3d View events from a chosen window and DRAW, to draw on the window.  Ton's idea was to give scripts a controlled way to integrate better within Blender.
Here's how it works:
- scripts must have a proper header, like:
# SPACEHANDLER.VIEW3D.EVENT
and then they are shown in 3d View's View menu, "Space Handler Scripts" submenu.  Check (mark, click on it) a script to make it active.
EVENT handlers should consult the Blender.event var to get the current event, which can be compared with values from the Draw module:
import Blender
from Blender import Draw
evt = Blender.event
if evt == Draw.AKEY:
  print "a"
elif evt == Draw.LEFTMOUSE:
  print "left mouse button"
else:
  return # ignore, pass event back to Blender
Blender.event = None # tell Blender not to process itself the event
DRAW handlers are free to draw to their owner 3D View. OpenGL attributes and modelview and projection matrices are pushed before running the handler and poped when it finishes.
To communicate between EVENT and DRAW handler scripts we have the Blender.Registry module, as always.
Still need to code some nice example, which should also serve to test properly space handlers.  Simple tests went fine.
- doc updates about the additions.
=======
Note: the UI part of the space handlers and script links is of course open for changes, I just tried to make it understandable.  Probably we won't use the scriptlinks icon for "None Available" (check 3d View -> View -> Space Handler Scripts), though it hints at what space handlers are.  The tooltips may not be accepted either, since other menus don't use them.  Opinions welcomed.
											
										 
											2005-05-08 21:20:34 +00:00
										 |  |  | 		if (event == SCRIPT_POSTRENDER) event = SCRIPT_RENDER; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		for( index = 0; index < scriptlink->totscript; index++ ) { | 
					
						
							|  |  |  | 			if( ( scriptlink->flag[index] == event ) && | 
					
						
							|  |  |  | 			    ( scriptlink->scripts[index] != NULL ) ) { | 
					
						
							|  |  |  | 				dict = CreateGlobalDictionary(  ); | 
					
						
							|  |  |  | 				ret = RunPython( ( Text * ) scriptlink-> | 
					
						
							|  |  |  | 						 scripts[index], dict ); | 
					
						
							|  |  |  | 				ReleaseGlobalDictionary( dict ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				if( !ret ) { | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 					/* Failed execution of the script */ | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 					BPY_Err_Handle( scriptlink-> | 
					
						
							|  |  |  | 							scripts[index]->name + | 
					
						
							|  |  |  | 							2 ); | 
					
						
							| 
									
										
										
										
											2004-07-16 03:08:43 +00:00
										 |  |  | 					//BPY_end_python ();
 | 
					
						
							|  |  |  | 					//BPY_start_python ();
 | 
					
						
							| 
									
										
										
										
											2004-05-04 14:27:41 +00:00
										 |  |  | 				} else { | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 					Py_DECREF( ret ); | 
					
						
							| 
									
										
										
										
											2004-05-04 14:27:41 +00:00
										 |  |  | 				} | 
					
						
							| 
									
										
										
										
											2004-07-16 03:08:43 +00:00
										 |  |  | 				/* If a scriptlink has just loaded a new .blend file, the
 | 
					
						
							|  |  |  | 				 * scriptlink pointer became invalid (see api2_2x/Blender.c), | 
					
						
							|  |  |  | 				 * so we stop here. */ | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 				if( during_scriptlink(  ) == -1 ) { | 
					
						
							| 
									
										
										
										
											2004-07-16 03:08:43 +00:00
										 |  |  | 					during_slink = 1; | 
					
						
							|  |  |  | 					break; | 
					
						
							|  |  |  | 				} | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-18 03:50:37 +00:00
										 |  |  | 		disable_where_scriptlink( (short)(during_slink - 1) ); | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 		/* cleanup bylink flag and clear link so PyObject
 | 
					
						
							|  |  |  | 		 * can be released  | 
					
						
							|  |  |  | 		 */ | 
					
						
							| 
									
										
										
										
											2007-12-07 09:51:02 +00:00
										 |  |  | 		PyDict_SetItemString(g_blenderdict, "bylink", Py_False); | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		PyDict_SetItemString( g_blenderdict, "link", Py_None ); | 
					
						
							| 
									
										
										
										
											2007-12-07 09:51:02 +00:00
										 |  |  | 		EXPP_dict_set_item_str( g_blenderdict, "event", PyString_FromString( "" ) ); | 
					
						
							| 
									
										
										
										
											2004-05-04 14:27:41 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2006-05-07 08:23:51 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
											  
											
												BPython:
- Made Blender.event var (previously only used by script links) hold ascii value -- where it applies -- of current event during events callback registered with Draw.Register(gui, events, button_events).  Useful for gui scripts like Campbell's Python console. No problem using this var to hold the value, since in gui scripts it was not used (always None).
- Updated Window and Window.Theme with new theme vars and the Time space.
- Script links:
-- Added "Render" event for script links (runs twice, second time as "PostEvent", for clean-up actions). Now FrameChanged links don't run when a single pic is rendered.
-- Added "Enable Script Links" button in the script buttons tab.  Now this bit gets saved in .blends along with the rest of G.f, so users can define per .blend if they are on or off by default.  "blender -y" also disables all slinks as happened before with OnLoad ones only.
-- Other small changes in the script buttons tab:
  When a link is added (button "new"), it becomes the active one for the window, no need to press a button to reach it.
  Also, a pupmenu showing all available texts is shown when "new" is pressed, so users can choose a text w/o having to type.  Cancel the popup to leave the string button empty (link exists, but has no script assigned).  A pulldown would be better UI-wise, but it's kinda weird to show both scripts and normal texts (Blender doesn't differentiate them) in a script links pulldown.  With a popup we can show only texts ending in ".py" (not done in this commit, need opinions) and if the script has no or another extension, case of many in old and current .blend's, there's still the string box for writing its name.
-- Implemented Ton's space handler script links:
Right now only for the 3d View,  but it's trivial to add for others.  There are two types: EVENT, to receive 3d View events from a chosen window and DRAW, to draw on the window.  Ton's idea was to give scripts a controlled way to integrate better within Blender.
Here's how it works:
- scripts must have a proper header, like:
# SPACEHANDLER.VIEW3D.EVENT
and then they are shown in 3d View's View menu, "Space Handler Scripts" submenu.  Check (mark, click on it) a script to make it active.
EVENT handlers should consult the Blender.event var to get the current event, which can be compared with values from the Draw module:
import Blender
from Blender import Draw
evt = Blender.event
if evt == Draw.AKEY:
  print "a"
elif evt == Draw.LEFTMOUSE:
  print "left mouse button"
else:
  return # ignore, pass event back to Blender
Blender.event = None # tell Blender not to process itself the event
DRAW handlers are free to draw to their owner 3D View. OpenGL attributes and modelview and projection matrices are pushed before running the handler and poped when it finishes.
To communicate between EVENT and DRAW handler scripts we have the Blender.Registry module, as always.
Still need to code some nice example, which should also serve to test properly space handlers.  Simple tests went fine.
- doc updates about the additions.
=======
Note: the UI part of the space handlers and script links is of course open for changes, I just tried to make it understandable.  Probably we won't use the scriptlinks icon for "None Available" (check 3d View -> View -> Space Handler Scripts), though it hints at what space handlers are.  The tooltips may not be accepted either, since other menus don't use them.  Opinions welcomed.
											
										 
											2005-05-08 21:20:34 +00:00
										 |  |  | /* SPACE HANDLERS */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* These are special script links that can be assigned to ScrArea's to
 | 
					
						
							|  |  |  |  * (EVENT type) receive events sent to a given space (and use or ignore them) or | 
					
						
							|  |  |  |  * (DRAW type) be called after the space is drawn, to draw anything on top of | 
					
						
							|  |  |  |  * the space area. */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* How to add space handlers to other spaces:
 | 
					
						
							|  |  |  |  * - add the space event defines to DNA_scriptlink_types.h, as done for | 
					
						
							|  |  |  |  *   3d view: SPACEHANDLER_VIEW3D_EVENT, for example; | 
					
						
							|  |  |  |  * - add the new defines to Blender.SpaceHandler dictionary in Blender.c; | 
					
						
							|  |  |  |  * - check space.c for how to call the event handlers; | 
					
						
							|  |  |  |  * - check drawview.c for how to call the draw handlers; | 
					
						
							|  |  |  |  * - check header_view3d.c for how to add the "Space Handler Scripts" menu. | 
					
						
							|  |  |  |  * Note: DRAW handlers should be called with 'event = 0', chech drawview.c */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int BPY_has_spacehandler(Text *text, ScrArea *sa) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	ScriptLink *slink; | 
					
						
							|  |  |  | 	int index; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (!sa || !text) return 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	slink = &sa->scriptlink; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for (index = 0; index < slink->totscript; index++) { | 
					
						
							|  |  |  | 		if (slink->scripts[index] && (slink->scripts[index] == (ID *)text)) | 
					
						
							|  |  |  | 			return 1; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return 0;	 | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int BPY_is_spacehandler(Text *text, char spacetype) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	TextLine *tline = text->lines.first; | 
					
						
							|  |  |  | 	unsigned short type = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (tline && (tline->len > 10)) { | 
					
						
							|  |  |  | 		char *line = tline->line; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* Expected format: # SPACEHANDLER.SPACE.TYPE
 | 
					
						
							|  |  |  | 		 * Ex: # SPACEHANDLER.VIEW3D.DRAW | 
					
						
							|  |  |  | 		 * The actual checks are forgiving, so slight variations also work. */ | 
					
						
							|  |  |  | 		if (line && line[0] == '#' && strstr(line, "HANDLER")) { | 
					
						
							|  |  |  | 			line++; /* skip '#' */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/* only done for 3D View right now, trivial to add for others: */ | 
					
						
							|  |  |  | 			switch (spacetype) { | 
					
						
							|  |  |  | 				case SPACE_VIEW3D: | 
					
						
							|  |  |  | 					if (strstr(line, "3D")) { /* VIEW3D, 3DVIEW */ | 
					
						
							|  |  |  | 						if (strstr(line, "DRAW")) type = SPACEHANDLER_VIEW3D_DRAW; | 
					
						
							|  |  |  | 						else if (strstr(line, "EVENT")) type = SPACEHANDLER_VIEW3D_EVENT; | 
					
						
							|  |  |  | 					} | 
					
						
							|  |  |  | 					break; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return type; /* 0 if not a space handler */ | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int BPY_del_spacehandler(Text *text, ScrArea *sa) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	ScriptLink *slink; | 
					
						
							|  |  |  | 	int i, j; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (!sa || !text) return -1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	slink = &sa->scriptlink; | 
					
						
							|  |  |  | 	if (slink->totscript < 1) return -1; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for (i = 0; i < slink->totscript; i++) { | 
					
						
							|  |  |  | 		if (text == (Text *)slink->scripts[i]) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			for (j = i; j < slink->totscript - 1; j++) { | 
					
						
							|  |  |  | 				slink->flag[j] = slink->flag[j+1]; | 
					
						
							|  |  |  | 				slink->scripts[j] = slink->scripts[j+1]; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 			slink->totscript--; | 
					
						
							|  |  |  | 			/* like done in buttons_script.c we just free memory
 | 
					
						
							|  |  |  | 			 * if all slinks have been removed -- less fragmentation, | 
					
						
							|  |  |  | 			 * these should be quite small arrays */ | 
					
						
							|  |  |  | 			if (slink->totscript == 0) { | 
					
						
							|  |  |  | 				if (slink->scripts) MEM_freeN(slink->scripts); | 
					
						
							|  |  |  | 				if (slink->flag) MEM_freeN(slink->flag); | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int BPY_add_spacehandler(Text *text, ScrArea *sa, char spacetype) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	unsigned short handlertype; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (!sa || !text) return -1; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-07-18 03:50:37 +00:00
										 |  |  | 	handlertype = (unsigned short)BPY_is_spacehandler(text, spacetype); | 
					
						
							| 
									
										
											  
											
												BPython:
- Made Blender.event var (previously only used by script links) hold ascii value -- where it applies -- of current event during events callback registered with Draw.Register(gui, events, button_events).  Useful for gui scripts like Campbell's Python console. No problem using this var to hold the value, since in gui scripts it was not used (always None).
- Updated Window and Window.Theme with new theme vars and the Time space.
- Script links:
-- Added "Render" event for script links (runs twice, second time as "PostEvent", for clean-up actions). Now FrameChanged links don't run when a single pic is rendered.
-- Added "Enable Script Links" button in the script buttons tab.  Now this bit gets saved in .blends along with the rest of G.f, so users can define per .blend if they are on or off by default.  "blender -y" also disables all slinks as happened before with OnLoad ones only.
-- Other small changes in the script buttons tab:
  When a link is added (button "new"), it becomes the active one for the window, no need to press a button to reach it.
  Also, a pupmenu showing all available texts is shown when "new" is pressed, so users can choose a text w/o having to type.  Cancel the popup to leave the string button empty (link exists, but has no script assigned).  A pulldown would be better UI-wise, but it's kinda weird to show both scripts and normal texts (Blender doesn't differentiate them) in a script links pulldown.  With a popup we can show only texts ending in ".py" (not done in this commit, need opinions) and if the script has no or another extension, case of many in old and current .blend's, there's still the string box for writing its name.
-- Implemented Ton's space handler script links:
Right now only for the 3d View,  but it's trivial to add for others.  There are two types: EVENT, to receive 3d View events from a chosen window and DRAW, to draw on the window.  Ton's idea was to give scripts a controlled way to integrate better within Blender.
Here's how it works:
- scripts must have a proper header, like:
# SPACEHANDLER.VIEW3D.EVENT
and then they are shown in 3d View's View menu, "Space Handler Scripts" submenu.  Check (mark, click on it) a script to make it active.
EVENT handlers should consult the Blender.event var to get the current event, which can be compared with values from the Draw module:
import Blender
from Blender import Draw
evt = Blender.event
if evt == Draw.AKEY:
  print "a"
elif evt == Draw.LEFTMOUSE:
  print "left mouse button"
else:
  return # ignore, pass event back to Blender
Blender.event = None # tell Blender not to process itself the event
DRAW handlers are free to draw to their owner 3D View. OpenGL attributes and modelview and projection matrices are pushed before running the handler and poped when it finishes.
To communicate between EVENT and DRAW handler scripts we have the Blender.Registry module, as always.
Still need to code some nice example, which should also serve to test properly space handlers.  Simple tests went fine.
- doc updates about the additions.
=======
Note: the UI part of the space handlers and script links is of course open for changes, I just tried to make it understandable.  Probably we won't use the scriptlinks icon for "None Available" (check 3d View -> View -> Space Handler Scripts), though it hints at what space handlers are.  The tooltips may not be accepted either, since other menus don't use them.  Opinions welcomed.
											
										 
											2005-05-08 21:20:34 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	if (handlertype) { | 
					
						
							|  |  |  | 		ScriptLink *slink = &sa->scriptlink; | 
					
						
							|  |  |  | 		void *stmp, *ftmp; | 
					
						
							|  |  |  | 		unsigned short space_event = SPACEHANDLER_VIEW3D_EVENT; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* extend slink */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		stmp= slink->scripts;		 | 
					
						
							|  |  |  | 		slink->scripts= MEM_mallocN(sizeof(ID*)*(slink->totscript+1), | 
					
						
							|  |  |  | 			"spacehandlerscripts"); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 		ftmp= slink->flag;		 | 
					
						
							|  |  |  | 		slink->flag= MEM_mallocN(sizeof(short*)*(slink->totscript+1), | 
					
						
							|  |  |  | 			"spacehandlerflags"); | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 		if (slink->totscript) { | 
					
						
							|  |  |  | 			memcpy(slink->scripts, stmp, sizeof(ID*)*(slink->totscript)); | 
					
						
							|  |  |  | 			MEM_freeN(stmp); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			memcpy(slink->flag, ftmp, sizeof(short)*(slink->totscript)); | 
					
						
							|  |  |  | 			MEM_freeN(ftmp); | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		switch (spacetype) { | 
					
						
							|  |  |  | 			case SPACE_VIEW3D: | 
					
						
							|  |  |  | 				if (handlertype == 1) space_event = SPACEHANDLER_VIEW3D_EVENT; | 
					
						
							|  |  |  | 				else space_event = SPACEHANDLER_VIEW3D_DRAW; | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 			default: | 
					
						
							|  |  |  | 				break; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		slink->scripts[slink->totscript] = (ID *)text; | 
					
						
							|  |  |  | 		slink->flag[slink->totscript]= space_event; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		slink->totscript++; | 
					
						
							|  |  |  | 		slink->actscript = slink->totscript; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return 0; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | int BPY_do_spacehandlers( ScrArea *sa, unsigned short event, | 
					
						
							|  |  |  | 	unsigned short space_event ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	ScriptLink *scriptlink; | 
					
						
							|  |  |  | 	int retval = 0; | 
					
						
							| 
									
										
										
										
											2006-04-26 08:22:39 +00:00
										 |  |  | 	 | 
					
						
							|  |  |  | 	if (!sa || !(G.f & G_DOSCRIPTLINKS)) return 0; | 
					
						
							|  |  |  | 	 | 
					
						
							| 
									
										
											  
											
												BPython:
- Made Blender.event var (previously only used by script links) hold ascii value -- where it applies -- of current event during events callback registered with Draw.Register(gui, events, button_events).  Useful for gui scripts like Campbell's Python console. No problem using this var to hold the value, since in gui scripts it was not used (always None).
- Updated Window and Window.Theme with new theme vars and the Time space.
- Script links:
-- Added "Render" event for script links (runs twice, second time as "PostEvent", for clean-up actions). Now FrameChanged links don't run when a single pic is rendered.
-- Added "Enable Script Links" button in the script buttons tab.  Now this bit gets saved in .blends along with the rest of G.f, so users can define per .blend if they are on or off by default.  "blender -y" also disables all slinks as happened before with OnLoad ones only.
-- Other small changes in the script buttons tab:
  When a link is added (button "new"), it becomes the active one for the window, no need to press a button to reach it.
  Also, a pupmenu showing all available texts is shown when "new" is pressed, so users can choose a text w/o having to type.  Cancel the popup to leave the string button empty (link exists, but has no script assigned).  A pulldown would be better UI-wise, but it's kinda weird to show both scripts and normal texts (Blender doesn't differentiate them) in a script links pulldown.  With a popup we can show only texts ending in ".py" (not done in this commit, need opinions) and if the script has no or another extension, case of many in old and current .blend's, there's still the string box for writing its name.
-- Implemented Ton's space handler script links:
Right now only for the 3d View,  but it's trivial to add for others.  There are two types: EVENT, to receive 3d View events from a chosen window and DRAW, to draw on the window.  Ton's idea was to give scripts a controlled way to integrate better within Blender.
Here's how it works:
- scripts must have a proper header, like:
# SPACEHANDLER.VIEW3D.EVENT
and then they are shown in 3d View's View menu, "Space Handler Scripts" submenu.  Check (mark, click on it) a script to make it active.
EVENT handlers should consult the Blender.event var to get the current event, which can be compared with values from the Draw module:
import Blender
from Blender import Draw
evt = Blender.event
if evt == Draw.AKEY:
  print "a"
elif evt == Draw.LEFTMOUSE:
  print "left mouse button"
else:
  return # ignore, pass event back to Blender
Blender.event = None # tell Blender not to process itself the event
DRAW handlers are free to draw to their owner 3D View. OpenGL attributes and modelview and projection matrices are pushed before running the handler and poped when it finishes.
To communicate between EVENT and DRAW handler scripts we have the Blender.Registry module, as always.
Still need to code some nice example, which should also serve to test properly space handlers.  Simple tests went fine.
- doc updates about the additions.
=======
Note: the UI part of the space handlers and script links is of course open for changes, I just tried to make it understandable.  Probably we won't use the scriptlinks icon for "None Available" (check 3d View -> View -> Space Handler Scripts), though it hints at what space handlers are.  The tooltips may not be accepted either, since other menus don't use them.  Opinions welcomed.
											
										 
											2005-05-08 21:20:34 +00:00
										 |  |  | 	scriptlink = &sa->scriptlink; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	if (scriptlink->totscript > 0) { | 
					
						
							|  |  |  | 		PyObject *dict; | 
					
						
							|  |  |  | 		PyObject *ret; | 
					
						
							|  |  |  | 		int index, during_slink = during_scriptlink(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* invalid scriptlinks (new .blend was just loaded), return */ | 
					
						
							|  |  |  | 		if (during_slink < 0) return 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		/* tell we're running a scriptlink.  The sum also tells if this script
 | 
					
						
							|  |  |  | 		 * is running nested inside another.  Blender.Load needs this info to | 
					
						
							| 
									
										
										
										
											2005-09-09 01:31:10 +00:00
										 |  |  | 		 * avoid trouble with invalid slink pointers. | 
					
						
							|  |  |  | 		 * Update (test): allow EVENT space handlers to call file/image selectors, | 
					
						
							|  |  |  | 		 * still disabled for DRAW space handlers: */ | 
					
						
							|  |  |  | 		if (event == 0) { /* event = 0: DRAW space handler */ | 
					
						
							|  |  |  | 			during_slink++; | 
					
						
							|  |  |  | 			disable_where_scriptlink( (short)during_slink ); | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
											  
											
												BPython:
- Made Blender.event var (previously only used by script links) hold ascii value -- where it applies -- of current event during events callback registered with Draw.Register(gui, events, button_events).  Useful for gui scripts like Campbell's Python console. No problem using this var to hold the value, since in gui scripts it was not used (always None).
- Updated Window and Window.Theme with new theme vars and the Time space.
- Script links:
-- Added "Render" event for script links (runs twice, second time as "PostEvent", for clean-up actions). Now FrameChanged links don't run when a single pic is rendered.
-- Added "Enable Script Links" button in the script buttons tab.  Now this bit gets saved in .blends along with the rest of G.f, so users can define per .blend if they are on or off by default.  "blender -y" also disables all slinks as happened before with OnLoad ones only.
-- Other small changes in the script buttons tab:
  When a link is added (button "new"), it becomes the active one for the window, no need to press a button to reach it.
  Also, a pupmenu showing all available texts is shown when "new" is pressed, so users can choose a text w/o having to type.  Cancel the popup to leave the string button empty (link exists, but has no script assigned).  A pulldown would be better UI-wise, but it's kinda weird to show both scripts and normal texts (Blender doesn't differentiate them) in a script links pulldown.  With a popup we can show only texts ending in ".py" (not done in this commit, need opinions) and if the script has no or another extension, case of many in old and current .blend's, there's still the string box for writing its name.
-- Implemented Ton's space handler script links:
Right now only for the 3d View,  but it's trivial to add for others.  There are two types: EVENT, to receive 3d View events from a chosen window and DRAW, to draw on the window.  Ton's idea was to give scripts a controlled way to integrate better within Blender.
Here's how it works:
- scripts must have a proper header, like:
# SPACEHANDLER.VIEW3D.EVENT
and then they are shown in 3d View's View menu, "Space Handler Scripts" submenu.  Check (mark, click on it) a script to make it active.
EVENT handlers should consult the Blender.event var to get the current event, which can be compared with values from the Draw module:
import Blender
from Blender import Draw
evt = Blender.event
if evt == Draw.AKEY:
  print "a"
elif evt == Draw.LEFTMOUSE:
  print "left mouse button"
else:
  return # ignore, pass event back to Blender
Blender.event = None # tell Blender not to process itself the event
DRAW handlers are free to draw to their owner 3D View. OpenGL attributes and modelview and projection matrices are pushed before running the handler and poped when it finishes.
To communicate between EVENT and DRAW handler scripts we have the Blender.Registry module, as always.
Still need to code some nice example, which should also serve to test properly space handlers.  Simple tests went fine.
- doc updates about the additions.
=======
Note: the UI part of the space handlers and script links is of course open for changes, I just tried to make it understandable.  Probably we won't use the scriptlinks icon for "None Available" (check 3d View -> View -> Space Handler Scripts), though it hints at what space handlers are.  The tooltips may not be accepted either, since other menus don't use them.  Opinions welcomed.
											
										 
											2005-05-08 21:20:34 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-11-06 13:44:26 +00:00
										 |  |  | 		if( !setup_armature_weakrefs()){ | 
					
						
							|  |  |  | 			printf("Oops - weakref dict, this is a bug\n"); | 
					
						
							|  |  |  | 			return 0; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		 | 
					
						
							| 
									
										
											  
											
												BPython:
- Made Blender.event var (previously only used by script links) hold ascii value -- where it applies -- of current event during events callback registered with Draw.Register(gui, events, button_events).  Useful for gui scripts like Campbell's Python console. No problem using this var to hold the value, since in gui scripts it was not used (always None).
- Updated Window and Window.Theme with new theme vars and the Time space.
- Script links:
-- Added "Render" event for script links (runs twice, second time as "PostEvent", for clean-up actions). Now FrameChanged links don't run when a single pic is rendered.
-- Added "Enable Script Links" button in the script buttons tab.  Now this bit gets saved in .blends along with the rest of G.f, so users can define per .blend if they are on or off by default.  "blender -y" also disables all slinks as happened before with OnLoad ones only.
-- Other small changes in the script buttons tab:
  When a link is added (button "new"), it becomes the active one for the window, no need to press a button to reach it.
  Also, a pupmenu showing all available texts is shown when "new" is pressed, so users can choose a text w/o having to type.  Cancel the popup to leave the string button empty (link exists, but has no script assigned).  A pulldown would be better UI-wise, but it's kinda weird to show both scripts and normal texts (Blender doesn't differentiate them) in a script links pulldown.  With a popup we can show only texts ending in ".py" (not done in this commit, need opinions) and if the script has no or another extension, case of many in old and current .blend's, there's still the string box for writing its name.
-- Implemented Ton's space handler script links:
Right now only for the 3d View,  but it's trivial to add for others.  There are two types: EVENT, to receive 3d View events from a chosen window and DRAW, to draw on the window.  Ton's idea was to give scripts a controlled way to integrate better within Blender.
Here's how it works:
- scripts must have a proper header, like:
# SPACEHANDLER.VIEW3D.EVENT
and then they are shown in 3d View's View menu, "Space Handler Scripts" submenu.  Check (mark, click on it) a script to make it active.
EVENT handlers should consult the Blender.event var to get the current event, which can be compared with values from the Draw module:
import Blender
from Blender import Draw
evt = Blender.event
if evt == Draw.AKEY:
  print "a"
elif evt == Draw.LEFTMOUSE:
  print "left mouse button"
else:
  return # ignore, pass event back to Blender
Blender.event = None # tell Blender not to process itself the event
DRAW handlers are free to draw to their owner 3D View. OpenGL attributes and modelview and projection matrices are pushed before running the handler and poped when it finishes.
To communicate between EVENT and DRAW handler scripts we have the Blender.Registry module, as always.
Still need to code some nice example, which should also serve to test properly space handlers.  Simple tests went fine.
- doc updates about the additions.
=======
Note: the UI part of the space handlers and script links is of course open for changes, I just tried to make it understandable.  Probably we won't use the scriptlinks icon for "None Available" (check 3d View -> View -> Space Handler Scripts), though it hints at what space handlers are.  The tooltips may not be accepted either, since other menus don't use them.  Opinions welcomed.
											
										 
											2005-05-08 21:20:34 +00:00
										 |  |  | 		/* set globals in Blender module to identify space handler scriptlink */ | 
					
						
							| 
									
										
										
										
											2007-12-07 09:51:02 +00:00
										 |  |  | 		PyDict_SetItemString(g_blenderdict, "bylink", Py_True); | 
					
						
							| 
									
										
											  
											
												BPython:
- Made Blender.event var (previously only used by script links) hold ascii value -- where it applies -- of current event during events callback registered with Draw.Register(gui, events, button_events).  Useful for gui scripts like Campbell's Python console. No problem using this var to hold the value, since in gui scripts it was not used (always None).
- Updated Window and Window.Theme with new theme vars and the Time space.
- Script links:
-- Added "Render" event for script links (runs twice, second time as "PostEvent", for clean-up actions). Now FrameChanged links don't run when a single pic is rendered.
-- Added "Enable Script Links" button in the script buttons tab.  Now this bit gets saved in .blends along with the rest of G.f, so users can define per .blend if they are on or off by default.  "blender -y" also disables all slinks as happened before with OnLoad ones only.
-- Other small changes in the script buttons tab:
  When a link is added (button "new"), it becomes the active one for the window, no need to press a button to reach it.
  Also, a pupmenu showing all available texts is shown when "new" is pressed, so users can choose a text w/o having to type.  Cancel the popup to leave the string button empty (link exists, but has no script assigned).  A pulldown would be better UI-wise, but it's kinda weird to show both scripts and normal texts (Blender doesn't differentiate them) in a script links pulldown.  With a popup we can show only texts ending in ".py" (not done in this commit, need opinions) and if the script has no or another extension, case of many in old and current .blend's, there's still the string box for writing its name.
-- Implemented Ton's space handler script links:
Right now only for the 3d View,  but it's trivial to add for others.  There are two types: EVENT, to receive 3d View events from a chosen window and DRAW, to draw on the window.  Ton's idea was to give scripts a controlled way to integrate better within Blender.
Here's how it works:
- scripts must have a proper header, like:
# SPACEHANDLER.VIEW3D.EVENT
and then they are shown in 3d View's View menu, "Space Handler Scripts" submenu.  Check (mark, click on it) a script to make it active.
EVENT handlers should consult the Blender.event var to get the current event, which can be compared with values from the Draw module:
import Blender
from Blender import Draw
evt = Blender.event
if evt == Draw.AKEY:
  print "a"
elif evt == Draw.LEFTMOUSE:
  print "left mouse button"
else:
  return # ignore, pass event back to Blender
Blender.event = None # tell Blender not to process itself the event
DRAW handlers are free to draw to their owner 3D View. OpenGL attributes and modelview and projection matrices are pushed before running the handler and poped when it finishes.
To communicate between EVENT and DRAW handler scripts we have the Blender.Registry module, as always.
Still need to code some nice example, which should also serve to test properly space handlers.  Simple tests went fine.
- doc updates about the additions.
=======
Note: the UI part of the space handlers and script links is of course open for changes, I just tried to make it understandable.  Probably we won't use the scriptlinks icon for "None Available" (check 3d View -> View -> Space Handler Scripts), though it hints at what space handlers are.  The tooltips may not be accepted either, since other menus don't use them.  Opinions welcomed.
											
										 
											2005-05-08 21:20:34 +00:00
										 |  |  | 		/* unlike normal scriptlinks, here Blender.link is int (space event type) */ | 
					
						
							| 
									
										
										
										
											2005-11-30 08:18:06 +00:00
										 |  |  | 		EXPP_dict_set_item_str(g_blenderdict, "link", PyInt_FromLong(space_event)); | 
					
						
							| 
									
										
											  
											
												BPython:
- Made Blender.event var (previously only used by script links) hold ascii value -- where it applies -- of current event during events callback registered with Draw.Register(gui, events, button_events).  Useful for gui scripts like Campbell's Python console. No problem using this var to hold the value, since in gui scripts it was not used (always None).
- Updated Window and Window.Theme with new theme vars and the Time space.
- Script links:
-- Added "Render" event for script links (runs twice, second time as "PostEvent", for clean-up actions). Now FrameChanged links don't run when a single pic is rendered.
-- Added "Enable Script Links" button in the script buttons tab.  Now this bit gets saved in .blends along with the rest of G.f, so users can define per .blend if they are on or off by default.  "blender -y" also disables all slinks as happened before with OnLoad ones only.
-- Other small changes in the script buttons tab:
  When a link is added (button "new"), it becomes the active one for the window, no need to press a button to reach it.
  Also, a pupmenu showing all available texts is shown when "new" is pressed, so users can choose a text w/o having to type.  Cancel the popup to leave the string button empty (link exists, but has no script assigned).  A pulldown would be better UI-wise, but it's kinda weird to show both scripts and normal texts (Blender doesn't differentiate them) in a script links pulldown.  With a popup we can show only texts ending in ".py" (not done in this commit, need opinions) and if the script has no or another extension, case of many in old and current .blend's, there's still the string box for writing its name.
-- Implemented Ton's space handler script links:
Right now only for the 3d View,  but it's trivial to add for others.  There are two types: EVENT, to receive 3d View events from a chosen window and DRAW, to draw on the window.  Ton's idea was to give scripts a controlled way to integrate better within Blender.
Here's how it works:
- scripts must have a proper header, like:
# SPACEHANDLER.VIEW3D.EVENT
and then they are shown in 3d View's View menu, "Space Handler Scripts" submenu.  Check (mark, click on it) a script to make it active.
EVENT handlers should consult the Blender.event var to get the current event, which can be compared with values from the Draw module:
import Blender
from Blender import Draw
evt = Blender.event
if evt == Draw.AKEY:
  print "a"
elif evt == Draw.LEFTMOUSE:
  print "left mouse button"
else:
  return # ignore, pass event back to Blender
Blender.event = None # tell Blender not to process itself the event
DRAW handlers are free to draw to their owner 3D View. OpenGL attributes and modelview and projection matrices are pushed before running the handler and poped when it finishes.
To communicate between EVENT and DRAW handler scripts we have the Blender.Registry module, as always.
Still need to code some nice example, which should also serve to test properly space handlers.  Simple tests went fine.
- doc updates about the additions.
=======
Note: the UI part of the space handlers and script links is of course open for changes, I just tried to make it understandable.  Probably we won't use the scriptlinks icon for "None Available" (check 3d View -> View -> Space Handler Scripts), though it hints at what space handlers are.  The tooltips may not be accepted either, since other menus don't use them.  Opinions welcomed.
											
										 
											2005-05-08 21:20:34 +00:00
										 |  |  | 		/* note: DRAW space_events set event to 0 */ | 
					
						
							| 
									
										
										
										
											2005-11-30 08:18:06 +00:00
										 |  |  | 		EXPP_dict_set_item_str(g_blenderdict, "event", PyInt_FromLong(event)); | 
					
						
							| 
									
										
											  
											
												BPython:
- Made Blender.event var (previously only used by script links) hold ascii value -- where it applies -- of current event during events callback registered with Draw.Register(gui, events, button_events).  Useful for gui scripts like Campbell's Python console. No problem using this var to hold the value, since in gui scripts it was not used (always None).
- Updated Window and Window.Theme with new theme vars and the Time space.
- Script links:
-- Added "Render" event for script links (runs twice, second time as "PostEvent", for clean-up actions). Now FrameChanged links don't run when a single pic is rendered.
-- Added "Enable Script Links" button in the script buttons tab.  Now this bit gets saved in .blends along with the rest of G.f, so users can define per .blend if they are on or off by default.  "blender -y" also disables all slinks as happened before with OnLoad ones only.
-- Other small changes in the script buttons tab:
  When a link is added (button "new"), it becomes the active one for the window, no need to press a button to reach it.
  Also, a pupmenu showing all available texts is shown when "new" is pressed, so users can choose a text w/o having to type.  Cancel the popup to leave the string button empty (link exists, but has no script assigned).  A pulldown would be better UI-wise, but it's kinda weird to show both scripts and normal texts (Blender doesn't differentiate them) in a script links pulldown.  With a popup we can show only texts ending in ".py" (not done in this commit, need opinions) and if the script has no or another extension, case of many in old and current .blend's, there's still the string box for writing its name.
-- Implemented Ton's space handler script links:
Right now only for the 3d View,  but it's trivial to add for others.  There are two types: EVENT, to receive 3d View events from a chosen window and DRAW, to draw on the window.  Ton's idea was to give scripts a controlled way to integrate better within Blender.
Here's how it works:
- scripts must have a proper header, like:
# SPACEHANDLER.VIEW3D.EVENT
and then they are shown in 3d View's View menu, "Space Handler Scripts" submenu.  Check (mark, click on it) a script to make it active.
EVENT handlers should consult the Blender.event var to get the current event, which can be compared with values from the Draw module:
import Blender
from Blender import Draw
evt = Blender.event
if evt == Draw.AKEY:
  print "a"
elif evt == Draw.LEFTMOUSE:
  print "left mouse button"
else:
  return # ignore, pass event back to Blender
Blender.event = None # tell Blender not to process itself the event
DRAW handlers are free to draw to their owner 3D View. OpenGL attributes and modelview and projection matrices are pushed before running the handler and poped when it finishes.
To communicate between EVENT and DRAW handler scripts we have the Blender.Registry module, as always.
Still need to code some nice example, which should also serve to test properly space handlers.  Simple tests went fine.
- doc updates about the additions.
=======
Note: the UI part of the space handlers and script links is of course open for changes, I just tried to make it understandable.  Probably we won't use the scriptlinks icon for "None Available" (check 3d View -> View -> Space Handler Scripts), though it hints at what space handlers are.  The tooltips may not be accepted either, since other menus don't use them.  Opinions welcomed.
											
										 
											2005-05-08 21:20:34 +00:00
										 |  |  | 		/* now run all assigned space handlers for this space and space_event */ | 
					
						
							|  |  |  | 		for( index = 0; index < scriptlink->totscript; index++ ) { | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/* for DRAW handlers: */ | 
					
						
							|  |  |  | 			if (event == 0) { | 
					
						
							|  |  |  | 				glPushAttrib(GL_ALL_ATTRIB_BITS); | 
					
						
							|  |  |  | 				glMatrixMode(GL_PROJECTION); | 
					
						
							|  |  |  | 				glPushMatrix(); | 
					
						
							|  |  |  | 				glMatrixMode(GL_MODELVIEW); | 
					
						
							|  |  |  | 				glPushMatrix(); | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			if( ( scriptlink->flag[index] == space_event ) && | 
					
						
							|  |  |  | 			    ( scriptlink->scripts[index] != NULL ) ) { | 
					
						
							|  |  |  | 				dict = CreateGlobalDictionary(); | 
					
						
							|  |  |  | 				ret = RunPython( ( Text * ) scriptlink->scripts[index], dict ); | 
					
						
							|  |  |  | 				ReleaseGlobalDictionary( dict ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				if (!ret) { /* Failed execution of the script */ | 
					
						
							|  |  |  | 					BPY_Err_Handle( scriptlink->scripts[index]->name+2 ); | 
					
						
							|  |  |  | 				} else { | 
					
						
							|  |  |  | 					Py_DECREF(ret); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 					/* an EVENT type (event != 0) script can either accept an event or
 | 
					
						
							|  |  |  | 					 * ignore it: | 
					
						
							|  |  |  | 					 * if the script sets Blender.event to None it accepted it; | 
					
						
							|  |  |  | 					 * otherwise the space's event handling callback that called us | 
					
						
							|  |  |  | 					 * can go on processing the event */ | 
					
						
							|  |  |  | 					if (event && (PyDict_GetItemString(g_blenderdict,"event") == Py_None)) | 
					
						
							|  |  |  | 						retval = 1; /* event was swallowed */ | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 				/* If a scriptlink has just loaded a new .blend file, the
 | 
					
						
							|  |  |  | 				 * scriptlink pointer became invalid (see api2_2x/Blender.c), | 
					
						
							|  |  |  | 				 * so we stop here. */ | 
					
						
							|  |  |  | 				if( during_scriptlink(  ) == -1 ) { | 
					
						
							|  |  |  | 					during_slink = 1; | 
					
						
							|  |  |  | 					if (event == 0) glPopAttrib(); | 
					
						
							|  |  |  | 					break; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 			/* for DRAW handlers: */ | 
					
						
							|  |  |  | 			if (event == 0) { | 
					
						
							|  |  |  | 				glMatrixMode(GL_PROJECTION); | 
					
						
							|  |  |  | 				glPopMatrix(); | 
					
						
							|  |  |  | 				glMatrixMode(GL_MODELVIEW); | 
					
						
							|  |  |  | 				glPopMatrix(); | 
					
						
							|  |  |  | 				glPopAttrib(); | 
					
						
							| 
									
										
										
										
											2005-09-09 01:31:10 +00:00
										 |  |  | 				disable_where_scriptlink( (short)(during_slink - 1) ); | 
					
						
							| 
									
										
											  
											
												BPython:
- Made Blender.event var (previously only used by script links) hold ascii value -- where it applies -- of current event during events callback registered with Draw.Register(gui, events, button_events).  Useful for gui scripts like Campbell's Python console. No problem using this var to hold the value, since in gui scripts it was not used (always None).
- Updated Window and Window.Theme with new theme vars and the Time space.
- Script links:
-- Added "Render" event for script links (runs twice, second time as "PostEvent", for clean-up actions). Now FrameChanged links don't run when a single pic is rendered.
-- Added "Enable Script Links" button in the script buttons tab.  Now this bit gets saved in .blends along with the rest of G.f, so users can define per .blend if they are on or off by default.  "blender -y" also disables all slinks as happened before with OnLoad ones only.
-- Other small changes in the script buttons tab:
  When a link is added (button "new"), it becomes the active one for the window, no need to press a button to reach it.
  Also, a pupmenu showing all available texts is shown when "new" is pressed, so users can choose a text w/o having to type.  Cancel the popup to leave the string button empty (link exists, but has no script assigned).  A pulldown would be better UI-wise, but it's kinda weird to show both scripts and normal texts (Blender doesn't differentiate them) in a script links pulldown.  With a popup we can show only texts ending in ".py" (not done in this commit, need opinions) and if the script has no or another extension, case of many in old and current .blend's, there's still the string box for writing its name.
-- Implemented Ton's space handler script links:
Right now only for the 3d View,  but it's trivial to add for others.  There are two types: EVENT, to receive 3d View events from a chosen window and DRAW, to draw on the window.  Ton's idea was to give scripts a controlled way to integrate better within Blender.
Here's how it works:
- scripts must have a proper header, like:
# SPACEHANDLER.VIEW3D.EVENT
and then they are shown in 3d View's View menu, "Space Handler Scripts" submenu.  Check (mark, click on it) a script to make it active.
EVENT handlers should consult the Blender.event var to get the current event, which can be compared with values from the Draw module:
import Blender
from Blender import Draw
evt = Blender.event
if evt == Draw.AKEY:
  print "a"
elif evt == Draw.LEFTMOUSE:
  print "left mouse button"
else:
  return # ignore, pass event back to Blender
Blender.event = None # tell Blender not to process itself the event
DRAW handlers are free to draw to their owner 3D View. OpenGL attributes and modelview and projection matrices are pushed before running the handler and poped when it finishes.
To communicate between EVENT and DRAW handler scripts we have the Blender.Registry module, as always.
Still need to code some nice example, which should also serve to test properly space handlers.  Simple tests went fine.
- doc updates about the additions.
=======
Note: the UI part of the space handlers and script links is of course open for changes, I just tried to make it understandable.  Probably we won't use the scriptlinks icon for "None Available" (check 3d View -> View -> Space Handler Scripts), though it hints at what space handlers are.  The tooltips may not be accepted either, since other menus don't use them.  Opinions welcomed.
											
										 
											2005-05-08 21:20:34 +00:00
										 |  |  | 			} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2007-12-07 09:51:02 +00:00
										 |  |  | 		PyDict_SetItemString(g_blenderdict, "bylink", Py_False); | 
					
						
							| 
									
										
										
										
											2005-11-30 08:18:06 +00:00
										 |  |  | 		PyDict_SetItemString(g_blenderdict, "link", Py_None ); | 
					
						
							|  |  |  | 		EXPP_dict_set_item_str(g_blenderdict, "event", PyString_FromString("")); | 
					
						
							| 
									
										
											  
											
												BPython:
- Made Blender.event var (previously only used by script links) hold ascii value -- where it applies -- of current event during events callback registered with Draw.Register(gui, events, button_events).  Useful for gui scripts like Campbell's Python console. No problem using this var to hold the value, since in gui scripts it was not used (always None).
- Updated Window and Window.Theme with new theme vars and the Time space.
- Script links:
-- Added "Render" event for script links (runs twice, second time as "PostEvent", for clean-up actions). Now FrameChanged links don't run when a single pic is rendered.
-- Added "Enable Script Links" button in the script buttons tab.  Now this bit gets saved in .blends along with the rest of G.f, so users can define per .blend if they are on or off by default.  "blender -y" also disables all slinks as happened before with OnLoad ones only.
-- Other small changes in the script buttons tab:
  When a link is added (button "new"), it becomes the active one for the window, no need to press a button to reach it.
  Also, a pupmenu showing all available texts is shown when "new" is pressed, so users can choose a text w/o having to type.  Cancel the popup to leave the string button empty (link exists, but has no script assigned).  A pulldown would be better UI-wise, but it's kinda weird to show both scripts and normal texts (Blender doesn't differentiate them) in a script links pulldown.  With a popup we can show only texts ending in ".py" (not done in this commit, need opinions) and if the script has no or another extension, case of many in old and current .blend's, there's still the string box for writing its name.
-- Implemented Ton's space handler script links:
Right now only for the 3d View,  but it's trivial to add for others.  There are two types: EVENT, to receive 3d View events from a chosen window and DRAW, to draw on the window.  Ton's idea was to give scripts a controlled way to integrate better within Blender.
Here's how it works:
- scripts must have a proper header, like:
# SPACEHANDLER.VIEW3D.EVENT
and then they are shown in 3d View's View menu, "Space Handler Scripts" submenu.  Check (mark, click on it) a script to make it active.
EVENT handlers should consult the Blender.event var to get the current event, which can be compared with values from the Draw module:
import Blender
from Blender import Draw
evt = Blender.event
if evt == Draw.AKEY:
  print "a"
elif evt == Draw.LEFTMOUSE:
  print "left mouse button"
else:
  return # ignore, pass event back to Blender
Blender.event = None # tell Blender not to process itself the event
DRAW handlers are free to draw to their owner 3D View. OpenGL attributes and modelview and projection matrices are pushed before running the handler and poped when it finishes.
To communicate between EVENT and DRAW handler scripts we have the Blender.Registry module, as always.
Still need to code some nice example, which should also serve to test properly space handlers.  Simple tests went fine.
- doc updates about the additions.
=======
Note: the UI part of the space handlers and script links is of course open for changes, I just tried to make it understandable.  Probably we won't use the scriptlinks icon for "None Available" (check 3d View -> View -> Space Handler Scripts), though it hints at what space handlers are.  The tooltips may not be accepted either, since other menus don't use them.  Opinions welcomed.
											
										 
											2005-05-08 21:20:34 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	 | 
					
						
							|  |  |  | 	/* retval:
 | 
					
						
							|  |  |  | 	 * space_event is of type EVENT: | 
					
						
							|  |  |  | 	 * 0 - event was returned, | 
					
						
							|  |  |  | 	 * 1 - event was processed; | 
					
						
							|  |  |  | 	 * space_event is of type DRAW: | 
					
						
							|  |  |  | 	 * 0 always */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return retval; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | /*****************************************************************************
 | 
					
						
							|  |  |  | * Description:	 | 
					
						
							|  |  |  | * Notes: | 
					
						
							|  |  |  | *****************************************************************************/ | 
					
						
							|  |  |  | void BPY_free_scriptlink( struct ScriptLink *slink ) | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	if( slink->totscript ) { | 
					
						
							| 
									
										
										
										
											2006-11-17 12:44:15 +00:00
										 |  |  | 		if( slink->flag ) { | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 			MEM_freeN( slink->flag ); | 
					
						
							| 
									
										
										
										
											2006-11-17 12:44:15 +00:00
										 |  |  | 			slink->flag= NULL; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		if( slink->scripts ) { | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 			MEM_freeN( slink->scripts ); | 
					
						
							| 
									
										
										
										
											2006-11-17 12:44:15 +00:00
										 |  |  | 			slink->scripts= NULL; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2003-05-13 01:54:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	return; | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											  
											
												BPython:
- Made Blender.event var (previously only used by script links) hold ascii value -- where it applies -- of current event during events callback registered with Draw.Register(gui, events, button_events).  Useful for gui scripts like Campbell's Python console. No problem using this var to hold the value, since in gui scripts it was not used (always None).
- Updated Window and Window.Theme with new theme vars and the Time space.
- Script links:
-- Added "Render" event for script links (runs twice, second time as "PostEvent", for clean-up actions). Now FrameChanged links don't run when a single pic is rendered.
-- Added "Enable Script Links" button in the script buttons tab.  Now this bit gets saved in .blends along with the rest of G.f, so users can define per .blend if they are on or off by default.  "blender -y" also disables all slinks as happened before with OnLoad ones only.
-- Other small changes in the script buttons tab:
  When a link is added (button "new"), it becomes the active one for the window, no need to press a button to reach it.
  Also, a pupmenu showing all available texts is shown when "new" is pressed, so users can choose a text w/o having to type.  Cancel the popup to leave the string button empty (link exists, but has no script assigned).  A pulldown would be better UI-wise, but it's kinda weird to show both scripts and normal texts (Blender doesn't differentiate them) in a script links pulldown.  With a popup we can show only texts ending in ".py" (not done in this commit, need opinions) and if the script has no or another extension, case of many in old and current .blend's, there's still the string box for writing its name.
-- Implemented Ton's space handler script links:
Right now only for the 3d View,  but it's trivial to add for others.  There are two types: EVENT, to receive 3d View events from a chosen window and DRAW, to draw on the window.  Ton's idea was to give scripts a controlled way to integrate better within Blender.
Here's how it works:
- scripts must have a proper header, like:
# SPACEHANDLER.VIEW3D.EVENT
and then they are shown in 3d View's View menu, "Space Handler Scripts" submenu.  Check (mark, click on it) a script to make it active.
EVENT handlers should consult the Blender.event var to get the current event, which can be compared with values from the Draw module:
import Blender
from Blender import Draw
evt = Blender.event
if evt == Draw.AKEY:
  print "a"
elif evt == Draw.LEFTMOUSE:
  print "left mouse button"
else:
  return # ignore, pass event back to Blender
Blender.event = None # tell Blender not to process itself the event
DRAW handlers are free to draw to their owner 3D View. OpenGL attributes and modelview and projection matrices are pushed before running the handler and poped when it finishes.
To communicate between EVENT and DRAW handler scripts we have the Blender.Registry module, as always.
Still need to code some nice example, which should also serve to test properly space handlers.  Simple tests went fine.
- doc updates about the additions.
=======
Note: the UI part of the space handlers and script links is of course open for changes, I just tried to make it understandable.  Probably we won't use the scriptlinks icon for "None Available" (check 3d View -> View -> Space Handler Scripts), though it hints at what space handlers are.  The tooltips may not be accepted either, since other menus don't use them.  Opinions welcomed.
											
										 
											2005-05-08 21:20:34 +00:00
										 |  |  | static int CheckAllSpaceHandlers(Text *text) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	bScreen *screen; | 
					
						
							|  |  |  | 	ScrArea *sa; | 
					
						
							|  |  |  | 	ScriptLink *slink; | 
					
						
							|  |  |  | 	int fixed = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	for (screen = G.main->screen.first; screen; screen = screen->id.next) { | 
					
						
							|  |  |  | 		for (sa = screen->areabase.first; sa; sa = sa->next) { | 
					
						
							|  |  |  | 			slink = &sa->scriptlink; | 
					
						
							|  |  |  | 			if (!slink->totscript) continue; | 
					
						
							|  |  |  | 			if (BPY_del_spacehandler(text, sa) == 0) fixed++; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 	return fixed; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-03-09 19:45:59 +00:00
										 |  |  | static int CheckAllScriptsFromList( ListBase * list, Text * text ) | 
					
						
							| 
									
										
										
										
											2004-11-27 18:32:26 +00:00
										 |  |  | { | 
					
						
							|  |  |  | 	ID *id; | 
					
						
							|  |  |  | 	ScriptLink *scriptlink; | 
					
						
							|  |  |  | 	int index; | 
					
						
							|  |  |  | 	int fixed = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	id = list->first; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	while( id != NULL ) { | 
					
						
							|  |  |  | 		scriptlink = ID_getScriptlink( id ); | 
					
						
							|  |  |  | 		if( scriptlink && scriptlink->totscript ) { | 
					
						
							|  |  |  | 			for( index = 0; index < scriptlink->totscript; index++) { | 
					
						
							|  |  |  | 				if ((Text *)scriptlink->scripts[index] == text) { | 
					
						
							|  |  |  | 					scriptlink->scripts[index] = NULL; | 
					
						
							|  |  |  | 					fixed++; | 
					
						
							|  |  |  | 				} | 
					
						
							|  |  |  | 			} | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 		id = id->next; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return fixed; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /* When a Text is deleted, we need to unlink it from eventual scriptlinks */ | 
					
						
							|  |  |  | int BPY_check_all_scriptlinks( Text * text ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	int fixed = 0; | 
					
						
							|  |  |  | 	fixed += CheckAllScriptsFromList( &( G.main->object ), text ); | 
					
						
							|  |  |  | 	fixed += CheckAllScriptsFromList( &( G.main->lamp ), text ); | 
					
						
							|  |  |  | 	fixed += CheckAllScriptsFromList( &( G.main->camera ), text ); | 
					
						
							|  |  |  | 	fixed += CheckAllScriptsFromList( &( G.main->mat ), text ); | 
					
						
							|  |  |  | 	fixed += CheckAllScriptsFromList( &( G.main->world ), text ); | 
					
						
							|  |  |  | 	fixed += CheckAllScriptsFromList( &( G.main->scene ), text ); | 
					
						
							| 
									
										
											  
											
												BPython:
- Made Blender.event var (previously only used by script links) hold ascii value -- where it applies -- of current event during events callback registered with Draw.Register(gui, events, button_events).  Useful for gui scripts like Campbell's Python console. No problem using this var to hold the value, since in gui scripts it was not used (always None).
- Updated Window and Window.Theme with new theme vars and the Time space.
- Script links:
-- Added "Render" event for script links (runs twice, second time as "PostEvent", for clean-up actions). Now FrameChanged links don't run when a single pic is rendered.
-- Added "Enable Script Links" button in the script buttons tab.  Now this bit gets saved in .blends along with the rest of G.f, so users can define per .blend if they are on or off by default.  "blender -y" also disables all slinks as happened before with OnLoad ones only.
-- Other small changes in the script buttons tab:
  When a link is added (button "new"), it becomes the active one for the window, no need to press a button to reach it.
  Also, a pupmenu showing all available texts is shown when "new" is pressed, so users can choose a text w/o having to type.  Cancel the popup to leave the string button empty (link exists, but has no script assigned).  A pulldown would be better UI-wise, but it's kinda weird to show both scripts and normal texts (Blender doesn't differentiate them) in a script links pulldown.  With a popup we can show only texts ending in ".py" (not done in this commit, need opinions) and if the script has no or another extension, case of many in old and current .blend's, there's still the string box for writing its name.
-- Implemented Ton's space handler script links:
Right now only for the 3d View,  but it's trivial to add for others.  There are two types: EVENT, to receive 3d View events from a chosen window and DRAW, to draw on the window.  Ton's idea was to give scripts a controlled way to integrate better within Blender.
Here's how it works:
- scripts must have a proper header, like:
# SPACEHANDLER.VIEW3D.EVENT
and then they are shown in 3d View's View menu, "Space Handler Scripts" submenu.  Check (mark, click on it) a script to make it active.
EVENT handlers should consult the Blender.event var to get the current event, which can be compared with values from the Draw module:
import Blender
from Blender import Draw
evt = Blender.event
if evt == Draw.AKEY:
  print "a"
elif evt == Draw.LEFTMOUSE:
  print "left mouse button"
else:
  return # ignore, pass event back to Blender
Blender.event = None # tell Blender not to process itself the event
DRAW handlers are free to draw to their owner 3D View. OpenGL attributes and modelview and projection matrices are pushed before running the handler and poped when it finishes.
To communicate between EVENT and DRAW handler scripts we have the Blender.Registry module, as always.
Still need to code some nice example, which should also serve to test properly space handlers.  Simple tests went fine.
- doc updates about the additions.
=======
Note: the UI part of the space handlers and script links is of course open for changes, I just tried to make it understandable.  Probably we won't use the scriptlinks icon for "None Available" (check 3d View -> View -> Space Handler Scripts), though it hints at what space handlers are.  The tooltips may not be accepted either, since other menus don't use them.  Opinions welcomed.
											
										 
											2005-05-08 21:20:34 +00:00
										 |  |  | 	fixed += CheckAllSpaceHandlers(text); | 
					
						
							| 
									
										
										
										
											2004-11-27 18:32:26 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	return fixed; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | /*****************************************************************************
 | 
					
						
							|  |  |  | * Description:  | 
					
						
							|  |  |  | * Notes: | 
					
						
							|  |  |  | *****************************************************************************/ | 
					
						
							|  |  |  | void BPY_copy_scriptlink( struct ScriptLink *scriptlink ) | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	void *tmp; | 
					
						
							| 
									
										
										
										
											2003-05-13 01:54:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	if( scriptlink->totscript ) { | 
					
						
							| 
									
										
										
										
											2003-05-13 01:54:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 		tmp = scriptlink->scripts; | 
					
						
							|  |  |  | 		scriptlink->scripts = | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 			MEM_mallocN( sizeof( ID * ) * scriptlink->totscript, | 
					
						
							|  |  |  | 				     "scriptlistL" ); | 
					
						
							|  |  |  | 		memcpy( scriptlink->scripts, tmp, | 
					
						
							|  |  |  | 			sizeof( ID * ) * scriptlink->totscript ); | 
					
						
							| 
									
										
										
										
											2003-05-13 01:54:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 		tmp = scriptlink->flag; | 
					
						
							|  |  |  | 		scriptlink->flag = | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 			MEM_mallocN( sizeof( short ) * scriptlink->totscript, | 
					
						
							|  |  |  | 				     "scriptlistF" ); | 
					
						
							|  |  |  | 		memcpy( scriptlink->flag, tmp, | 
					
						
							|  |  |  | 			sizeof( short ) * scriptlink->totscript ); | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2003-05-13 01:54:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	return; | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | /****************************************************************************
 | 
					
						
							|  |  |  | * Description: | 
					
						
							|  |  |  | * Notes:		Not implemented yet | 
					
						
							|  |  |  | *****************************************************************************/ | 
					
						
							|  |  |  | int BPY_call_importloader( char *name ) | 
					
						
							|  |  |  | {			/* XXX Should this function go away from Blender? */ | 
					
						
							|  |  |  | 	printf( "In BPY_call_importloader(name=%s)\n", name ); | 
					
						
							|  |  |  | 	return ( 0 ); | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | /*****************************************************************************
 | 
					
						
							|  |  |  | * Private functions | 
					
						
							|  |  |  | *****************************************************************************/ | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | /*****************************************************************************
 | 
					
						
							|  |  |  | * Description: This function executes the python script passed by text.	 | 
					
						
							|  |  |  | *		The Python dictionary containing global variables needs to | 
					
						
							|  |  |  | *		be passed in globaldict. | 
					
						
							|  |  |  | *****************************************************************************/ | 
					
						
							|  |  |  | PyObject *RunPython( Text * text, PyObject * globaldict ) | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	char *buf = NULL; | 
					
						
							| 
									
										
										
										
											2003-05-13 01:54:28 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /* The script text is compiled to Python bytecode and saved at text->compiled
 | 
					
						
							|  |  |  |  * to speed-up execution if the user executes the script multiple times */ | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	if( !text->compiled ) {	/* if it wasn't already compiled, do it now */ | 
					
						
							|  |  |  | 		buf = txt_to_buf( text ); | 
					
						
							| 
									
										
										
										
											2003-05-13 01:54:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		text->compiled = | 
					
						
							|  |  |  | 			Py_CompileString( buf, GetName( text ), | 
					
						
							|  |  |  | 					  Py_file_input ); | 
					
						
							| 
									
										
										
										
											2003-05-13 01:54:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		MEM_freeN( buf ); | 
					
						
							| 
									
										
										
										
											2003-05-13 01:54:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		if( PyErr_Occurred(  ) ) { | 
					
						
							|  |  |  | 			BPY_free_compiled_text( text ); | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 			return NULL; | 
					
						
							|  |  |  | 		} | 
					
						
							| 
									
										
										
										
											2003-05-13 01:54:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2003-06-09 20:07:43 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	return PyEval_EvalCode( text->compiled, globaldict, globaldict ); | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | /*****************************************************************************
 | 
					
						
							|  |  |  | * Description: This function returns the value of the name field of the	 | 
					
						
							|  |  |  | *	given Text struct. | 
					
						
							|  |  |  | *****************************************************************************/ | 
					
						
							|  |  |  | char *GetName( Text * text ) | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	return ( text->id.name + 2 ); | 
					
						
							| 
									
										
										
										
											2003-02-26 19:22:24 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | /*****************************************************************************
 | 
					
						
							|  |  |  | * Description: This function creates a new Python dictionary object. | 
					
						
							|  |  |  | *****************************************************************************/ | 
					
						
							|  |  |  | PyObject *CreateGlobalDictionary( void ) | 
					
						
							| 
									
										
										
										
											2003-03-18 20:21:26 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	PyObject *dict = PyDict_New(  ); | 
					
						
							| 
									
										
										
										
											2003-05-13 01:54:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	PyDict_SetItemString( dict, "__builtins__", PyEval_GetBuiltins(  ) ); | 
					
						
							| 
									
										
										
										
											2005-11-30 08:18:06 +00:00
										 |  |  | 	EXPP_dict_set_item_str( dict, "__name__", | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 			      PyString_FromString( "__main__" ) ); | 
					
						
							| 
									
										
										
										
											2003-03-18 20:21:26 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2005-05-22 17:40:00 +00:00
										 |  |  | 	return dict; | 
					
						
							| 
									
										
										
										
											2003-03-18 20:21:26 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | /*****************************************************************************
 | 
					
						
							|  |  |  | * Description: This function deletes a given Python dictionary object. | 
					
						
							|  |  |  | *****************************************************************************/ | 
					
						
							|  |  |  | void ReleaseGlobalDictionary( PyObject * dict ) | 
					
						
							| 
									
										
										
										
											2003-03-18 20:21:26 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	PyDict_Clear( dict ); | 
					
						
							|  |  |  | 	Py_DECREF( dict );	/* Release dictionary. */ | 
					
						
							| 
									
										
										
										
											2003-05-13 01:54:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	return; | 
					
						
							| 
									
										
										
										
											2003-03-18 20:21:26 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | /***************************************************************************
 | 
					
						
							|  |  |  | * Description: This function runs all scripts (if any) present in the | 
					
						
							|  |  |  | *		list argument. The event by which the function has been	 | 
					
						
							|  |  |  | *		called, is passed in the event argument. | 
					
						
							|  |  |  | *****************************************************************************/ | 
					
						
							|  |  |  | void DoAllScriptsFromList( ListBase * list, short event ) | 
					
						
							| 
									
										
										
										
											2003-03-19 18:57:23 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	ID *id; | 
					
						
							| 
									
										
										
										
											2003-03-19 18:57:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	id = list->first; | 
					
						
							| 
									
										
										
										
											2003-03-19 18:57:23 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	while( id != NULL ) { | 
					
						
							|  |  |  | 		BPY_do_pyscript( id, event ); | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 		id = id->next; | 
					
						
							|  |  |  | 	} | 
					
						
							| 
									
										
										
										
											2003-05-13 01:54:28 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	return; | 
					
						
							| 
									
										
										
										
											2003-03-19 18:57:23 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2003-07-03 01:42:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | PyObject *importText( char *name ) | 
					
						
							| 
									
										
										
										
											2003-07-03 01:42:00 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	Text *text; | 
					
						
							|  |  |  | 	char *txtname; | 
					
						
							|  |  |  | 	char *buf = NULL; | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	int namelen = strlen( name ); | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	txtname = malloc( namelen + 3 + 1 ); | 
					
						
							|  |  |  | 	if( !txtname ) | 
					
						
							|  |  |  | 		return NULL; | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	memcpy( txtname, name, namelen ); | 
					
						
							|  |  |  | 	memcpy( &txtname[namelen], ".py", 4 ); | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	text = ( Text * ) & ( G.main->text.first ); | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	while( text ) { | 
					
						
							|  |  |  | 		if( !strcmp( txtname, GetName( text ) ) ) | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 			break; | 
					
						
							|  |  |  | 		text = text->id.next; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	if( !text ) { | 
					
						
							|  |  |  | 		free( txtname ); | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 		return NULL; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	if( !text->compiled ) { | 
					
						
							|  |  |  | 		buf = txt_to_buf( text ); | 
					
						
							|  |  |  | 		text->compiled = | 
					
						
							|  |  |  | 			Py_CompileString( buf, GetName( text ), | 
					
						
							|  |  |  | 					  Py_file_input ); | 
					
						
							|  |  |  | 		MEM_freeN( buf ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 		if( PyErr_Occurred(  ) ) { | 
					
						
							|  |  |  | 			PyErr_Print(  ); | 
					
						
							|  |  |  | 			BPY_free_compiled_text( text ); | 
					
						
							|  |  |  | 			free( txtname ); | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 			return NULL; | 
					
						
							|  |  |  | 		} | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	free( txtname ); | 
					
						
							|  |  |  | 	return PyImport_ExecCodeModule( name, text->compiled ); | 
					
						
							| 
									
										
										
										
											2003-07-03 01:42:00 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyMethodDef bimport[] = { | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	{"blimport", blender_import, METH_VARARGS, "our own import"} | 
					
						
							| 
									
										
										
										
											2003-07-03 01:42:00 +00:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | PyObject *blender_import( PyObject * self, PyObject * args ) | 
					
						
							| 
									
										
										
										
											2003-07-03 01:42:00 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	PyObject *exception, *err, *tb; | 
					
						
							|  |  |  | 	char *name; | 
					
						
							|  |  |  | 	PyObject *globals = NULL, *locals = NULL, *fromlist = NULL; | 
					
						
							|  |  |  | 	PyObject *m; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	if( !PyArg_ParseTuple( args, "s|OOO:bimport", | 
					
						
							|  |  |  | 			       &name, &globals, &locals, &fromlist ) ) | 
					
						
							|  |  |  | 		return NULL; | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	m = PyImport_ImportModuleEx( name, globals, locals, fromlist ); | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	if( m ) | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 		return m; | 
					
						
							|  |  |  | 	else | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		PyErr_Fetch( &exception, &err, &tb );	/*restore for probable later use */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	m = importText( name ); | 
					
						
							|  |  |  | 	if( m ) {		/* found module, ignore above exception */ | 
					
						
							|  |  |  | 		PyErr_Clear(  ); | 
					
						
							|  |  |  | 		Py_XDECREF( exception ); | 
					
						
							|  |  |  | 		Py_XDECREF( err ); | 
					
						
							|  |  |  | 		Py_XDECREF( tb ); | 
					
						
							|  |  |  | 		printf( "imported from text buffer...\n" ); | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	} else { | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 		PyErr_Restore( exception, err, tb ); | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	} | 
					
						
							|  |  |  | 	return m; | 
					
						
							| 
									
										
										
										
											2003-07-03 01:42:00 +00:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | void init_ourImport( void ) | 
					
						
							| 
									
										
										
										
											2003-07-03 01:42:00 +00:00
										 |  |  | { | 
					
						
							| 
									
										
										
										
											2004-04-25 14:43:21 +00:00
										 |  |  | 	PyObject *m, *d; | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	PyObject *import = PyCFunction_New( bimport, NULL ); | 
					
						
							| 
									
										
										
										
											2003-07-03 01:42:00 +00:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2004-10-07 19:25:40 +00:00
										 |  |  | 	m = PyImport_AddModule( "__builtin__" ); | 
					
						
							|  |  |  | 	d = PyModule_GetDict( m ); | 
					
						
							| 
									
										
										
										
											2007-03-10 06:33:19 +00:00
										 |  |  | 	 | 
					
						
							| 
									
										
										
										
											2005-11-30 08:18:06 +00:00
										 |  |  | 	EXPP_dict_set_item_str( d, "__import__", import ); | 
					
						
							| 
									
										
										
										
											2003-07-03 01:42:00 +00:00
										 |  |  | } | 
					
						
							| 
									
										
										
										
											2005-10-14 17:26:57 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * find in-memory module and recompile | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject *reimportText( PyObject *module ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	Text *text; | 
					
						
							|  |  |  | 	char *txtname; | 
					
						
							|  |  |  | 	char *name; | 
					
						
							|  |  |  | 	char *buf = NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* get name, filename from the module itself */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	txtname = PyModule_GetFilename( module ); | 
					
						
							|  |  |  | 	name = PyModule_GetName( module ); | 
					
						
							|  |  |  | 	if( !txtname || !name) | 
					
						
							|  |  |  | 		return NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* look up the text object */ | 
					
						
							|  |  |  | 	text = ( Text * ) & ( G.main->text.first ); | 
					
						
							|  |  |  | 	while( text ) { | 
					
						
							|  |  |  | 		if( !strcmp( txtname, GetName( text ) ) ) | 
					
						
							|  |  |  | 			break; | 
					
						
							|  |  |  | 		text = text->id.next; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* uh-oh.... didn't find it */ | 
					
						
							|  |  |  | 	if( !text ) | 
					
						
							|  |  |  | 		return NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* if previously compiled, free the object */ | 
					
						
							|  |  |  | 	/* (can't see how could be NULL, but check just in case) */  | 
					
						
							| 
									
										
										
										
											2006-01-16 17:55:03 +00:00
										 |  |  | 	if( text->compiled ){ | 
					
						
							| 
									
										
										
										
											2005-10-14 17:26:57 +00:00
										 |  |  | 		Py_DECREF( (PyObject *)text->compiled ); | 
					
						
							| 
									
										
										
										
											2006-01-16 17:55:03 +00:00
										 |  |  | 	} | 
					
						
							| 
									
										
										
										
											2005-10-14 17:26:57 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | 	/* compile the buffer */ | 
					
						
							|  |  |  | 	buf = txt_to_buf( text ); | 
					
						
							|  |  |  | 	text->compiled = Py_CompileString( buf, GetName( text ), | 
					
						
							|  |  |  | 			Py_file_input ); | 
					
						
							|  |  |  | 	MEM_freeN( buf ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* if compile failed.... return this error */ | 
					
						
							|  |  |  | 	if( PyErr_Occurred(  ) ) { | 
					
						
							|  |  |  | 		PyErr_Print(  ); | 
					
						
							|  |  |  | 		BPY_free_compiled_text( text ); | 
					
						
							|  |  |  | 		return NULL; | 
					
						
							|  |  |  | 	} | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* make into a module */ | 
					
						
							|  |  |  | 	return PyImport_ExecCodeModule( name, text->compiled ); | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | /*
 | 
					
						
							|  |  |  |  * our reload() module, to handle reloading in-memory scripts | 
					
						
							|  |  |  |  */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyObject *blender_reload( PyObject * self, PyObject * args ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	PyObject *exception, *err, *tb; | 
					
						
							|  |  |  | 	PyObject *module = NULL; | 
					
						
							|  |  |  | 	PyObject *newmodule = NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* check for a module arg */ | 
					
						
							|  |  |  | 	if( !PyArg_ParseTuple( args, "O:breload", &module ) ) | 
					
						
							|  |  |  | 		return NULL; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* try reimporting from file */ | 
					
						
							|  |  |  | 	newmodule = PyImport_ReloadModule( module ); | 
					
						
							|  |  |  | 	if( newmodule ) | 
					
						
							|  |  |  | 		return newmodule; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	/* no file, try importing from memory */ | 
					
						
							|  |  |  | 	PyErr_Fetch( &exception, &err, &tb );	/*restore for probable later use */ | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	newmodule = reimportText( module ); | 
					
						
							|  |  |  | 	if( newmodule ) {		/* found module, ignore above exception */ | 
					
						
							|  |  |  | 		PyErr_Clear(  ); | 
					
						
							|  |  |  | 		Py_XDECREF( exception ); | 
					
						
							|  |  |  | 		Py_XDECREF( err ); | 
					
						
							|  |  |  | 		Py_XDECREF( tb ); | 
					
						
							|  |  |  | 	} else | 
					
						
							|  |  |  | 		PyErr_Restore( exception, err, tb ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	return newmodule; | 
					
						
							|  |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | static PyMethodDef breload[] = { | 
					
						
							|  |  |  | 	{"blreload", blender_reload, METH_VARARGS, "our own reload"} | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | void init_ourReload( void ) | 
					
						
							|  |  |  | { | 
					
						
							|  |  |  | 	PyObject *m, *d; | 
					
						
							|  |  |  | 	PyObject *reload = PyCFunction_New( breload, NULL ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | 	m = PyImport_AddModule( "__builtin__" ); | 
					
						
							|  |  |  | 	d = PyModule_GetDict( m ); | 
					
						
							| 
									
										
										
										
											2005-11-30 08:18:06 +00:00
										 |  |  | 	EXPP_dict_set_item_str( d, "reload", reload ); | 
					
						
							| 
									
										
										
										
											2005-10-14 17:26:57 +00:00
										 |  |  | } |