It can be assumed that all scripts comply with basic pep8 formatting regarding white-space, indentation etc. Also remove note in best practices page & update `tests/python/pep8.py`. If we want to exclude some scripts from make format, this can be done by adding them to `ignore_files` in: source/tools/utils_maintenance/autopep8_format_paths.py Or using `# nopep8` for to ignore for individual lines. Ref T98554
		
			
				
	
	
		
			131 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			131 lines
		
	
	
		
			2.7 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
| # SPDX-License-Identifier: GPL-2.0-or-later
 | |
| 
 | |
| if 1:
 | |
|     # Print once every 1000
 | |
|     GEN_PATH = True
 | |
|     PRINT_DATA = False
 | |
|     PRINT_DATA_INT = 1000
 | |
|     VERBOSE = False
 | |
|     VERBOSE_TYPE = False
 | |
|     MAX_RECURSIVE = 8
 | |
| else:
 | |
|     # Print everything
 | |
|     GEN_PATH = True
 | |
|     PRINT_DATA = True
 | |
|     PRINT_DATA_INT = 0
 | |
|     VERBOSE = False
 | |
|     VERBOSE_TYPE = False
 | |
|     MAX_RECURSIVE = 8
 | |
| 
 | |
| seek_count = [0]
 | |
| 
 | |
| 
 | |
| def seek(r, txt, recurs):
 | |
| 
 | |
|     seek_count[0] += 1
 | |
| 
 | |
|     if PRINT_DATA_INT:
 | |
|         if not (seek_count[0] % PRINT_DATA_INT):
 | |
|             print(seek_count[0], txt)
 | |
| 
 | |
|     if PRINT_DATA:
 | |
|         print(txt)
 | |
| 
 | |
|     newtxt = ''
 | |
| 
 | |
|     if recurs > MAX_RECURSIVE:
 | |
|         #print ("Recursion is over max")
 | |
|         #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 is not 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 GEN_PATH:
 | |
|             newtxt = txt + '.' + item
 | |
| 
 | |
|         if item == 'rna_type' and VERBOSE_TYPE is False:  # just avoid because it spits out loads of data
 | |
|             continue
 | |
| 
 | |
|         value = getattr(r, item, None)
 | |
| 
 | |
|         seek(value, newtxt, recurs + 1)
 | |
| 
 | |
|     if keys:
 | |
|         for k in keys:
 | |
|             if GEN_PATH:
 | |
|                 newtxt = txt + '["' + k + '"]'
 | |
|             seek(r.__getitem__(k), newtxt, recurs + 1)
 | |
| 
 | |
|     else:
 | |
|         try:
 | |
|             length = len(r)
 | |
|         except:
 | |
|             length = 0
 | |
| 
 | |
|         if VERBOSE is 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 GEN_PATH:
 | |
|                     newtxt = txt + '[' + str(i) + ']'
 | |
|                 seek(r[i], newtxt, recurs + 1)
 | |
|         else:
 | |
|             for i in range(length):
 | |
|                 if GEN_PATH:
 | |
|                     newtxt = txt + '[' + str(i) + ']'
 | |
|                 seek(r[i], newtxt, recurs + 1)
 | |
| 
 | |
| 
 | |
| seek(bpy.data, 'bpy.data', 0)
 | |
| # seek(bpy.types, 'bpy.types', 0)
 | |
| '''
 | |
| for d in dir(bpy.types):
 | |
|     t = getattr(bpy.types, d)
 | |
|     try:
 | |
|         r = t.bl_rna
 | |
|     except:
 | |
|         r = None
 | |
|     if r:
 | |
|         seek(r, 'bpy.types.' + d + '.bl_rna', 0)
 | |
| '''
 | |
| 
 | |
| # print dir(bpy)
 | |
| #import sys
 | |
| # sys.exit()
 | |
| 
 | |
| print("iter over ", seek_count, "rna items")
 |