From 74cf4746bed6fe3a4fec2b29e7456cce98bdd9b0 Mon Sep 17 00:00:00 2001 From: RealBadAngel Date: Sun, 3 Feb 2013 12:56:23 +0100 Subject: [PATCH] Added Injector --- technic/init.lua | 2 +- technic/injector.lua | 331 ++---------------- technic/textures/technic_injector_bottom.png | Bin 0 -> 2667 bytes technic/textures/technic_injector_side.png | Bin 0 -> 2541 bytes technic/textures/technic_injector_top.png | Bin 0 -> 2633 bytes .../technicx32/technic_injector_bottom.png | Bin 0 -> 2667 bytes .../technicx32/technic_injector_side.png | Bin 0 -> 2541 bytes .../technicx32/technic_injector_top.png | Bin 0 -> 2633 bytes 8 files changed, 37 insertions(+), 296 deletions(-) create mode 100644 technic/textures/technic_injector_bottom.png create mode 100644 technic/textures/technic_injector_side.png create mode 100644 technic/textures/technic_injector_top.png create mode 100644 technic/textures/technicx32/technic_injector_bottom.png create mode 100644 technic/textures/technicx32/technic_injector_side.png create mode 100644 technic/textures/technicx32/technic_injector_top.png diff --git a/technic/init.lua b/technic/init.lua index 184c8b9..5b6d3ef 100644 --- a/technic/init.lua +++ b/technic/init.lua @@ -51,7 +51,7 @@ dofile(modpath.."/screwdriver.lua") dofile(modpath.."/sonic_screwdriver.lua") -- mesecons and tubes related ---dofile(modpath.."/injector.lua") +dofile(modpath.."/injector.lua") dofile(modpath.."/node_breaker.lua") dofile(modpath.."/deployer.lua") dofile(modpath.."/constructor.lua") diff --git a/technic/injector.lua b/technic/injector.lua index 0a6a19c..0691777 100644 --- a/technic/injector.lua +++ b/technic/injector.lua @@ -5,16 +5,16 @@ minetest.register_craftitem("technic:injector", { minetest.register_node("technic:injector", { description = "Injector", - tiles = {"technic_iron_chest_top.png", "technic_iron_chest_top.png", "technic_iron_chest_side.png", - "technic_iron_chest_side.png", "technic_iron_chest_side.png", "technic_iron_chest_front.png"}, - paramtype2 = "facedir", - groups = {snappy=2,choppy=2,oddly_breakable_by_hand=2}, - legacy_facedir_simple = true, + tiles = {"technic_injector_top.png", "technic_injector_bottom.png", "technic_injector_side.png", + "technic_injector_side.png", "technic_injector_side.png", "technic_injector_side.png"}, + groups = chest_groups1, + tube = tubes_properties, sounds = default.node_sound_wood_defaults(), on_construct = function(pos) local meta = minetest.env:get_meta(pos) meta:set_string("formspec", - "invsize[9,9;]".. + "invsize[8,9;]".. + "label[0,0;Injector]".. "list[current_name;main;0,2;8,2;]".. "list[current_player;main;0,5;8,4;]") meta:set_string("infotext", "Injector") @@ -26,300 +26,41 @@ minetest.register_node("technic:injector", { local inv = meta:get_inventory() return inv:is_empty("main") end, - on_punch = function (pos, node, puncher) - local meta = minetest.env:get_meta(pos); - local inv = meta:get_inventory() - for _,stack in ipairs(inv:get_list("main")) do - if stack:get_name() ~="" then - inv:remove_item("main",stack) - pos1=pos - pos1.y=pos1.y - local x=pos1.x+1.5 - local z=pos1.z - item1=tube_item({x=pos1.x,y=pos1.y,z=pos1.z},stack) - item1:get_luaentity().start_pos = {x=pos1.x,y=pos1.y,z=pos1.z} - item1:setvelocity({x=1, y=0, z=0}) - item1:setacceleration({x=0, y=0, z=0}) - return - end - end -end, }) +minetest.register_abm({ + nodenames = {"technic:injector"}, + interval = 1, + chance = 1, -function tube_item(pos, item) - local TUBE_nodes = {} - local CHEST_nodes = {} - - TUBE_nodes[1]={} - TUBE_nodes[1].x=pos.x - TUBE_nodes[1].y=pos.y - TUBE_nodes[1].z=pos.z - - -table_index=1 - repeat - check_TUBE_node (TUBE_nodes,CHEST_nodes,table_index) - table_index=table_index+1 - if TUBE_nodes[table_index]==nil then break end - until false -found=table_index-1 - - -print("Found "..found.." tubes connected") -print(dump(CHEST_nodes)) - -- Take item in any format - local stack = ItemStack(item) - local obj = minetest.env:add_entity(pos, "technic:tubed_item") - obj:get_luaentity():set_item(stack:to_string()) - return obj -end - -minetest.register_entity("technic:tubed_item", { - initial_properties = { - hp_max = 1, - physical = false, - collisionbox = {0,0,0,0,0,0}, - visual = "sprite", - visual_size = {x=0.5, y=0.5}, - textures = {""}, - spritediv = {x=1, y=1}, - initial_sprite_basepos = {x=0, y=0}, - is_visible = false, - start_pos={}, - route={} - }, - - itemstring = '', - physical_state = false, - - set_item = function(self, itemstring) - self.itemstring = itemstring - local stack = ItemStack(itemstring) - local itemtable = stack:to_table() - local itemname = nil - if itemtable then - itemname = stack:to_table().name - end - local item_texture = nil - local item_type = "" - if minetest.registered_items[itemname] then - item_texture = minetest.registered_items[itemname].inventory_image - item_type = minetest.registered_items[itemname].type - end - prop = { - is_visible = true, - visual = "sprite", - textures = {"unknown_item.png"} - } - if item_texture and item_texture ~= "" then - prop.visual = "sprite" - prop.textures = {item_texture} - prop.visual_size = {x=0.3, y=0.3} - else - prop.visual = "wielditem" - prop.textures = {itemname} - prop.visual_size = {x=0.15, y=0.15} - end - self.object:set_properties(prop) + action = function(pos, node, active_object_count, active_object_count_wider) + local pos1={} + pos1.x = pos.x + pos1.y = pos.y-1 + pos1.z = pos.z + local meta=minetest.env:get_meta(pos1) + if meta:get_int("tubelike")==1 then inject_items (pos) end end, - - get_staticdata = function(self) - - return minetest.serialize({ - itemstring=self.itemstring, - velocity=self.object:getvelocity(), - start_pos=self.start_pos - }) - end, - - on_activate = function(self, staticdata) --- print (dump(staticdata)) - if staticdata=="" or staticdata==nil then return end - local item = minetest.deserialize(staticdata) - local stack = ItemStack(item.itemstring) - local itemtable = stack:to_table() - local itemname = nil - if itemtable then - itemname = stack:to_table().name - end - - if itemname then - self.start_pos=item.start_pos - self.object:setvelocity(item.velocity) - self.object:setacceleration({x=0, y=0, z=0}) - self.object:setpos(item.start_pos) - end - self:set_item(item.itemstring) - end, - - on_step = function(self, dtime) - if self.start_pos then - local pos = self.object:getpos() - local node = minetest.env:get_node(pos) - local meta = minetest.env:get_meta(pos) - tubelike=meta:get_int("tubelike") - local stack = ItemStack(self.itemstring) - local drop_pos=nil - - local velocity=self.object:getvelocity() - - if velocity==nil then print ("wypadl") return end - - if math.abs(velocity.x)==1 then - local next_node=math.abs(pos.x-self.start_pos.x) - if next_node >= 1 then - self.start_pos.x=self.start_pos.x+velocity.x - if check_pos_vector (self.start_pos, velocity)==0 then - if check_next_step (self.start_pos, velocity)==0 then - drop_pos=minetest.env:find_node_near({x=self.start_pos.x,y=self.start_pos.y,z=self.start_pos.z+velocity.x}, 1, "air") - if drop_pos then minetest.item_drop(stack, "", drop_pos) end - self.object:remove() - end - self.object:setpos(self.start_pos) - self.object:setvelocity(velocity) - return - end - end - end - - if math.abs(velocity.y)==1 then - local next_node=math.abs(pos.y-self.start_pos.y) - if next_node >= 1 then - self.start_pos.y=self.start_pos.y+velocity.y - if check_pos_vector (self.start_pos, velocity)==0 then - if check_next_step (self.start_pos, velocity)==0 then - drop_pos=minetest.env:find_node_near({x=self.start_pos.x+velocity.x,y=self.start_pos.y+velocity.y,z=self.start_pos.z+velocity.z}, 1, "air") - if drop_pos then minetest.item_drop(stack, "", drop_pos) end - self.object:remove() - end - self.object:setpos(self.start_pos) - self.object:setvelocity(velocity) - return - end - end - end - - if math.abs(velocity.z)==1 then - local next_node=math.abs(pos.z-self.start_pos.z) - if next_node >= 1 then - self.start_pos.z=self.start_pos.z+velocity.z - if check_pos_vector (self.start_pos, velocity)==0 then - if check_next_step (self.start_pos, velocity)==0 then - drop_pos=minetest.env:find_node_near({x=self.start_pos.x+velocity.x,y=self.start_pos.y+velocity.y,z=self.start_pos.z+velocity.z}, 1, "air") - if drop_pos then minetest.item_drop(stack, "", drop_pos) end - self.object:remove() - end - self.object:setpos(self.start_pos) - self.object:setvelocity(velocity) - return - end - end - end - end - -end }) - -function check_next_step (pos,velocity) -local meta -local tubelike - -if velocity.x==0 then -meta = minetest.env:get_meta({x=pos.x-1,y=pos.y,z=pos.z}) -tubelike=meta:get_int("tubelike") -if tubelike==1 then velocity.x=-1 velocity.y=0 velocity.z=0 return 1 end -meta = minetest.env:get_meta({x=pos.x+1,y=pos.y,z=pos.z}) -tubelike=meta:get_int("tubelike") -if tubelike==1 then velocity.x=1 velocity.y=0 velocity.z=0 return 1 end -end - -if velocity.z==0 then -meta = minetest.env:get_meta({x=pos.x,y=pos.y,z=pos.z+1}) -tubelike=meta:get_int("tubelike") -if tubelike==1 then velocity.x=0 velocity.y=0 velocity.z=1 return 1 end -meta = minetest.env:get_meta({x=pos.x,y=pos.y,z=pos.z-1}) -tubelike=meta:get_int("tubelike") -if tubelike==1 then velocity.x=0 velocity.y=0 velocity.z=-1 return 1 end -end - -if velocity.y==0 then -meta = minetest.env:get_meta({x=pos.x,y=pos.y+1,z=pos.z}) -tubelike=meta:get_int("tubelike") -if tubelike==1 then velocity.x=0 velocity.y=1 velocity.z=0 return 1 end -meta = minetest.env:get_meta({x=pos.x,y=pos.y-1,z=pos.z}) -tubelike=meta:get_int("tubelike") -if tubelike==1 then velocity.x=0 velocity.y=-1 velocity.z=0 return 1 end -end - -print ("spadl") -return 0 -end - -function check_pos_vector (pos,velocity) -added={} -added.x=pos.x+velocity.x -added.y=pos.y+velocity.y -added.z=pos.z+velocity.z -local meta=minetest.env:get_meta(added) ---print(dump(added).." : "..tubelike) -if meta:get_int("tubelike")==1 then return 1 end -return 0 -end - -function add_new_TUBE_node (TUBE_nodes,pos1,parent) -local i=1 - repeat - if TUBE_nodes[i]==nil then break end - if pos1.x==TUBE_nodes[i].x and pos1.y==TUBE_nodes[i].y and pos1.z==TUBE_nodes[i].z then return false end +function inject_items (pos) + local meta=minetest.env:get_meta(pos) + local inv = meta:get_inventory() + local i=0 + for _,stack in ipairs(inv:get_list("main")) do i=i+1 - until false -TUBE_nodes[i]={} -TUBE_nodes[i].x=pos1.x -TUBE_nodes[i].y=pos1.y -TUBE_nodes[i].z=pos1.z -TUBE_nodes[i].parent_x=parent.x -TUBE_nodes[i].parent_y=parent.y -TUBE_nodes[i].parent_z=parent.z - -return true + if stack then + local item0=stack:to_table() + if item0 then + item0["count"]="1" + local item1=tube_item({x=pos.x,y=pos.y,z=pos.z},item0) + item1:get_luaentity().start_pos = {x=pos.x,y=pos.y,z=pos.z} + item1:setvelocity({x=0, y=-1, z=0}) + item1:setacceleration({x=0, y=0, z=0}) + stack:take_item(1); + inv:set_stack("main", i, stack) + return + end + end + end end - -function check_TUBE_node (TUBE_nodes,CHEST_nodes,i) - local pos1={} - local parent={} - pos1.x=TUBE_nodes[i].x - pos1.y=TUBE_nodes[i].y - pos1.z=TUBE_nodes[i].z - parent.x=pos1.x - parent.y=pos1.y - parent.z=pos1.z - new_node_added=false - - pos1.x=pos1.x+1 - check_TUBE_node_subp (TUBE_nodes,CHEST_nodes,pos1,parent) - pos1.x=pos1.x-2 - check_TUBE_node_subp (TUBE_nodes,CHEST_nodes,pos1,parent) - pos1.x=pos1.x+1 - - pos1.y=pos1.y+1 - check_TUBE_node_subp (TUBE_nodes,CHEST_nodes,pos1,parent) - pos1.y=pos1.y-2 - check_TUBE_node_subp (TUBE_nodes,CHEST_nodes,pos1,parent) - pos1.y=pos1.y+1 - - pos1.z=pos1.z+1 - check_TUBE_node_subp (TUBE_nodes,CHEST_nodes,pos1,parent) - pos1.z=pos1.z-2 - check_TUBE_node_subp (TUBE_nodes,CHEST_nodes,pos1,parent) - pos1.z=pos1.z+1 -return new_node_added -end - -function check_TUBE_node_subp (TUBE_nodes,CHEST_nodes,pos1,parent) -meta = minetest.env:get_meta(pos1) -if meta:get_float("tubelike")==1 then add_new_TUBE_node(TUBE_nodes,pos1,parent) return end -nctr = minetest.env:get_node(pos1) -if minetest.get_item_group(nctr.name, "tubedevice_receiver") == 1 then add_new_TUBE_node(CHEST_nodes,pos1,parent) return end -end \ No newline at end of file diff --git a/technic/textures/technic_injector_bottom.png b/technic/textures/technic_injector_bottom.png new file mode 100644 index 0000000000000000000000000000000000000000..39916bd220aa3f8c7d76a68a99adddbd59bd6c7b GIT binary patch literal 2667 zcmV-x3Y7JUP)Px#24YJ`L;(K){{a7>y{D4^000SaNLh0L01l=A01l=Bhuo=e00007bV*G`2i*b# z3nMIwC9S*w014|!L_t(o!-bYvk7dbKg})fieC|ADWmVSXZnt}~8%vhlfIt}BFZ=<- z1O6-ZV|X;Lj1p}cTS5rvM(Q>goHgWBnOT{6$8*mRCnEfCvx`QkL_EbqM69)UtiARY zKl!si^?8=j9}L;7S17Hh%8JQ!f~g8to02riSS;r3?eDXkUlXS}b-AT=;H)7EL!u;O zy}V&E+hem@qQiu;ScCV(X+}{LWNE^3wPJ7Y4%e^FX!YM#Ta+Ye3f8gRR@7xp>jhdVnyR5FE1YvgK}2I( z_V;F-9G{TneSY!Tr-)BJ`H^?6V=@_$rWs}3(CcK}%op^#8Fg)GT1y;htn-+rrYH)W zZBb!@z@sIoFeVNInzp6i$yu%oY}+D)XFQp4eSOWK*X3qD$2mu9J?r%n@q_Pw=pQ|P zi~0PTTp7N7Fr{fN-895ChNiL9jlnrE&eQ2+gn?pJZt+&2qz9=GfOjo{lz5?NJ;Y&1 zRo6HV&ReWCT;8mCezD?*zx#Xq{Ij2-N0S-G7&^TX!{(Ilj3WkVf_0wdYJ-*$9)Zvr zFEvsLbfAgU1SciVxmy4St;cGG-If?JYZZ>Oh9v?*%#TM@@LWQi%nzE?y-lL_&H!V&GtaVsmwOld1b3k2f z8PE36hyV2-y!Fm|oSq!<{w%_KM_oB;-J*rYW9jvV#QiB@lJM)}Q~vRvzvA%hiut<4 zdrv=4xHHQ6_`QcryD2))*{oLtfxs(?@L&T?+ZvKI<>~nu_aA?U)#3)dfA4_preHFi z(3%U9uur5kN-LZL5$25UJ!G|9@Ry%{&Zqx&$fBqaQXsrX2*LHbUaQkFGM)6!Ii)>y7LCFjeU zhYufea&nBmckcixHQi7nSuh=R&{`1(0omjZ8Sv+S_fP!d%OjLhNGb5vfe?7_5mMrv z+ldu{R+4``d9uBDM8s{utcy1cYz0QcTs+ms4$n%Q}k~rex;*ul|2oxwG zNV+{zJpb_TzvSm%9-);)-~oZu8m$yUNdT1A|3l6>w3K{tc*(DhUm=u7Yk^jdGzv)L zkkivMI(f$N@i98jQapmY`}=IxFLAbq)RIJpJUcz(r=R^2V;usJN^yRE&YPBylIdgu z?0n&GK7Ya8QBD*9LSnHPYZ(p(yt=$%Hk%?>>jJG6SJzi0X^aXWOB1X&{PeT0*i;SR zZ(|p41XoHi8V>Q^(9%7wiQxxdI zaL9VOWH1`jzFHB65z>P-?l$cpgupq6QtJOD@O1{dWFXEE2nK^8 z^7+$4di_2pN6!fZO`a#jNlX+f0wr%Bv#*J~F>>!;?|0y@8Ii@BEDh;oF!|;EBeyst70Ppc` zR|)sW9Xe42KragMwk3>ndc7XAyZ6!0o*nY`Tkr7llb&gT5gY~<~XmNH)-W_mpdW1fB@DS&B zQ%hZ6qGg}ffz+A@dt*NNUd>;9{(M&f9`ZbAKA+>=&JFp7M!qRl@8OSs@R(Rj0zuVv9iTNO%td1oE{_dGAn4^8S904-R@X^?!ba&N^MRRwQYL zvn9PO#yWvi5-lY{N}?d7YAiqe;1Q1wru_Bi&v<%vMb)$jA?W1^-@ZHIqepuLp`@u> z9?TLNQ=_#;;ZQonID=Z&^oLypo~+YBFBeN@(|t}~p0GdAcpwONz*>r(`3UG_3G2qv z%ToU2cizRP39SR$8cb24C6vw+2+1%Cux*P( zgoIwNhYm{ur7?g;V!gz>T_#!}4m4UTHdTZ3g0`%vtC~Q1gbvy7! zkvc#%0j9a(-FM%ktXr})LC@z4#*;l3^Eu5>U~G$b-~)kDl29p(^ElHY!w}Q9^s@w~ z19YBJZns$PiGz@0yTNyWZlBLr6(kRu~j*Q)98TO@j_R+iii6 zk|2qYUb3|?9*>biFdUB27Z>OByM3zdh8K0swJm8)gR`DI(cCOIjK))5zC2_woUmCR z)5&w59{!BU-T_ThW2y~F)v*~4BNK5sWk{N)>4-x)9IADF7XJgwRq=ox5G(U76dwEFz9hJU(xMkES4+c zD57l}tb|u{+P)Px#24YJ`L;(K){{a7>y{D4^000SaNLh0L01l=A01l=Bhuo=e00007bV*G`2i*b# z3nLmupExA|010hLL_t(o!!4Fci)2f3g+DVN?hp|fky)8Fy+?I74K0ZV?X+oxXwZ+) zLg>Hf*9i%<5z<1an||=BDrr>6%( z(=!c645Qm@IS&Jye#6u0$g7vH_~r9Qa;Z4)VvN&@0C-|_HtLIpx_TwPsrJU-F)9jD`wuImuj@ae-ld?}gz{)$hZKk=KJ$lv|V z8=OKHUvPXpp|>|IIb#(}_4{L3mKEEi`K;i@{nM>PW4|v@9sX1yLifBdzz$&hRb} zT90JGs?j!quiqXJDjGs0tt+L1D0D&Cw@M!s=fDZH+nzO7meV7fE?`uqWo0c1=N%%@ z1V`5f8t?E_g7=tIsFigYS*MATGd>2MP6JoF9n}PXKA-6NEwv;>lyOdYDfkfZ-r?0V z&Y5b3R5Hh3zOvMUBA`mniINLzDYVX0s-U8%hjCu9l9@}Qq>2IO(}LjW`<|Q={`%&Y zS_-jg!A^u2aiX+QF;O}ZYE3la*&KE_ao-DP;>|U>tc=GKr!^7GC>2r_Qp)sQ19bRx zp~gy8h?CLM^6>b??d@}X-?jYJ@BW(m5BI#ed(CF!>AIfi94bOKL(GUxL#jqLBb7qi zG{mN1VnnVtbn8mjwm5avQkj;SS}UeXUK3R+B_+x(BM&P-zWIT5KH}fLeT#FRm#=={ z|2}--{cg`Z{X)Ol^7+$8?rxvc_8lKSyyfopmT@?;+h1e#%y2$4o=0}OE&XQ8{rf+2 zdw0h?P3#W`9=|Yk*lxExJ`Mb;8~MX;e`M1%G;zbXuTS_}C6$OeM^Q(J0Z~u{=L4l= ziV0v?DTs5_RLC??jX7sbE6WaQJ@Gyp|8>9edbh>9fM4c`u5bDL2p-i;@Re3Q>OF{n3;4cgSrg~sk*j{gY8lH$6`__& zP6aUfHj+yvyG-AD=4r-qW-N)cRw}}pR_4h#91Z|@7XqpZ;>fv@t7Agw3@XqTV;u&Z zdagGc1i54bm*{SuQOAjK7#L>5azRkMbId8BF@Od9qG+sC2jyv|-)uPz1N*}PKTR`N z+dW?%A9!=)x#~RX15pL1?)$3sI8`#R8dNi4Y&m{=KtvFAY&RX9zYsLdE8G4OV8)UN z;wd%bV`SS+{Pgk2n_vBwwrP!YYnxP)nunI?BTl6~#Hd_<(nw5F>dR z5!+!oW7QCZX_<*l!2lIQ1Ox~=A?l$N=9G~&FQ^7s#rOS|rfG1_@i0xiJIpPmR$B)y*a5}Nu?WnTnPfI`q(y4$YswvN& zJ>&lUJvZ0SIQ{a3_m$88`9JjA4Ng5up^760M@r?AlG={(Jh0tt2{H0`|3KSE^3@xj zcP;1POfCgKoQ~Yx-hsh1ol)m0CE=W>iGh+9?(gpj&hhy0jaoC&2M&kbWrMB@p=+rX ztmN;~GsfYB)y#P~;anh>gwvj78tL1H^V3)6@y!1Nm4SqjF|avM00000NkvXXu0mjf Dj+V}Q literal 0 HcmV?d00001 diff --git a/technic/textures/technic_injector_top.png b/technic/textures/technic_injector_top.png new file mode 100644 index 0000000000000000000000000000000000000000..440649ce85ded27b5fd2641da71fa5a90818f259 GIT binary patch literal 2633 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 Dj+V}Q literal 0 HcmV?d00001 diff --git a/technic/textures/technicx32/technic_injector_top.png b/technic/textures/technicx32/technic_injector_top.png new file mode 100644 index 0000000000000000000000000000000000000000..440649ce85ded27b5fd2641da71fa5a90818f259 GIT binary patch literal 2633 zcmV-P3byr$P)Px#24YJ`L;(K){{a7>y{D4^000SaNLh0L01l=A01l=Bhuo=e00007bV*G`2i*b# z3nKg4plb>^jfji|oXuv(^|P0_yAR*<>tFvZfB3II@cbvI zY_@xLyFIP1P?2ME;}C%{7c7n(6=Ps~IN%Ue;V=$(F^ubxIP|C*Qi)ja5M$VnBk9nw z+xM)Wwp?7^@WY4iabN%G&v{%v^8CeDtk-vpXARC7#$3oM>`TJiLwJQWJ2ynHrq94XQw1BvIpEgzR14xtJT z?;Iinn|+TW3~6NfkVq6%!T3OBz~w?;3WxokF$qqTqRJ3QVoKzch-0E4><=BwwetFB zH8CdK%a^Y(#&HrHh80)y8O~WMYsp4v#iAmJbr@#=FfNdCq`tf$u6OMB2eyX;4TfTb zF=xhQyq2WHa=A3l7* zOeZah@Z$M%cH0A`C^=_L$|TKb&cu?5Ig?AFXa?`t>~|DZ$Pw{|5NfcVR0>1a+37bX1m8Z%a_M5G;NIyLLDsGz)@(6YQb8A3K$if2u6f) z9O-^!eM*U3GKgh%Hpf;Kb~>dvhgb{7AXwVzl%h&IY54r*5jUToF$^P@7ng{va5kXU z5S+zWOBTUdhbV-il%im>VBJwd z&6F5PIg_;@Vo(FFay+hfs5>W@!fwCE&Ck!-uGh>jE=iv^_)tO22wVKqBS8eK z1?z;A6LsAXd^qyJ8jKNEn*qrQA3WX&bqH7^h!adW4s09*XK3q+x~|9^lhNwwfv)el zzk82)^(Q}}=rOenLw77RLfy7BRf8xXO3^|6)rlt#Bl~_Njw1j?45=F^0^%)JGu~TL zzeSzHI7cakm?G8~#OU!9TgQ+_j94-wVl2)XQp|L_70$or;nN-N>(@W$@ylnXr>8uw z-tjmUN>)%oD5wR^iULNJB+A%F3a}Y=C}3?MG!=0e5o^$NpojtCc(%QRl<`%?!{-NX zUVKH@b=*9EiMxCMj_YTy==WQ$XEWxL1_3O97_756F?jD$1gxR*fyu==VjYK=X(lyK z_n+yzj+ir2lzxAp?+yrpaAbgzsH=+ipYHhOpZ^vA^Pm5Lo6Jsd&eF6KO71wF)Z`)< zYjDOOMyP#_D!BR>(|ldy>Wa;w=X5sZ@o9}mu%V(W8C$^Qqg$MFSPIq!Vu{%Gz}fi; zf-;%SFzeNtD%31jD}r+<;Jv{)gL6Xgjv|T+9%C)edU8JyQ=|$N``r!~Bb75uW)l{( z86L%3q4o}I1Y;dZGo@q@;oZA;h!*;O#9du25Cf;Dr?}AJts?>sLso;9<0di?$4KoV zt0Gv&{ehtya8|J{V6CN3BQ|)f6o>{zu_(rQ?C6Q(6TkSyFX@KFq-`+EGHcF`=bkfM6|Ik2b>?`WW%np+lstYwFq|*5Sml-)u?4fD?ig7*c{gf)qn3r$^-HzU)w!o`82VbpNQaCv!&5#jv&5_f<9iL;Y4`ooUzhk?i3k>W_n z%CvDjt#@2pUh(nc8|LQ=cH0lkrc?g-=65V^UNMdXvER{5PB5aV3f>v2c1pM3QdJc` zG<<$|$N9w>`#rQxq^fIHt0&~UfBFa2qAaei$v*~2?>#YRhOXo4>WX3LP=uT_T9g6^ zLf7r_E-;^;^0eG=GMlhkZ>Xz^ltyxa*`x)IHDK87w#-jY_~HJ6q1$2Gruxk{zxoD5 z5R|H}Q3`bxSX`d5*=?!nhLSU(su2?NvpFS?G?NL=S*#JJ(