2009-12-25 15:50:53 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								 # ***** BEGIN GPL LICENSE BLOCK ***** 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 # 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 # This program is free software; you can redistribute it and/or 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 # modify it under the terms of the GNU General Public License 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 # as published by the Free Software Foundation; either version 2 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 # of the License, or (at your option) any later version. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 # 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 # This program is distributed in the hope that it will be useful, 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 # but WITHOUT ANY WARRANTY; without even the implied warranty of 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 # MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 # GNU General Public License for more details. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 # 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 # You should have received a copy of the GNU General Public License 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 # along with this program; if not, write to the Free Software Foundation, 
							 
						 
					
						
							
								
									
										
										
										
											2010-02-12 13:34:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								 # Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-25 15:50:53 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								 # 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 # Contributor(s): Campbell Barton 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 # 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								 # #**** END GPL LICENSE BLOCK #**** 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								script_help_msg  =  ''' 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								Usage ,  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								run  this  script  from  blenders  root  path  once  you  have  compiled  blender  
						 
					
						
							
								
									
										
										
										
											2010-01-31 21:52:26 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    . / blender . bin  - b  - P  / b / source / blender / python / doc / sphinx_doc_gen . py 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-25 15:50:53 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2010-01-06 09:42:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								This  will  generate  python  files  in  " ./source/blender/python/doc/sphinx-in "  
						 
					
						
							
								
									
										
										
										
											2009-12-25 15:50:53 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								Generate  html  docs   by  running . . .  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    
							 
						 
					
						
							
								
									
										
										
										
											2010-01-06 09:42:41 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    sphinx - build  source / blender / python / doc / sphinx - in  source / blender / python / doc / sphinx - out 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-28 10:48:17 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								For  PDF  generation  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    sphinx - build  - b  latex  source / blender / python / doc / sphinx - in  source / blender / python / doc / sphinx - out 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    cd  source / blender / python / doc / sphinx - out 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    make 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-25 15:50:53 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								''' 
  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
											
												Mathutils refactor & include in sphinx generated docs, (TODO, include getset'ers in docs)
 - Mathutils.MidpointVecs --> vector.lerp(other, fac)
 - Mathutils.AngleBetweenVecs --> vector.angle(other)
 - Mathutils.ProjectVecs --> vector.project(other)
 - Mathutils.DifferenceQuats --> quat.difference(other)
 - Mathutils.Slerp --> quat.slerp(other, fac)
 - Mathutils.Rand: removed, use pythons random module
 - Mathutils.RotationMatrix(angle, size, axis_flag, axis) --> Mathutils.RotationMatrix(angle, size, axis); merge axis & axis_flag args
 - Matrix.scalePart --> Matrix.scale_part
 - Matrix.translationPart --> Matrix.translation_part
 - Matrix.rotationPart --> Matrix.rotation_part
 - toMatrix --> to_matrix
 - toEuler --> to_euler
 - toQuat --> to_quat
 - Vector.toTrackQuat --> Vector.to_track_quat
											 
										 
										
											2010-01-25 09:44:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2009-12-25 15:50:53 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								import  os  
						 
					
						
							
								
									
										
										
										
											2009-12-26 16:47:25 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								import  inspect  
						 
					
						
							
								
									
										
										
										
											2009-12-25 15:50:53 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								import  bpy  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								import  rna_info  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								reload ( rna_info )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2010-02-28 13:45:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								EXAMPLE_SET  =  set ( )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								EXAMPLE_SET_USED  =  set ( )  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2009-12-25 15:50:53 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								def  range_str ( val ) :  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  val  <  - 10000000 : 	return  ' -inf ' 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  val  >   10000000 : 	return  ' inf ' 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  type ( val ) == float : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  ' %g '   %  val 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return  str ( val ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2010-02-28 13:45:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								def  write_example_ref ( ident ,  fw ,  example_id ,  ext = " .py " ) :  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  example_id  in  EXAMPLE_SET : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        fw ( " %s .. literalinclude:: ../examples/ %s %s \n \n "  %  ( ident ,  example_id ,  ext ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        EXAMPLE_SET_USED . add ( example_id ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  bpy . app . debug : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            print ( " \t skipping example: " ,  example_id ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2010-01-31 21:52:26 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								def  write_indented_lines ( ident ,  fn ,  text ,  strip = True ) :  
						 
					
						
							
								
									
										
										
										
											2009-12-25 15:50:53 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    if  text  is  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        return 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    for  l  in  text . split ( " \n " ) : 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-31 21:52:26 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        if  strip : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            fn ( ident  +  l . strip ( )  +  " \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            fn ( ident  +  l  +  " \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-25 15:50:53 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2010-01-22 02:04:25 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								def  pymethod2sphinx ( ident ,  fw ,  identifier ,  py_func ) :  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    ''' 
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    class  method  to  sphinx 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    ''' 
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    arg_str  =  inspect . formatargspec ( * inspect . getargspec ( py_func ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  arg_str . startswith ( " (self,  " ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        arg_str  =  " ( "  +  arg_str [ 7 : ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        func_type  =  " method " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    elif  arg_str . startswith ( " (cls,  " ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        arg_str  =  " ( "  +  arg_str [ 6 : ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        func_type  =  " classmethod " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        func_type  =  " staticmethod " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( ident  +  " ..  %s ::  %s %s \n \n "  %  ( func_type ,  identifier ,  arg_str ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  py_func . __doc__ : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        write_indented_lines ( ident  +  "     " ,  fw ,  py_func . __doc__ ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        fw ( " \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								def  pyfunc2sphinx ( ident ,  fw ,  identifier ,  py_func ,  is_class = True ) :  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    ''' 
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    function  or  class  method  to  sphinx 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    ''' 
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    arg_str  =  inspect . formatargspec ( * inspect . getargspec ( py_func ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  not  is_class : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        func_type  =  " function " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        # ther rest are class methods 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    elif  arg_str . startswith ( " (self,  " ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        arg_str  =  " ( "  +  arg_str [ 7 : ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        func_type  =  " method " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    elif  arg_str . startswith ( " (cls,  " ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        arg_str  =  " ( "  +  arg_str [ 6 : ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        func_type  =  " classmethod " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        func_type  =  " staticmethod " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( ident  +  " ..  %s ::  %s %s \n \n "  %  ( func_type ,  identifier ,  arg_str ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  py_func . __doc__ : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        write_indented_lines ( ident  +  "     " ,  fw ,  py_func . __doc__ . strip ( ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        fw ( " \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								def  py_c_func2sphinx ( ident ,  fw ,  identifier ,  py_func ,  is_class = True ) :  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    ''' 
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    c  defined  function  to  sphinx . 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    ''' 
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # dump the docstring, assume its formatted correctly 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  py_func . __doc__ : 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-31 21:52:26 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        write_indented_lines ( ident ,  fw ,  py_func . __doc__ ,  False ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-22 02:04:25 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        fw ( " \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        fw ( ident  +  " .. function::  %s () \n \n "  %  identifier ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        fw ( ident  +  "    Undocumented function. \n \n "  %  identifier ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								def  pyprop2sphinx ( ident ,  fw ,  identifier ,  py_prop ) :  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    ''' 
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    python  property  to  sphinx 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    ''' 
 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( ident  +  " .. attribute::  %s \n \n "  %  identifier ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    write_indented_lines ( ident  +  "     " ,  fw ,  py_prop . __doc__ ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  py_prop . fset  is  None : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        fw ( ident  +  "    (readonly) \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								def  pymodule2sphinx ( BASEPATH ,  module_name ,  module ,  title ) :  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    import  types 
							 
						 
					
						
							
								
									
										
										
											
												Mathutils refactor & include in sphinx generated docs, (TODO, include getset'ers in docs)
 - Mathutils.MidpointVecs --> vector.lerp(other, fac)
 - Mathutils.AngleBetweenVecs --> vector.angle(other)
 - Mathutils.ProjectVecs --> vector.project(other)
 - Mathutils.DifferenceQuats --> quat.difference(other)
 - Mathutils.Slerp --> quat.slerp(other, fac)
 - Mathutils.Rand: removed, use pythons random module
 - Mathutils.RotationMatrix(angle, size, axis_flag, axis) --> Mathutils.RotationMatrix(angle, size, axis); merge axis & axis_flag args
 - Matrix.scalePart --> Matrix.scale_part
 - Matrix.translationPart --> Matrix.translation_part
 - Matrix.rotationPart --> Matrix.rotation_part
 - toMatrix --> to_matrix
 - toEuler --> to_euler
 - toQuat --> to_quat
 - Vector.toTrackQuat --> Vector.to_track_quat
											 
										 
										
											2010-01-25 09:44:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # lame, python wont give some access 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    MethodDescriptorType  =  type ( dict . get ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    GetSetDescriptorType  =  type ( int . real ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    
							 
						 
					
						
							
								
									
										
										
										
											2010-01-31 21:52:26 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    
							 
						 
					
						
							
								
									
										
										
										
											2010-01-22 02:04:25 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    filepath  =  os . path . join ( BASEPATH ,  module_name  +  " .rst " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    file  =  open ( filepath ,  " w " ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-27 21:33:39 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2010-01-22 02:04:25 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    fw  =  file . write 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( title  +  " \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( ( " = "  *  len ( title ) )  +  " \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( " .. module::  %s \n \n "  %  module_name ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  module . __doc__ : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        # Note, may contain sphinx syntax, dont mangle! 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        fw ( module . __doc__ . strip ( ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        fw ( " \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-02-28 13:45:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    write_example_ref ( " " ,  fw ,  module_name ) 
							 
						 
					
						
							
								
									
										
										
											
												Mathutils refactor & include in sphinx generated docs, (TODO, include getset'ers in docs)
 - Mathutils.MidpointVecs --> vector.lerp(other, fac)
 - Mathutils.AngleBetweenVecs --> vector.angle(other)
 - Mathutils.ProjectVecs --> vector.project(other)
 - Mathutils.DifferenceQuats --> quat.difference(other)
 - Mathutils.Slerp --> quat.slerp(other, fac)
 - Mathutils.Rand: removed, use pythons random module
 - Mathutils.RotationMatrix(angle, size, axis_flag, axis) --> Mathutils.RotationMatrix(angle, size, axis); merge axis & axis_flag args
 - Matrix.scalePart --> Matrix.scale_part
 - Matrix.translationPart --> Matrix.translation_part
 - Matrix.rotationPart --> Matrix.rotation_part
 - toMatrix --> to_matrix
 - toEuler --> to_euler
 - toQuat --> to_quat
 - Vector.toTrackQuat --> Vector.to_track_quat
											 
										 
										
											2010-01-25 09:44:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    
							 
						 
					
						
							
								
									
										
										
										
											2010-01-31 21:52:26 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # write members of the module 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # only tested with PyStructs which are not exactly modules 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    for  attribute ,  descr  in  sorted ( type ( module ) . __dict__ . items ( ) ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  type ( descr )  ==  types . MemberDescriptorType : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            if  descr . __doc__ : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                fw ( " .. data::  %s \n \n "  %  attribute ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                write_indented_lines ( "     " ,  fw ,  descr . __doc__ ,  False ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                fw ( " \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    
							 
						 
					
						
							
								
									
										
										
											
												Mathutils refactor & include in sphinx generated docs, (TODO, include getset'ers in docs)
 - Mathutils.MidpointVecs --> vector.lerp(other, fac)
 - Mathutils.AngleBetweenVecs --> vector.angle(other)
 - Mathutils.ProjectVecs --> vector.project(other)
 - Mathutils.DifferenceQuats --> quat.difference(other)
 - Mathutils.Slerp --> quat.slerp(other, fac)
 - Mathutils.Rand: removed, use pythons random module
 - Mathutils.RotationMatrix(angle, size, axis_flag, axis) --> Mathutils.RotationMatrix(angle, size, axis); merge axis & axis_flag args
 - Matrix.scalePart --> Matrix.scale_part
 - Matrix.translationPart --> Matrix.translation_part
 - Matrix.rotationPart --> Matrix.rotation_part
 - toMatrix --> to_matrix
 - toEuler --> to_euler
 - toQuat --> to_quat
 - Vector.toTrackQuat --> Vector.to_track_quat
											 
										 
										
											2010-01-25 09:44:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    classes  =  [ ] 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-22 02:04:25 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    for  attribute  in  dir ( module ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  not  attribute . startswith ( " _ " ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            value  =  getattr ( module ,  attribute ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            value_type  =  type ( value ) 
							 
						 
					
						
							
								
									
										
										
											
												Mathutils refactor & include in sphinx generated docs, (TODO, include getset'ers in docs)
 - Mathutils.MidpointVecs --> vector.lerp(other, fac)
 - Mathutils.AngleBetweenVecs --> vector.angle(other)
 - Mathutils.ProjectVecs --> vector.project(other)
 - Mathutils.DifferenceQuats --> quat.difference(other)
 - Mathutils.Slerp --> quat.slerp(other, fac)
 - Mathutils.Rand: removed, use pythons random module
 - Mathutils.RotationMatrix(angle, size, axis_flag, axis) --> Mathutils.RotationMatrix(angle, size, axis); merge axis & axis_flag args
 - Matrix.scalePart --> Matrix.scale_part
 - Matrix.translationPart --> Matrix.translation_part
 - Matrix.rotationPart --> Matrix.rotation_part
 - toMatrix --> to_matrix
 - toEuler --> to_euler
 - toQuat --> to_quat
 - Vector.toTrackQuat --> Vector.to_track_quat
											 
										 
										
											2010-01-25 09:44:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2010-01-22 02:04:25 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            if  value_type  ==  types . FunctionType : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                pyfunc2sphinx ( " " ,  fw ,  attribute ,  value ,  is_class = False ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            elif  value_type  in  ( types . BuiltinMethodType ,  types . BuiltinFunctionType ) :  # both the same at the moment but to be future proof 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                # note: can't get args from these, so dump the string as is 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                # this means any module used like this must have fully formatted docstrings. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                py_c_func2sphinx ( " " ,  fw ,  attribute ,  value ,  is_class = False ) 
							 
						 
					
						
							
								
									
										
										
											
												Mathutils refactor & include in sphinx generated docs, (TODO, include getset'ers in docs)
 - Mathutils.MidpointVecs --> vector.lerp(other, fac)
 - Mathutils.AngleBetweenVecs --> vector.angle(other)
 - Mathutils.ProjectVecs --> vector.project(other)
 - Mathutils.DifferenceQuats --> quat.difference(other)
 - Mathutils.Slerp --> quat.slerp(other, fac)
 - Mathutils.Rand: removed, use pythons random module
 - Mathutils.RotationMatrix(angle, size, axis_flag, axis) --> Mathutils.RotationMatrix(angle, size, axis); merge axis & axis_flag args
 - Matrix.scalePart --> Matrix.scale_part
 - Matrix.translationPart --> Matrix.translation_part
 - Matrix.rotationPart --> Matrix.rotation_part
 - toMatrix --> to_matrix
 - toEuler --> to_euler
 - toQuat --> to_quat
 - Vector.toTrackQuat --> Vector.to_track_quat
											 
										 
										
											2010-01-25 09:44:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            elif  value_type  ==  type : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                classes . append ( ( attribute ,  value ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-22 02:04:25 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            # TODO, more types... 
							 
						 
					
						
							
								
									
										
										
											
												Mathutils refactor & include in sphinx generated docs, (TODO, include getset'ers in docs)
 - Mathutils.MidpointVecs --> vector.lerp(other, fac)
 - Mathutils.AngleBetweenVecs --> vector.angle(other)
 - Mathutils.ProjectVecs --> vector.project(other)
 - Mathutils.DifferenceQuats --> quat.difference(other)
 - Mathutils.Slerp --> quat.slerp(other, fac)
 - Mathutils.Rand: removed, use pythons random module
 - Mathutils.RotationMatrix(angle, size, axis_flag, axis) --> Mathutils.RotationMatrix(angle, size, axis); merge axis & axis_flag args
 - Matrix.scalePart --> Matrix.scale_part
 - Matrix.translationPart --> Matrix.translation_part
 - Matrix.rotationPart --> Matrix.rotation_part
 - toMatrix --> to_matrix
 - toEuler --> to_euler
 - toQuat --> to_quat
 - Vector.toTrackQuat --> Vector.to_track_quat
											 
										 
										
											2010-01-25 09:44:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # write collected classes now 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    for  ( attribute ,  value )  in  classes : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        # May need to be its own function 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        fw ( " .. class::  %s \n \n "  %  attribute ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  value . __doc__ : 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-31 21:52:26 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            write_indented_lines ( "     " ,  fw ,  value . __doc__ ,  False ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-27 21:33:39 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            fw ( " \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-02-28 13:45:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        write_example_ref ( "     " ,  fw ,  module_name  +  " . "  +  attribute ) 
							 
						 
					
						
							
								
									
										
										
											
												Mathutils refactor & include in sphinx generated docs, (TODO, include getset'ers in docs)
 - Mathutils.MidpointVecs --> vector.lerp(other, fac)
 - Mathutils.AngleBetweenVecs --> vector.angle(other)
 - Mathutils.ProjectVecs --> vector.project(other)
 - Mathutils.DifferenceQuats --> quat.difference(other)
 - Mathutils.Slerp --> quat.slerp(other, fac)
 - Mathutils.Rand: removed, use pythons random module
 - Mathutils.RotationMatrix(angle, size, axis_flag, axis) --> Mathutils.RotationMatrix(angle, size, axis); merge axis & axis_flag args
 - Matrix.scalePart --> Matrix.scale_part
 - Matrix.translationPart --> Matrix.translation_part
 - Matrix.rotationPart --> Matrix.rotation_part
 - toMatrix --> to_matrix
 - toEuler --> to_euler
 - toQuat --> to_quat
 - Vector.toTrackQuat --> Vector.to_track_quat
											 
										 
										
											2010-01-25 09:44:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2010-01-27 21:33:39 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        for  key  in  sorted ( value . __dict__ . keys ( ) ) : 
							 
						 
					
						
							
								
									
										
										
											
												Mathutils refactor & include in sphinx generated docs, (TODO, include getset'ers in docs)
 - Mathutils.MidpointVecs --> vector.lerp(other, fac)
 - Mathutils.AngleBetweenVecs --> vector.angle(other)
 - Mathutils.ProjectVecs --> vector.project(other)
 - Mathutils.DifferenceQuats --> quat.difference(other)
 - Mathutils.Slerp --> quat.slerp(other, fac)
 - Mathutils.Rand: removed, use pythons random module
 - Mathutils.RotationMatrix(angle, size, axis_flag, axis) --> Mathutils.RotationMatrix(angle, size, axis); merge axis & axis_flag args
 - Matrix.scalePart --> Matrix.scale_part
 - Matrix.translationPart --> Matrix.translation_part
 - Matrix.rotationPart --> Matrix.rotation_part
 - toMatrix --> to_matrix
 - toEuler --> to_euler
 - toQuat --> to_quat
 - Vector.toTrackQuat --> Vector.to_track_quat
											 
										 
										
											2010-01-25 09:44:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            if  key . startswith ( " __ " ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                continue 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-27 21:33:39 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            descr  =  value . __dict__ [ key ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            if  type ( descr )  ==  GetSetDescriptorType : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  descr . __doc__ : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    fw ( "    .. attribute::  %s \n \n "  %  key ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-31 21:52:26 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    write_indented_lines ( "     " ,  fw ,  descr . __doc__ ,  False ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-02-28 13:45:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    write_example_ref ( "     " ,  fw ,  module_name  +  " . "  +  attribute  +  " . "  +  key ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-27 21:33:39 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    fw ( " \n " ) 
							 
						 
					
						
							
								
									
										
										
											
												Mathutils refactor & include in sphinx generated docs, (TODO, include getset'ers in docs)
 - Mathutils.MidpointVecs --> vector.lerp(other, fac)
 - Mathutils.AngleBetweenVecs --> vector.angle(other)
 - Mathutils.ProjectVecs --> vector.project(other)
 - Mathutils.DifferenceQuats --> quat.difference(other)
 - Mathutils.Slerp --> quat.slerp(other, fac)
 - Mathutils.Rand: removed, use pythons random module
 - Mathutils.RotationMatrix(angle, size, axis_flag, axis) --> Mathutils.RotationMatrix(angle, size, axis); merge axis & axis_flag args
 - Matrix.scalePart --> Matrix.scale_part
 - Matrix.translationPart --> Matrix.translation_part
 - Matrix.rotationPart --> Matrix.rotation_part
 - toMatrix --> to_matrix
 - toEuler --> to_euler
 - toQuat --> to_quat
 - Vector.toTrackQuat --> Vector.to_track_quat
											 
										 
										
											2010-01-25 09:44:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2010-01-27 21:33:39 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        for  key  in  sorted ( value . __dict__ . keys ( ) ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            if  key . startswith ( " __ " ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                continue 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            descr  =  value . __dict__ [ key ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            if  type ( descr )  ==  MethodDescriptorType :  # GetSetDescriptorType, GetSetDescriptorType's are not documented yet 
							 
						 
					
						
							
								
									
										
										
											
												Mathutils refactor & include in sphinx generated docs, (TODO, include getset'ers in docs)
 - Mathutils.MidpointVecs --> vector.lerp(other, fac)
 - Mathutils.AngleBetweenVecs --> vector.angle(other)
 - Mathutils.ProjectVecs --> vector.project(other)
 - Mathutils.DifferenceQuats --> quat.difference(other)
 - Mathutils.Slerp --> quat.slerp(other, fac)
 - Mathutils.Rand: removed, use pythons random module
 - Mathutils.RotationMatrix(angle, size, axis_flag, axis) --> Mathutils.RotationMatrix(angle, size, axis); merge axis & axis_flag args
 - Matrix.scalePart --> Matrix.scale_part
 - Matrix.translationPart --> Matrix.translation_part
 - Matrix.rotationPart --> Matrix.rotation_part
 - toMatrix --> to_matrix
 - toEuler --> to_euler
 - toQuat --> to_quat
 - Vector.toTrackQuat --> Vector.to_track_quat
											 
										 
										
											2010-01-25 09:44:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                if  descr . __doc__ : 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-31 21:52:26 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    write_indented_lines ( "     " ,  fw ,  descr . __doc__ ,  False ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-02-28 13:45:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    write_example_ref ( "     " ,  fw ,  module_name  +  " . "  +  attribute  +  " . "  +  key ) 
							 
						 
					
						
							
								
									
										
										
											
												Mathutils refactor & include in sphinx generated docs, (TODO, include getset'ers in docs)
 - Mathutils.MidpointVecs --> vector.lerp(other, fac)
 - Mathutils.AngleBetweenVecs --> vector.angle(other)
 - Mathutils.ProjectVecs --> vector.project(other)
 - Mathutils.DifferenceQuats --> quat.difference(other)
 - Mathutils.Slerp --> quat.slerp(other, fac)
 - Mathutils.Rand: removed, use pythons random module
 - Mathutils.RotationMatrix(angle, size, axis_flag, axis) --> Mathutils.RotationMatrix(angle, size, axis); merge axis & axis_flag args
 - Matrix.scalePart --> Matrix.scale_part
 - Matrix.translationPart --> Matrix.translation_part
 - Matrix.rotationPart --> Matrix.rotation_part
 - toMatrix --> to_matrix
 - toEuler --> to_euler
 - toQuat --> to_quat
 - Vector.toTrackQuat --> Vector.to_track_quat
											 
										 
										
											2010-01-25 09:44:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    fw ( " \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-27 21:33:39 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            
							 
						 
					
						
							
								
									
										
										
											
												Mathutils refactor & include in sphinx generated docs, (TODO, include getset'ers in docs)
 - Mathutils.MidpointVecs --> vector.lerp(other, fac)
 - Mathutils.AngleBetweenVecs --> vector.angle(other)
 - Mathutils.ProjectVecs --> vector.project(other)
 - Mathutils.DifferenceQuats --> quat.difference(other)
 - Mathutils.Slerp --> quat.slerp(other, fac)
 - Mathutils.Rand: removed, use pythons random module
 - Mathutils.RotationMatrix(angle, size, axis_flag, axis) --> Mathutils.RotationMatrix(angle, size, axis); merge axis & axis_flag args
 - Matrix.scalePart --> Matrix.scale_part
 - Matrix.translationPart --> Matrix.translation_part
 - Matrix.rotationPart --> Matrix.rotation_part
 - toMatrix --> to_matrix
 - toEuler --> to_euler
 - toQuat --> to_quat
 - Vector.toTrackQuat --> Vector.to_track_quat
											 
										 
										
											2010-01-25 09:44:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        fw ( " \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-22 02:04:25 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    file . close ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2010-01-31 21:52:26 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2009-12-25 15:50:53 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								def  rna2sphinx ( BASEPATH ) :  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    structs ,  funcs ,  ops ,  props  =  rna_info . BuildRNAInfo ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    try : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        os . mkdir ( BASEPATH ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    except : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        pass 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # conf.py - empty for now 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    filepath  =  os . path . join ( BASEPATH ,  " conf.py " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    file  =  open ( filepath ,  " w " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw  =  file . write 
							 
						 
					
						
							
								
									
										
										
										
											2010-03-01 10:34:54 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2010-01-31 21:52:26 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    version_string  =  bpy . app . version_string . split ( " ( " ) [ 0 ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  bpy . app . build_revision  !=  " Unknown " : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        version_string  =  version_string  +  "  r "  +  bpy . app . build_revision 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    
							 
						 
					
						
							
								
									
										
										
										
											2009-12-25 15:50:53 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    fw ( " project =  ' Blender 3D ' \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # fw("master_doc = 'index'\n") 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( " copyright = u ' Blender Foundation ' \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-03-01 10:34:54 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    fw ( " version =  ' %s  - UNSTABLE API ' \n "  %  version_string ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( " release =  ' %s  - UNSTABLE API ' \n "  %  version_string ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # not helpful since the source us generated, adds to upload size. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( " html_copy_source = False \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-28 10:48:17 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    fw ( " \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # needed for latex, pdf gen 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( " latex_documents = [ ( ' contents ' ,  ' contents.tex ' ,  ' Blender Index ' ,  ' Blender Foundation ' ,  ' manual ' ), ] \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( " latex_paper_size =  ' a4paper ' \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-25 15:50:53 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    file . close ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    filepath  =  os . path . join ( BASEPATH ,  " contents.rst " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    file  =  open ( filepath ,  " w " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw  =  file . write 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    
							 
						 
					
						
							
								
									
										
										
										
											2010-01-27 22:17:27 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    fw ( " %% %% %% %% %% %% %% %% %% %% %% %% %% %% %% %% % \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( "  Blender Documentation contents \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( " %% %% %% %% %% %% %% %% %% %% %% %% %% %% %% %% % \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( " \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-31 21:52:26 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    fw ( " This document is an API reference for Blender  %s . built  %s . \n "  %  ( version_string ,  bpy . app . build_date ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-27 22:17:27 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    fw ( " \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( " An introduction to blender and python can be found at <http://wiki.blender.org/index.php/Dev:2.5/Py/API/Intro> \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-25 15:50:53 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    fw ( " \n " ) 
							 
						 
					
						
							
								
									
										
										
											
												merge own commits into render branch into trunk since 27560
27562, 27570, 27571, 27574, 27576, 27577, 27579, 27590, 27591, 27594, 27595, 27596, 27599, 27605, 27611, 27612, 27613, 27614, 27623
											 
										 
										
											2010-03-20 16:41:01 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    fw ( " `A PDF version of this document is also available <blender_python_reference_250.pdf>`__ \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( " \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-03-01 10:34:54 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    fw ( " .. warning:: The Python API in Blender is **UNSTABLE**, It should only be used for testing, any script written now may break in future releases. \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( "     \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( "    The following areas are subject to change. \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( "       * operator names and arguments \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( "       * function calls with the data api (any function calls with values accessed from bpy.data), including functions for importing and exporting meshes \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( "       * class registration (Operator, Panels, Menus, Headers) \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( "       * modules: bpy.props, blf) \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( "       * members in the bpy.context have to be reviewed \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( "       * python defined modal operators, especially drawing callbacks are highly experemental \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( "     \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( "    These parts of the API are relatively stable and are unlikely to change significantly \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( "       * data API, access to attributes of blender data such as mesh verts, material color, timeline frames and scene objects \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( "       * user interface functions for defining buttons, creation of menus, headers, panels \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( "       * modules: bgl, Mathutils and Geometry \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( " \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-25 15:50:53 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    fw ( " .. toctree:: \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-27 22:17:27 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    fw ( "    :maxdepth: 1 \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( "    bpy.ops.rst \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( "    bpy.types.rst \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-22 02:04:25 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # py modules 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-27 22:17:27 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    fw ( "    bpy.utils.rst \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( "    bpy.app.rst \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-22 02:04:25 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # C modules 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-27 22:17:27 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    fw ( "    bpy.props.rst \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-22 02:04:25 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    
							 
						 
					
						
							
								
									
										
										
										
											2010-01-27 22:17:27 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    fw ( "    Mathutils.rst \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-03-01 10:34:54 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    fw ( "    blf.rst \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-27 22:17:27 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    file . close ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # internal modules 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    filepath  =  os . path . join ( BASEPATH ,  " bpy.ops.rst " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    file  =  open ( filepath ,  " w " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw  =  file . write 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( " Blender Operators (bpy.ops) \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( " =========================== \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( " .. toctree:: \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( "    :glob: \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( "    bpy.ops.* \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    file . close ( ) 
							 
						 
					
						
							
								
									
										
										
											
												Mathutils refactor & include in sphinx generated docs, (TODO, include getset'ers in docs)
 - Mathutils.MidpointVecs --> vector.lerp(other, fac)
 - Mathutils.AngleBetweenVecs --> vector.angle(other)
 - Mathutils.ProjectVecs --> vector.project(other)
 - Mathutils.DifferenceQuats --> quat.difference(other)
 - Mathutils.Slerp --> quat.slerp(other, fac)
 - Mathutils.Rand: removed, use pythons random module
 - Mathutils.RotationMatrix(angle, size, axis_flag, axis) --> Mathutils.RotationMatrix(angle, size, axis); merge axis & axis_flag args
 - Matrix.scalePart --> Matrix.scale_part
 - Matrix.translationPart --> Matrix.translation_part
 - Matrix.rotationPart --> Matrix.rotation_part
 - toMatrix --> to_matrix
 - toEuler --> to_euler
 - toQuat --> to_quat
 - Vector.toTrackQuat --> Vector.to_track_quat
											 
										 
										
											2010-01-25 09:44:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2010-01-27 22:17:27 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    filepath  =  os . path . join ( BASEPATH ,  " bpy.types.rst " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    file  =  open ( filepath ,  " w " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw  =  file . write 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( " Blender Types (bpy.types) \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( " ========================= \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( " .. toctree:: \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( "    :glob: \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    fw ( "    bpy.types.* \n \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-25 15:50:53 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    file . close ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2010-01-27 22:17:27 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2010-01-22 02:04:25 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    # python modules 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    from  bpy  import  utils  as  module 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-27 22:17:27 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    pymodule2sphinx ( BASEPATH ,  " bpy.utils " ,  module ,  " Utilities (bpy.utils) " ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-31 21:52:26 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # C modules 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-22 02:04:25 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    from  bpy  import  app  as  module 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-27 22:17:27 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    pymodule2sphinx ( BASEPATH ,  " bpy.app " ,  module ,  " Application Data (bpy.app) " ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-22 02:04:25 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    from  bpy  import  props  as  module 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-27 22:17:27 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    pymodule2sphinx ( BASEPATH ,  " bpy.props " ,  module ,  " Property Definitions (bpy.props) " ) 
							 
						 
					
						
							
								
									
										
										
											
												Mathutils refactor & include in sphinx generated docs, (TODO, include getset'ers in docs)
 - Mathutils.MidpointVecs --> vector.lerp(other, fac)
 - Mathutils.AngleBetweenVecs --> vector.angle(other)
 - Mathutils.ProjectVecs --> vector.project(other)
 - Mathutils.DifferenceQuats --> quat.difference(other)
 - Mathutils.Slerp --> quat.slerp(other, fac)
 - Mathutils.Rand: removed, use pythons random module
 - Mathutils.RotationMatrix(angle, size, axis_flag, axis) --> Mathutils.RotationMatrix(angle, size, axis); merge axis & axis_flag args
 - Matrix.scalePart --> Matrix.scale_part
 - Matrix.translationPart --> Matrix.translation_part
 - Matrix.rotationPart --> Matrix.rotation_part
 - toMatrix --> to_matrix
 - toEuler --> to_euler
 - toQuat --> to_quat
 - Vector.toTrackQuat --> Vector.to_track_quat
											 
										 
										
											2010-01-25 09:44:04 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    import  Mathutils  as  module 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-27 22:17:27 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    pymodule2sphinx ( BASEPATH ,  " Mathutils " ,  module ,  " Math Types & Utilities (Mathutils) " ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-22 02:04:25 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    del  module 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2010-03-01 10:34:54 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    import  blf  as  module 
							 
						 
					
						
							
								
									
										
										
										
											2010-02-28 14:57:26 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    pymodule2sphinx ( BASEPATH ,  " blf " ,  module ,  " Blender Font Drawing (blf) " ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-02-28 11:54:48 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    del  module 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-27 22:17:27 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2009-12-25 15:50:53 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								    if  0 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        filepath  =  os . path . join ( BASEPATH ,  " bpy.rst " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        file  =  open ( filepath ,  " w " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        fw  =  file . write 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        fw ( " \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        title  =  " :mod:`bpy` --- Blender Python Module " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        fw ( " %s \n %s \n \n "  %  ( title ,  " = "  *  len ( title ) ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        fw ( " .. module:: bpy.types \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        file . close ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2009-12-26 16:47:25 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								    def  write_param ( ident ,  fw ,  prop ,  is_return = False ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  is_return : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            id_name  =  " return " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            id_type  =  " rtype " 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-18 10:45:54 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            kwargs  =  { " as_ret " :  True ,  " class_fmt " :  " :class:` %s ` " } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            identifier  =  " " 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-25 15:50:53 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								        else : 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-26 16:47:25 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            id_name  =  " arg " 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            id_type  =  " type " 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-18 10:45:54 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            kwargs  =  { " as_arg " :  True ,  " class_fmt " :  " :class:` %s ` " } 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            identifier  =  "   %s "  %  prop . identifier 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-25 15:50:53 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2010-01-18 10:45:54 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        type_descr  =  prop . get_type_description ( * * kwargs ) 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-26 16:47:25 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        if  prop . name  or  prop . description : 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-18 10:45:54 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            fw ( ident  +  " : %s %s :  %s \n "  %  ( id_name ,  identifier ,  " ,  " . join ( [ val  for  val  in  ( prop . name ,  prop . description )  if  val ] ) ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        fw ( ident  +  " : %s %s :  %s \n "  %  ( id_type ,  identifier ,  type_descr ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-25 15:50:53 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    def  write_struct ( struct ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        #if not struct.identifier.startswith("Sc") and not struct.identifier.startswith("I"): 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        #    return 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2010-01-02 19:01:19 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        #if not struct.identifier == "Object": 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        #    return 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-25 15:50:53 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        filepath  =  os . path . join ( BASEPATH ,  " bpy.types. %s .rst "  %  struct . identifier ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        file  =  open ( filepath ,  " w " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        fw  =  file . write 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  struct . base :  
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            title  =  " %s ( %s ) "  %  ( struct . identifier ,  struct . base . identifier ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            title  =  struct . identifier 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        fw ( " %s \n %s \n \n "  %  ( title ,  " = "  *  len ( title ) ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        fw ( " .. module:: bpy.types \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        bases  =  struct . get_bases ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  bases : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            if  len ( bases )  >  1 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                fw ( " base classes ---  " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                fw ( " base class ---  " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            fw ( " ,  " . join ( [ ( " :class:` %s ` "  %  base . identifier )  for  base  in  reversed ( bases ) ] ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            fw ( " \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        subclasses  =  [ s  for  s  in  structs . values ( )  if  s . base  is  struct ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  subclasses : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            fw ( " subclasses ---  \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            fw ( " ,  " . join ( [ ( " :class:` %s ` "  %  s . identifier )  for  s  in  subclasses ] ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            fw ( " \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  struct . base : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            fw ( " .. class::  %s ( %s ) \n \n "  %  ( struct . identifier ,  struct . base . identifier ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        else : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            fw ( " .. class::  %s \n \n "  %  struct . identifier ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        fw ( "     %s \n \n "  %  struct . description ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        for  prop  in  struct . properties : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            fw ( "    .. attribute::  %s \n \n "  %  prop . identifier ) 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-26 16:47:25 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            if  prop . description : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                fw ( "        %s \n \n "  %  prop . description ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-17 20:59:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            type_descr  =  prop . get_type_description ( class_fmt = " :class:` %s ` " ) 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-26 16:47:25 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            fw ( "       *type*  %s \n \n "  %  type_descr ) 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-25 15:50:53 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								        
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        # python attributes 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        py_properties  =  struct . get_py_properties ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        py_prop  =  None 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        for  identifier ,  py_prop  in  py_properties : 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-22 02:04:25 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            pyprop2sphinx ( "     " ,  fw ,  identifier ,  py_prop ) 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-25 15:50:53 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								        del  py_properties ,  py_prop 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        for  func  in  struct . functions : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            args_str  =  " ,  " . join ( [ prop . get_arg_default ( force = False )  for  prop  in  func . args ] ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            fw ( "    .. method::  %s ( %s ) \n \n "  %  ( func . identifier ,  args_str ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            fw ( "        %s \n \n "  %  func . description ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            for  prop  in  func . args : 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-26 16:47:25 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                write_param ( "        " ,  fw ,  prop ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2010-01-02 18:55:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            if  len ( func . return_values )  ==  1 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                write_param ( "        " ,  fw ,  func . return_values [ 0 ] ,  is_return = True ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-17 20:59:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            elif  func . return_values :  # multiple return values 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                fw ( "       :return ( %s ): \n "  %  " ,  " . join ( [ prop . identifier  for  prop  in  func . return_values ] ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-02 18:55:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                for  prop  in  func . return_values : 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-17 20:59:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    type_descr  =  prop . get_type_description ( as_ret = True ,  class_fmt = " :class:` %s ` " ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-02 18:55:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    descr  =  prop . description 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    if  not  descr : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                        descr  =  prop . name 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-17 20:59:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                    fw ( "          ` %s `,  %s ,  %s \n \n "  %  ( prop . identifier ,  descr ,  type_descr ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-02 18:55:07 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2009-12-26 16:47:25 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            fw ( " \n " ) 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-25 15:50:53 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        # python methods 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        py_funcs  =  struct . get_py_functions ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        py_func  =  None 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        for  identifier ,  py_func  in  py_funcs : 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-22 02:04:25 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            pyfunc2sphinx ( "     " ,  fw ,  identifier ,  py_func ,  is_class = True ) 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-25 15:50:53 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								        del  py_funcs ,  py_func 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  struct . references : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            # use this otherwise it gets in the index for a normal heading. 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            fw ( " .. rubric:: References \n \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            for  ref  in  struct . references : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                ref_split  =  ref . split ( " . " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                if  len ( ref_split )  >  2 : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                    ref  =  ref_split [ - 2 ]  +  " . "  +  ref_split [ - 1 ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                fw ( " * :class:` %s ` \n "  %  ref ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            fw ( " \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    for  struct  in  structs . values ( ) : 
							 
						 
					
						
							
								
									
										
										
										
											2010-02-16 15:01:34 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        # TODO, rna_info should filter these out! 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  " _OT_ "  in  struct . identifier : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            continue 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-25 15:50:53 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								        write_struct ( struct ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    # oeprators 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    def  write_ops ( ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        fw  =  None 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        last_mod  =  ' ' 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        for  op_key  in  sorted ( ops . keys ( ) ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            op  =  ops [ op_key ] 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            if  last_mod  !=  op . module_name : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                filepath  =  os . path . join ( BASEPATH ,  " bpy.ops. %s .rst "  %  op . module_name ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                file  =  open ( filepath ,  " w " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                fw  =  file . write 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                title  =  " %s  Operators "   %  ( op . module_name [ 0 ] . upper ( )  +  op . module_name [ 1 : ] ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                fw ( " %s \n %s \n \n "  %  ( title ,  " = "  *  len ( title ) ) ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                fw ( " .. module:: bpy.ops. %s \n \n "  %  op . module_name ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                last_mod  =  op . module_name 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            args_str  =  " ,  " . join ( [ prop . get_arg_default ( force = True )  for  prop  in  op . args ] ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            fw ( " .. function::  %s ( %s ) \n \n "  %  ( op . func_name ,  args_str ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-26 16:47:25 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            if  op . description : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                fw ( "     %s \n \n "  %  op . description ) 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-25 15:50:53 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								            for  prop  in  op . args : 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-17 20:59:35 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								                write_param ( "     " ,  fw ,  prop ) 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-26 16:47:25 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								            if  op . args : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                fw ( " \n " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
									
										
										
										
											2009-12-25 15:50:53 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								            location  =  op . get_location ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            if  location  !=  ( None ,  None ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                fw ( "    *python operator source --- ` %s : %d `*  \n \n "  %  location ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    write_ops ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    file . close ( ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								if  __name__  ==  ' __main__ ' :  
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    if  ' bpy '  not  in  dir ( ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        print ( " \n Error, this script must run from inside blender2.5 " ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        print ( script_help_msg ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    else : 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-31 21:52:26 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        import  shutil 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        path_in  =  ' source/blender/python/doc/sphinx-in ' 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        path_out  =  ' source/blender/python/doc/sphinx-in ' 
							 
						 
					
						
							
								
									
										
										
										
											2010-02-28 13:45:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        path_examples  =  ' source/blender/python/doc/examples ' 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-31 21:52:26 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        shutil . rmtree ( path_in ,  True ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        shutil . rmtree ( path_out ,  True ) 
							 
						 
					
						
							
								
									
										
										
										
											2010-02-28 13:45:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        for  f  in  os . listdir ( path_examples ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            if  f . endswith ( " .py " ) : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                EXAMPLE_SET . add ( os . path . splitext ( f ) [ 0 ] ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        
							 
						 
					
						
							
								
									
										
										
										
											2010-01-31 21:52:26 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        rna2sphinx ( path_in ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        # for fast module testing 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-27 22:17:27 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        # os.system("rm source/blender/python/doc/sphinx-in/bpy.types.*.rst") 
							 
						 
					
						
							
								
									
										
										
										
											2010-01-31 21:52:26 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        # os.system("rm source/blender/python/doc/sphinx-in/bpy.ops.*.rst") 
							 
						 
					
						
							
								
									
										
										
										
											2010-02-28 13:45:08 +00:00 
										
									 
								 
							 
							
								
									
										 
								
							 
							
								 
							
							
								        
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        EXAMPLE_SET_UNUSED  =  EXAMPLE_SET  -  EXAMPLE_SET_USED 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								        if  EXAMPLE_SET_UNUSED : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            print ( " \n Unused examples found in  ' %s ' ... "  %  path_examples ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            for  f  in  EXAMPLE_SET_UNUSED : 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								                print ( "      %s .py "  %  f ) 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								            print ( "    %d  total \n "  %  len ( EXAMPLE_SET_UNUSED ) ) 
							 
						 
					
						
							
								
									
										
										
										
											2009-12-25 15:50:53 +00:00 
										
									 
								 
							 
							
								
							 
							
								 
							
							
								
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    import  sys 
							 
						 
					
						
							
								
							 
							
								
							 
							
								 
							
							
								    sys . exit ( )