custom_shelf/utils.py

183 lines
5.0 KiB
Python
Raw Normal View History

2022-03-04 12:28:53 +01:00
import bpy
import os
from os import listdir,mkdir,scandir
from os.path import join,dirname,splitext,isdir,exists,basename
from bpy.types import Operator, Panel, PropertyGroup
from bpy.props import *
import subprocess
import json
id_type = {"Action" : "actions", "Armature":"armatures", "Brush":"brushes", "CacheFile":"cache_files", "Camera":"cameras",
"Curve":"curves", "FreestyleLineStyle":"linestyles", "GreasePencil":"grease_pencil", "Group":"groups",
"Image":"images", "Key":"shape_keys", "Light":"lights", "Lattice":"lattices", "Library":"librairies", "Mask":"masks",
"Material":"materials", "Mesh":"meshes", "MetaBall":"metaballs", "MovieClip":"movieclips", "NodeTree":"node_groups",
"Object":"objects", "PaintCurve":"paint_curves", "Palette":"palettes", "ParticleSettings":"particles",
"Scene":"scenes", "Screen":"screens", "Sound":"sounds", "Speaker":"speakers", "Text":"texts", "Texture":"textures",
"VectorFont":"fonts", "WindowManager":"window_managers", "World":"worlds"}
def report(var,message,type='INFO') :
print([a for a in locals()])
print([a for a in globals()])
if 'self' in var :
var['self'].report({type}, message)
else :
print('')
print(type)
print(message)
def read_json(path):
jsonFile = path
if os.path.exists(jsonFile):
try :
with open(jsonFile) as data_file:
return (json.load(data_file))
except :
print("the file %s not json readable"%jsonFile)
return
def search_filter(search,str) :
return search.lower() in str.lower()
def title(string) :
return string.replace('_',' ').replace('-',' ').title()
def arg_name(string) :
return string.replace(' ','_').replace('-','_').lower().strip('_')
def open_folder(path) :
try:
os.startfile(path)
except:
subprocess.Popen(['xdg-open', path])
def dic_to_args(dic):
import collections
args = collections.OrderedDict()
for k,v in dic.items() :
if k in ('icon','description') or not isinstance(k,str):
continue
if isinstance(v,str) :
if '/' in v or '\\' in v :
args[k] = StringProperty(default=v,subtype = "FILE_PATH")
else :
args[k] = StringProperty(default=v)
elif isinstance(v,bool) :
args[k] = BoolProperty(default=v)
elif isinstance(v,float) :
args[k] = FloatProperty(default=v,precision=3)
elif isinstance(v,int) :
args[k] = IntProperty(default=v)
elif isinstance(v,dict) :
if v.get("items") and isinstance(v["items"],(tuple,list)) :
args[k] = EnumProperty(items = [(i,i,"") for i in v["items"]])
elif v.get("collection") and isinstance(v["collection"],str) :
if v["collection"] not in id_type :
print("Collection %s not supported must be in %s"%(v["collection"],id_type))
#args[k] = PointerProperty(type = getattr(bpy.types,v["collection"]))
else :
args[k] = PointerProperty(type = getattr(bpy.types,v["collection"]),poll = v.get('poll'))
return args
def read_info(script_path) :
import collections
if isinstance(script_path,list) :
lines =script_path
else :
with open(script_path,encoding="utf-8") as f:
lines = f.read().splitlines()
info = {}
for i,l in enumerate(lines) :
if i >= 10 :
return info,lines
if l.startswith("info") :
info_start = i
info_str = l
while info_str.endswith(',') or not info_str.endswith('}') or i == len(lines)-1:
i+=1
info_str+= lines[i]
info_end = i
opening_brace_index = info_str.find('{')
try :
info = eval(info_str[opening_brace_index:])
except :
print('The info header in the file %s cannot be read'%script_path)
break
info = [(k,v) for k,v in info.items()]
info.sort(key = lambda x : info_str.find(x[0]))
info = collections.OrderedDict(info)
del lines[info_start:info_end+1]
break
# remove backspace
for i in range(len(lines)) :
if lines[0] :
break
else :
lines.pop(0)
for i in range(len(lines)) :
if lines[-1] :
break
else :
lines.pop(-1)
return info,lines
def dic_to_str(dic,keys= None,spaces = 4) :
if not keys :
keys = sorted(dic)
line = '{\n'
for k in keys :
v = dic[k]
line += ' '*spaces
if isinstance(k,str) :
line +="'%s'"%k
else :
line += "%s"%k
line += ' : '
if isinstance(v,str) :
line +="'%s'"%v
else :
line += "%s"%v
line += ',\n'
line += '}\n\n'
return line