execlib.py 12 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406
  1. #/usr/bin/python3
  2. import copy
  3. import __main__ as MAIN
  4. from lib.cprint import cprint
  5. from collections import OrderedDict
  6. import json
  7. try:
  8. import memcache
  9. mc = memcache.Client(['127.0.0.1:11211'], debug=0)
  10. except:
  11. mc = None
  12. def reshape_exec(data ,value=None,xfade=0,flash=0,ptfade=0,DELAY=None):
  13. f=0 #fade
  14. out = []
  15. delay=0
  16. for row in data:
  17. #cprint("reshape_exec in:",row)
  18. line = {}
  19. line["DELAY"]=delay
  20. if type(value) is float:
  21. line["VALUE"] = value #round(value,3)
  22. else:
  23. line["VALUE"] = value
  24. if "FX" not in row:
  25. cprint("698 FX not in row...",row,color="red")
  26. row["FX"] = ""
  27. else:
  28. if type(row["FX"]) is not str:
  29. cprint("702 FX is not str...",row,color="red")
  30. row["FX"] = ""
  31. if value is not None:
  32. line["FX"] = row["FX"].split(":",1)[-1]
  33. else:
  34. line["FX"] = row["FX"]
  35. if row["FX2"]:
  36. line["FX2"] = row["FX2"]
  37. if row["FIX"]:
  38. line["FIX"] = row["FIX"]
  39. if row["ATTR"]:
  40. line["ATTR"] = row["ATTR"]
  41. if row["VALUE"] is not None:
  42. if value is None:
  43. v=row["VALUE"]
  44. if type(v) is float:
  45. line["VALUE"] = v #round(v,3)
  46. else:
  47. line["VALUE"] = v
  48. if row["ATTR"] in ["PAN","TILT"]:
  49. f = ptfade
  50. for a in ["DIM","ZOOM","FOCUS","RED","GREEN","BLUE","WHITE","AMBER","IRIS","BLADE"]:
  51. #FADE ATTRIBUTES
  52. if a in row["ATTR"]:
  53. f = xfade
  54. break
  55. if flash:
  56. xfade = 0
  57. if type( f ) is float:
  58. line["FADE"] = round(f,4)
  59. else:
  60. line["FADE"] = f
  61. if 0:
  62. cprint("reshape_exec j",line,color="red")
  63. #cprint("reshape_exec out:",line)
  64. out.append(line)
  65. if DELAY:
  66. if DELAY._is():
  67. delay+=DELAY.val()/100 #0.02
  68. return out
  69. import lib.showlib as showlib
  70. def EXEC_CFG_CHECKER(sdata):
  71. "repair CFG "
  72. ok = 0
  73. if "CFG" not in sdata:
  74. sdata["CFG"] = OrderedDict()
  75. ok += 1
  76. if "FADE" not in sdata["CFG"]:
  77. sdata["CFG"]["FADE"] = 4
  78. ok += 1
  79. if "DELAY" not in sdata["CFG"]:
  80. sdata["CFG"]["DELAY"] = 0
  81. ok += 1
  82. if "BUTTON" not in sdata["CFG"]:
  83. sdata["CFG"]["BUTTON"] = "GO"
  84. ok += 1
  85. if "HTP-MASTER" not in sdata["CFG"]:
  86. sdata["CFG"]["HTP-MASTER"] = 100 #%
  87. ok += 1
  88. if "SIZE-MASTER" not in sdata["CFG"]:
  89. sdata["CFG"]["SIZE-MASTER"] = 100 #%
  90. ok += 1
  91. if "SPEED-MASTER" not in sdata["CFG"]:
  92. sdata["CFG"]["SPEED-MASTER"] = 100 #%
  93. ok += 1
  94. if "OFFSET-MASTER" not in sdata["CFG"]:
  95. sdata["CFG"]["OFFSET-MASTER"] = 100 #%
  96. ok += 1
  97. #try:del sdata["CFG"]["SPEED-MASTER"] #= 100 #%
  98. #except:pass
  99. return ok
  100. import time
  101. class EXEC(): #Presets():
  102. def __init__(self):
  103. self.base = showlib.Base()
  104. self._last_copy = None
  105. self._last_move = None
  106. self.fx_buffer = {}
  107. def load_exec(self):
  108. filename="exec"
  109. filename="presets" # preset.sav
  110. d,l = self.base._load(filename)
  111. for i in d:
  112. sdata = d[i]
  113. ok = EXEC_CFG_CHECKER(sdata)
  114. start = time.time()
  115. if mc:
  116. index=[]
  117. for i,v in enumerate(l):
  118. key="EXEC-"+str(i)
  119. mc.set(key,json.dumps(d[v]))
  120. index.append(key)
  121. key2="EXEC-LABEL-"+str(i)
  122. mc.set(key2,l[i] )
  123. mc.set("EXEC-INDEX",json.dumps(index))
  124. print("---------------------------------------",start - time.time())
  125. self.val_exec = d
  126. self.label_exec = l
  127. def check_cfg(self,nr=None):
  128. cprint("EXEC.check_cfg()",nr)#,color="red")
  129. ok = 0
  130. if nr is not None:
  131. if nr in self.val_exec:
  132. sdata = self.val_exec[nr]
  133. ok += self._check_cfg(sdata)
  134. else:
  135. cprint("nr not in data ",nr,color="red")
  136. else:
  137. for nr in self.val_exec:
  138. sdata = self.val_exec[nr]
  139. ok += self._check_cfg(sdata)
  140. return ok
  141. def _check_cfg(self,sdata):
  142. cprint("EXEC._check_cfg()")#,color="red")
  143. ok = EXEC_CFG_CHECKER(sdata)
  144. if ok:
  145. cprint("REPAIR CFG's",ok,sdata["CFG"],color="red")
  146. return ok
  147. def backup_exec(self,save_as="",new=0):
  148. filename = "exec" # new
  149. filename = "presets" # preset.sav
  150. data = self.val_exec
  151. labels = self.label_exec
  152. if new:
  153. data = [] #*512
  154. labls = [""]*512
  155. r=self.base._backup(filename,data,labels,save_as)
  156. return r
  157. def get_cfg(self,nr):
  158. cprint("EXEC.get_cfg()",nr)
  159. self.check_cfg(nr)
  160. if nr not in self.val_exec:
  161. cprint("get_cfg",self,"error get_cfg no nr:",nr,color="red")
  162. return {}
  163. if "CFG" in self.val_exec[nr]:
  164. return self.val_exec[nr]["CFG"]
  165. def clean(self,nr):
  166. if nr not in self.val_exec:
  167. self.val_exec[nr] = OrderedDict()
  168. #self.val_exec[nr]["VALUE"] = 0
  169. #self.val_exec[nr]["FX"] = ""
  170. sdata = self.val_exec[nr]
  171. for fix in sdata:
  172. #print("exec.clear()",nr,fix,sdata[fix])
  173. for attr in sdata[fix]:
  174. row = sdata[fix][attr]
  175. if fix == "CFG":
  176. continue
  177. if "VALUE" not in row:
  178. row["VALUE"] = None
  179. if "FX" not in row:
  180. row["FX"] = ""
  181. if "FX2" not in row:
  182. row["FX2"] = OrderedDict()
  183. elif row["FX2"]:
  184. for k in ["SIZE","SPEED","START","OFFSET"]:
  185. row["FX2"][k] = int( row["FX2"][k] )
  186. row["FX"] = ""
  187. if "FX" in row and row["FX"] and not row["FX2"]: # rebuild old FX to Dict-FX2
  188. #"off:0:0:0:16909:-:"
  189. x = row["FX"].split(":")
  190. cprint("-fx",x,len(x))
  191. #'FX2': {'TYPE': 'sinus', 'SIZE': 200, 'SPEED': 30, 'START': 0, 'OFFSET': 2805, 'BASE': '-'}}
  192. if len(x) >= 6:
  193. row["FX2"]["TYPE"] = x[0]
  194. row["FX2"]["SIZE"] = int(x[1])
  195. row["FX2"]["SPEED"] = int(x[2])
  196. row["FX2"]["START"] = int(x[3])
  197. row["FX2"]["OFFSET"] = int(x[4])
  198. row["FX2"]["BASE"] = x[5]
  199. row["FXOLD"] = row["FX"]
  200. row["FX"] = ""
  201. #cprint("exec.clear()",nr,fix,row)
  202. def get_raw_map(self,nr):
  203. self.clean(nr)
  204. cprint("get_raw_map",nr)
  205. sdata = self.val_exec[nr]
  206. cmd = ""
  207. out = []
  208. dmx=-1
  209. for fix in sdata:
  210. if fix == "CFG":
  211. #print("CFG",nr,sdata[fix])
  212. continue
  213. for attr in sdata[fix]:
  214. x = {}
  215. #print("RAW",attr)
  216. x["FIX"] = fix
  217. x["ATTR"] = attr
  218. x["VALUE"] = sdata[fix][attr]["VALUE"]
  219. x["FX"] = sdata[fix][attr]["FX"]
  220. x["FX2"] = sdata[fix][attr]["FX2"]
  221. #x["DMX"] = sdata[fix][attr]["NR"]
  222. out.append(x)
  223. return out
  224. def get_btn_txt(self,nr):
  225. sdata=self.val_exec[nr]
  226. BTN="go"
  227. if "CFG" in sdata:
  228. if "BUTTON" in sdata["CFG"]:
  229. BTN = sdata["CFG"]["BUTTON"]
  230. _label = self.label_exec[nr] # = label
  231. #txt=str(nr+1)+":"+str(BTN)+":"+str(len(sdata)-1)+"\n"+_label
  232. #txt=str(nr+1)+" "+str(BTN)+" "+str(len(sdata)-1)+"\n"+_label
  233. txt="{} {} {}\n{}".format(nr+1,BTN,len(sdata)-1,_label)
  234. cprint("get_btn_txt",nr,[txt])
  235. return txt
  236. def _btn_cfg(self,nr,txt=None):
  237. if nr not in self.val_exec:
  238. return ""
  239. if "CFG" not in self.val_exec[nr]:
  240. self.val_exec[nr]["CFG"] = OrderedDict()
  241. return self.val_exec[nr]["CFG"]
  242. def btn_cfg(self,nr,txt=None):
  243. if nr not in self.val_exec:
  244. return ""
  245. if "CFG" not in self.val_exec[nr]:
  246. self.val_exec[nr]["CFG"] = OrderedDict()
  247. if "BUTTON" not in self.val_exec[nr]["CFG"]:
  248. self.val_exec[nr]["CFG"]["BUTTON"] = ""
  249. if type(txt) is str:
  250. self.val_exec[nr]["CFG"]["BUTTON"] = txt
  251. if self.val_exec[nr]["CFG"]["BUTTON"] is None:
  252. self.val_exec[nr]["CFG"]["BUTTON"] = ""
  253. MAIN.master._refresh_exec(nr=nr)
  254. cprint("EEE", self.val_exec[nr]["CFG"]["BUTTON"] )
  255. return self.val_exec[nr]["CFG"]["BUTTON"]
  256. def label(self,nr,txt=None):
  257. if nr not in self.label_exec:
  258. return ""
  259. if type(txt) is str:
  260. self.label_exec[nr] = txt
  261. cprint("set label",nr,[txt])
  262. cprint("??? ?? set label",nr,[txt])
  263. return self.label_exec[nr]
  264. def clear_move(self):
  265. cprint("EXEC.clear_move()",end=" ")
  266. self.clear_copy()
  267. def clear_copy(self):
  268. cprint("EXEC.clear_copy()",end=" ")
  269. if self._last_copy is not None:
  270. cprint("=OK=",color="red")
  271. self._last_copy = None
  272. else:
  273. cprint("=NONE=",color="green")
  274. def copy(self,nr,overwrite=1):
  275. cprint("EXEC._copy",nr,"last",self._last_copy)
  276. if nr >= 0:
  277. if self._last_copy is not None:
  278. if MAIN.modes.val("COPY"):
  279. MAIN.modes.val("COPY",3)
  280. ok = self._copy(self._last_copy,nr,overwrite=overwrite)
  281. return ok #ok
  282. else:
  283. if MAIN.modes.val("COPY"):
  284. MAIN.modes.val("COPY",2)
  285. self._last_copy = nr
  286. cprint("EXEC.copy START ",color="red")
  287. return 0
  288. return 1 # on error reset move
  289. def _copy(self,nr_from,nr_to,overwrite=1):
  290. cprint("EXEC._copy",nr_from,"to",nr_to)
  291. self.check_cfg(nr_from)
  292. if type(self._last_copy) is None:
  293. cprint("EXEC._copy last nr is None",color="red")
  294. return 0
  295. cprint("------ EXEC._copy", nr_from in self.val_exec , nr_to in self.val_exec)
  296. if nr_from in self.val_exec and nr_to in self.val_exec:
  297. fdata = self.val_exec[nr_from]
  298. tdata = self.val_exec[nr_to]
  299. #cprint(fdata)
  300. flabel = self.label_exec[nr_from]
  301. tlabel = self.label_exec[nr_to]
  302. self.val_exec[nr_to] = copy.deepcopy(fdata)
  303. self.label_exec[nr_to] = flabel
  304. if not overwrite: #default
  305. cprint("overwrite",overwrite)
  306. self.val_exec[nr_from] = copy.deepcopy(tdata)
  307. self.label_exec[nr_from] = tlabel
  308. #self.label_exec[nr_from] = "MOVE"
  309. self.clear_copy()
  310. cprint("EXEC.copy OK",color="green")
  311. return 1
  312. def move(self,nr):
  313. cprint("EXEC.move",self._last_copy,"to",nr)
  314. if nr >= 0:
  315. last = self._last_copy
  316. if MAIN.modes.val("MOVE"):
  317. MAIN.modes.val("MOVE",2)
  318. ok= self.copy(nr,overwrite=0)
  319. if ok and last >= 0:
  320. if MAIN.modes.val("MOVE"):
  321. MAIN.modes.val("MOVE",3)
  322. cprint("EXEC.move OK",color="red")
  323. #self.delete(last)
  324. return ok,nr,last #ok
  325. return 0,nr,last # on error reset move
  326. def delete(self,nr):
  327. cprint("EXEC.delete",nr)
  328. ok=0
  329. if nr in self.val_exec:
  330. self.val_exec[nr] = OrderedDict()
  331. self.label_exec[nr] = "-"
  332. ok = 1
  333. self.check_cfg(nr)
  334. return ok
  335. def rec(self,nr,data,arg=""):
  336. cprint("rec",self,"rec()",len(data),arg)
  337. self.check_cfg(nr)
  338. self._check_cfg(data) #by ref
  339. odata=self.val_exec[nr]
  340. #print("odata",odata)
  341. if "CFG" in odata:
  342. if "BUTTON" in odata["CFG"]:
  343. data["CFG"]["BUTTON"] = odata["CFG"]["BUTTON"]
  344. self.val_exec[nr] = data
  345. return 1