Merge branch 'master' into blender2.8
[blender.git] / source / blender / python / rna_dump.py
1 # ##### BEGIN GPL LICENSE BLOCK #####
2 #
3 #  This program is free software; you can redistribute it and/or
4 #  modify it under the terms of the GNU General Public License
5 #  as published by the Free Software Foundation; either version 2
6 #  of the License, or (at your option) any later version.
7 #
8 #  This program is distributed in the hope that it will be useful,
9 #  but WITHOUT ANY WARRANTY; without even the implied warranty of
10 #  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
11 #  GNU General Public License for more details.
12 #
13 #  You should have received a copy of the GNU General Public License
14 #  along with this program; if not, write to the Free Software Foundation,
15 #  Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
16 #
17 # Contributor(s): Campbell Barton
18 #
19 # ##### END GPL LICENSE BLOCK #####
20
21 # <pep8 compliant>
22
23 if 1:
24     # Print once every 1000
25     GEN_PATH = True
26     PRINT_DATA = False
27     PRINT_DATA_INT = 1000
28     VERBOSE = False
29     VERBOSE_TYPE = False
30     MAX_RECURSIVE = 8
31 else:
32     # Print everything
33     GEN_PATH = True
34     PRINT_DATA = True
35     PRINT_DATA_INT = 0
36     VERBOSE = False
37     VERBOSE_TYPE = False
38     MAX_RECURSIVE = 8
39
40 seek_count = [0]
41
42
43 def seek(r, txt, recurs):
44
45     seek_count[0] += 1
46
47     if PRINT_DATA_INT:
48         if not (seek_count[0] % PRINT_DATA_INT):
49             print(seek_count[0], txt)
50
51     if PRINT_DATA:
52         print(txt)
53
54     newtxt = ''
55
56     if recurs > MAX_RECURSIVE:
57         #print ("Recursion is over max")
58         #print (txt)
59         return
60
61     type_r = type(r)
62
63     # print(type_r)
64     # print(dir(r))
65
66     # basic types
67     if type_r in (float, int, bool, type(None)):
68         if PRINT_DATA:
69             print(txt + ' -> ' + str(r))
70         return
71
72     if type_r == str:
73         if PRINT_DATA:
74             print(txt + ' -> "' + str(r) + '"')
75         return
76
77     try:
78         keys = r.keys()
79     except:
80         keys = None
81
82     if keys is not None:
83         if PRINT_DATA:
84             print(txt + '.keys() - ' + str(r.keys()))
85
86     try:
87         __members__ = dir(r)
88     except:
89         __members__ = []
90
91     for item in __members__:
92         if item.startswith("__"):
93             continue
94
95         if GEN_PATH:
96             newtxt = txt + '.' + item
97
98         if item == 'rna_type' and VERBOSE_TYPE is False:  # just avoid because it spits out loads of data
99             continue
100
101         value = getattr(r, item, None)
102
103         seek(value, newtxt, recurs + 1)
104
105     if keys:
106         for k in keys:
107             if GEN_PATH:
108                 newtxt = txt + '["' + k + '"]'
109             seek(r.__getitem__(k), newtxt, recurs + 1)
110
111     else:
112         try:
113             length = len(r)
114         except:
115             length = 0
116
117         if VERBOSE is False and length >= 4:
118             for i in (0, length - 1):
119                 if i > 0:
120                     if PRINT_DATA:
121                         print((" " * len(txt)) + " ... skipping " + str(length - 2) + " items ...")
122
123                 if GEN_PATH:
124                     newtxt = txt + '[' + str(i) + ']'
125                 seek(r[i], newtxt, recurs + 1)
126         else:
127             for i in range(length):
128                 if GEN_PATH:
129                     newtxt = txt + '[' + str(i) + ']'
130                 seek(r[i], newtxt, recurs + 1)
131
132
133 seek(bpy.data, 'bpy.data', 0)
134 # seek(bpy.types, 'bpy.types', 0)
135 '''
136 for d in dir(bpy.types):
137     t = getattr(bpy.types, d)
138     try:        r = t.bl_rna
139     except:     r = None
140     if r:
141         seek(r, 'bpy.types.' + d + '.bl_rna', 0)
142 '''
143
144 # print dir(bpy)
145 #import sys
146 # sys.exit()
147
148 print("iter over ", seek_count, "rna items")