local project = {} local packaged = true local baseRequire = require local require = function(path) for _,v in pairs(project)do for name,b in pairs(v)do if(name==path)then return b() end end end return baseRequire(path); end local getProject = function(subDir) if(subDir~=nil)then return project[subDir] end return project end project['objects'] = {}project['libraries'] = {}project['default'] = {}project['objects']['Animation'] = function(...)local cc=require("utils").getValueFromXML local dc=require("basaltEvent")local _d,ad,bd,cd=math.floor,math.sin,math.cos,math.pi;local dd=function(_ba,aba,bba)return _ba+ (aba-_ba)*bba end local __a=function(_ba)return _ba end;local a_a=function(_ba)return 1 -_ba end local b_a=function(_ba)return _ba*_ba*_ba end local c_a=function(_ba)return a_a(b_a(a_a(_ba)))end local d_a=function(_ba)return dd(b_a(_ba),c_a(_ba),_ba)end;local _aa=function(_ba)return ad((_ba*cd)/2)end local aaa=function(_ba)return a_a(bd(( _ba*cd)/2))end local baa=function(_ba)return- (bd(cd*x)-1)/2 end local caa={linear=__a,lerp=dd,flip=a_a,easeIn=b_a,easeOut=c_a,easeInOut=d_a,easeOutSine=_aa,easeInSine=aaa,easeInOutSine=baa}local daa={} return function(_ba)local aba={}local bba="Animation"local cba;local dba={}local _ca=0;local aca=false;local bca=1;local cca=false local dca=dc()local _da=0;local ada;local bda=false;local cda=false;local dda="easeOut"local __b;local function a_b(_ab)for aab,bab in pairs(_ab)do bab(aba,dba[bca].t,bca)end end local function b_b(_ab)if(bca==1)then _ab:animationStartHandler()end;if(dba[bca]~=nil)then a_b(dba[bca].f) _ca=dba[bca].t end;bca=bca+1 if(dba[bca]==nil)then if(cca)then bca=1;_ca=0 else _ab:animationDoneHandler()return end end;if(dba[bca].t>0)then cba=os.startTimer(dba[bca].t-_ca)else b_b(_ab)end end local function c_b(_ab,aab)for n=1,#dba do if(dba[n].t==_ab)then table.insert(dba[n].f,aab)return end end for n=1,#dba do if(dba[n].t>_ab)then if (dba[n-1]~=nil)then if(dba[n-1].t<_ab)then table.insert(dba,n-1,{t=_ab,f={aab}})return end else table.insert(dba,n,{t=_ab,f={aab}})return end end end if(#dba<=0)then table.insert(dba,1,{t=_ab,f={aab}})return elseif( dba[#dba].t<_ab)then table.insert(dba,{t=_ab,f={aab}})end end local function d_b(_ab,aab,bab,cab,dab,_bb,abb,bbb)local cbb=__b;local dbb,_cb;local acb=""if(cbb.parent~=nil)then acb=cbb.parent:getName()end;acb=acb..cbb:getName() c_b(cab+0.05,function() if (abb~=nil)then if(daa[abb]==nil)then daa[abb]={}end;if(daa[abb][acb]~=nil)then if( daa[abb][acb]~=bbb)then daa[abb][acb]:cancel()end end;daa[abb][acb]=bbb end;dbb,_cb=dab(cbb)end) for n=0.05,bab+0.01,0.05 do c_b(cab+n,function() local bcb=math.floor(caa.lerp(dbb,_ab,caa[dda](n/bab))+0.5) local ccb=math.floor(caa.lerp(_cb,aab,caa[dda](n/bab))+0.5)_bb(cbb,bcb,ccb) if(abb~=nil)then if(n>=bab-0.01)then if(daa[abb][acb]==bbb)then daa[abb][acb]= nil end end end end)end end aba={name=_ba,getType=function(_ab)return bba end,getBaseFrame=function(_ab)if(_ab.parent~=nil)then return _ab.parent:getBaseFrame()end;return _ab end,setMode=function(_ab,aab) dda=aab;return _ab end,generateXMLEventFunction=function(_ab,aab,bab) local cab=function(dab) if(dab:sub(1,1)=="#")then local _bb=_ab:getBaseFrame():getDeepObject(dab:sub(2,dab:len())) if(_bb~=nil)and(_bb.internalObjetCall~=nil)then aab(_ab,function() _bb:internalObjetCall()end)end else aab(_ab,_ab:getBaseFrame():getVariable(dab))end end;if(type(bab)=="string")then cab(bab)elseif(type(bab)=="table")then for dab,_bb in pairs(bab)do cab(_bb)end end;return _ab end,setValuesByXMLData=function(_ab,aab)bda= cc("loop",aab)==true and true or false if( cc("object",aab)~=nil)then local bab=_ab:getBaseFrame():getDeepObject(cc("object",aab))if(bab==nil)then bab=_ab:getBaseFrame():getVariable(cc("object",aab))end if(bab~=nil)then _ab:setObject(bab)end end if(aab["move"]~=nil)then local bab=cc("x",aab["move"]) local cab=cc("y",aab["move"])local dab=cc("duration",aab["move"]) local _bb=cc("time",aab["move"])_ab:move(bab,cab,dab,_bb)end if(aab["size"]~=nil)then local bab=cc("width",aab["size"]) local cab=cc("height",aab["size"])local dab=cc("duration",aab["size"]) local _bb=cc("time",aab["size"])_ab:size(bab,cab,dab,_bb)end if(aab["offset"]~=nil)then local bab=cc("x",aab["offset"]) local cab=cc("y",aab["offset"])local dab=cc("duration",aab["offset"]) local _bb=cc("time",aab["offset"])_ab:offset(bab,cab,dab,_bb)end if(aab["textColor"]~=nil)then local bab=cc("duration",aab["textColor"])local cab=cc("time",aab["textColor"])local dab={} local _bb=aab["textColor"]["color"] if(_bb~=nil)then if(_bb.properties~=nil)then _bb={_bb}end;for abb,bbb in pairs(_bb)do table.insert(dab,colors[bbb:value()])end end;if(bab~=nil)and(#dab>0)then _ab:changeTextColor(bab,cab or 0,table.unpack(dab))end end if(aab["background"]~=nil)then local bab=cc("duration",aab["background"])local cab=cc("time",aab["background"])local dab={} local _bb=aab["background"]["color"] if(_bb~=nil)then if(_bb.properties~=nil)then _bb={_bb}end;for abb,bbb in pairs(_bb)do table.insert(dab,colors[bbb:value()])end end;if(bab~=nil)and(#dab>0)then _ab:changeBackground(bab,cab or 0,table.unpack(dab))end end if(aab["text"]~=nil)then local bab=cc("duration",aab["text"]) local cab=cc("time",aab["text"])local dab={}local _bb=aab["text"]["text"] if(_bb~=nil)then if(_bb.properties~=nil)then _bb={_bb}end;for abb,bbb in pairs(_bb)do table.insert(dab,bbb:value())end end;if(bab~=nil)and(#dab>0)then _ab:changeText(bab,cab or 0,table.unpack(dab))end end;if(cc("onDone",aab)~=nil)then _ab:generateXMLEventFunction(_ab.onDone,cc("onDone",aab))end;if(cc("onStart",aab)~=nil)then _ab:generateXMLEventFunction(_ab.onDone,cc("onStart",aab))end if (cc("autoDestroy",aab)~=nil)then if(cc("autoDestroy",aab))then cda=true end end;dda=cc("mode",aab)or dda if(cc("play",aab)~=nil)then if (cc("play",aab))then _ab:play(bda)end end;return _ab end,getZIndex=function(_ab)return 1 end,getName=function(_ab)return _ab.name end,setObject=function(_ab,aab)__b=aab;return _ab end,move=function(_ab,aab,bab,cab,dab,_bb)__b= _bb or __b d_b(aab,bab,cab,dab or 0,__b.getPosition,__b.setPosition,"position",_ab)return _ab end,offset=function(_ab,aab,bab,cab,dab,_bb)__b= _bb or __b d_b(aab,bab,cab,dab or 0,__b.getOffset,__b.setOffset,"offset",_ab)return _ab end,size=function(_ab,aab,bab,cab,dab,_bb)__b=_bb or __b d_b(aab,bab,cab,dab or 0,__b.getSize,__b.setSize,"size",_ab)return _ab end,changeText=function(_ab,aab,bab,...) local cab={...}bab=bab or 0;__b=obj or __b;for n=1,#cab do c_b(bab+n* (aab/#cab),function() __b.setText(__b,cab[n])end)end;return _ab end,changeBackground=function(_ab,aab,bab,...) local cab={...}bab=bab or 0;__b=obj or __b;for n=1,#cab do c_b(bab+n* (aab/#cab),function() __b.setBackground(__b,cab[n])end)end;return _ab end,changeTextColor=function(_ab,aab,bab,...) local cab={...}bab=bab or 0;__b=obj or __b;for n=1,#cab do c_b(bab+n* (aab/#cab),function() __b.setForeground(__b,cab[n])end)end;return _ab end,add=function(_ab,aab,bab) ada=aab c_b((bab or _da)+ (dba[#dba]~=nil and dba[#dba].t or 0),aab)return _ab end,wait=function(_ab,aab)_da=aab;return _ab end,rep=function(_ab,aab) if( ada~=nil)then for n=1,aab or 1 do c_b((wait or _da)+ (dba[#dba]~=nil and dba[#dba].t or 0),ada)end end;return _ab end,onDone=function(_ab,aab) dca:registerEvent("animation_done",aab)return _ab end,onStart=function(_ab,aab) dca:registerEvent("animation_start",aab)return _ab end,setAutoDestroy=function(_ab,aab) cda=aab~=nil and aab or true;return _ab end,animationDoneHandler=function(_ab) dca:sendEvent("animation_done",_ab)_ab.parent:removeEvent("other_event",_ab)if(cda)then _ab.parent:removeObject(_ab)_ab=nil end end,animationStartHandler=function(_ab) dca:sendEvent("animation_start",_ab)end,clear=function(_ab)dba={}ada=nil;_da=0;bca=1;_ca=0;cca=false;return _ab end,play=function(_ab,aab) _ab:cancel()aca=true;cca=aab and true or false;bca=1;_ca=0 if(dba[bca]~=nil)then if( dba[bca].t>0)then cba=os.startTimer(dba[bca].t)else b_b(_ab)end else _ab:animationDoneHandler()end;_ab.parent:addEvent("other_event",_ab)return _ab end,cancel=function(_ab)if( cba~=nil)then os.cancelTimer(cba)cca=false end aca=false;_ab.parent:removeEvent("other_event",_ab)return _ab end,internalObjetCall=function(_ab) _ab:play(bda)end,eventHandler=function(_ab,aab,bab)if(aca)then if(aab=="timer")and(bab==cba)then if(dba[bca]~=nil)then b_b(_ab)else _ab:animationDoneHandler()end end end end}aba.__index=aba;return aba end end; project['objects']['Button'] = function(...)local _a=require("Object")local aa=require("utils") local ba=aa.getValueFromXML;local ca=require("tHex") return function(da)local _b=_a(da)local ab="Button"local bb="center" local cb="center"_b:setZIndex(5)_b:setValue("Button")_b.width=12 _b.height=3 local db={init=function(_c)_c.bgColor=_c.parent:getTheme("ButtonBG") _c.fgColor=_c.parent:getTheme("ButtonText")end,getType=function(_c)return ab end,setHorizontalAlign=function(_c,ac)bb=ac _c:updateDraw()return _c end,setVerticalAlign=function(_c,ac)cb=ac;_c:updateDraw()return _c end,setText=function(_c,ac) _b:setValue(ac)_c:updateDraw()return _c end,setValuesByXMLData=function(_c,ac) _b.setValuesByXMLData(_c,ac) if(ba("text",ac)~=nil)then _c:setText(ba("text",ac))end;if(ba("horizontalAlign",ac)~=nil)then bb=ba("horizontalAlign",ac)end;if(ba("verticalAlign",ac)~=nil)then cb=ba("verticalAlign",ac)end;return _c end,draw=function(_c) if (_b.draw(_c))then if(_c.parent~=nil)then local ac,bc=_c:getAnchorPosition() local cc,dc=_c:getSize()local _d=aa.getTextVerticalAlign(dc,cb) for n=1,dc do if(n==_d)then _c.parent:setText(ac,bc+ (n-1),aa.getTextHorizontalAlign(_c:getValue(),cc,bb)) _c.parent:setFG(ac,bc+ (n-1),aa.getTextHorizontalAlign(ca[_c.fgColor]:rep(_c:getValue():len()),cc,bb))end end end end end}return setmetatable(db,_b)end end; project['objects']['Checkbox'] = function(...)local d=require("Object")local _a=require("utils") local aa=_a.getValueFromXML return function(ba)local ca=d(ba)local da="Checkbox"ca:setZIndex(5)ca:setValue(false) ca.width=1;ca.height=1;local _b="\42" local ab={getType=function(bb)return da end,setSymbol=function(bb,cb)_b=cb;bb:updateDraw()return bb end,mouseHandler=function(bb,cb,db,_c) if (ca.mouseHandler(bb,cb,db,_c))then if(cb==1)then if (bb:getValue()~=true)and(bb:getValue()~=false)then bb:setValue(false)else bb:setValue(not bb:getValue())end bb:updateDraw()return true end end;return false end,touchHandler=function(bb,cb,db)return bb:mouseHandler(1,cb,db)end,setValuesByXMLData=function(bb,cb) ca.setValuesByXMLData(bb,cb) if(aa("checked",cb)~=nil)then if(aa("checked",cb))then bb:setValue(true)else bb:setValue(false)end end;return bb end,draw=function(bb) if (ca.draw(bb))then if(bb.parent~=nil)then local cb,db=bb:getAnchorPosition() local _c,ac=bb:getSize()local bc=_a.getTextVerticalAlign(ac,"center")if (bb.bgColor~=false)then bb.parent:drawBackgroundBox(cb,db,_c,ac,bb.bgColor)end for n=1,ac do if(n==bc)then if(bb:getValue()==true)then bb.parent:writeText(cb, db+ (n-1),_a.getTextHorizontalAlign(_b,_c,"center"),bb.bgColor,bb.fgColor)else bb.parent:writeText(cb,db+ (n-1),_a.getTextHorizontalAlign(" ",_c,"center"),bb.bgColor,bb.fgColor)end end end end end end,init=function(bb) ca.init(bb)bb.bgColor=bb.parent:getTheme("CheckboxBG") bb.fgColor=bb.parent:getTheme("CheckboxText")bb.parent:addEvent("mouse_click",bb)end}return setmetatable(ab,ca)end end; project['objects']['Dropdown'] = function(...)local d=require("Object")local _a=require("utils") local aa=require("utils").getValueFromXML return function(ba)local ca=d(ba)local da="Dropdown"ca.width=12;ca.height=1;ca:setZIndex(6) local _b={}local ab;local bb;local cb=true;local db="left"local _c=0;local ac=16;local bc=6;local cc="\16"local dc="\31"local _d=false local ad={getType=function(bd) return da end,setValuesByXMLData=function(bd,cd)ca.setValuesByXMLData(bd,cd) if (aa("selectionBG",cd)~=nil)then ab=colors[aa("selectionBG",cd)]end;if(aa("selectionFG",cd)~=nil)then bb=colors[aa("selectionFG",cd)]end;if(aa("dropdownWidth",cd)~=nil)then ac=aa("dropdownWidth",cd)end;if(aa("dropdownHeight",cd)~=nil)then bc=aa("dropdownHeight",cd)end;if(aa("offset",cd)~=nil)then _c=aa("offset",cd)end if(cd["item"]~=nil)then local dd=cd["item"]if (dd.properties~=nil)then dd={dd}end;for __a,a_a in pairs(dd)do bd:addItem(aa("text",a_a),colors[aa("bg",a_a)],colors[aa("fg",a_a)])end end end,setOffset=function(bd,cd) _c=cd;bd:updateDraw()return bd end,getOffset=function(bd)return _c end,addItem=function(bd,cd,dd,__a,...) table.insert(_b,{text=cd,bgCol= dd or bd.bgColor,fgCol=__a or bd.fgColor,args={...}})bd:updateDraw()return bd end,getAll=function(bd)return _b end,removeItem=function(bd,cd)table.remove(_b,cd)bd:updateDraw()return bd end,getItem=function(bd,cd)return _b[cd]end,getItemIndex=function(bd)local cd=bd:getValue()for dd,__a in pairs(_b)do if(__a==cd)then return dd end end end,clear=function(bd) _b={}bd:setValue({})bd:updateDraw()return bd end,getItemCount=function(bd)return #_b end,editItem=function(bd,cd,dd,__a,a_a,...)table.remove(_b,cd) table.insert(_b,cd,{text=dd,bgCol=__a or bd.bgColor,fgCol= a_a or bd.fgColor,args={...}})bd:updateDraw()return bd end,selectItem=function(bd,cd)bd:setValue( _b[cd]or{})bd:updateDraw()return bd end,setSelectedItem=function(bd,cd,dd,__a)ab= cd or bd.bgColor;bb=dd or bd.fgColor;cb=__a bd:updateDraw()return bd end,setDropdownSize=function(bd,cd,dd)ac,bc=cd,dd bd:updateDraw()return bd end,mouseHandler=function(bd,cd,dd,__a) if(_d)then local a_a,b_a=bd:getAbsolutePosition(bd:getAnchorPosition()) if(cd==1)then if(#_b>0)then for n=1,bc do if(_b[n+_c]~=nil)then if (a_a<=dd)and(a_a+ac>dd)and(b_a+n==__a)then bd:setValue(_b[n+_c])bd:updateDraw() local c_a=bd:getEventSystem():sendEvent("mouse_click",bd,"mouse_click",dir,dd,__a)if(c_a==false)then return c_a end;return true end end end end end end if(ca.mouseHandler(bd,cd,dd,__a))then _d=(not _d)bd:updateDraw()return true else if(_d)then bd:updateDraw()_d=false end;return false end end,mouseUpHandler=function(bd,cd,dd,__a) if (_d)then local a_a,b_a=bd:getAbsolutePosition(bd:getAnchorPosition()) if(cd==1)then if(#_b>0)then for n=1,bc do if(_b[n+_c]~=nil)then if (a_a<=dd)and(a_a+ac>dd)and(b_a+n==__a)then _d=false;bd:updateDraw() local c_a=bd:getEventSystem():sendEvent("mouse_up",bd,"mouse_up",dir,dd,__a)if(c_a==false)then return c_a end;return true end end end end end end end,scrollHandler=function(bd,cd,dd,__a) if (_d)and(bd:isFocused())then _c=_c+cd;if(_c<0)then _c=0 end;if(cd==1)then if(#_b>bc)then if (_c>#_b-bc)then _c=#_b-bc end else _c=math.min(#_b-1,0)end end local a_a=bd:getEventSystem():sendEvent("mouse_scroll",bd,"mouse_scroll",cd,dd,__a)if(a_a==false)then return a_a end;bd:updateDraw()return true end end,draw=function(bd) if (ca.draw(bd))then local cd,dd=bd:getAnchorPosition()local __a,a_a=bd:getSize() if (bd.parent~=nil)then if(bd.bgColor~=false)then bd.parent:drawBackgroundBox(cd,dd,__a,a_a,bd.bgColor)end;local b_a=bd:getValue() local c_a=_a.getTextHorizontalAlign(( b_a~=nil and b_a.text or""),__a,db):sub(1, __a-1).. (_d and dc or cc) bd.parent:writeText(cd,dd,c_a,bd.bgColor,bd.fgColor) if(_d)then for n=1,bc do if(_b[n+_c]~=nil)then if(_b[n+_c]==b_a)then if(cb)then bd.parent:writeText(cd,dd+n,_a.getTextHorizontalAlign(_b[n+ _c].text,ac,db),ab,bb)else bd.parent:writeText(cd,dd+n,_a.getTextHorizontalAlign(_b[n+_c].text,ac,db),_b[n+ _c].bgCol,_b[n+_c].fgCol)end else bd.parent:writeText(cd,dd+n,_a.getTextHorizontalAlign(_b[n+_c].text,ac,db),_b[n+ _c].bgCol,_b[n+_c].fgCol)end end end end end end end,init=function(bd) bd.bgColor=bd.parent:getTheme("DropdownBG")bd.fgColor=bd.parent:getTheme("DropdownText") ab=bd.parent:getTheme("SelectionBG")bb=bd.parent:getTheme("SelectionText")if(bd.parent~=nil)then bd.parent:addEvent("mouse_click",bd)bd.parent:addEvent("mouse_up",bd) bd.parent:addEvent("mouse_scroll",bd)end end}return setmetatable(ad,ca)end end; project['objects']['Graphic'] = function(...)local da=require("Object")local _b=require("geometricPoints") local ab=require("tHex")local bb=require("utils").getValueFromXML local cb,db,_c,ac=string.sub,string.len,math.max,math.min return function(bc)local cc=da(bc)local dc="Graphic"cc:setZIndex(2)local _d={}local ad={}local bd={} local cd=false;local dd,__a=0,0;local a_a=false;local b_a,c_a;local d_a,_aa=40,15;local aaa=false;local baa={}for n=1,16 do baa[string.byte("0123456789abcdef",n,n)]= 2 ^ (n-1)end local function caa(dba)local _ca={}for i=1, #dba do _ca[i]=dba:sub(i,i)end;return _ca end local function daa(dba,_ca,aca,bca,cca) if(_ca>=1)and(_ca<=bca)then if(dba+db(cca)>0)and(dba<=aca)then local dca=ad[_ca]local _da;local ada=dba+#cca-1 if(dba<1)then cca=cb(cca,1 -dba+1,aca-dba+1)elseif(ada>aca)then cca=cb(cca,1,aca-dba+1)end if(dba>1)then _da=cb(dca,1,dba-1)..cca else _da=cca end;if ada ad[y]:len())then ad[y]=ad[y].. (ab[cc.bgColor]):rep(dba-ad[y]:len())else ad[y]=ad[y]:sub(1,dba)end else ad[y]=(ab[cc.bgColor]):rep(dba)end end end;_ba() local function aba() local function dba(b_b,c_b)local d_b={}for x=1,c_b:len()do d_b[x]=baa[string.byte(c_b,x,x)]or 0 end;table.insert(b_b,d_b)end function parseImage(b_b)if type(b_b)~="string"then error("bad argument #1 (expected string, got "..type(b_b)..")")end;local c_b={}for d_b in (b_b.."\n"):gmatch("(.-)\n")do dba(c_b,d_b)end;return c_b end;local _ca=""for y=1,#ad do if(y==#ad)then _ca=_ca..ad[y]else _ca=_ca..ad[y].."\n"end end;local aca=parseImage(_ca) local bca={[0]={8,4,3,6,5},{4,14,8,7},{6,10,8,7},{9,11,8,0},{1,14,8,0},{13,12,8,0},{2,10,8,0},{15,8,10,11,12,14},{0,7,1,9,2,13},{3,11,8,7},{2,6,7,15},{9,3,7,15},{13,5,7,15},{5,12,8,7},{1,4,7,15},{7,10,11,12,14}}local cca,dca,_da={},{},{}for i=0,15 do dca[2 ^i]=i end do local b_b="0123456789abcdef" for i=1,16 do cca[b_b:sub(i,i)]= i-1;cca[i-1]=b_b:sub(i,i) _da[b_b:sub(i,i)]=2 ^ (i-1)_da[2 ^ (i-1)]=b_b:sub(i,i)local c_b=bca[i-1]for i=1,#c_b do c_b[i]=2 ^c_b[i]end end end local function ada(b_b)local c_b=bca[dca[b_b[#b_b][1] ] ] for j=1,#c_b do local d_b=c_b[j]for i=1, #b_b-1 do if b_b[i][1]==d_b then return i end end end;return 1 end local function bda(b_b,c_b) if not c_b then local _ab={}c_b={}for i=1,6 do local aab=b_b[i]local bab=c_b[aab] c_b[aab],_ab[i]=bab and(bab+1)or 1,aab end;b_b=_ab end;local d_b={}for _ab,aab in pairs(c_b)do d_b[#d_b+1]={_ab,aab}end if# d_b>1 then while#d_b>2 do table.sort(d_b,function(_bb,abb)return _bb[2]>abb[2]end)local aab,bab=ada(d_b),#d_b;local cab,dab=d_b[bab][1],d_b[aab][1]for i=1,6 do if b_b[i]== cab then b_b[i]=dab;d_b[aab][2]=d_b[aab][2]+1 end end;d_b[bab]=nil end;local _ab=128;for i=1,#b_b-1 do if b_b[i]~=b_b[6]then _ab=_ab+2 ^ (i-1)end end;return string.char(_ab),_da[d_b[1][1]==b_b[6]and d_b[2][1]or d_b[1][1] ], _da[b_b[6] ]else return"\128",_da[b_b[1] ],_da[b_b[1] ]end end local cda,dda,__b,a_b={{},{},{}},0,#aca+#aca%3,cc.bgColor or colors.black for i=1,#aca do if#aca[i]>dda then dda=#aca[i]end end for y=0,__b-1,3 do local b_b,c_b,d_b,_ab={},{},{},1 for x=0,dda-1,2 do local aab,bab={},{} for yy=1,3 do for xx=1,2 do aab[#aab+1]= (aca[y+yy]and aca[y+yy][ x+xx])and(aca[y+yy][x+xx]==0 and a_b or aca[y+yy][ x+xx])or a_b;bab[aab[#aab] ]= bab[aab[#aab] ]and(bab[aab[#aab] ]+1)or 1 end end;b_b[_ab],c_b[_ab],d_b[_ab]=bda(aab,bab)_ab=_ab+1 end cda[1][#cda[1]+1],cda[2][#cda[2]+1],cda[3][#cda[3]+1]=table.concat(b_b),table.concat(c_b),table.concat(d_b)end;cda.width,cda.height=#cda[1][1],#cda[1]bd=cda end local function bba()local dba,_ca=d_a,_aa;if(cd)then dba=dba*2;_ca=_ca*3 end;for aca,bca in pairs(_d)do for cca,dca in pairs(bca[1])do daa(dca.x,dca.y,dba,_ca,bca[2])end end;if(cd)then aba()end end local cba={init=function(dba)dba.bgColor=dba.parent:getTheme("GraphicBG")end,getType=function(dba)return dc end,setSize=function(dba,_ca,aca,bca)cc.setSize(dba,_ca,aca,bca)if not(aaa)then d_a=_ca _aa=aca;_ba()end;bba()return dba end,setOffset=function(dba,_ca,aca)dd= _ca or dd;__a=aca or __a;return dba end,setCanvasSize=function(dba,_ca,aca) d_a,_aa=_ca,aca;aaa=true;_ba()return dba end,clearCanvas=function(dba)_d={}ad={}_ba()end,getOffset=function(dba)return dd,__a end,setValuesByXMLData=function(dba,_ca)cc.setValuesByXMLData(dba,_ca) if( bb("text",_ca)~=nil)then dba:setText(bb("text",_ca))end;if(bb("xOffset",_ca)~=nil)then dba:setOffset(bb("xOffset",_ca),__a)end;if(bb("yOffset",_ca)~=nil)then dba:setOffset(dd,bb("yOffset",_ca))end;if(bb("wCanvas",_ca)~=nil)then d_a=bb("wCanvas",_ca)end;if(bb("hCanvas",_ca)~=nil)then _aa=bb("hCanvas",_ca)end;if(bb("shrink",_ca)~=nil)then if(bb("shrink",_ca))then dba:shrink()end end if (bb("dragable",_ca)~=nil)then if(bb("dragable",_ca))then a_a=true end end if(_ca["ellipse"]~=nil)then local aca=_ca["ellipse"]if(aca.properties~=nil)then aca={aca}end for bca,cca in pairs(aca)do local dca=colors[bb("color",cca)] local _da=bb("radius",cca)local ada=bb("radius2",cca)local bda=bb("x",cca)local cda=bb("y",cca) local dda=bb("filled",cca)dba:addEllipse(dca,_da,ada,bda,cda,dda)end end if(_ca["circle"]~=nil)then local aca=_ca["circle"]if(aca.properties~=nil)then aca={aca}end for bca,cca in pairs(aca)do local dca=colors[bb("color",cca)] local _da=tonumber(bb("radius",cca))local ada=tonumber(bb("x",cca)) local bda=tonumber(bb("y",cca))local cda=bb("filled",cca) dba:addCircle(dca,_da,ada,bda,cda)end end if(_ca["line"]~=nil)then local aca=_ca["line"] if(aca.properties~=nil)then aca={aca}end for bca,cca in pairs(aca)do local dca=colors[bb("color",cca)] local _da=tonumber(bb("x",cca))local ada=tonumber(bb("x2",cca)) local bda=tonumber(bb("y",cca))local cda=tonumber(bb("y2",cca)) dba:addLine(dca,_da,bda,ada,cda)end end if(_ca["rectangle"]~=nil)then local aca=_ca["rectangle"]if (aca.properties~=nil)then aca={aca}end for bca,cca in pairs(aca)do local dca=colors[bb("color",cca)]local _da=tonumber(bb("x",cca)) local ada=tonumber(bb("x2",cca))local bda=tonumber(bb("y",cca)) local cda=tonumber(bb("y2",cca)) local dda=bb("filled",cca)=="true"and true or false;dba:addRectangle(dca,_da,bda,ada,cda,dda)end end if(_ca["triangle"]~=nil)then local aca=_ca["triangle"]if(aca.properties~=nil)then aca={aca}end for bca,cca in pairs(aca)do local dca=colors[bb("color",cca)] local _da=tonumber(bb("x",cca))local ada=tonumber(bb("x2",cca)) local bda=tonumber(bb("x2",cca))local cda=tonumber(bb("y",cca)) local dda=tonumber(bb("y2",cca))local __b=tonumber(bb("y3",cca))local a_b=bb("filled",cca) dba:addTriangle(dca,_da,cda,ada,dda,bda,__b,a_b)end end;return dba end,addCircle=function(dba,_ca,aca,bca,cca,dca) local _da=ab[_ca] table.insert(_d,{_b.circle(bca or 1,cca or 1,aca,dca),ab[_ca]})bba()return dba end,addEllipse=function(dba,_ca,aca,bca,cca,dca,_da) table.insert(_d,{_b.ellipse( cca or 1,dca or 1,aca,bca,_da),ab[_ca]})bba()return dba end,addLine=function(dba,_ca,aca,bca,cca,dca) table.insert(_d,{_b.line( aca or 1,bca or 1,cca or 1,dca or 1),ab[_ca]})bba()return dba end,addTriangle=function(dba,_ca,aca,bca,cca,dca,_da,ada,bda) table.insert(_d,{_b.triangle( aca or 1,bca or 1,cca or 1,dca or 1,_da or 1,ada or 1,bda),ab[_ca]})bba()return dba end,addRectangle=function(dba,_ca,aca,bca,cca,dca,_da) table.insert(_d,{_b.rectangle( aca or 1,bca or 1,cca or 1,dca or 1,_da),ab[_ca]})bba()return dba end,shrink=function(dba) cd=true;_ba()aba()return dba end,setDragable=function(dba,_ca) a_a=_ca==true and true or false;return dba end,mouseHandler=function(dba,_ca,aca,bca,cca) if(cc.mouseHandler(dba,_ca,aca,bca,cca))then if (a_a)then if(_ca=="mouse_click")then b_a,c_a=bca,cca end if(_ca=="mouse_drag")then if (b_a~=nil)and(c_a~=nil)then dd=_c(ac(dd+b_a-bca,d_a-dba:getWidth()),0)b_a=bca __a=_c(ac(__a+c_a-cca,_aa-dba:getHeight()),0)c_a=cca end end end;return true end;return false end,draw=function(dba) if (cc.draw(dba))then if(dba.parent~=nil)then local _ca,aca=dba:getAnchorPosition() local bca,cca=dba:getSize()if(dba.bgColor~=false)then dba.parent:drawBackgroundBox(_ca,aca,bca,cca,dba.bgColor)end if(cd)then local dca,_da,ada=bd[1],bd[2],bd[3] for i=1,bd.height do local bda,cda=_ca+dd,aca+i-1 +__a if (cda>aca-1)and(cda<=aca+cca-1)and(bda<=bca+_ca)then local dda=dca[i]local __b,a_b,b_b=_c(bda,_ca),_c(1 -bda+1,1),ac( bca- (bda-_ca),bca) if type(dda)=="string"then dba.parent:setText(__b,cda,cb(dda,a_b,b_b)) dba.parent:setFG(__b,cda,cb(_da[i],a_b,b_b)) dba.parent:setBG(__b,cda,cb(ada[i],a_b,b_b))elseif type(dda)=="table"then dba.parent:setText(__b,cda,cb(dda[2],a_b,b_b)) dba.parent:setFG(__b,cda,cb(_da[i],a_b,b_b)) dba.parent:setBG(__b,cda,cb(ada[i],a_b,b_b))end end end else for i=1,#ad do local dca,_da=_ca+dd,aca+i-1 +__a if (_da>aca-1)and(_da<=aca+cca-1)and(dca<=bca+_ca)then local ada,bda,cda=_c(dca,_ca),_c(1 -dca+1,1),ac(bca- (dca-_ca),bca) dba.parent:setBG(ada,_da,cb(ad[i],bda,cda))end end end end;dba:setVisualChanged(false)end end}return setmetatable(cba,cc)end end; project['objects']['Image'] = function(...)local c=require("Object") local d=require("utils").getValueFromXML return function(_a)local aa=c(_a)local ba="Image"aa:setZIndex(2)local ca;local da;local _b=false local function ab() local cb={[0]={8,4,3,6,5},{4,14,8,7},{6,10,8,7},{9,11,8,0},{1,14,8,0},{13,12,8,0},{2,10,8,0},{15,8,10,11,12,14},{0,7,1,9,2,13},{3,11,8,7},{2,6,7,15},{9,3,7,15},{13,5,7,15},{5,12,8,7},{1,4,7,15},{7,10,11,12,14}}local db,_c,ac={},{},{}for i=0,15 do _c[2 ^i]=i end do local cd="0123456789abcdef" for i=1,16 do db[cd:sub(i,i)]= i-1;db[i-1]=cd:sub(i,i) ac[cd:sub(i,i)]=2 ^ (i-1)ac[2 ^ (i-1)]=cd:sub(i,i)local dd=cb[i-1]for i=1,#dd do dd[i]=2 ^dd[i]end end end local function bc(cd)local dd=cb[_c[cd[#cd][1] ] ] for j=1,#dd do local __a=dd[j]for i=1,#cd-1 do if cd[i][1]==__a then return i end end end;return 1 end local function cc(cd,dd) if not dd then local a_a={}dd={}for i=1,6 do local b_a=cd[i]local c_a=dd[b_a] dd[b_a],a_a[i]=c_a and(c_a+1)or 1,b_a end;cd=a_a end;local __a={}for a_a,b_a in pairs(dd)do __a[#__a+1]={a_a,b_a}end if #__a>1 then while#__a>2 do table.sort(__a,function(aaa,baa)return aaa[2]>baa[2]end)local b_a,c_a=bc(__a),#__a;local d_a,_aa=__a[c_a][1],__a[b_a][1]for i=1,6 do if cd[i]==d_a then cd[i]=_aa;__a[b_a][2]=__a[b_a][2]+1 end end;__a[c_a]=nil end;local a_a=128 for i=1,#cd-1 do if cd[i]~=cd[6]then a_a=a_a+2 ^ (i-1)end end return string.char(a_a),ac[__a[1][1]==cd[6]and __a[2][1]or __a[1][1] ],ac[cd[6] ]else return"\128",ac[cd[1] ],ac[cd[1] ]end end local dc,_d,ad,bd={{},{},{}},0,#ca+#ca%3,aa.bgColor or colors.black;for i=1,#ca do if#ca[i]>_d then _d=#ca[i]end end for y=0,ad-1,3 do local cd,dd,__a,a_a={},{},{},1 for x=0,_d-1,2 do local b_a,c_a={},{} for yy=1,3 do for xx=1,2 do b_a[#b_a+1]=(ca[y+yy]and ca[y+yy][x+xx])and (ca[y+ yy][x+xx]==0 and bd or ca[y+yy][x+xx])or bd;c_a[b_a[#b_a] ]= c_a[b_a[#b_a] ]and(c_a[b_a[#b_a] ]+1)or 1 end end;cd[a_a],dd[a_a],__a[a_a]=cc(b_a,c_a)a_a=a_a+1 end dc[1][#dc[1]+1],dc[2][#dc[2]+1],dc[3][#dc[3]+1]=table.concat(cd),table.concat(dd),table.concat(__a)end;dc.width,dc.height=#dc[1][1],#dc[1]da=dc end local bb={init=function(cb)cb.bgColor=cb.parent:getTheme("ImageBG")end,getType=function(cb)return ba end,loadImage=function(cb,db)ca=paintutils.loadImage(db)_b=false cb:updateDraw()return cb end,shrink=function(cb)ab()_b=true cb:updateDraw()return cb end,setValuesByXMLData=function(cb,db)aa.setValuesByXMLData(cb,db) if( d("shrink",db)~=nil)then if(d("shrink",db))then cb:shrink()end end if(d("path",db)~=nil)then cb:loadImage(d("path",db))end;return cb end,draw=function(cb) if (aa.draw(cb))then if(cb.parent~=nil)then if(ca~=nil)then local db,_c=cb:getAnchorPosition() local ac,bc=cb:getSize() if(_b)then local cc,dc,_d=da[1],da[2],da[3] for i=1,da.height do local ad=cc[i] if type(ad)=="string"then cb.parent:setText(db, _c+i-1,ad) cb.parent:setFG(db,_c+i-1,dc[i])cb.parent:setBG(db,_c+i-1,_d[i])elseif type(ad)=="table"then cb.parent:setText(db,_c+i-1,ad[2])cb.parent:setFG(db,_c+ i-1,dc[i]) cb.parent:setBG(db,_c+i-1,_d[i])end end else for yPos=1,math.min(#ca,bc)do local cc=ca[yPos] for xPos=1,math.min(#cc,ac)do if cc[xPos]>0 then cb.parent:drawBackgroundBox( db+xPos-1,_c+yPos-1,1,1,cc[xPos])end end end end end end end end}return setmetatable(bb,aa)end end; project['objects']['Input'] = function(...)local _a=require("Object")local aa=require("utils") local ba=require("basaltLogs")local ca=aa.getValueFromXML return function(da)local _b=_a(da)local ab="Input"local bb="text"local cb=0 _b:setZIndex(5)_b:setValue("")_b.width=10;_b.height=1;local db=1;local _c=1;local ac=""local bc;local cc local dc=ac;local _d=false local ad={getType=function(bd)return ab end,setInputType=function(bd,cd)if(cd=="password")or(cd=="number")or (cd=="text")then bb=cd end bd:updateDraw()return bd end,setDefaultText=function(bd,cd,dd,__a)ac=cd bc=__a or bc;cc=dd or cc;if(bd:isFocused())then dc=""else dc=ac end bd:updateDraw()return bd end,getInputType=function(bd)return bb end,setValue=function(bd,cd) _b.setValue(bd,tostring(cd)) if not(_d)then if(bd:isFocused())then db=tostring(cd):len()+1;_c=math.max(1, db-bd:getWidth()+1) local dd,__a=bd:getAnchorPosition() bd.parent:setCursor(true,dd+db-_c,__a+math.floor(bd.height/2),bd.fgColor)end end;bd:updateDraw()return bd end,getValue=function(bd) local cd=_b.getValue(bd)return bb=="number"and tonumber(cd)or cd end,setInputLimit=function(bd,cd)cb= tonumber(cd)or cb;bd:updateDraw()return bd end,getInputLimit=function(bd)return cb end,setValuesByXMLData=function(bd,cd)_b.setValuesByXMLData(bd,cd)local dd,__a;if( ca("defaultBG",cd)~=nil)then dd=ca("defaultBG",cd)end;if( ca("defaultFG",cd)~=nil)then __a=ca("defaultFG",cd)end;if( ca("default",cd)~=nil)then bd:setDefaultText(ca("default",cd),__a~=nil and colors[__a],dd~=nil and colors[dd])end if (ca("limit",cd)~=nil)then bd:setInputLimit(ca("limit",cd))end if(ca("type",cd)~=nil)then bd:setInputType(ca("type",cd))end;return bd end,getFocusHandler=function(bd) _b.getFocusHandler(bd) if(bd.parent~=nil)then local cd,dd=bd:getAnchorPosition()dc=""if(ac~="")then bd:updateDraw()end bd.parent:setCursor(true,cd+db-_c,dd+math.max(math.ceil( bd:getHeight()/2 -1,1)),bd.fgColor)end end,loseFocusHandler=function(bd) _b.loseFocusHandler(bd)if(bd.parent~=nil)then dc=ac;if(ac~="")then bd:updateDraw()end bd.parent:setCursor(false)end end,keyHandler=function(bd,cd) if (_b.keyHandler(bd,cd))then local dd,__a=bd:getSize()_d=true if(cd==keys.backspace)then local _aa=tostring(_b.getValue())if(db>1)then bd:setValue(_aa:sub(1,db-2).._aa:sub(db,_aa:len()))if(db>1)then db=db-1 end if(_c>1)then if(db<_c)then _c=_c-1 end end end end;if(cd==keys.enter)then if(bd.parent~=nil)then end end if(cd== keys.right)then local _aa=tostring(_b.getValue()):len()db=db+1;if(db>_aa)then db=_aa+1 end;if(db<1)then db=1 end;if (db<_c)or(db>=dd+_c)then _c=db-dd+1 end;if(_c<1)then _c=1 end end if(cd==keys.left)then db=db-1;if(db>=1)then if(db<_c)or(db>=dd+_c)then _c=db end end;if(db<1)then db=1 end;if(_c<1)then _c=1 end end;local a_a,b_a=bd:getAnchorPosition() local c_a=tostring(_b.getValue()) local d_a=(db<=c_a:len()and db-1 or c_a:len())- (_c-1)if(d_a>bd.x+dd-1)then d_a=bd.x+dd-1 end;if (bd.parent~=nil)then bd.parent:setCursor(true,a_a+d_a,b_a+math.max(math.ceil(__a/2 -1,1)),bd.fgColor)end;_d=false;return true end;return false end,charHandler=function(bd,cd) if (_b.charHandler(bd,cd))then _d=true;local dd,__a=bd:getSize()local a_a=_b.getValue() if(a_a:len()=dd+_c)then _c=_c+1 end end;local b_a,c_a=bd:getAnchorPosition() local d_a=tostring(_b.getValue()) local _aa=(db<=d_a:len()and db-1 or d_a:len())- (_c-1)local aaa=bd:getX()if(_aa>aaa+dd-1)then _aa=aaa+dd-1 end;if( bd.parent~=nil)then bd.parent:setCursor(true,b_a+_aa,c_a+ math.max(math.ceil(__a/2 -1,1)),bd.fgColor)end;_d=false bd:updateDraw()return true end;return false end,mouseHandler=function(bd,cd,dd,__a) if (_b.mouseHandler(bd,cd,dd,__a))then local a_a,b_a=bd:getAnchorPosition() local c_a,d_a=bd:getAbsolutePosition(a_a,b_a)local _aa,aaa=bd:getSize()db=dd-c_a+_c;local baa=_b.getValue()if(db> baa:len())then db=baa:len()+1 end;if(db<_c)then _c=db-1 if(_c<1)then _c=1 end end bd.parent:setCursor(true,c_a+db-1,d_a+ math.max(math.ceil(aaa/2 -1,1)),bd.fgColor)return true end end,eventHandler=function(bd,cd,dd,__a,a_a,b_a) if (_b.eventHandler(bd,cd,dd,__a,a_a,b_a))then if(cd=="paste")then if(bd:isFocused())then local c_a=_b.getValue() local d_a,_aa=bd:getSize()_d=true if(bb=="number")then local aba=c_a if(dd==".")or(tonumber(dd)~=nil)then bd:setValue(c_a:sub(1, db-1)..dd..c_a:sub(db,c_a:len()))db=db+dd:len()end if(tonumber(_b.getValue())==nil)then bd:setValue(aba)end else bd:setValue(c_a:sub(1,db-1)..dd..c_a:sub(db,c_a:len()))db=db+dd:len()end;if(db>=d_a+_c)then _c=(db+1)-d_a end local aaa,baa=bd:getAnchorPosition()local caa=tostring(_b.getValue()) local daa=( db<=caa:len()and db-1 or caa:len())- (_c-1)local _ba=bd:getX() if(daa>_ba+d_a-1)then daa=_ba+d_a-1 end;if(bd.parent~=nil)then bd.parent:setCursor(true,aaa+daa,baa+ math.max(math.ceil(_aa/2 -1,1)),bd.fgColor)end bd:updateDraw()_d=false end end end end,draw=function(bd) if (_b.draw(bd))then if(bd.parent~=nil)then local cd,dd=bd:getAnchorPosition() local __a,a_a=bd:getSize()local b_a=aa.getTextVerticalAlign(a_a,"center")if (bd.bgColor~=false)then bd.parent:drawBackgroundBox(cd,dd,__a,a_a,bd.bgColor)end for n=1,a_a do if(n==b_a)then local c_a=tostring(_b.getValue())local d_a=bd.bgColor;local _aa=bd.fgColor;local aaa;if(c_a:len()<=0)then aaa=dc;d_a=bc or d_a;_aa= cc or _aa end;aaa=dc if(c_a~="")then aaa=c_a end;aaa=aaa:sub(_c,__a+_c-1)local baa=__a-aaa:len()if(baa<0)then baa=0 end;if(bb=="password")and(c_a~="")then aaa=string.rep("*",aaa:len())end aaa=aaa..string.rep(bd.bgSymbol,baa)bd.parent:writeText(cd,dd+ (n-1),aaa,d_a,_aa)end end;if(bd:isFocused())then bd.parent:setCursor(true,cd+db-_c,dd+math.max(math.ceil( bd:getHeight()/2 -1,1)),bd.fgColor)end end end end,init=function(bd) bd.bgColor=bd.parent:getTheme("InputBG")bd.fgColor=bd.parent:getTheme("InputText") if (bd.parent~=nil)then bd.parent:addEvent("mouse_click",bd) bd.parent:addEvent("key",bd)bd.parent:addEvent("char",bd) bd.parent:addEvent("other_event",bd)end end}return setmetatable(ad,_b)end end; project['objects']['Label'] = function(...)local ba=require("Object")local ca=require("utils") local da=ca.getValueFromXML;local _b=ca.createText;local ab=require("tHex")local bb=require("bigfont") return function(cb) local db=ba(cb)local _c="Label"db:setZIndex(3)local ac=true;db:setValue("Label") db.width=5;local bc="left"local cc="top"local dc=0;local _d,ad=false,false local bd={getType=function(cd)return _c end,setText=function(cd,dd) dd=tostring(dd)db:setValue(dd)if(ac)then cd.width=dd:len()end cd:updateDraw()return cd end,setBackground=function(cd,dd) db.setBackground(cd,dd)ad=true;cd:updateDraw()return cd end,setForeground=function(cd,dd) db.setForeground(cd,dd)_d=true;cd:updateDraw()return cd end,setTextAlign=function(cd,dd,__a) bc=dd or bc;cc=__a or cc;cd:updateDraw()return cd end,setFontSize=function(cd,dd)if( dd>0)and(dd<=4)then dc=dd-1 or 0 end cd:updateDraw()return cd end,getFontSize=function(cd)return dc+1 end,setValuesByXMLData=function(cd,dd) db.setValuesByXMLData(cd,dd) if(da("text",dd)~=nil)then cd:setText(da("text",dd))end if(da("verticalAlign",dd)~=nil)then cc=da("verticalAlign",dd)end;if(da("horizontalAlign",dd)~=nil)then bc=da("horizontalAlign",dd)end;if(da("font",dd)~=nil)then cd:setFontSize(da("font",dd))end;return cd end,setSize=function(cd,dd,__a,a_a) db.setSize(cd,dd,__a,a_a)ac=false;cd:updateDraw()return cd end,draw=function(cd) if (db.draw(cd))then if(cd.parent~=nil)then local dd,__a=cd:getAnchorPosition() local a_a,b_a=cd:getSize()local c_a=ca.getTextVerticalAlign(b_a,cc) if(dc==0)then if not(ac)then local d_a=_b(cd:getValue(),cd:getWidth())for _aa,aaa in pairs(d_a)do cd.parent:writeText(dd,__a+_aa-1,aaa,cd.bgColor,cd.fgColor)end else cd.parent:writeText(dd,__a,cd:getValue(),cd.bgColor,cd.fgColor)end else local d_a=bb(dc,cd:getValue(),cd.fgColor,cd.bgColor or colors.lightGray) if(ac)then cd:setSize(#d_a[1][1],#d_a[1]-1)end;local _aa,aaa=cd.parent:getSize() local baa,caa=#d_a[1][1],#d_a[1] dd=dd or math.floor((_aa-baa)/2)+1 __a=__a or math.floor((aaa-caa)/2)+1 for i=1,caa do cd.parent:setFG(dd,__a+i-2,d_a[2][i])cd.parent:setBG(dd, __a+i-2,d_a[3][i])cd.parent:setText(dd, __a+i-2,d_a[1][i])end end end end end,init=function(cd) if (db.init(cd))then cd.bgColor=cd.parent:getTheme("LabelBG") cd.fgColor=cd.parent:getTheme("LabelText") if (cd.parent.bgColor==colors.black)and(cd.fgColor==colors.black)then cd.fgColor=colors.lightGray end end end}return setmetatable(bd,db)end end; project['objects']['List'] = function(...)local d=require("Object")local _a=require("utils") local aa=_a.getValueFromXML return function(ba)local ca=d(ba)local da="List"ca.width=16;ca.height=6;ca:setZIndex(5)local _b={} local ab;local bb;local cb=true;local db="left"local _c=0;local ac=true local bc={getType=function(cc)return da end,addItem=function(cc,dc,_d,ad,...) table.insert(_b,{text=dc,bgCol=_d or cc.bgColor,fgCol= ad or cc.fgColor,args={...}})if(#_b==1)then cc:setValue(_b[1])end cc:updateDraw()return cc end,setOffset=function(cc,dc) _c=dc;cc:updateDraw()return cc end,getOffset=function(cc)return _c end,removeItem=function(cc,dc) table.remove(_b,dc)cc:updateDraw()return cc end,getItem=function(cc,dc)return _b[dc]end,getAll=function(cc)return _b end,getItemIndex=function(cc)local dc=cc:getValue() for _d,ad in pairs(_b)do if(ad==dc)then return _d end end end,clear=function(cc)_b={}cc:setValue({}) cc:updateDraw()return cc end,getItemCount=function(cc)return#_b end,editItem=function(cc,dc,_d,ad,bd,...) table.remove(_b,dc) table.insert(_b,dc,{text=_d,bgCol=ad or cc.bgColor,fgCol=bd or cc.fgColor,args={...}})cc:updateDraw()return cc end,selectItem=function(cc,dc)cc:setValue( _b[dc]or{})cc:updateDraw()return cc end,setSelectedItem=function(cc,dc,_d,ad)ab= dc or cc.bgColor;bb=_d or cc.fgColor cb=ad~=nil and ad or true;cc:updateDraw()return cc end,setScrollable=function(cc,dc) ac=dc;if(dc==nil)then ac=true end;cc:updateDraw()return cc end,setValuesByXMLData=function(cc,dc) ca.setValuesByXMLData(cc,dc)if(aa("selectionBG",dc)~=nil)then ab=colors[aa("selectionBG",dc)]end;if(aa("selectionFG",dc)~=nil)then bb=colors[aa("selectionFG",dc)]end;if(aa("scrollable",dc)~=nil)then if (aa("scrollable",dc))then cc:setScrollable(true)else cc:setScrollable(false)end end;if (aa("offset",dc)~=nil)then _c=aa("offset",dc)end if(dc["item"]~=nil)then local _d=dc["item"]if(_d.properties~=nil)then _d={_d}end;for ad,bd in pairs(_d)do cc:addItem(aa("text",bd),colors[aa("bg",bd)],colors[aa("fg",bd)])end end;return cc end,scrollHandler=function(cc,dc,_d,ad) if (ca.scrollHandler(cc,dc,_d,ad))then if(ac)then local bd,cd=cc:getSize()_c=_c+dc;if(_c<0)then _c=0 end;if(dc>=1)then if(#_b>cd)then if (_c>#_b-cd)then _c=#_b-cd end;if(_c>=#_b)then _c=#_b-1 end else _c=_c-1 end end cc:updateDraw()end;return true end;return false end,mouseHandler=function(cc,dc,_d,ad) if (ca.mouseHandler(cc,dc,_d,ad))then local bd,cd=cc:getAbsolutePosition(cc:getAnchorPosition())local dd,__a=cc:getSize() if(#_b>0)then for n=1,__a do if(_b[n+_c]~=nil)then if (bd<=_d)and(bd+dd>_d)and(cd+n-1 ==ad)then cc:setValue(_b[n+_c]) cc:updateDraw()end end end end;return true end;return false end,dragHandler=function(cc,dc,_d,ad)return cc:mouseHandler(dc,_d,ad)end,touchHandler=function(cc,dc,_d) return cc:mouseHandler(1,dc,_d)end,draw=function(cc) if(ca.draw(cc))then if(cc.parent~=nil)then local dc,_d=cc:getAnchorPosition()local ad,bd=cc:getSize()if(cc.bgColor~=false)then cc.parent:drawBackgroundBox(dc,_d,ad,bd,cc.bgColor)end for n=1,bd do if(_b[n+_c]~=nil)then if(_b[n+_c]== cc:getValue())then if(cb)then cc.parent:writeText(dc,_d+n-1,_a.getTextHorizontalAlign(_b[n+_c].text,ad,db),ab,bb)else cc.parent:writeText(dc,_d+n-1,_a.getTextHorizontalAlign(_b[n+_c].text,ad,db),_b[ n+_c].bgCol,_b[n+_c].fgCol)end else cc.parent:writeText(dc,_d+n-1,_a.getTextHorizontalAlign(_b[n+_c].text,ad,db),_b[ n+_c].bgCol,_b[n+_c].fgCol)end end end end end end,init=function(cc) cc.bgColor=cc.parent:getTheme("ListBG")cc.fgColor=cc.parent:getTheme("ListText") ab=cc.parent:getTheme("SelectionBG")bb=cc.parent:getTheme("SelectionText") cc.parent:addEvent("mouse_click",cc)cc.parent:addEvent("mouse_drag",cc) cc.parent:addEvent("mouse_scroll",cc)end}return setmetatable(bc,ca)end end; project['objects']['Menubar'] = function(...)local _a=require("Object")local aa=require("utils") local ba=aa.getValueFromXML;local ca=require("tHex") return function(da)local _b=_a(da)local ab="Menubar"local bb={}_b.width=30 _b.height=1;_b:setZIndex(5)local cb={}local db;local _c;local ac=true;local bc="left"local cc=0;local dc=1 local _d=false local function ad()local bd=0;local cd=0;local dd=bb:getWidth() for n=1,#cb do if(cd+cb[n].text:len()+ dc*2 >dd)then if(cddd)then cc=dd end;bd:updateDraw() return bd end,getOffset=function(bd)return cc end,setScrollable=function(bd,cd) _d=cd;if(cd==nil)then _d=true end;return bd end,setValuesByXMLData=function(bd,cd) _b.setValuesByXMLData(bd,cd)if(ba("selectionBG",cd)~=nil)then db=colors[ba("selectionBG",cd)]end;if(ba("selectionFG",cd)~=nil)then _c=colors[ba("selectionFG",cd)]end;if(ba("scrollable",cd)~=nil)then if (ba("scrollable",cd))then bd:setScrollable(true)else bd:setScrollable(false)end end if (ba("offset",cd)~=nil)then bd:setOffset(ba("offset",cd))end;if(ba("space",cd)~=nil)then dc=ba("space",cd)end if( cd["item"]~=nil)then local dd=cd["item"]if(dd.properties~=nil)then dd={dd}end;for __a,a_a in pairs(dd)do bd:addItem(ba("text",a_a),colors[ba("bg",a_a)],colors[ba("fg",a_a)])end end;return bd end,removeItem=function(bd,cd) table.remove(cb,cd)bd:updateDraw()return bd end,getItem=function(bd,cd)return cb[cd]end,getItemCount=function(bd)return #cb end,editItem=function(bd,cd,dd,__a,a_a,...)table.remove(cb,cd) table.insert(cb,cd,{text=dd,bgCol=__a or bd.bgColor,fgCol= a_a or bd.fgColor,args={...}})bd:updateDraw()return bd end,selectItem=function(bd,cd)bd:setValue( cb[cd]or{})bd:updateDraw()return bd end,setSelectedItem=function(bd,cd,dd,__a)db= cd or bd.bgColor;_c=dd or bd.fgColor;ac=__a bd:updateDraw()return bd end,mouseHandler=function(bd,cd,dd,__a) if (_b.mouseHandler(bd,cd,dd,__a))then local a_a,b_a=bd:getAbsolutePosition(bd:getAnchorPosition())local c_a,d_a=bd:getSize()local _aa=0 for n=1,#cb do if(cb[n]~=nil)then if (a_a+_aa<=dd+cc)and(a_a+_aa+ cb[n].text:len()+ (dc*2)>dd+cc)and(b_a==__a)then bd:setValue(cb[n]) bd:getEventSystem():sendEvent(event,bd,event,0,dd,__a,cb[n])end;_aa=_aa+cb[n].text:len()+dc*2 end end;bd:updateDraw()return true end;return false end,scrollHandler=function(bd,cd,dd,__a) if (_b.scrollHandler(bd,cd,dd,__a))then if(_d)then cc=cc+cd;if(cc<0)then cc=0 end;local a_a=ad()if(cc>a_a)then cc=a_a end bd:updateDraw()end;return true end;return false end,draw=function(bd) if (_b.draw(bd))then if(bd.parent~=nil)then local cd,dd=bd:getAnchorPosition() local __a,a_a=bd:getSize()if(bd.bgColor~=false)then bd.parent:drawBackgroundBox(cd,dd,__a,a_a,bd.bgColor)end;local b_a=""local c_a=""local d_a="" for _aa,aaa in pairs(cb)do local baa= (" "):rep(dc)..aaa.text.. (" "):rep(dc)b_a=b_a..baa if(aaa==bd:getValue())then c_a=c_a.. ca[db or aaa.bgCol or bd.bgColor]:rep(baa:len())d_a=d_a.. ca[_c or aaa.FgCol or bd.fgColor]:rep(baa:len())else c_a=c_a.. ca[aaa.bgCol or bd.bgColor]:rep(baa:len())d_a=d_a.. ca[aaa.FgCol or bd.fgColor]:rep(baa:len())end end bd.parent:setText(cd,dd,b_a:sub(cc+1,__a+cc)) bd.parent:setBG(cd,dd,c_a:sub(cc+1,__a+cc)) bd.parent:setFG(cd,dd,d_a:sub(cc+1,__a+cc))end end end,init=function(bd) bd.bgColor=bd.parent:getTheme("MenubarBG")bd.fgColor=bd.parent:getTheme("MenubarText") db=bd.parent:getTheme("SelectionBG")_c=bd.parent:getTheme("SelectionText") bd.parent:addEvent("mouse_click",bd)bd.parent:addEvent("mouse_scroll",bd)end}return setmetatable(bb,_b)end end; project['objects']['Pane'] = function(...)local c=require("Object")local d=require("basaltLogs") return function(_a)local aa=c(_a) local ba="Pane" local ca={getType=function(da)return ba end,setBackground=function(da,_b,ab,bb)aa.setBackground(da,_b,ab,bb)return da end,init=function(da)if (aa.init(da))then da.bgColor=da.parent:getTheme("PaneBG") da.fgColor=da.parent:getTheme("PaneBG")end end}return setmetatable(ca,aa)end end; project['objects']['Program'] = function(...)local ba=require("Object")local ca=require("tHex") local da=require("process")local _b=require("utils").getValueFromXML local ab=require("basaltLogs")local bb=string.sub return function(cb,db)local _c=ba(cb)local ac="Program"_c:setZIndex(5)local bc;local cc local function dc(b_a,c_a,d_a,_aa,aaa) local baa,caa=1,1;local daa,_ba=colors.black,colors.white;local aba=false;local bba=false;local cba={}local dba={} local _ca={}local aca={}local bca;local cca={}for i=0,15 do local aab=2 ^i aca[aab]={db:getBasaltInstance().getBaseTerm().getPaletteColour(aab)}end;local function dca() bca=(" "):rep(d_a) for n=0,15 do local aab=2 ^n;local bab=ca[aab]cca[aab]=bab:rep(d_a)end end local function _da()dca()local aab=bca local bab=cca[colors.white]local cab=cca[colors.black] for n=1,_aa do cba[n]=bb(cba[n]==nil and aab or cba[n]..aab:sub(1, d_a-cba[n]:len()),1,d_a) _ca[n]=bb(_ca[n]==nil and bab or _ca[n].. bab:sub(1,d_a-_ca[n]:len()),1,d_a) dba[n]=bb(dba[n]==nil and cab or dba[n].. cab:sub(1,d_a-dba[n]:len()),1,d_a)end;_c.updateDraw(_c)end;_da()local function ada()if baa>=1 and caa>=1 and baa<=d_a and caa<=_aa then else end end local function bda(aab,bab,cab) local dab=baa;local _bb=dab+#aab-1 if caa>=1 and caa<=_aa then if dab<=d_a and _bb>=1 then if dab==1 and _bb== d_a then cba[caa]=aab;_ca[caa]=bab;dba[caa]=cab else local abb,bbb,cbb if dab<1 then local _db= 1 -dab+1;local adb=d_a-dab+1;abb=bb(aab,_db,adb) bbb=bb(bab,_db,adb)cbb=bb(cab,_db,adb)elseif _bb>d_a then local _db=d_a-dab+1;abb=bb(aab,1,_db) bbb=bb(bab,1,_db)cbb=bb(cab,1,_db)else abb=aab;bbb=bab;cbb=cab end;local dbb=cba[caa]local _cb=_ca[caa]local acb=dba[caa]local bcb,ccb,dcb if dab>1 then local _db=dab-1;bcb= bb(dbb,1,_db)..abb;ccb=bb(_cb,1,_db)..bbb dcb=bb(acb,1,_db)..cbb else bcb=abb;ccb=bbb;dcb=cbb end if _bb=1 and _bb<=_aa then cba[newY]=cba[_bb]dba[newY]=dba[_bb]_ca[newY]=_ca[_bb]else cba[newY]=bab _ca[newY]=cab;dba[newY]=dab end end end;if(bba)then ada()end end,isColor=function()return db:getBasaltInstance().getBaseTerm().isColor()end,isColour=function()return db:getBasaltInstance().getBaseTerm().isColor()end,write=function(aab) aab=tostring(aab)if(bba)then bda(aab,ca[_ba]:rep(aab:len()),ca[daa]:rep(aab:len()))end end,clearLine=function() if (bba)then cda(1,caa,(" "):rep(d_a)) dda(1,caa,ca[daa]:rep(d_a))__b(1,caa,ca[_ba]:rep(d_a))end;if(bba)then ada()end end,clear=function() for n=1,_aa do cda(1,n,(" "):rep(d_a)) dda(1,n,ca[daa]:rep(d_a))__b(1,n,ca[_ba]:rep(d_a))end;if(bba)then ada()end end,blit=function(aab,bab,cab)if type(aab)~="string"then error("bad argument #1 (expected string, got "..type(aab)..")",2)end;if type(bab)~="string"then error( "bad argument #2 (expected string, got "..type(bab)..")",2)end;if type(cab)~="string"then error( "bad argument #3 (expected string, got "..type(cab)..")",2)end if #bab~=#aab or#cab~=#aab then error("Arguments must be the same length",2)end;if(bba)then bda(aab,bab,cab)end end}return _ab end;_c.width=30;_c.height=12;local _d=dc(1,1,_c.width,_c.height)local ad local bd=false;local cd={} local function dd(b_a)local c_a,d_a=_d.getCursorPos() local _aa,aaa=b_a:getAnchorPosition()local baa,caa=b_a:getSize() if(_aa+c_a-1 >=1 and _aa+c_a-1 <=_aa+baa-1 and d_a+aaa-1 >=1 and d_a+aaa-1 <=aaa+caa-1)then b_a.parent:setCursor(_d.getCursorBlink(), _aa+c_a-1,d_a+aaa-1,_d.getTextColor())end end local function __a(b_a,c_a,d_a,_aa,aaa)if(ad==nil)then return false end if not(ad:isDead())then if not(bd)then local baa,caa=b_a:getAbsolutePosition(b_a:getAnchorPosition( nil,nil,true))ad:resume(c_a,d_a,_aa-baa+1,aaa-caa+1) dd(b_a)end end end local function a_a(b_a,c_a,d_a,_aa)if(ad==nil)then return false end if not(ad:isDead())then if not(bd)then if(b_a.draw)then ad:resume(c_a,d_a,_aa)dd(b_a)end end end end bc={getType=function(b_a)return ac end,show=function(b_a)_c.show(b_a) _d.setBackgroundColor(b_a.bgColor)_d.setTextColor(b_a.fgColor) _d.basalt_setVisible(true)return b_a end,hide=function(b_a) _c.hide(b_a)_d.basalt_setVisible(false)return b_a end,setPosition=function(b_a,c_a,d_a,_aa) _c.setPosition(b_a,c_a,d_a,_aa) _d.basalt_reposition(b_a:getAnchorPosition())return b_a end,setValuesByXMLData=function(b_a,c_a) _c.setValuesByXMLData(b_a,c_a)if(_b("path",c_a)~=nil)then cc=_b("path",c_a)end if( _b("execute",c_a)~=nil)then if(_b("execute",c_a))then if(cc~=nil)then b_a:execute(cc)end end end end,getBasaltWindow=function()return _d end,getBasaltProcess=function()return ad end,setSize=function(b_a,c_a,d_a,_aa)_c.setSize(b_a,c_a,d_a,_aa) _d.basalt_resize(b_a:getWidth(),b_a:getHeight())return b_a end,getStatus=function(b_a)if(ad~=nil)then return ad:getStatus()end;return"inactive"end,execute=function(b_a,c_a,...)cc= c_a or cc;ad=da:new(cc,_d,...) _d.setBackgroundColor(colors.black)_d.setTextColor(colors.white)_d.clear() _d.setCursorPos(1,1)_d.setBackgroundColor(b_a.bgColor) _d.setTextColor(b_a.fgColor)_d.basalt_setVisible(true)ad:resume()bd=false if (b_a.parent~=nil)then b_a.parent:addEvent("mouse_click",b_a) b_a.parent:addEvent("mouse_up",b_a)b_a.parent:addEvent("mouse_drag",b_a) b_a.parent:addEvent("mouse_scroll",b_a)b_a.parent:addEvent("key",b_a) b_a.parent:addEvent("key_up",b_a)b_a.parent:addEvent("char",b_a) b_a.parent:addEvent("other_event",b_a)end;return b_a end,stop=function(b_a)if( ad~=nil)then if not(ad:isDead())then ad:resume("terminate")if(ad:isDead())then if( b_a.parent~=nil)then b_a.parent:setCursor(false)end end end end b_a.parent:removeEvents(b_a)return b_a end,pause=function(b_a,c_a)bd= c_a or(not bd) if(ad~=nil)then if not(ad:isDead())then if not(bd)then b_a:injectEvents(cd)cd={}end end end;return b_a end,isPaused=function(b_a)return bd end,injectEvent=function(b_a,c_a,d_a,_aa,aaa,baa,caa) if(ad~=nil)then if not(ad:isDead())then if(bd==false)or(caa)then ad:resume(c_a,d_a,_aa,aaa,baa)else table.insert(cd,{event=c_a,args={d_a,_aa,aaa,baa}})end end end;return b_a end,getQueuedEvents=function(b_a)return cd end,updateQueuedEvents=function(b_a,c_a)cd=c_a or cd;return b_a end,injectEvents=function(b_a,c_a)if(ad~=nil)then if not (ad:isDead())then for d_a,_aa in pairs(c_a)do ad:resume(_aa.event,table.unpack(_aa.args))end end end;return b_a end,mouseHandler=function(b_a,c_a,d_a,_aa) if (_c.mouseHandler(b_a,c_a,d_a,_aa))then __a(b_a,"mouse_click",c_a,d_a,_aa)return true end;return false end,mouseUpHandler=function(b_a,c_a,d_a,_aa) if (_c.mouseUpHandler(b_a,c_a,d_a,_aa))then __a(b_a,"mouse_up",c_a,d_a,_aa)return true end;return false end,scrollHandler=function(b_a,c_a,d_a,_aa) if (_c.scrollHandler(b_a,c_a,d_a,_aa))then __a(b_a,"mouse_scroll",c_a,d_a,_aa)return true end;return false end,dragHandler=function(b_a,c_a,d_a,_aa) if (_c.dragHandler(b_a,c_a,d_a,_aa))then __a(b_a,"mouse_drag",c_a,d_a,_aa)return true end;return false end,keyHandler=function(b_a,c_a,d_a)if (_c.keyHandler(b_a,c_a,d_a))then a_a(b_a,"key",c_a,d_a)return true end;return false end,keyUpHandler=function(b_a,c_a)if (_c.keyUpHandler(b_a,c_a))then a_a(b_a,"key_up",c_a)return true end return false end,charHandler=function(b_a,c_a)if (_c.charHandler(b_a,c_a))then a_a(b_a,"char",c_a)return true end return false end,getFocusHandler=function(b_a) _c.getFocusHandler(b_a) if(ad~=nil)then if not(ad:isDead())then if not(bd)then if(b_a.parent~=nil)then local c_a,d_a=_d.getCursorPos()local _aa,aaa=b_a:getAnchorPosition() if(b_a.parent~=nil)then local baa,caa=b_a:getSize() if (_aa+c_a-1 >=1 and _aa+c_a-1 <=_aa+baa-1 and d_a+aaa-1 >=1 and d_a+aaa-1 <=aaa+caa-1)then b_a.parent:setCursor(_d.getCursorBlink(),_aa+c_a-1,d_a+aaa-1,_d.getTextColor())end end end end end end end,loseFocusHandler=function(b_a) _c.loseFocusHandler(b_a) if(ad~=nil)then if not(ad:isDead())then if(b_a.parent~=nil)then b_a.parent:setCursor(false)end end end end,eventHandler=function(b_a,c_a,d_a,_aa,aaa,baa) if (_c.eventHandler(b_a,c_a,d_a,_aa,aaa,baa))then if(ad==nil)then return end if(c_a=="dynamicValueEvent")then local caa,daa=_d.getSize() local _ba,aba=b_a:getSize() if(caa~=_ba)or(daa~=aba)then _d.basalt_resize(_ba,aba)if not (ad:isDead())then ad:resume("term_resize")end end _d.basalt_reposition(b_a:getAnchorPosition())end if not(ad:isDead())then if not(bd)then if(c_a~="terminate")then ad:resume(c_a,d_a,_aa,aaa,baa)end if(b_a:isFocused())then local caa,daa=b_a:getAnchorPosition()local _ba,aba=_d.getCursorPos() if(b_a.parent~=nil)then local bba,cba=b_a:getSize() if (caa+_ba-1 >=1 and caa+_ba-1 <=caa+bba-1 and aba+daa-1 >=1 and aba+daa-1 <=daa+cba-1)then b_a.parent:setCursor(_d.getCursorBlink(),caa+_ba-1,aba+daa-1,_d.getTextColor())end end;if(c_a=="terminate")then ab(b_a:isFocused())ad:resume(c_a) b_a.parent:setCursor(false)return true end end else table.insert(cd,{event=c_a,args={d_a,_aa,aaa,baa}})end end;return false end end,draw=function(b_a) if (_c.draw(b_a))then if(b_a.parent~=nil)then local c_a,d_a=b_a:getAnchorPosition() local _aa,aaa=b_a:getSize()_d.basalt_reposition(c_a,d_a)_d.basalt_update()end end end,init=function(b_a) b_a.bgColor=b_a.parent:getTheme("ProgramBG")end}return setmetatable(bc,_c)end end; project['objects']['Progressbar'] = function(...)local c=require("Object") local d=require("utils").getValueFromXML return function(_a)local aa=c(_a)local ba="Progressbar"local ca=0;aa:setZIndex(5) aa:setValue(false)aa.width=25;aa.height=1;local da;local _b=""local ab=colors.white;local bb=""local cb=0 local db={init=function(_c) _c.bgColor=_c.parent:getTheme("ProgressbarBG")_c.fgColor=_c.parent:getTheme("ProgressbarText") da=_c.parent:getTheme("ProgressbarActiveBG")end,getType=function(_c)return ba end,setValuesByXMLData=function(_c,ac)aa.setValuesByXMLData(_c,ac)if(d("direction",ac)~= nil)then cb=d("direction",ac)end if( d("progressColor",ac)~=nil)then da=colors[d("progressColor",ac)]end if(d("progressSymbol",ac)~=nil)then _b=d("progressSymbol",ac)end;if(d("backgroundSymbol",ac)~=nil)then bb=d("backgroundSymbol",ac)end if (d("progressSymbolColor",ac)~=nil)then ab=colors[d("progressSymbolColor",ac)]end;if(d("onDone",ac)~=nil)then _c:generateXMLEventFunction(_c.onProgressDone,d("onDone",ac))end;return _c end,setDirection=function(_c,ac) cb=ac;_c:updateDraw()return _c end,setProgressBar=function(_c,ac,bc,cc)da=ac or da _b=bc or _b;ab=cc or ab;_c:updateDraw()return _c end,setBackgroundSymbol=function(_c,ac) bb=ac:sub(1,1)_c:updateDraw()return _c end,setProgress=function(_c,ac)if (ac>=0)and(ac<=100)and(ca~=ac)then ca=ac;_c:setValue(ca)if(ca==100)then _c:progressDoneHandler()end end _c:updateDraw()return _c end,getProgress=function(_c)return ca end,onProgressDone=function(_c,ac)_c:registerEvent("progress_done",ac) return _c end,progressDoneHandler=function(_c) _c:sendEvent("progress_done",_c)end,draw=function(_c) if(aa.draw(_c))then if(_c.parent~=nil)then local ac,bc=_c:getAnchorPosition()local cc,dc=_c:getSize()if(_c.bgColor~=false)then _c.parent:drawBackgroundBox(ac,bc,cc,dc,_c.bgColor)end;if(bb~="")then _c.parent:drawTextBox(ac,bc,cc,dc,bb)end;if(_c.fgColor~=false)then _c.parent:drawForegroundBox(ac,bc,cc,dc,_c.fgColor)end if(cb==1)then _c.parent:drawBackgroundBox(ac,bc,cc,dc/100 *ca,da) _c.parent:drawForegroundBox(ac,bc,cc,dc/100 *ca,ab) _c.parent:drawTextBox(ac,bc,cc,dc/100 *ca,_b)elseif(cb==2)then _c.parent:drawBackgroundBox(ac,bc+math.ceil(dc-dc/100 *ca),cc, dc/100 *ca,da) _c.parent:drawForegroundBox(ac,bc+math.ceil(dc-dc/100 *ca),cc,dc/ 100 *ca,ab) _c.parent:drawTextBox(ac,bc+math.ceil(dc-dc/100 *ca),cc, dc/100 *ca,_b)elseif(cb==3)then _c.parent:drawBackgroundBox(ac+math.ceil(cc-cc/100 *ca),bc, cc/100 *ca,dc,da) _c.parent:drawForegroundBox(ac+math.ceil(cc-cc/100 *ca),bc, cc/100 *ca,dc,ab) _c.parent:drawTextBox(ac+math.ceil(cc-cc/100 *ca),bc,cc/100 * ca,dc,_b)else _c.parent:drawBackgroundBox(ac,bc,cc/100 *ca,dc,da) _c.parent:drawForegroundBox(ac,bc,cc/100 *ca,dc,ab) _c.parent:drawTextBox(ac,bc,cc/100 *ca,dc,_b)end end end end}return setmetatable(db,aa)end end; project['objects']['Radio'] = function(...)local d=require("Object")local _a=require("utils") local aa=_a.getValueFromXML return function(ba)local ca=d(ba)local da="Radio"ca.width=8;ca:setZIndex(5)local _b={}local ab;local bb;local cb local db;local _c;local ac;local bc=true;local cc="\7"local dc="left" local _d={getType=function(ad)return da end,setValuesByXMLData=function(ad,bd) ca.setValuesByXMLData(ad,bd)if(aa("selectionBG",bd)~=nil)then ab=colors[aa("selectionBG",bd)]end;if(aa("selectionFG",bd)~=nil)then bb=colors[aa("selectionFG",bd)]end;if(aa("boxBG",bd)~=nil)then cb=colors[aa("boxBG",bd)]end;if(aa("inactiveBoxBG",bd)~=nil)then _c=colors[aa("inactiveBoxBG",bd)]end;if(aa("inactiveBoxFG",bd)~=nil)then ac=colors[aa("inactiveBoxFG",bd)]end;if(aa("boxFG",bd)~=nil)then db=colors[aa("boxFG",bd)]end;if(aa("symbol",bd)~=nil)then cc=aa("symbol",bd)end if(bd["item"]~=nil)then local cd=bd["item"]if (cd.properties~=nil)then cd={cd}end;for dd,__a in pairs(cd)do ad:addItem(aa("text",__a),aa("x",__a),aa("y",__a),colors[aa("bg",__a)],colors[aa("fg",__a)])end end;return ad end,addItem=function(ad,bd,cd,dd,__a,a_a,...) table.insert(_b,{x= cd or 1,y=dd or 1,text=bd,bgCol=__a or ad.bgColor,fgCol=a_a or ad.fgColor,args={...}})if(#_b==1)then ad:setValue(_b[1])end ad:updateDraw()return ad end,getAll=function(ad)return _b end,removeItem=function(ad,bd)table.remove(_b,bd)ad:updateDraw()return ad end,getItem=function(ad,bd)return _b[bd]end,getItemIndex=function(ad)local bd=ad:getValue()for cd,dd in pairs(_b)do if(dd==bd)then return cd end end end,clear=function(ad) _b={}ad:setValue({})ad:updateDraw()return ad end,getItemCount=function(ad)return #_b end,editItem=function(ad,bd,cd,dd,__a,a_a,b_a,...)table.remove(_b,bd) table.insert(_b,bd,{x=dd or 1,y=__a or 1,text=cd,bgCol=a_a or ad.bgColor,fgCol=b_a or ad.fgColor,args={...}})ad:updateDraw()return ad end,selectItem=function(ad,bd)ad:setValue( _b[bd]or{})ad:updateDraw()return ad end,setActiveSymbol=function(ad,bd) cc=bd:sub(1,1)ad:updateDraw()return ad end,setSelectedItem=function(ad,bd,cd,dd,__a,a_a)ab=bd or ab bb=cd or bb;cb=dd or cb;db=__a or db;bc=a_a~=nil and a_a or true ad:updateDraw()return ad end,mouseHandler=function(ad,bd,cd,dd) if(#_b> 0)then local __a,a_a=ad:getAbsolutePosition(ad:getAnchorPosition()) for b_a,c_a in pairs(_b)do if(__a+c_a.x-1 <=cd)and( __a+c_a.x-1 +c_a.text:len()+1 >=cd)and( a_a+c_a.y-1 ==dd)then ad:setValue(c_a) local d_a=ad:getEventSystem():sendEvent("mouse_click",ad,"mouse_click",bd,cd,dd)if(d_a==false)then return d_a end;if(ad.parent~=nil)then ad.parent:setFocusedObject(ad)end;ad:updateDraw()return true end end end;return false end,draw=function(ad) if( ad.parent~=nil)then local bd,cd=ad:getAnchorPosition() for dd,__a in pairs(_b)do if (__a==ad:getValue())then if(dc=="left")then ad.parent:writeText(__a.x+bd-1,__a.y+cd-1,cc,cb,db) ad.parent:writeText(__a.x+2 +bd-1,__a.y+cd-1,__a.text,ab,bb)end else ad.parent:drawBackgroundBox( __a.x+bd-1,__a.y+cd-1,1,1,_c or ad.bgColor) ad.parent:writeText(__a.x+2 +bd-1,__a.y+cd-1,__a.text,__a.bgCol,__a.fgCol)end end;return true end end,init=function(ad) ad.bgColor=ad.parent:getTheme("MenubarBG")ad.fgColor=ad.parent:getTheme("MenubarFG") ab=ad.parent:getTheme("SelectionBG")bb=ad.parent:getTheme("SelectionText") cb=ad.parent:getTheme("MenubarBG")db=ad.parent:getTheme("MenubarText") ad.parent:addEvent("mouse_click",ad)end}return setmetatable(_d,ca)end end; project['objects']['Scrollbar'] = function(...)local c=require("Object") local d=require("utils").getValueFromXML return function(_a)local aa=c(_a)local ba="Scrollbar"aa.width=1;aa.height=8;aa:setValue(1) aa:setZIndex(2)local ca="vertical"local da=" "local _b;local ab="\127"local bb=aa.height;local cb=1;local db=1 local function _c(bc,cc,dc,_d) local ad,bd=bc:getAbsolutePosition(bc:getAnchorPosition())local cd,dd=bc:getSize() if(ca=="horizontal")then for _index=0,cd do if (ad+_index==dc)and(bd<=_d)and(bd+dd>_d)then cb=math.min(_index+1,cd- (db-1))bc:setValue(bb/cd* (cb))bc:updateDraw()end end end if(ca=="vertical")then for _index=0,dd do if (bd+_index==_d)and(ad<=dc)and(ad+cd>dc)then cb=math.min(_index+1,dd- (db-1)) bc:setValue(bb/dd* (cb))bc:updateDraw()end end end end local ac={getType=function(bc)return ba end,setSymbol=function(bc,cc)da=cc:sub(1,1)bc:updateDraw()return bc end,setValuesByXMLData=function(bc,cc) aa.setValuesByXMLData(bc,cc) if(d("maxValue",cc)~=nil)then bb=d("maxValue",cc)end;if(d("backgroundSymbol",cc)~=nil)then ab=d("backgroundSymbol",cc):sub(1,1)end;if(d("symbol",cc)~=nil)then da=d("symbol",cc):sub(1,1)end;if(d("barType",cc)~=nil)then ca=d("barType",cc):lower()end;if(d("symbolSize",cc)~=nil)then bc:setSymbolSize(d("symbolSize",cc))end;if(d("symbolColor",cc)~=nil)then _b=colors[d("symbolColor",cc)]end;if(d("index",cc)~=nil)then bc:setIndex(d("index",cc))end end,setIndex=function(bc,cc) cb=cc;if(cb<1)then cb=1 end;local dc,_d=bc:getSize() cb=math.min(cb,(ca=="vertical"and _d or dc)- (db-1)) bc:setValue(bb/ (ca=="vertical"and _d or dc)*cb)bc:updateDraw()return bc end,getIndex=function(bc)return cb end,setSymbolSize=function(bc,cc)db=tonumber(cc)or 1;local dc,_d=bc:getSize() if(ca== "vertical")then bc:setValue(cb-1 * (bb/ (_d- (db-1)))- (bb/ (_d- (db-1))))elseif(ca=="horizontal")then bc:setValue(cb-1 * (bb/ (dc- (db-1)))- (bb/ (dc- (db-1))))end;bc:updateDraw()return bc end,setMaxValue=function(bc,cc) bb=cc;bc:updateDraw()return bc end,setBackgroundSymbol=function(bc,cc) ab=string.sub(cc,1,1)bc:updateDraw()return bc end,setSymbolColor=function(bc,cc)_b=cc bc:updateDraw()return bc end,setBarType=function(bc,cc)ca=cc:lower()bc:updateDraw() return bc end,mouseHandler=function(bc,cc,dc,_d)if(aa.mouseHandler(bc,cc,dc,_d))then _c(bc,cc,dc,_d)return true end;return false end,dragHandler=function(bc,cc,dc,_d)if (aa.dragHandler(bc,cc,dc,_d))then _c(bc,cc,dc,_d)return true end;return false end,scrollHandler=function(bc,cc,dc,_d) if (aa.scrollHandler(bc,cc,dc,_d))then local ad,bd=bc:getSize()cb=cb+cc;if(cb<1)then cb=1 end cb=math.min(cb,( ca=="vertical"and bd or ad)- (db-1)) bc:setValue(bb/ (ca=="vertical"and bd or ad)*cb)bc:updateDraw()end end,draw=function(bc) if (aa.draw(bc))then if(bc.parent~=nil)then local cc,dc=bc:getAnchorPosition() local _d,ad=bc:getSize() if(ca=="horizontal")then bc.parent:writeText(cc,dc,ab:rep(cb-1),bc.bgColor,bc.fgColor) bc.parent:writeText(cc+cb-1,dc,da:rep(db),_b,_b) bc.parent:writeText(cc+cb+db-1,dc,ab:rep(_d- (cb+db-1)),bc.bgColor,bc.fgColor)end if(ca=="vertical")then for n=0,ad-1 do if(cb==n+1)then for curIndexOffset=0,math.min(db-1,ad)do bc.parent:writeText(cc,dc+n+curIndexOffset,da,_b,_b)end else if (n+1 cb-1 +db)then bc.parent:writeText(cc,dc+n,ab,bc.bgColor,bc.fgColor)end end end end end end end,init=function(bc) bc.bgColor=bc.parent:getTheme("ScrollbarBG")bc.fgColor=bc.parent:getTheme("ScrollbarText") _b=bc.parent:getTheme("ScrollbarSymbolColor")bc.parent:addEvent("mouse_click",bc) bc.parent:addEvent("mouse_drag",bc)bc.parent:addEvent("mouse_scroll",bc)end}return setmetatable(ac,aa)end end; project['objects']['Slider'] = function(...)local d=require("Object")local _a=require("basaltLogs") local aa=require("utils").getValueFromXML return function(ba)local ca=d(ba)local da="Slider"ca.width=8;ca.height=1;ca:setValue(1) local _b="horizontal"local ab=" "local bb;local cb="\140"local db=ca.width;local _c=1;local ac=1 local function bc(dc,_d,ad,bd) local cd,dd=dc:getAbsolutePosition(dc:getAnchorPosition())local __a,a_a=dc:getSize() if(_b=="horizontal")then for _index=0,__a do if (cd+_index==ad)and(dd<=bd)and(dd+a_a>bd)then _c=math.min(_index+1,__a- (ac-1))dc:setValue(db/__a* (_c))dc:updateDraw()end end end if(_b=="vertical")then for _index=0,a_a do if (dd+_index==bd)and(cd<=ad)and(cd+__a>ad)then _c=math.min(_index+1,a_a- (ac-1)) dc:setValue(db/a_a* (_c))dc:updateDraw()end end end end local cc={getType=function(dc)return da end,setSymbol=function(dc,_d)ab=_d:sub(1,1)dc:updateDraw()return dc end,setValuesByXMLData=function(dc,_d) ca.setValuesByXMLData(dc,_d) if(aa("maxValue",_d)~=nil)then db=aa("maxValue",_d)end;if(aa("backgroundSymbol",_d)~=nil)then cb=aa("backgroundSymbol",_d):sub(1,1)end;if(aa("barType",_d)~=nil)then _b=aa("barType",_d):lower()end;if(aa("symbol",_d)~=nil)then ab=aa("symbol",_d):sub(1,1)end;if(aa("symbolSize",_d)~=nil)then dc:setSymbolSize(aa("symbolSize",_d))end;if(aa("symbolColor",_d)~=nil)then bb=colors[aa("symbolColor",_d)]end;if(aa("index",_d)~=nil)then dc:setIndex(aa("index",_d))end end,setIndex=function(dc,_d) _c=_d;if(_c<1)then _c=1 end;local ad,bd=dc:getSize() _c=math.min(_c,(_b=="vertical"and bd or ad)- (ac-1)) dc:setValue(db/ (_b=="vertical"and bd or ad)*_c)dc:updateDraw()return dc end,getIndex=function(dc)return _c end,setSymbolSize=function(dc,_d)ac=tonumber(_d)or 1 if(_b=="vertical")then dc:setValue(_c-1 * (db/ (h- (ac-1)))- (db/ (h- (ac-1))))elseif(_b=="horizontal")then dc:setValue(_c-1 * (db/ (w- (ac-1)))- (db/ (w- (ac-1))))end;dc:updateDraw()return dc end,setMaxValue=function(dc,_d) db=_d;return dc end,setBackgroundSymbol=function(dc,_d)cb=string.sub(_d,1,1) dc:updateDraw()return dc end,setSymbolColor=function(dc,_d)bb=_d;dc:updateDraw()return dc end,setBarType=function(dc,_d) _b=_d:lower()dc:updateDraw()return dc end,mouseHandler=function(dc,_d,ad,bd)if (ca.mouseHandler(dc,_d,ad,bd))then bc(dc,_d,ad,bd)return true end;return false end,dragHandler=function(dc,_d,ad,bd)if (ca.dragHandler(dc,_d,ad,bd))then bc(dc,_d,ad,bd)return true end;return false end,scrollHandler=function(dc,_d,ad,bd) if (ca.scrollHandler(dc,_d,ad,bd))then local cd,dd=dc:getSize()_c=_c+_d;if(_c<1)then _c=1 end _c=math.min(_c,( _b=="vertical"and dd or cd)- (ac-1)) dc:setValue(db/ (_b=="vertical"and dd or cd)*_c)dc:updateDraw()return true end;return false end,draw=function(dc) if (ca.draw(dc))then if(dc.parent~=nil)then local _d,ad=dc:getAnchorPosition() local bd,cd=dc:getSize() if(_b=="horizontal")then dc.parent:writeText(_d,ad,cb:rep(_c-1),dc.bgColor,dc.fgColor) dc.parent:writeText(_d+_c-1,ad,ab:rep(ac),bb,bb) dc.parent:writeText(_d+_c+ac-1,ad,cb:rep(bd- (_c+ac-1)),dc.bgColor,dc.fgColor)end if(_b=="vertical")then for n=0,cd-1 do if(_c==n+1)then for curIndexOffset=0,math.min(ac-1,cd)do dc.parent:writeText(_d,ad+n+curIndexOffset,ab,bb,bb)end else if (n+1 <_c)or(n+1 >_c-1 +ac)then dc.parent:writeText(_d,ad+n,cb,dc.bgColor,dc.fgColor)end end end end end end end,init=function(dc) dc.bgColor=dc.parent:getTheme("SliderBG")dc.fgColor=dc.parent:getTheme("SliderText") bb=dc.parent:getTheme("SliderSymbolColor")dc.parent:addEvent("mouse_click",dc) dc.parent:addEvent("mouse_drag",dc)dc.parent:addEvent("mouse_scroll",dc)end}return setmetatable(cc,ca)end end; project['objects']['Switch'] = function(...)local c=require("Object") local d=require("utils").getValueFromXML return function(_a)local aa=c(_a)local ba="Switch"aa.width=2;aa.height=1 aa.bgColor=colors.lightGray;aa.fgColor=colors.gray;aa:setValue(false)aa:setZIndex(5) local ca=colors.black;local da=colors.red;local _b=colors.green local ab={getType=function(bb)return ba end,setSymbolColor=function(bb,cb)ca=cb bb:updateDraw()return bb end,setActiveBackground=function(bb,cb)_b=cb;bb:updateDraw()return bb end,setInactiveBackground=function(bb,cb) da=cb;bb:updateDraw()return bb end,setValuesByXMLData=function(bb,cb) aa.setValuesByXMLData(bb,cb)if(d("inactiveBG",cb)~=nil)then da=colors[d("inactiveBG",cb)]end;if(d("activeBG",cb)~=nil)then _b=colors[d("activeBG",cb)]end;if(d("symbolColor",cb)~=nil)then ca=colors[d("symbolColor",cb)]end end,mouseHandler=function(bb,cb,db,_c) if (aa.mouseHandler(bb,cb,db,_c))then local ac,bc=bb:getAbsolutePosition(bb:getAnchorPosition())bb:setValue(not bb:getValue()) bb:updateDraw()return true end end,draw=function(bb) if (aa.draw(bb))then if(bb.parent~=nil)then local cb,db=bb:getAnchorPosition() local _c,ac=bb:getSize() bb.parent:drawBackgroundBox(cb,db,_c,ac,bb.bgColor) if(bb:getValue())then bb.parent:drawBackgroundBox(cb,db,1,ac,_b)bb.parent:drawBackgroundBox(cb+1,db,1,ac,ca)else bb.parent:drawBackgroundBox(cb,db,1,ac,ca)bb.parent:drawBackgroundBox(cb+1,db,1,ac,da)end end end end,init=function(bb) bb.bgColor=bb.parent:getTheme("SwitchBG")bb.fgColor=bb.parent:getTheme("SwitchText") ca=bb.parent:getTheme("SwitchBGSymbol")da=bb.parent:getTheme("SwitchInactive") _b=bb.parent:getTheme("SwitchActive")bb.parent:addEvent("mouse_click",bb)end}return setmetatable(ab,aa)end end; project['objects']['Textfield'] = function(...)local aa=require("Object")local ba=require("tHex") local ca=require("basaltLogs")local da=require("utils").getValueFromXML;local _b=string.rep return function(ab) local bb=aa(ab)local cb="Textfield"local db,_c,ac,bc=1,1,1,1;local cc={""}local dc={""}local _d={""}local ad={}local bd={} bb.width=30;bb.height=12;bb:setZIndex(5) local function cd(b_a,c_a)local d_a={} if(b_a:len()>0)then for _aa in string.gmatch(b_a,c_a)do local aaa,baa=string.find(b_a,_aa) if(aaa~=nil)and(baa~=nil)then table.insert(d_a,aaa)table.insert(d_a,baa) local caa=string.sub(b_a,1,(aaa-1))local daa=string.sub(b_a,baa+1,b_a:len())b_a=caa.. (":"):rep(_aa:len())..daa end end end;return d_a end local function dd(b_a,c_a)c_a=c_a or bc local d_a=ba[b_a.fgColor]:rep(_d[c_a]:len()) local _aa=ba[b_a.bgColor]:rep(dc[c_a]:len()) for aaa,baa in pairs(bd)do local caa=cd(cc[c_a],baa[1]) if(#caa>0)then for x=1,#caa/2 do local daa=x*2 -1;if( baa[2]~=nil)then d_a=d_a:sub(1,caa[daa]-1)..ba[baa[2] ]:rep(caa[daa+1]- (caa[daa]-1)).. d_a:sub(caa[daa+1]+1,d_a:len())end;if (baa[3]~=nil)then _aa=_aa:sub(1,caa[daa]-1).. ba[baa[3] ]:rep(caa[daa+1]- (caa[daa]-1)).._aa:sub(caa[daa+1]+1,_aa:len())end end end end for aaa,baa in pairs(ad)do for caa,daa in pairs(baa)do local _ba=cd(cc[c_a],daa) if(#_ba>0)then for x=1,#_ba/2 do local aba=x*2 -1 d_a=d_a:sub(1, _ba[aba]-1).. ba[aaa]:rep(_ba[aba+1]- (_ba[aba]-1))..d_a:sub(_ba[aba+1]+1,d_a:len())end end end end;_d[c_a]=d_a;dc[c_a]=_aa;b_a:updateDraw()end;local function __a(b_a)for n=1,#cc do dd(b_a,n)end end local a_a={getType=function(b_a)return cb end,setBackground=function(b_a,c_a) bb.setBackground(b_a,c_a)__a(b_a)return b_a end,setForeground=function(b_a,c_a) bb.setForeground(b_a,c_a)__a(b_a)return b_a end,setValuesByXMLData=function(b_a,c_a) bb.setValuesByXMLData(b_a,c_a) if(c_a["lines"]~=nil)then local d_a=c_a["lines"]["line"]if (d_a.properties~=nil)then d_a={d_a}end;for _aa,aaa in pairs(d_a)do b_a:addLine(aaa:value())end end if(c_a["keywords"]~=nil)then for d_a,_aa in pairs(c_a["keywords"])do if(colors[d_a]~=nil)then local aaa=_aa;if(aaa.properties~=nil)then aaa={aaa}end;local baa={} for caa,daa in pairs(aaa)do local _ba=daa["keyword"]if(daa["keyword"].properties~=nil)then _ba={daa["keyword"]}end;for aba,bba in pairs(_ba)do table.insert(baa,bba:value())end end;b_a:addKeywords(colors[d_a],baa)end end end if(c_a["rules"]~=nil)then if(c_a["rules"]["rule"]~=nil)then local d_a=c_a["rules"]["rule"]if(c_a["rules"]["rule"].properties~=nil)then d_a={c_a["rules"]["rule"]}end for _aa,aaa in pairs(d_a)do if(da("pattern",aaa)~=nil)then b_a:addRule(da("pattern",aaa),colors[da("fg",aaa)],colors[da("bg",aaa)])end end end end end,getLines=function(b_a)return cc end,getLine=function(b_a,c_a)return cc[c_a]end,editLine=function(b_a,c_a,d_a) cc[c_a]=d_a or cc[c_a]b_a:updateDraw()return b_a end,clear=function(b_a) cc={""}dc={""}_d={""}db,_c,ac,bc=1,1,1,1;b_a:updateDraw()return b_a end,addLine=function(b_a,c_a,d_a) if( c_a~=nil)then if(#cc==1)and(cc[1]=="")then cc[1]=c_a dc[1]=ba[b_a.bgColor]:rep(c_a:len())_d[1]=ba[b_a.fgColor]:rep(c_a:len()) return b_a end if(d_a~=nil)then table.insert(cc,d_a,c_a) table.insert(dc,d_a,ba[b_a.bgColor]:rep(c_a:len())) table.insert(_d,ba[b_a.fgColor]:rep(c_a:len()))else table.insert(cc,c_a) table.insert(dc,ba[b_a.bgColor]:rep(c_a:len())) table.insert(_d,ba[b_a.fgColor]:rep(c_a:len()))end end;b_a:updateDraw()return b_a end,addKeywords=function(b_a,c_a,d_a)if( ad[c_a]==nil)then ad[c_a]={}end;for _aa,aaa in pairs(d_a)do table.insert(ad[c_a],aaa)end;b_a:updateDraw()return b_a end,addRule=function(b_a,c_a,d_a,_aa) table.insert(bd,{c_a,d_a,_aa})b_a:updateDraw()return b_a end,editRule=function(b_a,c_a,d_a,_aa)for aaa,baa in pairs(bd)do if(baa[1]==c_a)then bd[aaa][2]=d_a;bd[aaa][3]=_aa end end;b_a:updateDraw()return b_a end,removeRule=function(b_a,c_a) for d_a,_aa in pairs(bd)do if(_aa[1]==c_a)then table.remove(bd,d_a)end end;b_a:updateDraw()return b_a end,setKeywords=function(b_a,c_a,d_a) ad[c_a]=d_a;b_a:updateDraw()return b_a end,removeLine=function(b_a,c_a)table.remove(cc,c_a or #cc) if(#cc<=0)then table.insert(cc,"")end;b_a:updateDraw()return b_a end,getTextCursor=function(b_a)return ac,bc end,getFocusHandler=function(b_a)bb.getFocusHandler(b_a) if(b_a.parent~=nil)then local c_a,d_a=b_a:getAnchorPosition()if(b_a.parent~=nil)then b_a.parent:setCursor(true,c_a+ac-_c,d_a+bc-db,b_a.fgColor)end end end,loseFocusHandler=function(b_a) bb.loseFocusHandler(b_a) if(b_a.parent~=nil)then b_a.parent:setCursor(false)end end,keyHandler=function(b_a,c_a) if (bb.keyHandler(b_a,event,c_a))then local d_a,_aa=b_a:getAnchorPosition()local aaa,baa=b_a:getSize() if(c_a== keys.backspace)then if(cc[bc]=="")then if(bc>1)then table.remove(cc,bc) table.remove(_d,bc)table.remove(dc,bc)ac=cc[bc-1]:len()+1;_c= ac-aaa+1;if(_c<1)then _c=1 end;bc=bc-1 end elseif(ac<=1)then if(bc>1)then ac=cc[bc-1]:len()+1;_c=ac-aaa+1 if(_c<1)then _c=1 end;cc[bc-1]=cc[bc-1]..cc[bc] _d[bc-1]=_d[bc-1].._d[bc]dc[bc-1]=dc[bc-1]..dc[bc]table.remove(cc,bc) table.remove(_d,bc)table.remove(dc,bc)bc=bc-1 end else cc[bc]=cc[bc]:sub(1,ac-2)..cc[bc]:sub(ac,cc[bc]:len()) _d[bc]=_d[bc]:sub(1,ac-2).._d[bc]:sub(ac,_d[bc]:len()) dc[bc]=dc[bc]:sub(1,ac-2)..dc[bc]:sub(ac,dc[bc]:len())if(ac>1)then ac=ac-1 end if(_c>1)then if(ac<_c)then _c=_c-1 end end end;if(bccc[bc]:len())then if(cc[bc+1]~=nil)then cc[bc]=cc[bc].. cc[bc+1]table.remove(cc,bc+1) table.remove(dc,bc+1)table.remove(_d,bc+1)end else cc[bc]=cc[bc]:sub(1,ac-1)..cc[bc]:sub(ac+1,cc[bc]:len()) _d[bc]=_d[bc]:sub(1,ac-1).._d[bc]:sub(ac+1,_d[bc]:len()) dc[bc]=dc[bc]:sub(1,ac-1)..dc[bc]:sub(ac+1,dc[bc]:len())end;dd(b_a)end if(c_a==keys.enter)then table.insert(cc,bc+1,cc[bc]:sub(ac,cc[bc]:len())) table.insert(_d,bc+1,_d[bc]:sub(ac,_d[bc]:len())) table.insert(dc,bc+1,dc[bc]:sub(ac,dc[bc]:len()))cc[bc]=cc[bc]:sub(1,ac-1) _d[bc]=_d[bc]:sub(1,ac-1)dc[bc]=dc[bc]:sub(1,ac-1)bc=bc+1;ac=1;_c=1;if(bc-db>=baa)then db=db+1 end;b_a:setValue("")end if(c_a==keys.up)then if(bc>1)then bc=bc-1;if(ac>cc[bc]:len()+1)then ac= cc[bc]:len()+1 end;if(_c>1)then if(ac<_c)then _c=ac-aaa+1;if(_c<1)then _c=1 end end end;if(db>1)then if( bccc[bc]:len()+1)then ac= cc[bc]:len()+1 end;if(_c>1)then if(ac<_c)then _c=ac-aaa+1;if(_c<1)then _c=1 end end end;if(bc>= db+baa)then db=db+1 end end end if(c_a==keys.right)then ac=ac+1;if(bc<#cc)then if(ac>cc[bc]:len()+1)then ac=1 bc=bc+1 end elseif(ac>cc[bc]:len())then ac=cc[bc]:len()+1 end;if(ac<1)then ac=1 end;if (ac<_c)or(ac>=aaa+_c)then _c=ac-aaa+1 end if(_c<1)then _c=1 end end if(c_a==keys.left)then ac=ac-1;if(ac>=1)then if(ac<_c)or(ac>=aaa+_c)then _c=ac end end if(bc>1)then if(ac<1)then bc=bc-1 ac=cc[bc]:len()+1;_c=ac-aaa+1 end end;if(ac<1)then ac=1 end;if(_c<1)then _c=1 end end;local caa= (ac<=cc[bc]:len()and ac-1 or cc[bc]:len())- (_c-1)if(caa> b_a.x+aaa-1)then caa=b_a.x+aaa-1 end;local daa=( bc-db=aaa+_c)then _c=_c+1 end;dd(b_a) b_a:setValue("")local caa= (ac<=cc[bc]:len()and ac-1 or cc[bc]:len())- (_c-1)if(caa> b_a.x+aaa-1)then caa=b_a.x+aaa-1 end;local daa=( bc-dbcaa+d_a- (aaa+1)+_c)and(caacc[bc]:len())then ac=cc[bc]:len()+1 end if(ac<_c)then _c=ac-1;if(_c<1)then _c=1 end end;if(b_a.parent~=nil)then b_a.parent:setCursor(true,caa+ac-_c,daa+bc-db,b_a.fgColor)end;b_a:updateDraw()end end;return true end end,scrollHandler=function(b_a,c_a,d_a,_aa) if (bb.scrollHandler(b_a,c_a,d_a,_aa))then local aaa,baa=b_a:getAbsolutePosition(b_a:getAnchorPosition())local caa,daa=b_a:getAnchorPosition()local _ba,aba=b_a:getSize() db=db+c_a;if(db>#cc- (aba-1))then db=#cc- (aba-1)end if(db<1)then db=1 end if(b_a.parent~=nil)then if (aaa+ac-_c>=aaa and aaa+ac-_c=baa and baa+bc-dbcc[bc]:len())then ac= cc[bc]:len()+1 end if(ac<_c)then _c=ac-1;if(_c<1)then _c=1 end end end;if(b_a.parent~=nil)then b_a.parent:setCursor(true,caa+ac-_c,daa+bc-db,b_a.fgColor)end;return true end end,eventHandler=function(b_a,c_a,d_a,_aa,aaa,baa) if (bb.eventHandler(b_a,c_a,d_a,_aa,aaa,baa))then if(c_a=="paste")then if(b_a:isFocused())then local caa,daa=b_a:getSize() cc[bc]= cc[bc]:sub(1,ac-1)..d_a..cc[bc]:sub(ac,cc[bc]:len()) _d[bc]=_d[bc]:sub(1,ac-1).. ba[b_a.fgColor]:rep(d_a:len()).._d[bc]:sub(ac,_d[bc]:len()) dc[bc]=dc[bc]:sub(1,ac-1).. ba[b_a.bgColor]:rep(d_a:len())..dc[bc]:sub(ac,dc[bc]:len())ac=ac+d_a:len()if(ac>=caa+_c)then _c=(ac+1)-caa end local _ba,aba=b_a:getAnchorPosition() b_a.parent:setCursor(true,_ba+ac-_c,aba+bc-db,b_a.fgColor)dd(b_a)b_a:updateDraw()end end end end,draw=function(b_a) if (bb.draw(b_a))then if(b_a.parent~=nil)then local c_a,d_a=b_a:getAnchorPosition() local _aa,aaa=b_a:getSize() for n=1,aaa do local baa=""local caa=""local daa=""if(cc[n+db-1]~=nil)then baa=cc[n+db-1] daa=_d[n+db-1]caa=dc[n+db-1]end baa=baa:sub(_c,_aa+_c-1)caa=caa:sub(_c,_aa+_c-1) daa=daa:sub(_c,_aa+_c-1)local _ba=_aa-baa:len()if(_ba<0)then _ba=0 end baa=baa.._b(b_a.bgSymbol,_ba)caa=caa.._b(ba[b_a.bgColor],_ba)daa=daa.. _b(ba[b_a.fgColor],_ba) b_a.parent:setText(c_a,d_a+n-1,baa)b_a.parent:setBG(c_a,d_a+n-1,caa)b_a.parent:setFG(c_a, d_a+n-1,daa)end;if(b_a:isFocused())then local baa,caa=b_a:getAnchorPosition() b_a.parent:setCursor(true, baa+ac-_c,caa+bc-db,b_a.fgColor)end end end end,init=function(b_a) b_a.bgColor=b_a.parent:getTheme("TextfieldBG")b_a.fgColor=b_a.parent:getTheme("TextfieldText") b_a.parent:addEvent("mouse_click",b_a)b_a.parent:addEvent("mouse_scroll",b_a) b_a.parent:addEvent("mouse_drag",b_a)b_a.parent:addEvent("key",b_a) b_a.parent:addEvent("char",b_a)b_a.parent:addEvent("other_event",b_a)end}return setmetatable(a_a,bb)end end; project['objects']['Thread'] = function(...)local b=require("utils").getValueFromXML return function(c)local d;local _a="Thread"local aa;local ba local ca=false local da=function(_b,ab) if(ab:sub(1,1)=="#")then local bb=_b:getBaseFrame():getDeepObject(ab:sub(2,ab:len())) if(bb~=nil)and(bb.internalObjetCall~=nil)then return(function() bb:internalObjetCall()end)end else return _b:getBaseFrame():getVariable(ab)end;return _b end d={name=c,getType=function(_b)return _a end,getZIndex=function(_b)return 1 end,getName=function(_b)return _b.name end,getBaseFrame=function(_b)if (_b.parent~=nil)then return _b.parent:getBaseFrame()end return _b end,setValuesByXMLData=function(_b,ab)local bb;if(b("thread",ab)~=nil)then bb=da(_b,b("thread",ab))end if(b("start",ab)~=nil)then if (b("start",ab))and(bb~=nil)then _b:start(bb)end end;return _b end,start=function(_b,ab) if( ab==nil)then error("Function provided to thread is nil")end;aa=ab;ba=coroutine.create(aa)ca=true local bb,cb=coroutine.resume(ba)if not(bb)then if(cb~="Terminated")then error("Thread Error Occurred - "..cb)end end _b.parent:addEvent("other_event",_b)return _b end,getStatus=function(_b,ab)if( ba~=nil)then return coroutine.status(ba)end;return nil end,stop=function(_b,ab) ca=false;_b.parent:removeEvent("other_event",_b)return _b end,eventHandler=function(_b,ab,bb,cb,db) if (ca)then if(coroutine.status(ba)~="dead")then local _c,ac=coroutine.resume(ba,ab,bb,cb,db)if not(_c)then if(ac~="Terminated")then error("Thread Error Occurred - "..ac)end end else ca=false end end end}d.__index=d;return d end end; project['objects']['Timer'] = function(...)local c=require("basaltEvent") local d=require("utils").getValueFromXML return function(_a)local aa="Timer"local ba=0;local ca=0;local da=0;local _b;local ab=c()local bb=false local cb=function(_c,ac,bc) local cc=function(dc) if(dc:sub(1,1)=="#")then local _d=_c:getBaseFrame():getDeepObject(dc:sub(2,dc:len())) if(_d~=nil)and(_d.internalObjetCall~=nil)then ac(_c,function() _d:internalObjetCall()end)end else ac(_c,_c:getBaseFrame():getVariable(dc))end end;if(type(bc)=="string")then cc(bc)elseif(type(bc)=="table")then for dc,_d in pairs(bc)do cc(_d)end end;return _c end local db={name=_a,getType=function(_c)return aa end,setValuesByXMLData=function(_c,ac) if(d("time",ac)~=nil)then ba=d("time",ac)end;if(d("repeat",ac)~=nil)then ca=d("repeat",ac)end if( d("start",ac)~=nil)then if(d("start",ac))then _c:start()end end;if(d("onCall",ac)~=nil)then cb(_c,_c.onCall,d("onCall",ac))end;return _c end,getBaseFrame=function(_c) if( _c.parent~=nil)then return _c.parent:getBaseFrame()end;return _c end,getZIndex=function(_c)return 1 end,getName=function(_c) return _c.name end,setTime=function(_c,ac,bc)ba=ac or 0;ca=bc or 1;return _c end,start=function(_c)if(bb)then os.cancelTimer(_b)end;da=ca;_b=os.startTimer(ba)bb=true _c.parent:addEvent("other_event",_c)return _c end,isActive=function(_c)return bb end,cancel=function(_c)if( _b~=nil)then os.cancelTimer(_b)end;bb=false _c.parent:removeEvent("other_event",_c)return _c end,onCall=function(_c,ac) ab:registerEvent("timed_event",ac)return _c end,eventHandler=function(_c,ac,bc) if ac=="timer"and bc==_b and bb then ab:sendEvent("timed_event",_c) if(da>=1)then da=da-1;if(da>=1)then _b=os.startTimer(ba)end elseif(da==-1)then _b=os.startTimer(ba)end end end}db.__index=db;return db end end; project['libraries']['basaltDraw'] = function(...)local d=require("tHex")local _a,aa=string.sub,string.rep return function(ba) local ca=ba or term.current()local da;local _b,ab=ca.getSize()local bb={}local cb={}local db={}local _c={}local ac={}local bc={}local cc local dc={}local function _d()cc=aa(" ",_b) for n=0,15 do local a_a=2 ^n;local b_a=d[a_a]dc[a_a]=aa(b_a,_b)end end;_d() local function ad()_d()local a_a=cc local b_a=dc[colors.white]local c_a=dc[colors.black] for currentY=1,ab do bb[currentY]=_a( bb[currentY]==nil and a_a or bb[currentY]..a_a:sub(1,_b-bb[currentY]:len()),1,_b) db[currentY]=_a(db[currentY]==nil and b_a or db[currentY]..b_a:sub(1,_b- db[currentY]:len()),1,_b) cb[currentY]=_a(cb[currentY]==nil and c_a or cb[currentY]..c_a:sub(1,_b- cb[currentY]:len()),1,_b)end end;ad() local function bd(a_a,b_a,c_a) if(b_a>=1)and(b_a<=ab)then if (a_a+c_a:len()>0)and(a_a<=_b)then local d_a=bb[b_a]local _aa;local aaa=a_a+#c_a-1 if(a_a<1)then local baa=1 -a_a+1 local caa=_b-a_a+1;c_a=_a(c_a,baa,caa)elseif(aaa>_b)then local baa=_b-a_a+1;c_a=_a(c_a,1,baa)end if(a_a>1)then local baa=a_a-1;_aa=_a(d_a,1,baa)..c_a else _aa=c_a end;if aaa<_b then _aa=_aa.._a(d_a,aaa+1,_b)end bb[b_a]=_aa end end end local function cd(a_a,b_a,c_a) if(b_a>=1)and(b_a<=ab)then if(a_a+c_a:len()>0)and(a_a<=_b)then local d_a=cb[b_a]local _aa;local aaa=a_a+#c_a-1 if(a_a<1)then c_a=_a(c_a,1 -a_a+1,_b-a_a+1)elseif(aaa>_b)then c_a=_a(c_a,1,_b-a_a+1)end if(a_a>1)then _aa=_a(d_a,1,a_a-1)..c_a else _aa=c_a end;if aaa<_b then _aa=_aa.._a(d_a,aaa+1,_b)end cb[b_a]=_aa end end end local function dd(a_a,b_a,c_a) if(b_a>=1)and(b_a<=ab)then if(a_a+c_a:len()>0)and(a_a<=_b)then local d_a=db[b_a]local _aa;local aaa=a_a+#c_a-1 if(a_a<1)then local baa=1 -a_a+1;local caa=_b-a_a+1 c_a=_a(c_a,baa,caa)elseif(aaa>_b)then local baa=_b-a_a+1;c_a=_a(c_a,1,baa)end if(a_a>1)then local baa=a_a-1;_aa=_a(d_a,1,baa)..c_a else _aa=c_a end;if aaa<_b then _aa=_aa.._a(d_a,aaa+1,_b)end db[b_a]=_aa end end end local __a={setSize=function(a_a,b_a)_b,ab=a_a,b_a;ad()end,setMirror=function(a_a)da=a_a end,setBG=function(a_a,b_a,c_a)cd(a_a,b_a,c_a)end,setText=function(a_a,b_a,c_a) bd(a_a,b_a,c_a)end,setFG=function(a_a,b_a,c_a)dd(a_a,b_a,c_a)end,drawBackgroundBox=function(a_a,b_a,c_a,d_a,_aa)for n=1,d_a do cd(a_a,b_a+ (n-1),aa(d[_aa],c_a))end end,drawForegroundBox=function(a_a,b_a,c_a,d_a,_aa) for n=1,d_a do dd(a_a,b_a+ (n-1),aa(d[_aa],c_a))end end,drawTextBox=function(a_a,b_a,c_a,d_a,_aa)for n=1,d_a do bd(a_a,b_a+ (n-1),aa(_aa,c_a))end end,writeText=function(a_a,b_a,c_a,d_a,_aa) if(c_a~=nil)then bd(a_a,b_a,c_a)if(d_a~=nil)and(d_a~=false)then cd(a_a,b_a,aa(d[d_a],c_a:len()))end;if(_aa~=nil)and(_aa~=false)then dd(a_a,b_a,aa(d[_aa],c_a:len()))end end end,update=function() local a_a,b_a=ca.getCursorPos()local c_a=false if(ca.getCursorBlink~=nil)then c_a=ca.getCursorBlink()end;ca.setCursorBlink(false)if(da~=nil)then ca.setCursorBlink(false)end for n=1,ab do ca.setCursorPos(1,n) ca.blit(bb[n],db[n],cb[n])if(da~=nil)then da.setCursorPos(1,n) da.blit(bb[n],db[n],cb[n])end end;ca.setBackgroundColor(colors.black) ca.setCursorBlink(c_a)ca.setCursorPos(a_a,b_a) if(da~=nil)then da.setBackgroundColor(colors.black)da.setCursorBlink(c_a)da.setCursorPos(a_a,b_a)end end,setTerm=function(a_a) ca=a_a end}return __a end end; project['libraries']['basaltEvent'] = function(...) return function()local a={}local b={} local c={registerEvent=function(d,_a,aa)if(a[_a]==nil)then a[_a]={}b[_a]=1 end a[_a][b[_a] ]=aa;b[_a]=b[_a]+1;return b[_a]-1 end,removeEvent=function(d,_a,aa)a[_a][aa[_a] ]= nil end,sendEvent=function(d,_a,...)local aa if(a[_a]~=nil)then for ba,ca in pairs(a[_a])do local da=ca(...)if(da== false)then aa=da end end end;return aa end}c.__index=c;return c end end; project['libraries']['basaltLogs'] = function(...)local _a=""local aa="basaltLog.txt"local ba="Debug" fs.delete(_a~=""and _a.."/"..aa or aa) local ca={__call=function(da,_b,ab)if(_b==nil)then return end local bb=_a~=""and _a.."/"..aa or aa local cb=fs.open(bb,fs.exists(bb)and"a"or"w") cb.writeLine("[Basalt][".. (ab and ab or ba).."]: "..tostring(_b))cb.close()end}return setmetatable({},ca) end; project['libraries']['bigfont'] = function(...)local ba=require("tHex") local ca={{"\32\32\32\137\156\148\158\159\148\135\135\144\159\139\32\136\157\32\159\139\32\32\143\32\32\143\32\32\32\32\32\32\32\32\147\148\150\131\148\32\32\32\151\140\148\151\140\147","\32\32\32\149\132\149\136\156\149\144\32\133\139\159\129\143\159\133\143\159\133\138\32\133\138\32\133\32\32\32\32\32\32\150\150\129\137\156\129\32\32\32\133\131\129\133\131\132","\32\32\32\130\131\32\130\131\32\32\129\32\32\32\32\130\131\32\130\131\32\32\32\32\143\143\143\32\32\32\32\32\32\130\129\32\130\135\32\32\32\32\131\32\32\131\32\131","\139\144\32\32\143\148\135\130\144\149\32\149\150\151\149\158\140\129\32\32\32\135\130\144\135\130\144\32\149\32\32\139\32\159\148\32\32\32\32\159\32\144\32\148\32\147\131\132","\159\135\129\131\143\149\143\138\144\138\32\133\130\149\149\137\155\149\159\143\144\147\130\132\32\149\32\147\130\132\131\159\129\139\151\129\148\32\32\139\131\135\133\32\144\130\151\32","\32\32\32\32\32\32\130\135\32\130\32\129\32\129\129\131\131\32\130\131\129\140\141\132\32\129\32\32\129\32\32\32\32\32\32\32\131\131\129\32\32\32\32\32\32\32\32\32","\32\32\32\32\149\32\159\154\133\133\133\144\152\141\132\133\151\129\136\153\32\32\154\32\159\134\129\130\137\144\159\32\144\32\148\32\32\32\32\32\32\32\32\32\32\32\151\129","\32\32\32\32\133\32\32\32\32\145\145\132\141\140\132\151\129\144\150\146\129\32\32\32\138\144\32\32\159\133\136\131\132\131\151\129\32\144\32\131\131\129\32\144\32\151\129\32","\32\32\32\32\129\32\32\32\32\130\130\32\32\129\32\129\32\129\130\129\129\32\32\32\32\130\129\130\129\32\32\32\32\32\32\32\32\133\32\32\32\32\32\129\32\129\32\32","\150\156\148\136\149\32\134\131\148\134\131\148\159\134\149\136\140\129\152\131\32\135\131\149\150\131\148\150\131\148\32\148\32\32\148\32\32\152\129\143\143\144\130\155\32\134\131\148","\157\129\149\32\149\32\152\131\144\144\131\148\141\140\149\144\32\149\151\131\148\32\150\32\150\131\148\130\156\133\32\144\32\32\144\32\130\155\32\143\143\144\32\152\129\32\134\32","\130\131\32\131\131\129\131\131\129\130\131\32\32\32\129\130\131\32\130\131\32\32\129\32\130\131\32\130\129\32\32\129\32\32\133\32\32\32\129\32\32\32\130\32\32\32\129\32","\150\140\150\137\140\148\136\140\132\150\131\132\151\131\148\136\147\129\136\147\129\150\156\145\138\143\149\130\151\32\32\32\149\138\152\129\149\32\32\157\152\149\157\144\149\150\131\148","\149\143\142\149\32\149\149\32\149\149\32\144\149\32\149\149\32\32\149\32\32\149\32\149\149\32\149\32\149\32\144\32\149\149\130\148\149\32\32\149\32\149\149\130\149\149\32\149","\130\131\129\129\32\129\131\131\32\130\131\32\131\131\32\131\131\129\129\32\32\130\131\32\129\32\129\130\131\32\130\131\32\129\32\129\131\131\129\129\32\129\129\32\129\130\131\32","\136\140\132\150\131\148\136\140\132\153\140\129\131\151\129\149\32\149\149\32\149\149\32\149\137\152\129\137\152\129\131\156\133\149\131\32\150\32\32\130\148\32\152\137\144\32\32\32","\149\32\32\149\159\133\149\32\149\144\32\149\32\149\32\149\32\149\150\151\129\138\155\149\150\130\148\32\149\32\152\129\32\149\32\32\32\150\32\32\149\32\32\32\32\32\32\32","\129\32\32\130\129\129\129\32\129\130\131\32\32\129\32\130\131\32\32\129\32\129\32\129\129\32\129\32\129\32\131\131\129\130\131\32\32\32\129\130\131\32\32\32\32\140\140\132","\32\154\32\159\143\32\149\143\32\159\143\32\159\144\149\159\143\32\159\137\145\159\143\144\149\143\32\32\145\32\32\32\145\149\32\144\32\149\32\143\159\32\143\143\32\159\143\32","\32\32\32\152\140\149\151\32\149\149\32\145\149\130\149\157\140\133\32\149\32\154\143\149\151\32\149\32\149\32\144\32\149\149\153\32\32\149\32\149\133\149\149\32\149\149\32\149","\32\32\32\130\131\129\131\131\32\130\131\32\130\131\129\130\131\129\32\129\32\140\140\129\129\32\129\32\129\32\137\140\129\130\32\129\32\130\32\129\32\129\129\32\129\130\131\32","\144\143\32\159\144\144\144\143\32\159\143\144\159\138\32\144\32\144\144\32\144\144\32\144\144\32\144\144\32\144\143\143\144\32\150\129\32\149\32\130\150\32\134\137\134\134\131\148","\136\143\133\154\141\149\151\32\129\137\140\144\32\149\32\149\32\149\154\159\133\149\148\149\157\153\32\154\143\149\159\134\32\130\148\32\32\149\32\32\151\129\32\32\32\32\134\32","\133\32\32\32\32\133\129\32\32\131\131\32\32\130\32\130\131\129\32\129\32\130\131\129\129\32\129\140\140\129\131\131\129\32\130\129\32\129\32\130\129\32\32\32\32\32\129\32","\32\32\32\32\149\32\32\149\32\32\32\32\32\32\32\32\149\32\32\149\32\32\32\32\32\32\32\32\149\32\32\149\32\32\32\32\32\32\32\32\149\32\32\149\32\32\32\32","\32\32\32\32\32\32\32\32\32\32\32\32\32\149\32\32\149\32\32\149\32\32\149\32\32\149\32\32\149\32\32\149\32\32\149\32\32\32\32\32\32\32\32\32\32\32\32\32","\32\32\32\32\32\32\32\32\32\32\32\32\32\32\32\32\32\32\32\32\32\32\32\32\32\32\32\32\32\32\32\32\32\32\32\32\32\32\32\32\32\32\32\32\32\32\32\32","\32\32\32\32\149\32\32\149\32\32\32\32\32\32\32\32\149\32\32\149\32\32\32\32\32\32\32\32\149\32\32\149\32\32\32\32\32\32\32\32\149\32\32\149\32\32\32\32","\32\32\32\32\32\32\32\32\32\32\32\32\32\149\32\32\149\32\32\149\32\32\149\32\32\149\32\32\149\32\32\149\32\32\149\32\32\32\32\32\32\32\32\32\32\32\32\32","\32\149\32\32\149\32\32\149\32\32\149\32\32\149\32\32\149\32\32\149\32\32\149\32\32\149\32\32\149\32\32\149\32\32\149\32\32\149\32\32\149\32\32\149\32\32\149\32","\32\32\32\32\145\32\159\139\32\151\131\132\155\143\132\134\135\145\32\149\32\158\140\129\130\130\32\152\147\155\157\134\32\32\144\144\32\32\32\32\32\32\152\131\155\131\131\129","\32\32\32\32\149\32\149\32\145\148\131\32\149\32\149\140\157\132\32\148\32\137\155\149\32\32\32\149\154\149\137\142\32\153\153\32\131\131\149\131\131\129\149\135\145\32\32\32","\32\32\32\32\129\32\130\135\32\131\131\129\134\131\132\32\129\32\32\129\32\131\131\32\32\32\32\130\131\129\32\32\32\32\129\129\32\32\32\32\32\32\130\131\129\32\32\32","\150\150\32\32\148\32\134\32\32\132\32\32\134\32\32\144\32\144\150\151\149\32\32\32\32\32\32\145\32\32\152\140\144\144\144\32\133\151\129\133\151\129\132\151\129\32\145\32","\130\129\32\131\151\129\141\32\32\142\32\32\32\32\32\149\32\149\130\149\149\32\143\32\32\32\32\142\132\32\154\143\133\157\153\132\151\150\148\151\158\132\151\150\148\144\130\148","\32\32\32\140\140\132\32\32\32\32\32\32\32\32\32\151\131\32\32\129\129\32\32\32\32\134\32\32\32\32\32\32\32\129\129\32\129\32\129\129\130\129\129\32\129\130\131\32","\156\143\32\159\141\129\153\140\132\153\137\32\157\141\32\159\142\32\150\151\129\150\131\132\140\143\144\143\141\145\137\140\148\141\141\144\157\142\32\159\140\32\151\134\32\157\141\32","\157\140\149\157\140\149\157\140\149\157\140\149\157\140\149\157\140\149\151\151\32\154\143\132\157\140\32\157\140\32\157\140\32\157\140\32\32\149\32\32\149\32\32\149\32\32\149\32","\129\32\129\129\32\129\129\32\129\129\32\129\129\32\129\129\32\129\129\131\129\32\134\32\131\131\129\131\131\129\131\131\129\131\131\129\130\131\32\130\131\32\130\131\32\130\131\32","\151\131\148\152\137\145\155\140\144\152\142\145\153\140\132\153\137\32\154\142\144\155\159\132\150\156\148\147\32\144\144\130\145\136\137\32\146\130\144\144\130\145\130\136\32\151\140\132","\151\32\149\151\155\149\149\32\149\149\32\149\149\32\149\149\32\149\149\32\149\152\137\144\157\129\149\149\32\149\149\32\149\149\32\149\149\32\149\130\150\32\32\157\129\149\32\149","\131\131\32\129\32\129\130\131\32\130\131\32\130\131\32\130\131\32\130\131\32\32\32\32\130\131\32\130\131\32\130\131\32\130\131\32\130\131\32\32\129\32\130\131\32\133\131\32","\156\143\32\159\141\129\153\140\132\153\137\32\157\141\32\159\142\32\159\159\144\152\140\144\156\143\32\159\141\129\153\140\132\157\141\32\130\145\32\32\147\32\136\153\32\130\146\32","\152\140\149\152\140\149\152\140\149\152\140\149\152\140\149\152\140\149\149\157\134\154\143\132\157\140\133\157\140\133\157\140\133\157\140\133\32\149\32\32\149\32\32\149\32\32\149\32","\130\131\129\130\131\129\130\131\129\130\131\129\130\131\129\130\131\129\130\130\131\32\134\32\130\131\129\130\131\129\130\131\129\130\131\129\32\129\32\32\129\32\32\129\32\32\129\32","\159\134\144\137\137\32\156\143\32\159\141\129\153\140\132\153\137\32\157\141\32\32\132\32\159\143\32\147\32\144\144\130\145\136\137\32\146\130\144\144\130\145\130\138\32\146\130\144","\149\32\149\149\32\149\149\32\149\149\32\149\149\32\149\149\32\149\149\32\149\131\147\129\138\134\149\149\32\149\149\32\149\149\32\149\149\32\149\154\143\149\32\157\129\154\143\149","\130\131\32\129\32\129\130\131\32\130\131\32\130\131\32\130\131\32\130\131\32\32\32\32\130\131\32\130\131\129\130\131\129\130\131\129\130\131\129\140\140\129\130\131\32\140\140\129"},{"000110000110110000110010101000000010000000100101","000000110110000000000010101000000010000000100101","000000000000000000000000000000000000000000000000","100010110100000010000110110000010100000100000110","000000110000000010110110000110000000000000110000","000000000000000000000000000000000000000000000000","000000110110000010000000100000100000000000000010","000000000110110100010000000010000000000000000100","000000000000000000000000000000000000000000000000","010000000000100110000000000000000000000110010000","000000000000000000000000000010000000010110000000","000000000000000000000000000000000000000000000000","011110110000000100100010110000000100000000000000","000000000000000000000000000000000000000000000000","000000000000000000000000000000000000000000000000","110000110110000000000000000000010100100010000000","000010000000000000110110000000000100010010000000","000000000000000000000000000000000000000000000000","010110010110100110110110010000000100000110110110","000000000000000000000110000000000110000000000000","000000000000000000000000000000000000000000000000","010100010110110000000000000000110000000010000000","110110000000000000110000110110100000000010000000","000000000000000000000000000000000000000000000000","000100011111000100011111000100011111000100011111","000000000000100100100100011011011011111111111111","000000000000000000000000000000000000000000000000","000100011111000100011111000100011111000100011111","000000000000100100100100011011011011111111111111","100100100100100100100100100100100100100100100100","000000110100110110000010000011110000000000011000","000000000100000000000010000011000110000000001000","000000000000000000000000000000000000000000000000","010000100100000000000000000100000000010010110000","000000000000000000000000000000110110110110110000","000000000000000000000000000000000000000000000000","110110110110110110000000110110110110110110110110","000000000000000000000110000000000000000000000000","000000000000000000000000000000000000000000000000","000000000000110110000110010000000000000000010010","000010000000000000000000000000000000000000000000","000000000000000000000000000000000000000000000000","110110110110110110110000110110110110000000000000","000000000000000000000110000000000000000000000000","000000000000000000000000000000000000000000000000","110110110110110110110000110000000000000000010000","000000000000000000000000100000000000000110000110","000000000000000000000000000000000000000000000000"}}local da={}local _b={} do local cb=0;local db=#ca[1]local _c=#ca[1][1] for i=1,db,3 do for j=1,_c,3 do local ac=string.char(cb)local bc={}bc[1]=ca[1][i]:sub(j,j+2) bc[2]=ca[1][i+1]:sub(j,j+2)bc[3]=ca[1][i+2]:sub(j,j+2)local cc={}cc[1]=ca[2][i]:sub(j, j+2)cc[2]=ca[2][i+1]:sub(j,j+2)cc[3]=ca[2][ i+2]:sub(j,j+2)_b[ac]={bc,cc}cb=cb+1 end end;da[1]=_b end local function ab(cb,db)local _c={["0"]="1",["1"]="0"}if cb<=#da then return true end for f=#da+1,cb do local ac={}local bc=da[ f-1] for char=0,255 do local cc=string.char(char)local dc={}local _d={} local ad=bc[cc][1]local bd=bc[cc][2] for i=1,#ad do local cd,dd,__a,a_a,b_a,c_a={},{},{},{},{},{} for j=1,#ad[1]do local d_a=_b[ad[i]:sub(j,j)][1]table.insert(cd,d_a[1])table.insert(dd,d_a[2]) table.insert(__a,d_a[3])local _aa=_b[ad[i]:sub(j,j)][2] if bd[i]:sub(j,j)=="1"then table.insert(a_a,(_aa[1]:gsub("[01]",_c))) table.insert(b_a,(_aa[2]:gsub("[01]",_c))) table.insert(c_a,(_aa[3]:gsub("[01]",_c)))else table.insert(a_a,_aa[1]) table.insert(b_a,_aa[2])table.insert(c_a,_aa[3])end end;table.insert(dc,table.concat(cd)) table.insert(dc,table.concat(dd))table.insert(dc,table.concat(__a)) table.insert(_d,table.concat(a_a))table.insert(_d,table.concat(b_a)) table.insert(_d,table.concat(c_a))end;ac[cc]={dc,_d}if db then db="Font"..f.."Yeld"..char os.queueEvent(db)os.pullEvent(db)end end;da[f]=ac end;return true end local function bb(cb,db,_c,ac,bc) if not type(db)=="string"then error("Not a String",3)end local cc=type(_c)=="string"and _c:sub(1,1)or ba[_c]or error("Wrong Front Color",3) local dc=type(ac)=="string"and ac:sub(1,1)or ba[ac]or error("Wrong Back Color",3)if(da[cb]==nil)then ab(3,false)end;local _d=da[cb]or error("Wrong font size selected",3)if db==""then return{{""},{""},{""}}end;local ad={} for c_a in db:gmatch('.')do table.insert(ad,c_a)end;local bd={}local cd=#_d[ad[1] ][1] for nLine=1,cd do local c_a={} for i=1,#ad do c_a[i]=_d[ad[i] ]and _d[ad[i] ][1][nLine]or""end;bd[nLine]=table.concat(c_a)end;local dd={}local __a={}local a_a={["0"]=cc,["1"]=dc}local b_a={["0"]=dc,["1"]=cc} for nLine=1,cd do local c_a={}local d_a={} for i=1,#ad do local _aa=_d[ad[i] ]and _d[ad[i] ][2][nLine]or"" c_a[i]=_aa:gsub("[01]", bc and{["0"]=_c:sub(i,i),["1"]=ac:sub(i,i)}or a_a) d_a[i]=_aa:gsub("[01]", bc and{["0"]=ac:sub(i,i),["1"]=_c:sub(i,i)}or b_a)end;dd[nLine]=table.concat(c_a) __a[nLine]=table.concat(d_a)end;return{bd,dd,__a}end;return bb end; project['libraries']['geometricPoints'] = function(...) local function _a(da,_b,ab,bb)local cb={}if da==ab and _b==bb then return{x=da,y=ab}end local db=math.min(da,ab)local _c,ac,bc;if db==da then ac,_c,bc=_b,ab,bb else ac,_c,bc=bb,da,_b end;local cc,dc=_c-db, bc-ac if cc>math.abs(dc)then local _d=ac;local ad=dc/cc;for x=db,_c do table.insert(cb,{x=x,y=math.floor( _d+0.5)}) _d=_d+ad end else local _d,ad=db,cc/dc if bc>=ac then for y=ac,bc do table.insert(cb,{x=math.floor( _d+0.5),y=y})_d=_d+ ad end else for y=ac,bc,-1 do table.insert(cb,{x=math.floor(_d+0.5),y=y})_d=_d-ad end end end;return cb end local function aa(da,_b,ab)local bb={}for x=-ab,ab+1 do local cb=math.floor(math.sqrt(ab*ab-x*x)) for y=-cb,cb+1 do table.insert(bb,{x=da+x,y=_b+y})end end;return bb end local function ba(da,_b,ab,bb,cb)local db,_c=math.ceil(math.floor(ab-0.5)/2),math.ceil( math.floor(bb-0.5)/2)local ac,bc=0,_c local cc=( ( _c*_c)- (db*db*_c)+ (0.25 *db*db))local dc=2 *_c^2 *ac;local _d=2 *db^2 *bc;local ad={} while dc<_d do table.insert(ad,{x=ac+da,y=bc+_b})table.insert(ad,{x=-ac+da,y=bc+_b})table.insert(ad,{x=ac+ da,y=-bc+_b}) table.insert(ad,{x=-ac+da,y=-bc+_b})if cb then for y=-bc+_b+1,bc+_b-1 do table.insert(ad,{x=ac+da,y=y})table.insert(ad,{x= -ac+da,y=y})end end if cc<0 then ac=ac+1 dc=dc+2 *_c^2;cc=cc+dc+_c^2 else ac,bc=ac+1,bc-1;dc=dc+2 *_c^2 _d=_d-2 *db^2;cc=cc+dc-_d+_c^2 end end local bd=( ( (_c*_c)* ( (ac+0.5)* (ac+0.5)))+ ( (db*db)* ( (bc-1)* (bc-1)))- (db*db*_c*_c)) while bc>=0 do table.insert(ad,{x=ac+da,y=bc+_b})table.insert(ad,{x=- ac+da,y=bc+_b}) table.insert(ad,{x=ac+da,y=-bc+_b})table.insert(ad,{x=-ac+da,y=-bc+_b}) if cb then for y=-bc+_b, bc+_b do table.insert(ad,{x=ac+da,y=y}) table.insert(ad,{x=-ac+da,y=y})end end if bd>0 then bc=bc-1;_d=_d-2 *db^2;bd=bd+db^2 -_d else bc=bc-1;ac=ac+1;_d=_d-2 * db^2;dc=dc+2 *_c^2;bd=bd+dc-_d+db^2 end end;return ad end;local function ca(da,_b,ab,bb)return ba(da,_b,ab,ab,bb)end return {circle=function(da,_b,ab,bb) return ca(da,_b,ab,bb)end,rectangle=function(da,_b,ab,bb,cb)local db={} if(cb)then for y=_b,bb do for x=da,ab do table.insert(db,{x=x,y=y})end end else for y=_b,bb do for x=da,ab do if (x==da)or(x==ab)or(y==_b)or(y==bb)then table.insert(db,{x=x,y=y})end end end end;return db end,triangle=function(da,_b,ab,bb,cb,db,_c) local function ac(dc,_d,ad,bd,cd,dd,__a)local a_a=(dd-_d)/ (__a-ad)local b_a=(dd-bd)/ (__a-cd)local c_a=math.ceil( ad-0.5) local d_a=math.ceil(__a-0.5)-1 for y=c_a,d_a do local _aa=a_a* (y+0.5 -ad)+_d local aaa=b_a* (y+0.5 -cd)+bd;local baa=math.ceil(_aa-0.5)local caa=math.ceil(aaa-0.5)for x=baa,caa do table.insert(dc,{x=x,y=y})end end end local function bc(dc,_d,ad,bd,cd,dd,__a)local a_a=(bd-_d)/ (cd-ad)local b_a=(dd-_d)/ (__a-ad) local c_a=math.ceil(ad-0.5)local d_a=math.ceil(__a-0.5)-1 for y=c_a,d_a do local _aa=a_a* (y+0.5 -ad)+_d;local aaa=b_a* (y+0.5 -ad)+_d local baa=math.ceil(_aa-0.5)local caa=math.ceil(aaa-0.5)for x=baa,caa do table.insert(dc,{x=x,y=y})end end end;local cc={} if(_c)then if bb<_b then da,_b,ab,bb=ab,bb,da,_b end;if db",">") _a=string.gsub(_a,"\"",""") _a=string.gsub(_a,"([^%w%&%;%p%\t% ])",function(aa) return string.format("&#x%X;",string.byte(aa))end)return _a end function d:FromXmlString(_a) _a=string.gsub(_a,"&#x([%x]+)%;",function(aa) return string.char(tonumber(aa,16))end) _a=string.gsub(_a,"&#([0-9]+)%;",function(aa)return string.char(tonumber(aa,10))end)_a=string.gsub(_a,""","\"") _a=string.gsub(_a,"'","'")_a=string.gsub(_a,">",">") _a=string.gsub(_a,"<","<")_a=string.gsub(_a,"&","&")return _a end;function d:ParseArgs(_a,aa) string.gsub(aa,"(%w+)=([\"'])(.-)%2",function(ba,ca,da) _a:addProperty(ba,self:FromXmlString(da))end)end function d:ParseXmlText(_a) local aa={}local ba=c()table.insert(aa,ba)local ca,da,_b,ab,bb;local cb,db=1,1 while true do ca,db,da,_b,ab,bb=string.find(_a,"<(%/?)([%w_:]+)(.-)(%/?)>",cb)if not ca then break end;local ac=string.sub(_a,cb,ca-1) if not string.find(ac,"^%s*$")then local bc=(ba:value()or"")..self:FromXmlString(ac)aa[#aa]:setValue(bc)end if bb=="/"then local bc=c(_b)self:ParseArgs(bc,ab)ba:addChild(bc)elseif da==""then local bc=c(_b)self:ParseArgs(bc,ab)table.insert(aa,bc) ba=bc else local bc=table.remove(aa)ba=aa[#aa]if#aa<1 then error("XmlParser: nothing to close with ".._b)end;if bc:name()~=_b then error("XmlParser: trying to close "..bc.name.. " with ".._b)end;ba:addChild(bc)end;cb=db+1 end;local _c=string.sub(_a,cb)if#aa>1 then error("XmlParser: unclosed "..aa[#aa]:name())end;return ba end function d:loadFile(_a,aa)if not aa then aa=system.ResourceDirectory end local ba=system.pathForFile(_a,aa)local ca,da=io.open(ba,"r") if ca and not da then local _b=ca:read("*a") io.close(ca)return self:ParseXmlText(_b),nil else print(da)return nil end end;return d end; project['libraries']['process'] = function(...)local d={}local _a={}local aa=0 function _a:new(ba,ca,...)local da={...} local _b=setmetatable({path=ba},{__index=self})_b.window=ca;_b.processId=aa _b.coroutine=coroutine.create(function() shell.execute(ba,table.unpack(da))end)d[aa]=_b;aa=aa+1;return _b end function _a:resume(ba,...)term.redirect(self.window) if(self.filter~=nil)then if (ba~=self.filter)then return end;self.filter=nil end;local ca,da=coroutine.resume(self.coroutine,ba,...) self.window=term.current()if ca then self.filter=da else error(da)end end function _a:isDead() if(self.coroutine~=nil)then if (coroutine.status(self.coroutine)=="dead")then table.remove(d,self.processId)return true end else return true end;return false end function _a:getStatus()if(self.coroutine~=nil)then return coroutine.status(self.coroutine)end;return nil end function _a:start()coroutine.resume(self.coroutine)end;return _a end; project['libraries']['tHex'] = function(...) return {[colors.white]="0",[colors.orange]="1",[colors.magenta]="2",[colors.lightBlue]="3",[colors.yellow]="4",[colors.lime]="5",[colors.pink]="6",[colors.gray]="7",[colors.lightGray]="8",[colors.cyan]="9",[colors.purple]="a",[colors.blue]="b",[colors.brown]="c",[colors.green]="d",[colors.red]="e",[colors.black]="f"} end; project['libraries']['utils'] = function(...) local b=function(c,d)if d==nil then d="%s"end;local _a={}for aa in string.gmatch(c,"([^"..d.."]+)")do table.insert(_a,aa)end;return _a end return {getTextHorizontalAlign=function(c,d,_a,aa)c=string.sub(c,1,d)local ba=d-string.len(c) if(_a=="right")then c=string.rep( aa or" ",ba)..c elseif(_a=="center")then c=string.rep(aa or" ",math.floor( ba/2))..c.. string.rep(aa or" ",math.floor(ba/2)) c=c.. (string.len(c)baa[x])then table.insert(baa,x,abc)break end else table.insert(baa,abc)end end;if(#baa<=0)then table.insert(baa,abc)end;aaa[abc]={}end;_bc.parent=caa;if(_bc.init~=nil)then _bc:init()end table.insert(aaa[abc],_bc)return _bc end local function bdb(_bc,abc) for bbc,cbc in pairs(daa)do for dbc,_cc in pairs(cbc)do for acc,bcc in pairs(_cc)do if(bcc==abc)then table.remove(daa[bbc][dbc],acc)if(_bc.parent~=nil)then if(ad(daa[event])<=0)then _bc.parent:removeEvent(bbc,_bc)end end end end end end end local function cdb(_bc)for abc,bbc in pairs(aaa)do for cbc,dbc in pairs(bbc)do if(dbc==_bc)then table.remove(aaa[abc],cbc) bdb(caa,_bc)return true end end end return false end;local function ddb(_bc,abc,bbc) for cbc,dbc in pairs(daa[abc])do for _cc,acc in pairs(dbc)do if(acc:getName()==bbc)then return acc end end end end local function __c(_bc,abc,bbc) local cbc=bbc:getZIndex()if(daa[abc]==nil)then daa[abc]={}end;if(_ba[abc]==nil)then _ba[abc]={}end if(ddb(_bc,abc,bbc.name)~=nil)then return nil end if(_bc.parent~=nil)then _bc.parent:addEvent(abc,_bc)end;cab[abc]=true if(daa[abc][cbc]==nil)then for x=1,#_ba[abc]+1 do if (_ba[abc][x]~=nil)then if(cbc==_ba[abc][x])then break end;if(cbc>_ba[abc][x])then table.insert(_ba[abc],x,cbc)break end else table.insert(_ba[abc],cbc)end end if(#_ba[abc]<=0)then table.insert(_ba[abc],cbc)end;daa[abc][cbc]={}end;table.insert(daa[abc][cbc],bbc)return bbc end local function a_c(_bc,abc,bbc) if(daa[abc]~=nil)then for cbc,dbc in pairs(daa[abc])do for _cc,acc in pairs(dbc)do if(acc==bbc)then table.remove(daa[abc][cbc],_cc)if(#daa[abc][cbc]<=0)then daa[abc][cbc]=nil if(_bc.parent~=nil)then if( ad(daa[abc])<=0)then cab[abc]=false _bc.parent:removeEvent(abc,_bc)end end end;return true end end end end;return false end local function b_c(_bc)local abc,bbc=pcall(load("return ".._bc)) if not(abc)then error(_bc.. " is not a valid dynamic code")end;return load("return ".._bc)()end local function c_c(_bc,abc,bbc)for cbc,dbc in pairs(cba)do if(dbc[2]==bbc)and(dbc[4]==abc)then return dbc end end;dba=dba+1 cba[dba]={0,bbc,{},abc,dba}return cba[dba]end local function d_c(_bc,abc)local bbc={}local cbc={}for dbc in abc:gmatch("%a+%.x")do local _cc=dbc:gsub("%.x","") if (_cc~="self")and(_cc~="parent")then table.insert(bbc,_cc)end end for dbc in abc:gmatch("%w+%.y")do local _cc=dbc:gsub("%.y","")if(_cc~="self")and(_cc~="parent")then table.insert(bbc,_cc)end end;for dbc in abc:gmatch("%a+%.w")do local _cc=dbc:gsub("%.w","") if(_cc~="self")and (_cc~="parent")then table.insert(bbc,_cc)end end for dbc in abc:gmatch("%a+%.h")do local _cc=dbc:gsub("%.h","")if(_cc~="self")and(_cc~="parent")then table.insert(bbc,_cc)end end for dbc,_cc in pairs(bbc)do cbc[_cc]=dcb(_cc)if(cbc[_cc]==nil)then error("Dynamic Values - unable to find object ".._cc)end end;cbc["self"]=_bc;cbc["parent"]=_bc:getParent()return cbc end local function _ac(_bc,abc)local bbc=_bc;for cbc in _bc:gmatch("%w+%.x")do bbc=bbc:gsub(cbc,abc[cbc:gsub("%.x","")]:getX())end;for cbc in _bc:gmatch("%w+%.y")do bbc=bbc:gsub(cbc,abc[cbc:gsub("%.y","")]:getY())end;for cbc in _bc:gmatch("%w+%.w")do bbc=bbc:gsub(cbc,abc[cbc:gsub("%.w","")]:getWidth())end;for cbc in _bc:gmatch("%w+%.h")do bbc=bbc:gsub(cbc,abc[cbc:gsub("%.h","")]:getHeight())end;return bbc end local function aac(_bc) if(#cba>0)then for n=1,dba do if(cba[n]~=nil)then local abc;if(#cba[n][3]<=0)then cba[n][3]=d_c(cba[n][4],cba[n][2])end abc=_ac(cba[n][2],cba[n][3])cba[n][1]=b_c(abc)if(cba[n][4]:getType()=="Frame")then cba[n][4]:recalculateDynamicValues()end end end for abc,bbc in pairs(baa)do if(aaa[bbc]~=nil)then for cbc,dbc in pairs(aaa[bbc])do if(dbc.eventHandler~=nil)then dbc:eventHandler("dynamicValueEvent",_bc)end end end end end end;local function bac(_bc)return cba[_bc][1]end local function cac(_bc) for abc,bbc in pairs(aaa)do for cbc,dbc in pairs(bbc)do if (dbc.getHeight~=nil)and(dbc.getY~=nil)then local _cc,acc=dbc:getHeight(),dbc:getY()if(_cc+acc-_bc:getHeight()>bda)then bda=dd(_cc+acc-_bc:getHeight(),0)end end end end end;local function dac(_bc) if(d_b~=c_b)then if(d_b~=nil)then d_b:loseFocusHandler()end;if (c_b~=nil)then c_b:getFocusHandler()end;d_b=c_b end end caa={barActive=false,barBackground=colors.gray,barTextcolor=colors.black,barText="New Frame",barTextAlign="left",addEvent=__c,removeEvent=a_c,removeEvents=bdb,getEvent=ddb,newDynamicValue=c_c,recalculateDynamicValues=aac,getDynamicValue=bac,getType=function(_bc)return _aa end,setFocusedObject=function(_bc,abc)c_b=abc;return _bc end,getVariable=function(_bc,abc) return c_a.getVariable(abc)end,setSize=function(_bc,abc,bbc,cbc)d_a.setSize(_bc,abc,bbc,cbc)if (_bc.parent==nil)then dab=_c(_ca)end for dbc,_cc in pairs(baa)do if(aaa[_cc]~=nil)then for acc,bcc in pairs(aaa[_cc])do if( bcc.eventHandler~=nil)then bcc:eventHandler("basalt_resize",bcc,_bc)end end end end;_bc:recalculateDynamicValues()_ab=false;return _bc end,setTheme=function(_bc,abc,bbc) if( type(abc)=="table")then bba=abc elseif(type(abc)=="string")then bba[abc]=bbc end;_bc:updateDraw()return _bc end,getTheme=function(_bc,abc) return bba[abc]or(_bc.parent~=nil and _bc.parent:getTheme(abc)or c_a.getTheme(abc))end,setPosition=function(_bc,abc,bbc,cbc) d_a.setPosition(_bc,abc,bbc,cbc) for dbc,_cc in pairs(baa)do if(aaa[_cc]~=nil)then for acc,bcc in pairs(aaa[_cc])do if(bcc.eventHandler~=nil)then bcc:eventHandler("basalt_reposition",bcc,_bc)end end end end;_bc:recalculateDynamicValues()return _bc end,getBasaltInstance=function(_bc)return c_a end,setOffset=function(_bc,abc,bbc) dbb=abc~=nil and math.floor(abc<0 and math.abs(abc)or-abc)or dbb _cb=bbc~=nil and math.floor(bbc<0 and math.abs(bbc)or-bbc)or _cb;_bc:updateDraw()return _bc end,getOffsetInternal=function(_bc)return dbb,_cb end,getOffset=function(_bc) return dbb<0 and math.abs(dbb)or-dbb, _cb<0 and math.abs(_cb)or-_cb end,removeFocusedObject=function(_bc)c_b=nil;return _bc end,getFocusedObject=function(_bc) return d_b end,setCursor=function(_bc,abc,bbc,cbc,dbc) if(_bc.parent~=nil)then local _cc,acc=_bc:getAnchorPosition() _bc.parent:setCursor( abc or false,(bbc or 0)+_cc-1,(cbc or 0)+acc-1,dbc or cbb)else local _cc,acc=_bc:getAbsolutePosition(_bc:getAnchorPosition(_bc:getX(),_bc:getY(),true))_bb=abc or false;if(bbc~=nil)then abb=_cc+bbc-1 end;if(cbc~=nil)then bbb=acc+ cbc-1 end;cbb=dbc or cbb;if(_bb)then _ca.setTextColor(cbb)_ca.setCursorPos(abb,bbb)_ca.setCursorBlink(_bb)else _ca.setCursorBlink(false)end end;return _bc end,setMovable=function(_bc,abc) if( _bc.parent~=nil)then a_b=abc or not a_b _bc.parent:addEvent("mouse_click",_bc)cab["mouse_click"]=true _bc.parent:addEvent("mouse_up",_bc)cab["mouse_up"]=true _bc.parent:addEvent("mouse_drag",_bc)cab["mouse_drag"]=true end;return _bc end,setScrollable=function(_bc,abc)ada=( abc or abc==nil)and true or false if( _bc.parent~=nil)then _bc.parent:addEvent("mouse_scroll",_bc)end;cab["mouse_scroll"]=true;return _bc end,setScrollAmount=function(_bc,abc)bda= abc or bda;aab=false;return _bc end,getScrollAmount=function(_bc)return aab and bda or cac(_bc)end,show=function(_bc)d_a.show(_bc) if(_bc.parent==nil)then c_a.setActiveFrame(_bc)if(bca)then c_a.setMonitorFrame(aca,_bc)else c_a.setMainFrame(_bc)end end;return _bc end,hide=function(_bc) d_a.hide(_bc) if(_bc.parent==nil)then if(activeFrame==_bc)then activeFrame=nil end;if(bca)then if( c_a.getMonitorFrame(aca)==_bc)then c_a.setActiveFrame(nil)end else if(c_a.getMainFrame()==_bc)then c_a.setMainFrame(nil)end end end;return _bc end,addLayout=function(_bc,abc) if( abc~=nil)then if(fs.exists(abc))then local bbc=fs.open(abc,"r") local cbc=bc:ParseXmlText(bbc.readAll())bbc.close()acb={}_bc:setValuesByXMLData(cbc)end end;return _bc end,getLastLayout=function(_bc)return acb end,addLayoutFromString=function(_bc,abc)if(abc~=nil)then local bbc=bc:ParseXmlText(abc) _bc:setValuesByXMLData(bbc)end;return _bc end,setValuesByXMLData=function(_bc,abc) d_a.setValuesByXMLData(_bc,abc)if(_d("movable",abc)~=nil)then if(_d("movable",abc))then _bc:setMovable(true)end end;if( _d("scrollable",abc)~=nil)then if(_d("scrollable",abc))then _bc:setScrollable(true)end end;if (_d("monitor",abc)~=nil)then _bc:setMonitor(_d("monitor",abc)):show()end;if(_d("mirror",abc)~=nil)then _bc:setMirror(_d("mirror",abc))end if(_d("bar",abc)~=nil)then if(_d("bar",abc))then _bc:showBar(true)else _bc:showBar(false)end end if(_d("barText",abc)~=nil)then _bc.barText=_d("barText",abc)end;if(_d("barBG",abc)~=nil)then _bc.barBackground=colors[_d("barBG",abc)]end;if(_d("barFG",abc)~=nil)then _bc.barTextcolor=colors[_d("barFG",abc)]end;if(_d("barAlign",abc)~=nil)then _bc.barTextAlign=_d("barAlign",abc)end;if(_d("layout",abc)~=nil)then _bc:addLayout(_d("layout",abc))end;if(_d("xOffset",abc)~=nil)then _bc:setOffset(_d("xOffset",abc),_cb)end;if(_d("yOffset",abc)~=nil)then _bc:setOffset(_cb,_d("yOffset",abc))end;if(_d("scrollAmount",abc)~=nil)then _bc:setScrollAmount(_d("scrollAmount",abc))end;local bbc=abc:children() for cbc,dbc in pairs(bbc)do if(dbc.___name~="animation")then local _cc=dbc.___name:gsub("^%l",string.upper) if(db[_cc]~=nil)then ccb(dbc,_bc["add".._cc],_bc)end end end;ccb(abc["frame"],_bc.addFrame,_bc) ccb(abc["animation"],_bc.addAnimation,_bc)return _bc end,showBar=function(_bc,abc)_bc.barActive= abc or not _bc.barActive;_bc:updateDraw() return _bc end,setBar=function(_bc,abc,bbc,cbc)_bc.barText=abc or""_bc.barBackground= bbc or _bc.barBackground _bc.barTextcolor=cbc or _bc.barTextcolor;_bc:updateDraw()return _bc end,setBarTextAlign=function(_bc,abc)_bc.barTextAlign= abc or"left"_bc:updateDraw()return _bc end,setMirror=function(_bc,abc)if( _bc.parent~=nil)then error("Frame has to be a base frame in order to attach a mirror.")end;__b=abc;if(mirror~=nil)then dab.setMirror(mirror)end;cda=true;return _bc end,removeMirror=function(_bc)mirror= nil;cda=false;dab.setMirror(nil)return _bc end,setMonitor=function(_bc,abc) if( abc~=nil)and(abc~=false)then if (peripheral.getType(abc)=="monitor")then _ca=peripheral.wrap(abc)cca=true end if(_bc.parent~=nil)then _bc.parent:removeObject(_bc)end;bca=true;c_a.setMonitorFrame(abc,_bc)else _ca=parentTerminal bca=false;if(c_a.getMonitorFrame(aca)==_bc)then c_a.setMonitorFrame(aca,nil)end end;dab=_c(_ca)_bc:setSize(_ca.getSize())_ab=true aca=abc or nil;_bc:updateDraw()return _bc end,loseFocusHandler=function(_bc) d_a.loseFocusHandler(_bc)if(d_b~=nil)then d_b:loseFocusHandler()d_b=nil end end,getFocusHandler=function(_bc) d_a.getFocusHandler(_bc) if(_bc.parent~=nil)then if(a_b)then _bc.parent:removeEvents(_bc) _bc.parent:removeObject(_bc)_bc.parent:addObject(_bc)for abc,bbc in pairs(cab)do if(bbc)then _bc.parent:addEvent(abc,_bc)end end _bc:updateDraw()end end;if(d_b~=nil)then d_b:getFocusHandler()end end,eventHandler=function(_bc,abc,bbc,cbc,dbc,_cc) d_a.eventHandler(_bc,abc,bbc,cbc,dbc,_cc) if(daa["other_event"]~=nil)then for acc,bcc in ipairs(_ba["other_event"])do if( daa["other_event"][bcc]~=nil)then for ccc,dcc in dc(daa["other_event"][bcc])do if (dcc.eventHandler~=nil)then if(dcc:eventHandler(abc,bbc,cbc,dbc,_cc))then return true end end end end end end;if(_ab)and not(bca)then if(_bc.parent==nil)then if(abc=="term_resize")then _bc:setSize(_ca.getSize())_ab=true end end end if(bca)then if(_ab)then if (abc=="monitor_resize")and(bbc==aca)then _bc:setSize(_ca.getSize()) _ab=true;_bc:updateDraw()end end if(abc=="peripheral")and(bbc==aca)then if (peripheral.getType(aca)=="monitor")then cca=true;_ca=peripheral.wrap(aca)dab=_c(_ca) _bc:updateDraw()end end if(abc=="peripheral_detach")and(bbc==aca)then cca=false end end if(cda)then if(peripheral.getType(__b)=="monitor")then dda=true dab.setMirror(peripheral.wrap(__b))end;if(abc=="peripheral_detach")and (bbc==__b)then cca=false end if (abc=="monitor_touch")and(__b==bbc)then _bc:mouseHandler(1,cbc,dbc,true)end end if(abc=="terminate")and(_bc.parent==nil)then c_a.stop()end end,mouseHandler=function(_bc,abc,bbc,cbc) if (d_a.mouseHandler(_bc,abc,bbc,cbc))then if(daa["mouse_click"]~=nil)then _bc:setCursor(false) for dbc,_cc in ipairs(_ba["mouse_click"])do if(daa["mouse_click"][_cc]~=nil)then for acc,bcc in dc(daa["mouse_click"][_cc])do if(bcc.mouseHandler~=nil)then if(bcc:mouseHandler(abc,bbc,cbc))then dac(_bc)return true end end end end end end if(a_b)then local dbc,_cc=_bc:getAbsolutePosition(_bc:getAnchorPosition())if (bbc>=dbc)and(bbc<=dbc+_bc:getWidth()-1)and(cbc==_cc)then b_b=true;dca=dbc-bbc _da=yOff and 1 or 0 end end;_bc:removeFocusedObject()dac(_bc)return true end;return false end,mouseUpHandler=function(_bc,abc,bbc,cbc)if (b_b)then b_b=false end if(d_a.mouseUpHandler(_bc,abc,bbc,cbc))then if (daa["mouse_up"]~=nil)then for dbc,_cc in ipairs(_ba["mouse_up"])do if(daa["mouse_up"][_cc]~=nil)then for acc,bcc in dc(daa["mouse_up"][_cc])do if(bcc.mouseUpHandler~=nil)then if(bcc:mouseUpHandler(abc,bbc,cbc))then dac(_bc)return true end end end end end end;dac(_bc)return true end;return false end,scrollHandler=function(_bc,abc,bbc,cbc) if (d_a.scrollHandler(_bc,abc,bbc,cbc))then if(daa["mouse_scroll"]~=nil)then for _cc,acc in pairs(_ba["mouse_scroll"])do if( daa["mouse_scroll"][acc]~=nil)then for bcc,ccc in dc(daa["mouse_scroll"][acc])do if(ccc.scrollHandler~= nil)then if(ccc:scrollHandler(abc,bbc,cbc))then dac(_bc)return true end end end end end end;local dbc=_cb if(ada)then cac(_bc)if(abc>0)or(abc<0)then _cb=dd(cd(_cb-abc,0),-bda)_bc:updateDraw()end end;_bc:removeFocusedObject()dac(_bc) if(_cb==dbc)then return false end;return true end;return false end,dragHandler=function(_bc,abc,bbc,cbc) if (b_b)then local dbc,_cc=_bc.parent:getOffsetInternal()dbc=dbc<0 and math.abs(dbc)or-dbc;_cc= _cc<0 and math.abs(_cc)or-_cc;local acc=1;local bcc=1;if(_bc.parent~=nil)then acc,bcc=_bc.parent:getAbsolutePosition(_bc.parent:getAnchorPosition())end _bc:setPosition( bbc+dca- (acc-1)+dbc,cbc+_da- (bcc-1)+_cc)_bc:updateDraw()return true end if(daa["mouse_drag"]~=nil)then for dbc,_cc in ipairs(_ba["mouse_drag"])do if( daa["mouse_drag"][_cc]~=nil)then for acc,bcc in dc(daa["mouse_drag"][_cc])do if (bcc.dragHandler~=nil)then if(bcc:dragHandler(abc,bbc,cbc))then dac(_bc)return true end end end end end end;dac(_bc)d_a.dragHandler(_bc,abc,bbc,cbc)return false end,keyHandler=function(_bc,abc,bbc) if (_bc:isFocused())or(_bc.parent==nil)then local cbc=_bc:getEventSystem():sendEvent("key",_bc,"key",abc)if(cbc==false)then return false end if(daa["key"]~=nil)then for dbc,_cc in pairs(_ba["key"])do if( daa["key"][_cc]~=nil)then for acc,bcc in dc(daa["key"][_cc])do if(bcc.keyHandler~=nil)then if (bcc:keyHandler(abc,bbc))then return true end end end end end end end;return false end,keyUpHandler=function(_bc,abc) if (_bc:isFocused())or(_bc.parent==nil)then local bbc=_bc:getEventSystem():sendEvent("key_up",_bc,"key_up",abc)if(bbc==false)then return false end if(daa["key_up"]~=nil)then for cbc,dbc in pairs(_ba["key_up"])do if(daa["key_up"][dbc]~=nil)then for _cc,acc in dc(daa["key_up"][dbc])do if( acc.keyUpHandler~=nil)then if(acc:keyUpHandler(abc))then return true end end end end end end end;return false end,charHandler=function(_bc,abc) if (_bc:isFocused())or(_bc.parent==nil)then local bbc=_bc:getEventSystem():sendEvent("char",_bc,"char",abc)if(bbc==false)then return false end if(daa["char"]~=nil)then for cbc,dbc in pairs(_ba["char"])do if(daa["char"][dbc]~=nil)then for _cc,acc in dc(daa["char"][dbc])do if (acc.charHandler~=nil)then if(acc:charHandler(abc))then return true end end end end end end end;return false end,setText=function(_bc,abc,bbc,cbc) local dbc,_cc=_bc:getAnchorPosition() if(bbc>=1)and(bbc<=_bc:getHeight())then if(_bc.parent~=nil)then _bc.parent:setText(dd( abc+ (dbc-1),dbc),_cc+bbc-1,bd(cbc,dd(1 -abc+1,1),dd( _bc:getWidth()-abc+1,1)))else dab.setText(dd(abc+ (dbc-1),dbc),_cc+bbc-1,bd(cbc,dd(1 -abc+1,1),dd( _bc:getWidth()-abc+1,1)))end end end,setBG=function(_bc,abc,bbc,cbc) local dbc,_cc=_bc:getAnchorPosition() if(bbc>=1)and(bbc<=_bc:getHeight())then if(_bc.parent~=nil)then _bc.parent:setBG(dd( abc+ (dbc-1),dbc),_cc+bbc-1,bd(cbc,dd(1 -abc+1,1),dd( _bc:getWidth()-abc+1,1)))else dab.setBG(dd(abc+ (dbc-1),dbc),_cc+bbc-1,bd(cbc,dd(1 -abc+1,1),dd( _bc:getWidth()-abc+1,1)))end end end,setFG=function(_bc,abc,bbc,cbc) local dbc,_cc=_bc:getAnchorPosition() if(bbc>=1)and(bbc<=_bc:getHeight())then if(_bc.parent~=nil)then _bc.parent:setFG(dd( abc+ (dbc-1),dbc),_cc+bbc-1,bd(cbc,dd(1 -abc+1,1),dd( _bc:getWidth()-abc+1,1)))else dab.setFG(dd(abc+ (dbc-1),dbc),_cc+bbc-1,bd(cbc,dd(1 -abc+1,1),dd( _bc:getWidth()-abc+1,1)))end end end,writeText=function(_bc,abc,bbc,cbc,dbc,_cc) local acc,bcc=_bc:getAnchorPosition() if(bbc>=1)and(bbc<=_bc:getHeight())then if(_bc.parent~=nil)then _bc.parent:writeText(dd( abc+ (acc-1),acc),bcc+bbc-1,bd(cbc,dd(1 -abc+1,1), _bc:getWidth()-abc+1),dbc,_cc)else dab.writeText(dd(abc+ (acc-1),acc),bcc+bbc-1,bd(cbc,dd(1 -abc+1,1),dd( _bc:getWidth()-abc+1,1)),dbc,_cc)end end end,drawBackgroundBox=function(_bc,abc,bbc,cbc,dbc,_cc) local acc,bcc=_bc:getAnchorPosition() dbc=(bbc<1 and( dbc+bbc>_bc:getHeight()and _bc:getHeight()or dbc+bbc-1)or( dbc+ bbc>_bc:getHeight()and _bc:getHeight()-bbc+1 or dbc)) cbc=(abc<1 and(cbc+abc>_bc:getWidth()and _bc:getWidth()or cbc+ abc-1)or( cbc+abc>_bc:getWidth()and _bc:getWidth()-abc+1 or cbc)) if(_bc.parent~=nil)then _bc.parent:drawBackgroundBox(dd(abc+ (acc-1),acc),dd(bbc+ (bcc-1),bcc),cbc,dbc,_cc)else dab.drawBackgroundBox(dd(abc+ (acc-1),acc),dd(bbc+ (bcc-1),bcc),cbc,dbc,_cc)end end,drawTextBox=function(_bc,abc,bbc,cbc,dbc,_cc) local acc,bcc=_bc:getAnchorPosition() dbc=(bbc<1 and( dbc+bbc>_bc:getHeight()and _bc:getHeight()or dbc+bbc-1)or( dbc+ bbc>_bc:getHeight()and _bc:getHeight()-bbc+1 or dbc)) cbc=(abc<1 and(cbc+abc>_bc:getWidth()and _bc:getWidth()or cbc+ abc-1)or( cbc+abc>_bc:getWidth()and _bc:getWidth()-abc+1 or cbc)) if(_bc.parent~=nil)then _bc.parent:drawTextBox(dd(abc+ (acc-1),acc),dd(bbc+ (bcc-1),bcc),cbc,dbc,bd(_cc,1,1))else dab.drawTextBox(dd(abc+ (acc-1),acc),dd(bbc+ (bcc-1),bcc),cbc,dbc,bd(_cc,1,1))end end,drawForegroundBox=function(_bc,abc,bbc,cbc,dbc,_cc) local acc,bcc=_bc:getAnchorPosition() dbc=(bbc<1 and( dbc+bbc>_bc:getHeight()and _bc:getHeight()or dbc+bbc-1)or( dbc+ bbc>_bc:getHeight()and _bc:getHeight()-bbc+1 or dbc)) cbc=(abc<1 and(cbc+abc>_bc:getWidth()and _bc:getWidth()or cbc+ abc-1)or( cbc+abc>_bc:getWidth()and _bc:getWidth()-abc+1 or cbc)) if(_bc.parent~=nil)then _bc.parent:drawForegroundBox(dd(abc+ (acc-1),acc),dd(bbc+ (bcc-1),bcc),cbc,dbc,_cc)else dab.drawForegroundBox(dd(abc+ (acc-1),acc),dd(bbc+ (bcc-1),bcc),cbc,dbc,_cc)end end,draw=function(_bc,abc)if (bca)and not(cca)then return false end if(_bc.parent==nil)then if(_bc:getDraw()== false)then return false end end if(d_a.draw(_bc))then local bbc,cbc=_bc:getAbsolutePosition(_bc:getAnchorPosition())local dbc,_cc=_bc:getAnchorPosition()local acc,bcc=_bc:getSize() if( _bc.parent==nil)then if(_bc.bgColor~=false)then dab.drawBackgroundBox(dbc,_cc,acc,bcc,_bc.bgColor)dab.drawTextBox(dbc,_cc,acc,bcc," ")end;if(_bc.fgColor~=false)then dab.drawForegroundBox(dbc,_cc,acc,bcc,_bc.fgColor)end end if(_bc.barActive)then if(_bc.parent~=nil)then _bc.parent:writeText(dbc,_cc,ac.getTextHorizontalAlign(_bc.barText,acc,_bc.barTextAlign),_bc.barBackground,_bc.barTextcolor)else dab.writeText(dbc,_cc,ac.getTextHorizontalAlign(_bc.barText,acc,_bc.barTextAlign),_bc.barBackground,_bc.barTextcolor)end if(_bc:getBorder("left"))then if(_bc.parent~=nil)then _bc.parent:drawBackgroundBox(dbc-1,_cc,1,1,_bc.barBackground)if(_bc.bgColor~=false)then _bc.parent:drawBackgroundBox(dbc-1,_cc+1,1,bcc-1,_bc.bgColor)end end end if(_bc:getBorder("top"))then if(_bc.parent~=nil)then _bc.parent:drawBackgroundBox(dbc-1,_cc-1,acc+1,1,_bc.barBackground)end end end;for ccc,dcc in dc(baa)do if(aaa[dcc]~=nil)then for _dc,adc in pairs(aaa[dcc])do if(adc.draw~=nil)then adc:draw()end end end end end end,updateTerm=function(_bc)if (bca)and not(cca)then return false end;dab.update()end,addObject=function(_bc,abc)return adb(abc)end,removeObject=function(_bc,abc)return cdb(abc)end,getObject=function(_bc,abc)return dcb(abc)end,getDeepObject=function(_bc,abc)return _db(abc)end,addFrame=function(_bc,abc) local bbc=c_a.newFrame(abc or cc(),_bc,nil,c_a)return adb(bbc)end,init=function(_bc) if not(bab)then if(a_a~=nil)then d_a.width,d_a.height=a_a:getSize() _bc:setBackground(a_a:getTheme("FrameBG")) _bc:setForeground(a_a:getTheme("FrameText"))else d_a.width,d_a.height=_ca.getSize() _bc:setBackground(c_a.getTheme("BasaltBG")) _bc:setForeground(c_a.getTheme("BasaltText"))end;bab=true end end} for _bc,abc in pairs(db)do caa["add".._bc]=function(bbc,cbc) return adb(abc(cbc or cc(),bbc))end end;setmetatable(caa,d_a)return caa end end; project['default']['loadObjects'] = function(...)local d={}if(packaged)then for ba,ca in pairs(getProject("objects"))do d[ba]=ca()end;return d end local _a=table.pack(...)local aa=fs.getDir(_a[2]or"Basalt")if(aa==nil)then error("Unable to find directory ".. _a[2].." please report this bug to our discord.")end;for ba,ca in pairs(fs.list(fs.combine(aa,"objects")))do if(ca~="example.lua")then local da=ca:gsub(".lua","")d[da]=require(da)end end;return d end; project['default']['Object'] = function(...)local aa=require("basaltEvent")local ba=require("utils") local ca=ba.splitString;local da=ba.numberFromString;local _b=ba.getValueFromXML return function(ab)local bb="Object"local cb={}local db=1 local _c;local ac="topLeft"local bc=false;local cc=true;local dc=false;local _d=false local ad={left=false,right=false,top=false,bottom=false}local bd=colors.black;local cd=true;local dd=false;local __a,a_a,b_a,c_a=0,0,0,0;local d_a=true;local _aa={} local aaa=aa() cb={x=1,y=1,width=1,height=1,bgColor=colors.black,bgSymbol=" ",bgSymbolColor=colors.black,fgColor=colors.white,transparentColor=false,name=ab or"Object",parent=nil,show=function(baa)cc=true baa:updateDraw()return baa end,hide=function(baa)cc=false;baa:updateDraw()return baa end,enable=function(baa) cd=true;return baa end,disable=function(baa)cd=false;return baa end,generateXMLEventFunction=function(baa,caa,daa) local _ba=function(aba) if (aba:sub(1,1)=="#")then local bba=baa:getBaseFrame():getDeepObject(aba:sub(2,aba:len())) if(bba~=nil)and(bba.internalObjetCall~=nil)then caa(baa,function() bba:internalObjetCall()end)end else caa(baa,baa:getBaseFrame():getVariable(aba))end end;if(type(daa)=="string")then _ba(daa)elseif(type(daa)=="table")then for aba,bba in pairs(daa)do _ba(bba)end end;return baa end,setValuesByXMLData=function(baa,caa) local daa=baa:getBaseFrame()if(_b("x",caa)~=nil)then baa:setPosition(_b("x",caa),baa.y)end;if(_b("y",caa)~=nil)then baa:setPosition(baa.x,_b("y",caa))end;if(_b("width",caa)~=nil)then baa:setSize(_b("width",caa),baa.height)end;if(_b("height",caa)~=nil)then baa:setSize(baa.width,_b("height",caa))end;if(_b("bg",caa)~=nil)then baa:setBackground(colors[_b("bg",caa)])end;if(_b("fg",caa)~=nil)then baa:setForeground(colors[_b("fg",caa)])end;if(_b("value",caa)~=nil)then baa:setValue(colors[_b("value",caa)])end if(_b("visible",caa)~=nil)then if (_b("visible",caa))then baa:show()else baa:hide()end end if(_b("enabled",caa)~=nil)then if(_b("enabled",caa))then baa:enable()else baa:disable()end end;if(_b("zIndex",caa)~=nil)then baa:setZIndex(_b("zIndex",caa))end;if(_b("anchor",caa)~=nil)then baa:setAnchor(_b("anchor",caa))end;if(_b("shadowColor",caa)~=nil)then baa:setShadow(colors[_b("shadowColor",caa)])end;if(_b("border",caa)~=nil)then baa:setBorder(colors[_b("border",caa)])end;if(_b("borderLeft",caa)~=nil)then ad["left"]=_b("borderLeft",caa)end;if(_b("borderTop",caa)~=nil)then ad["top"]=_b("borderTop",caa)end;if(_b("borderRight",caa)~=nil)then ad["right"]=_b("borderRight",caa)end;if(_b("borderBottom",caa)~=nil)then ad["bottom"]=_b("borderBottom",caa)end;if(_b("borderColor",caa)~=nil)then baa:setBorder(colors[_b("borderColor",caa)])end;if (_b("ignoreOffset",caa)~=nil)then if(_b("ignoreOffset",caa))then baa:ignoreOffset(true)end end;if (_b("onClick",caa)~=nil)then baa:generateXMLEventFunction(baa.onClick,_b("onClick",caa))end;if (_b("onClickUp",caa)~=nil)then baa:generateXMLEventFunction(baa.onClickUp,_b("onClickUp",caa))end;if (_b("onScroll",caa)~=nil)then baa:generateXMLEventFunction(baa.onScroll,_b("onScroll",caa))end;if (_b("onDrag",caa)~=nil)then baa:generateXMLEventFunction(baa.onDrag,_b("onDrag",caa))end;if(_b("onKey",caa)~=nil)then baa:generateXMLEventFunction(baa.onKey,_b("onKey",caa))end;if(_b("onKeyUp",caa)~=nil)then baa:generateXMLEventFunction(baa.onKeyUp,_b("onKeyUp",caa))end;if (_b("onChange",caa)~=nil)then baa:generateXMLEventFunction(baa.onChange,_b("onChange",caa))end;if (_b("onResize",caa)~=nil)then baa:generateXMLEventFunction(baa.onResize,_b("onResize",caa))end;if (_b("onReposition",caa)~=nil)then baa:generateXMLEventFunction(baa.onReposition,_b("onReposition",caa))end;if (_b("onEvent",caa)~=nil)then baa:generateXMLEventFunction(baa.onEvent,_b("onEvent",caa))end;if (_b("onGetFocus",caa)~=nil)then baa:generateXMLEventFunction(baa.onGetFocus,_b("onGetFocus",caa))end;if (_b("onLoseFocus",caa)~=nil)then baa:generateXMLEventFunction(baa.onLoseFocus,_b("onLoseFocus",caa))end baa:updateDraw()return baa end,isVisible=function(baa)return cc end,setFocus=function(baa)if(baa.parent~=nil)then baa.parent:setFocusedObject(baa)end;return baa end,setZIndex=function(baa,caa) db=caa if(baa.parent~=nil)then baa.parent:removeObject(baa) baa.parent:addObject(baa)baa:updateEventHandlers()end;return baa end,updateEventHandlers=function(baa) for caa,daa in pairs(_aa)do if(daa)then baa.parent:addEvent(caa,baa)end end end,getZIndex=function(baa)return db end,getType=function(baa)return bb end,getName=function(baa)return baa.name end,remove=function(baa)if(baa.parent~=nil)then baa.parent:removeObject(baa)end;baa:updateDraw()return baa end,setParent=function(baa,caa) if( caa.getType~=nil and caa:getType()=="Frame")then baa:remove()caa:addObject(baa)if(baa.draw)then baa:show()end end;return baa end,setValue=function(baa,caa) if( _c~=caa)then _c=caa;baa:updateDraw()baa:valueChangedHandler()end;return baa end,getValue=function(baa)return _c end,getDraw=function(baa)return d_a end,updateDraw=function(baa,caa)d_a=caa;if(caa==nil)then d_a=true end;if(d_a)then if(baa.parent~=nil)then baa.parent:updateDraw()end end;return baa end,getEventSystem=function(baa)return aaa end,getParent=function(baa)return baa.parent end,setPosition=function(baa,caa,daa,_ba) if(type(caa)=="number")then baa.x= _ba and baa:getX()+caa or caa end;if(type(daa)=="number")then baa.y=_ba and baa:getY()+daa or daa end if(baa.parent~=nil)then if(type(caa)=="string")then baa.x=baa.parent:newDynamicValue(baa,caa)end;if(type(daa)=="string")then baa.y=baa.parent:newDynamicValue(baa,daa)end baa.parent:recalculateDynamicValues()end;aaa:sendEvent("basalt_reposition",baa) baa:updateDraw()return baa end,getX=function(baa)return type(baa.x)=="number"and baa.x or math.floor(baa.x[1]+0.5)end,getY=function(baa)return type(baa.y)=="number"and baa.y or math.floor(baa.y[1]+0.5)end,getPosition=function(baa)return baa:getX(),baa:getY()end,getVisibility=function(baa)return cc end,setVisibility=function(baa,caa) cc=caa or not cc;baa:updateDraw()return baa end,setSize=function(baa,caa,daa,_ba)if(type(caa)== "number")then baa.width=_ba and baa.width+caa or caa end if(type(daa)=="number")then baa.height=_ba and baa.height+daa or daa end if(baa.parent~=nil)then if(type(caa)=="string")then baa.width=baa.parent:newDynamicValue(baa,caa)end;if(type(daa)=="string")then baa.height=baa.parent:newDynamicValue(baa,daa)end baa.parent:recalculateDynamicValues()end;aaa:sendEvent("basalt_resize",baa) baa:updateDraw()return baa end,getHeight=function(baa) return type(baa.height)=="number"and baa.height or math.floor(baa.height[1]+0.5)end,getWidth=function(baa)return type(baa.width)=="number"and baa.width or math.floor(baa.width[1]+0.5)end,getSize=function(baa)return baa:getWidth(),baa:getHeight()end,calculateDynamicValues=function(baa) if( type(baa.width)=="table")then baa.width:calculate()end if(type(baa.height)=="table")then baa.height:calculate()end if(type(baa.x)=="table")then baa.x:calculate()end if(type(baa.y)=="table")then baa.y:calculate()end;baa:updateDraw()return baa end,setBackground=function(baa,caa,daa,_ba)baa.bgColor= caa or false baa.bgSymbol=daa or(baa.bgColor~=false and baa.bgSymbol or false)baa.bgSymbolColor=_ba or baa.bgSymbolColor baa:updateDraw()return baa end,setTransparent=function(baa,caa)baa.transparentColor= caa or false;baa.bgSymbol=false;baa.bgSymbolColor=false baa:updateDraw()return baa end,getBackground=function(baa)return baa.bgColor end,setForeground=function(baa,caa)baa.fgColor=caa or false baa:updateDraw()return baa end,getForeground=function(baa)return baa.fgColor end,setShadow=function(baa,caa)if( caa==false)then _d=false else bd=caa;_d=true end baa:updateDraw()return baa end,isShadowActive=function(baa)return _d end,setBorder=function(baa,...) if( ...~=nil)then local caa={...} for daa,_ba in pairs(caa)do if(_ba=="left")or(#caa==1)then ad["left"]=caa[1]end;if(_ba=="top")or(#caa==1)then ad["top"]=caa[1]end;if(_ba=="right")or(#caa==1)then ad["right"]=caa[1]end;if(_ba=="bottom")or(#caa==1)then ad["bottom"]=caa[1]end end end;baa:updateDraw()return baa end,getBorder=function(baa,caa)if( caa=="left")then return borderLeft end if(caa=="top")then return borderTop end;if(caa=="right")then return borderRight end;if(caa=="bottom")then return borderBottom end end,draw=function(baa) if (cc)then if(baa.parent~=nil)then local caa,daa=baa:getAnchorPosition() local _ba,aba=baa:getSize()local bba,cba=baa.parent:getSize() if(caa+_ba<1)or(caa>bba)or(daa+ aba<1)or(daa>cba)then return false end;if(baa.transparentColor~=false)then baa.parent:drawForegroundBox(caa,daa,_ba,aba,baa.transparentColor)end;if(baa.bgColor~=false)then baa.parent:drawBackgroundBox(caa,daa,_ba,aba,baa.bgColor)end if(baa.bgSymbol~=false)then baa.parent:drawTextBox(caa,daa,_ba,aba,baa.bgSymbol)if(baa.bgSymbol~=" ")then baa.parent:drawForegroundBox(caa,daa,_ba,aba,baa.bgSymbolColor)end end if(_d)then baa.parent:drawBackgroundBox(caa+1,daa+aba,_ba,1,bd) baa.parent:drawBackgroundBox(caa+_ba,daa+1,1,aba,bd) baa.parent:drawForegroundBox(caa+1,daa+aba,_ba,1,bd) baa.parent:drawForegroundBox(caa+_ba,daa+1,1,aba,bd)end if(ad["left"]~=false)then baa.parent:drawTextBox(caa-1,daa,1,aba,"\149") baa.parent:drawBackgroundBox(caa-1,daa,1,aba,ad["left"]) baa.parent:drawForegroundBox(caa-1,daa,1,aba,baa.parent.bgColor)end if(ad["left"]~=false)and(ad["top"]~=false)then baa.parent:drawTextBox( caa-1,daa-1,1,1,"\151")baa.parent:drawBackgroundBox( caa-1,daa-1,1,1,ad["left"]) baa.parent:drawForegroundBox( caa-1,daa-1,1,1,baa.parent.bgColor)end if(ad["top"]~=false)then baa.parent:drawTextBox(caa,daa-1,_ba,1,"\131") baa.parent:drawBackgroundBox(caa,daa-1,_ba,1,ad["top"]) baa.parent:drawForegroundBox(caa,daa-1,_ba,1,baa.parent.bgColor)end if(ad["top"]~=false)and(ad["right"]~=false)then baa.parent:drawTextBox( caa+_ba,daa-1,1,1,"\148") baa.parent:drawForegroundBox( caa+_ba,daa-1,1,1,ad["right"])end;if(ad["right"]~=false)then baa.parent:drawTextBox(caa+_ba,daa,1,aba,"\149") baa.parent:drawForegroundBox(caa+_ba,daa,1,aba,ad["right"])end if( ad["right"]~=false)and(ad["bottom"]~=false)then baa.parent:drawTextBox( caa+_ba,daa+aba,1,1,"\129") baa.parent:drawForegroundBox( caa+_ba,daa+aba,1,1,ad["right"])end;if(ad["bottom"]~=false)then baa.parent:drawTextBox(caa,daa+aba,_ba,1,"\131") baa.parent:drawForegroundBox(caa,daa+aba,_ba,1,ad["bottom"])end if( ad["bottom"]~=false)and(ad["left"]~=false)then baa.parent:drawTextBox( caa-1,daa+aba,1,1,"\130") baa.parent:drawForegroundBox( caa-1,daa+aba,1,1,ad["left"])end end;d_a=false;return true end;return false end,getAbsolutePosition=function(baa,caa,daa) if( caa==nil)or(daa==nil)then caa,daa=baa:getAnchorPosition()end if(baa.parent~=nil)then local _ba,aba=baa.parent:getAbsolutePosition()caa=_ba+caa-1;daa=aba+daa-1 end;return caa,daa end,getAnchorPosition=function(baa,caa,daa,_ba)if( caa==nil)then caa=baa:getX()end if(daa==nil)then daa=baa:getY()end if(baa.parent~=nil)then local aba,bba=baa.parent:getSize() if(ac=="top")then caa=math.floor( aba/2)+caa-1 elseif(ac=="topRight")then caa=aba+caa-1 elseif(ac=="right")then caa=aba+caa-1 daa=math.floor(bba/2)+daa-1 elseif(ac=="bottomRight")then caa=aba+caa-1;daa=bba+daa-1 elseif(ac=="bottom")then caa=math.floor( aba/2)+caa-1;daa=bba+daa-1 elseif(ac== "bottomLeft")then daa=bba+daa-1 elseif(ac=="left")then daa=math.floor(bba/2)+daa-1 elseif(ac=="center")then caa=math.floor(aba/2)+caa-1;daa=math.floor( bba/2)+daa-1 end;local cba,dba=baa.parent:getOffsetInternal()if not(bc or _ba)then return caa+ cba,daa+dba end end;return caa,daa end,ignoreOffset=function(baa,caa) bc=caa;if(caa==nil)then bc=true end;return baa end,getBaseFrame=function(baa) if( baa.parent~=nil)then return baa.parent:getBaseFrame()end;return baa end,setAnchor=function(baa,caa)ac=caa baa:updateDraw()return baa end,getAnchor=function(baa)return ac end,onChange=function(baa,...) for caa,daa in pairs(table.pack(...))do if(type(daa)=="function")then baa:registerEvent("value_changed",daa)end end;return baa end,onClick=function(baa,...) for caa,daa in pairs(table.pack(...))do if(type(daa)=="function")then baa:registerEvent("mouse_click",daa)end end;if(baa.parent~=nil)then baa.parent:addEvent("mouse_click",baa)_aa["mouse_click"]=true end;return baa end,onClickUp=function(baa,...)for caa,daa in pairs(table.pack(...))do if(type(daa)=="function")then baa:registerEvent("mouse_up",daa)end end;if(baa.parent~=nil)then baa.parent:addEvent("mouse_up",baa)_aa["mouse_up"]=true end;return baa end,onScroll=function(baa,...) for caa,daa in pairs(table.pack(...))do if(type(daa)=="function")then baa:registerEvent("mouse_scroll",daa)end end if(baa.parent~=nil)then baa.parent:addEvent("mouse_scroll",baa)_aa["mouse_scroll"]=true end;return baa end,onDrag=function(baa,...) for caa,daa in pairs(table.pack(...))do if(type(daa)=="function")then baa:registerEvent("mouse_drag",daa)end end if(baa.parent~=nil)then baa.parent:addEvent("mouse_drag",baa)_aa["mouse_drag"]=true baa.parent:addEvent("mouse_click",baa)_aa["mouse_click"]=true baa.parent:addEvent("mouse_up",baa)_aa["mouse_up"]=true end;return baa end,onEvent=function(baa,...) for caa,daa in pairs(table.pack(...))do if(type(daa)=="function")then baa:registerEvent("other_event",daa)end end;if(baa.parent~=nil)then baa.parent:addEvent("other_event",baa)_aa["other_event"]=true end;return baa end,onKey=function(baa,...) if (cd)then for caa,daa in pairs(table.pack(...))do if(type(daa)=="function")then baa:registerEvent("key",daa)baa:registerEvent("char",daa)end end if (baa.parent~=nil)then baa.parent:addEvent("key",baa) baa.parent:addEvent("char",baa)_aa["key"]=true;_aa["char"]=true end end;return baa end,onResize=function(baa,...) for caa,daa in pairs(table.pack(...))do if(type(daa)=="function")then baa:registerEvent("basalt_resize",daa)end end;return baa end,onReposition=function(baa,...) for caa,daa in pairs(table.pack(...))do if(type(daa)=="function")then baa:registerEvent("basalt_reposition",daa)end end;return baa end,onKeyUp=function(baa,...)for caa,daa in pairs(table.pack(...))do if(type(daa)=="function")then baa:registerEvent("key_up",daa)end end;if(baa.parent~=nil)then baa.parent:addEvent("key_up",baa)_aa["key_up"]=true end;return baa end,isFocused=function(baa)if( baa.parent~=nil)then return baa.parent:getFocusedObject()==baa end;return false end,onGetFocus=function(baa,...) for caa,daa in pairs(table.pack(...))do if(type(daa)=="function")then baa:registerEvent("get_focus",daa)end end;if(baa.parent~=nil)then baa.parent:addEvent("mouse_click",baa)_aa["mouse_click"]=true end;return baa end,onLoseFocus=function(baa,...) for caa,daa in pairs(table.pack(...))do if(type(daa)=="function")then baa:registerEvent("lose_focus",daa)end end;if(baa.parent~=nil)then baa.parent:addEvent("mouse_click",baa)_aa["mouse_click"]=true end;return baa end,registerEvent=function(baa,caa,daa)return aaa:registerEvent(caa,daa)end,removeEvent=function(baa,caa,daa) return aaa:removeEvent(caa,daa)end,sendEvent=function(baa,caa,...)return aaa:sendEvent(caa,baa,...)end,isCoordsInObject=function(baa,caa,daa) if (cc)and(cd)then local _ba,aba=baa:getAbsolutePosition(baa:getAnchorPosition())local bba,cba=baa:getSize() if (_ba<=caa)and(_ba+bba>caa)and(aba<=daa)and(aba+cba>daa)then return true end end;return false end,mouseHandler=function(baa,caa,daa,_ba,aba) if (baa:isCoordsInObject(daa,_ba))then local bba=aaa:sendEvent("mouse_click",baa,"mouse_click",caa,daa,_ba,aba)if(bba==false)then return false end;if(baa.parent~=nil)then baa.parent:setFocusedObject(baa)end;dd=true;__a,a_a=daa,_ba;return true end;return false end,mouseUpHandler=function(baa,caa,daa,_ba) dd=false if(baa:isCoordsInObject(daa,_ba))then local aba=aaa:sendEvent("mouse_up",baa,"mouse_up",caa,daa,_ba)if(aba==false)then return false end;return true end;return false end,dragHandler=function(baa,caa,daa,_ba) if (dd)then local aba,bba,cba,dba=0,0,1,1 if(baa.parent~=nil)then aba,bba=baa.parent:getOffsetInternal()aba=aba<0 and math.abs(aba)or-aba;bba=bba<0 and math.abs(bba)or-bba cba,dba=baa.parent:getAbsolutePosition(baa.parent:getAnchorPosition())end local _ca,aca=daa+b_a- (cba-1)+aba,_ba+c_a- (dba-1)+bba local bca=aaa:sendEvent("mouse_drag",baa,caa,_ca,aca,__a-daa,a_a-_ba,daa,_ba) local cca,dca=baa:getAbsolutePosition(baa:getAnchorPosition())__a,a_a=daa,_ba;if(bca~=nil)then return bca end;if(baa.parent~=nil)then baa.parent:setFocusedObject(baa)end;return true end if(baa:isCoordsInObject(daa,_ba))then local aba,bba=baa:getAbsolutePosition(baa:getAnchorPosition())__a,a_a=daa,_ba;b_a,c_a=aba-daa,bba-_ba end;return false end,scrollHandler=function(baa,caa,daa,_ba) if (baa:isCoordsInObject(daa,_ba))then local aba=aaa:sendEvent("mouse_scroll",baa,"mouse_scroll",caa,daa,_ba)if(aba==false)then return false end;if(baa.parent~=nil)then baa.parent:setFocusedObject(baa)end;return true end;return false end,keyHandler=function(baa,caa,daa)if (cd)and(cc)then if(baa:isFocused())then local _ba=aaa:sendEvent("key",baa,"key",caa,daa)if(_ba==false)then return false end;return true end end;return false end,keyUpHandler=function(baa,caa)if (cd)and(cc)then if(baa:isFocused())then local daa=aaa:sendEvent("key_up",baa,"key_up",caa)if(daa==false)then return false end;return true end end;return false end,charHandler=function(baa,caa)if (cd)and(cc)then if(baa:isFocused())then local daa=aaa:sendEvent("char",baa,"char",caa)if(daa==false)then return false end;return true end end return false end,valueChangedHandler=function(baa) aaa:sendEvent("value_changed",baa,_c)end,eventHandler=function(baa,caa,daa,_ba,aba,bba) local cba=aaa:sendEvent("other_event",baa,caa,daa,_ba,aba,bba)if(cba~=nil)then return cba end;return true end,getFocusHandler=function(baa) local caa=aaa:sendEvent("get_focus",baa)if(caa~=nil)then return caa end;return true end,loseFocusHandler=function(baa) dd=false;local caa=aaa:sendEvent("lose_focus",baa) if(caa~=nil)then return caa end;return true end,init=function(baa) if (baa.parent~=nil)then for caa,daa in pairs(_aa)do if(daa)then baa.parent:addEvent(caa,baa)end end end;if not(dc)then dc=true;return true end end}cb.__index=cb;return cb end end; project['default']['theme'] = function(...) return {BasaltBG=colors.lightGray,BasaltText=colors.black,FrameBG=colors.gray,FrameText=colors.black,ButtonBG=colors.gray,ButtonText=colors.black,CheckboxBG=colors.gray,CheckboxText=colors.black,InputBG=colors.gray,InputText=colors.black,TextfieldBG=colors.gray,TextfieldText=colors.black,ListBG=colors.gray,ListText=colors.black,MenubarBG=colors.gray,MenubarText=colors.black,DropdownBG=colors.gray,DropdownText=colors.black,RadioBG=colors.gray,RadioText=colors.black,SelectionBG=colors.black,SelectionText=colors.lightGray,GraphicBG=colors.black,ImageBG=colors.black,PaneBG=colors.black,ProgramBG=colors.black,ProgressbarBG=colors.gray,ProgressbarText=colors.black,ProgressbarActiveBG=colors.black,ScrollbarBG=colors.lightGray,ScrollbarText=colors.gray,ScrollbarSymbolColor=colors.black,SliderBG=false,SliderText=colors.gray,SliderSymbolColor=colors.black,SwitchBG=colors.lightGray,SwitchText=colors.gray,SwitchBGSymbol=colors.black,SwitchInactive=colors.red,SwitchActive=colors.green,LabelBG=false,LabelText=colors.black} end; local baa=require("basaltEvent")() local caa=require("Frame")local daa=require("theme")local _ba=require("utils") local aba=require("basaltLogs")local bba=_ba.uuid;local cba=_ba.createText;local dba=term.current()local _ca="1.6.0" local aca=true local bca=fs.getDir(table.pack(...)[2]or"")local cca,dca,_da,ada,bda={},{},{},{},{}local cda,dda,__b,a_b;local b_b={}if not term.isColor or not term.isColor()then error('Basalt requires an advanced (golden) computer to run.',0)end;local function c_b()a_b=false dba.clear()dba.setCursorPos(1,1)end;local d_b=function(cbb,dbb) ada[cbb]=dbb end local _ab=function(cbb)return ada[cbb]end;local aab=function(cbb)daa=cbb end local bab=function(cbb)return daa[cbb]end local cab={getMainFrame=function()return cda end,setVariable=d_b,getVariable=_ab,getTheme=bab,setMainFrame=function(cbb)cda=cbb end,getActiveFrame=function()return dda end,setActiveFrame=function(cbb)dda=cbb end,getFocusedObject=function()return __b end,setFocusedObject=function(cbb)__b=cbb end,getMonitorFrame=function(cbb)return _da[cbb]end,setMonitorFrame=function(cbb,dbb)if(cda==dbb)then cda=nil end;_da[cbb]=dbb end,getBaseTerm=function()return dba end,stop=c_b,newFrame=caa,getDirectory=function()return bca end} local dab=function(cbb)dba.clear()dba.setBackgroundColor(colors.black) dba.setTextColor(colors.red)local dbb,_cb=dba.getSize() if(b_b.logging)then aba(cbb,"Error")end;local acb=cba("Basalt error: "..cbb,dbb)local bcb=1;for ccb,dcb in pairs(acb)do dba.setCursorPos(1,bcb)dba.write(dcb)bcb=bcb+1 end;dba.setCursorPos(1, bcb+1)a_b=false end local function _bb(cbb,dbb,_cb,acb,bcb) if(#bda>0)then local ccb={} for n=1,#bda do if(bda[n]~=nil)then if (coroutine.status(bda[n])=="suspended")then local dcb,_db=coroutine.resume(bda[n],cbb,dbb,_cb,acb,bcb)if not(dcb)then dab(_db)end else table.insert(ccb,n)end end end for n=1,#ccb do table.remove(bda,ccb[n]- (n-1))end end end local function abb()if(a_b==false)then return end;if(cda~=nil)then cda:draw() cda:updateTerm()end for cbb,dbb in pairs(_da)do dbb:draw()dbb:updateTerm()end end local function bbb(cbb,dbb,_cb,acb,bcb)if (baa:sendEvent("basaltEventCycle",cbb,dbb,_cb,acb,bcb)==false)then return end if(cda~=nil)then if(cbb=="mouse_click")then cda:mouseHandler(dbb,_cb,acb,false)dda=cda elseif(cbb=="mouse_drag")then cda:dragHandler(dbb,_cb,acb,bcb) dda=cda elseif(cbb=="mouse_up")then cda:mouseUpHandler(dbb,_cb,acb,bcb)dda=cda elseif(cbb== "mouse_scroll")then cda:scrollHandler(dbb,_cb,acb,bcb)dda=cda end end if(cbb=="monitor_touch")then if(_da[dbb]~=nil)then _da[dbb]:mouseHandler(1,_cb,acb,true)dda=_da[dbb]end end if(cbb=="char")then if(dda~=nil)then dda:charHandler(dbb)end end;if(cbb=="key_up")then if(dda~=nil)then dda:keyUpHandler(dbb)end cca[dbb]=false end if(cbb=="key")then if(dda~=nil)then dda:keyHandler(dbb,_cb)end;cca[dbb]=true end if(cbb=="terminate")then if(dda~=nil)then dda:eventHandler(cbb) if(a_b==false)then return end end end if (cbb~="mouse_click")and(cbb~="mouse_up")and(cbb~="mouse_scroll")and(cbb~="mouse_drag")and(cbb~="key")and(cbb~="key_up")and(cbb~= "char")and(cbb~="terminate")then for ccb,dcb in pairs(dca)do dcb:eventHandler(cbb,dbb,_cb,acb,bcb)end end;_bb(cbb,dbb,_cb,acb,bcb)abb()end b_b={logging=false,setTheme=aab,getTheme=bab,drawFrames=abb,getVersion=function()return _ca end,setVariable=d_b,getVariable=_ab,setBaseTerm=function(cbb)dba=cbb end,log=function(...)aba(...)end,autoUpdate=function(cbb) a_b=cbb;if(cbb==nil)then a_b=true end;local function dbb()abb()while a_b do bbb(os.pullEventRaw())end end local _cb,acb=xpcall(dbb,debug.traceback)if not(_cb)then dab(acb)return end end,update=function(cbb,dbb,_cb,acb,bcb) if( cbb~=nil)then local ccb,dcb=xpcall(bbb,debug.traceback,cbb,dbb,_cb,acb,bcb)if not(ccb)then dab(dcb)return end end end,stop=c_b,stopUpdate=c_b,isKeyDown=function(cbb)if( cca[cbb]==nil)then return false end;return cca[cbb]end,getFrame=function(cbb)for dbb,_cb in pairs(dca)do if(_cb.name==cbb)then return _cb end end end,getActiveFrame=function()return dda end,setActiveFrame=function(cbb) if(cbb:getType()=="Frame")then dda=cbb;return true end;return false end,onEvent=function(...) for cbb,dbb in pairs(table.pack(...))do if(type(dbb)=="function")then baa:registerEvent("basaltEventCycle",dbb)end end end,schedule=function(cbb) assert(cbb~= "function","Schedule needs a function in order to work!")return function(...)local dbb=coroutine.create(cbb) local _cb,acb=coroutine.resume(dbb,...)if(_cb)then table.insert(bda,dbb)else dab(acb)end end end,createFrame=function(cbb)cbb= cbb or bba() for _cb,acb in pairs(dca)do if(acb.name==cbb)then return nil end end;local dbb=caa(cbb,nil,nil,cab)dbb:init() table.insert(dca,dbb)if (cda==nil)and(dbb:getName()~="basaltDebuggingFrame")then dbb:show()end;return dbb end,removeFrame=function(cbb)dca[cbb]= nil end,setProjectDir=function(cbb)bca=cbb end,debug=function(...)local cbb={...}if(cda==nil)then print(...)return end;if(cda.name~="basaltDebuggingFrame")then if (cda~=b_b.debugFrame)then b_b.debugLabel:setParent(cda)end end;local dbb=""for _cb,acb in pairs(cbb)do dbb=dbb.. tostring(acb).. (#cbb~=_cb and", "or"")end b_b.debugLabel:setText("[Debug] "..dbb)for _cb,acb in pairs(cba(dbb,b_b.debugList:getWidth()))do b_b.debugList:addItem(acb)end if( b_b.debugList:getItemCount()>50)then b_b.debugList:removeItem(1)end b_b.debugList:setValue(b_b.debugList:getItem(b_b.debugList:getItemCount()))if (b_b.debugList.getItemCount()>b_b.debugList:getHeight())then b_b.debugList:setOffset(b_b.debugList:getItemCount()- b_b.debugList:getHeight())end b_b.debugLabel:show()end} b_b.debugFrame=b_b.createFrame("basaltDebuggingFrame"):showBar():setBackground(colors.lightGray):setBar("Debug",colors.black,colors.gray) b_b.debugFrame:addButton("back"):setAnchor("topRight"):setSize(1,1):setText("\22"):onClick(function()if( b_b.oldFrame~=nil)then b_b.oldFrame:show()end end):setBackground(colors.red):show() b_b.debugList=b_b.debugFrame:addList("debugList"):setSize("parent.w - 2","parent.h - 3"):setPosition(2,3):setScrollable(true):show() b_b.debugLabel=b_b.debugFrame:addLabel("debugLabel"):onClick(function() b_b.oldFrame=cda;b_b.debugFrame:show()end):setBackground(colors.black):setForeground(colors.white):setAnchor("bottomLeft"):ignoreOffset():setZIndex(20):show()return b_b