- rearranged modules bpyui -> bpy.ui, bpy -> bpy.data, remove bpydoc - new module bpy.types, stores a list of all struct types - added __rna__ attribute to types - eg bpy.types.World.__rna__ so you can access the rna data from a type. (so bpydoc.structs isnt needed anymore) - removed unused subtyping method (use python subclassing rather then C PyTypeObject)
113 lines
2.5 KiB
Python
113 lines
2.5 KiB
Python
# ***** BEGIN GPL LICENSE BLOCK *****
|
|
#
|
|
# This program is free software; you can redistribute it and/or
|
|
# modify it under the terms of the GNU General Public License
|
|
# as published by the Free Software Foundation; either version 2
|
|
# of the License, or (at your option) any later version.
|
|
#
|
|
# This program is distributed in the hope that it will be useful,
|
|
# but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
# GNU General Public License for more details.
|
|
#
|
|
# You should have received a copy of the GNU General Public License
|
|
# along with this program; if not, write to the Free Software Foundation,
|
|
# Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
|
|
#
|
|
# Contributor(s): Campbell Barton
|
|
#
|
|
# #**** END GPL LICENSE BLOCK #****
|
|
|
|
|
|
PRINT_DATA = True
|
|
VERBOSE = False
|
|
VERBOSE_TYPE = False
|
|
SKIP_RECURSIVE = False
|
|
|
|
|
|
def seek(r, txt):
|
|
print(txt)
|
|
newtxt = ''
|
|
|
|
if len(txt) > 200:
|
|
print ("Somthing is wrong")
|
|
print (txt)
|
|
return
|
|
|
|
type_r = type(r)
|
|
|
|
# print(type_r)
|
|
# print(dir(r))
|
|
|
|
# basic types
|
|
if type_r in (float, int, bool, type(None)):
|
|
if PRINT_DATA:
|
|
print(txt + ' -> ' + str(r))
|
|
return
|
|
|
|
if type_r == str:
|
|
if PRINT_DATA:
|
|
print(txt + ' -> "' + str(r) + '"')
|
|
return
|
|
|
|
try: keys = r.keys()
|
|
except: keys = None
|
|
|
|
if keys != None:
|
|
if PRINT_DATA:
|
|
print(txt + '.keys() - ' + str(r.keys()))
|
|
|
|
try: __members__ = dir(r)
|
|
except: __members__ = []
|
|
|
|
for item in __members__:
|
|
if item.startswith('__'):
|
|
continue
|
|
|
|
if PRINT_DATA: newtxt = txt + '.' + item
|
|
|
|
if item == 'rna_type' and VERBOSE_TYPE==False: # just avoid because it spits out loads of data
|
|
continue
|
|
|
|
if SKIP_RECURSIVE:
|
|
if item in txt:
|
|
if PRINT_DATA:
|
|
print(newtxt + ' - (skipping to avoid recursive search)')
|
|
continue
|
|
|
|
try: value = getattr(r, item)
|
|
except: value = None
|
|
|
|
seek( value, newtxt)
|
|
|
|
|
|
if keys:
|
|
for k in keys:
|
|
if PRINT_DATA: newtxt = txt + '["' + k + '"]'
|
|
seek(r.__getitem__(k), newtxt)
|
|
|
|
else:
|
|
try: length = len( r )
|
|
except: length = 0
|
|
|
|
if VERBOSE==False and length >= 4:
|
|
for i in (0, length-1):
|
|
if i>0:
|
|
if PRINT_DATA:
|
|
print((' '*len(txt)) + ' ... skipping '+str(length-2)+' items ...')
|
|
|
|
if PRINT_DATA: newtxt = txt + '[' + str(i) + ']'
|
|
seek(r[i], newtxt)
|
|
else:
|
|
for i in range(length):
|
|
if PRINT_DATA: newtxt = txt + '[' + str(i) + ']'
|
|
seek(r[i], newtxt)
|
|
|
|
#print (dir(bpy))
|
|
seek(bpy.data, 'bpy.data')
|
|
|
|
|
|
#print dir(bpy)
|
|
#import sys
|
|
#sys.exit()
|