aboutsummaryrefslogtreecommitdiff
path: root/stairsplus/slabs.lua
Commit message (Expand)AuthorAge
* texture transparency patches, made by erstazi THANKSOch Noe2024-09-20
* "_two_sides" also train compatibleOch Noe2021-07-28
* 1/16 slabs are now train compatibleOch Noe2021-07-28
* build a list of all of the stairsplus slab/stair/etc... shapes (#70)Vanessa Ezekowitz2017-02-23
* add a few new shapes to the table saw: (#67)Vanessa Ezekowitz2017-02-21
* Prepare for v1.0.0 releaseHugo Locurcio2017-02-19
* allow passing paramtype2 to the nodes being created (#65)Vanessa Ezekowitz2017-01-26
* Run cleanfile on all files, fixing whitespace issues.Auke Kok2016-12-31
* Add Alias Functions (#54)Thomas--S2016-10-03
* Fix drop logic. (#49)John Cole2016-07-12
* Add support for the alternative drop syntax (#46)Thomas--S2016-06-17
* Make stairplus:register_* functions work without using register_all.Pierre-Yves Rollo2015-11-01
* Additional crafting recipes for slabsMarcin2015-07-04
* Add size information to slab description (by est31).Calinou2015-03-03
* More informative and shorter headers.Calinou2015-01-12
* Add licensing headers to all files, fix intllib global variable warnings.Calinou2015-01-11
* Add compressed cobblestone, crafted with 9 cobblestone.Calinou2014-12-27
* Make Stairs+ recipes mod-agnostic.Calinou2014-07-28
* Code cleanup, new Stairs+ recipes.Calinou2014-07-21
* New recipes, code cleanup.Calinou2014-07-03
* Code cleanup. Add tar and more stone types.Calinou2014-06-27
* New recipes for Stairs+ nodes. Allows crafting most useful Stairs+ nodes. Mor...Calinou2014-05-04
* Merge ShadowNinja's rewrite.Calinou2014-03-09
* Big update: new stair types, code looks better.Calinou2014-01-20
* Rewrite slightly to use the new 6d facedir prediction code in builtin.Vanessa Ezekowitz2013-11-07
* Fix dropsCalinou2013-10-27
* New slab types: 1/16, 1/8, 7/8, 15/16 slabs (suggested by VanessaE), reorgani...Calinou2013-10-26
* Allow stair/slab crafting by default, can be disabled in _config.txtCalinou2013-09-15
* More BlocksCalinou2013-07-11
ass="hl kwd">pairs(atlatc.envs) do ac.nodes[ph]={env=en} return end end function ac.getform(pos, meta_p) local meta = meta_p or minetest.get_meta(pos) local envs_asvalues={} local ph=minetest.pos_to_string(pos) local nodetbl = ac.nodes[ph] local env, code, err = nil, "", "" if nodetbl then code=nodetbl.code or "" err=nodetbl.err or "" env=nodetbl.env or "" end local sel = 1 for n,_ in pairs(atlatc.envs) do envs_asvalues[#envs_asvalues+1]=n if n==env then sel=#envs_asvalues end end local form = "size[10,10]dropdown[0,0;3;env;"..table.concat(envs_asvalues, ",")..";"..sel.."]" .."button[4,0;2,1;save;Save]button[7,0;2,1;cle;Clear local env] textarea[0.2,1;10,10;code;Code;"..minetest.formspec_escape(code).."]" .."label[0,9.8;"..err.."]" return form end function ac.after_dig_node(pos, node, player) advtrains.invalidate_all_paths(pos) advtrains.ndb.clear(pos) local ph=minetest.pos_to_string(pos) ac.nodes[ph]=nil end function ac.on_receive_fields(pos, formname, fields, player) if not minetest.check_player_privs(player:get_player_name(), {atlatc=true}) then minetest.chat_send_player(player:get_player_name(), "Missing privilege: atlatc - Operation cancelled!") return end local meta=minetest.get_meta(pos) local ph=minetest.pos_to_string(pos) local nodetbl = ac.nodes[ph] or {} --if fields.quit then return end if fields.env then nodetbl.env=fields.env end if fields.code then nodetbl.code=fields.code end if fields.save then nodetbl.err=nil end if fields.cle then nodetbl.data={} end ac.nodes[ph]=nodetbl meta:set_string("formspec", ac.getform(pos, meta)) if nodetbl.env then meta:set_string("infotext", "LuaAutomation component, assigned to environment '"..nodetbl.env.."'") else meta:set_string("infotext", "LuaAutomation component, invalid enviroment set!") end end function ac.run_in_env(pos, evtdata, customfct_p) local ph=minetest.pos_to_string(pos) local nodetbl = ac.nodes[ph] if not nodetbl then atwarn("LuaAutomation component at",ph,": Data not in memory! Please visit component and click 'Save'!") return end local meta if minetest.get_node_or_nil(pos) then meta=minetest.get_meta(pos) end if not nodetbl.env or not atlatc.envs[nodetbl.env] then atwarn("LuaAutomation component at",ph,": Not an existing environment: "..(nodetbl.env or "<nil>")) return false end if not nodetbl.code or nodetbl.code=="" then atwarn("LuaAutomation component at",ph,": No code to run! (insert -- to suppress warning)") return false end local customfct=customfct_p or {} -- add interrupt function customfct.interrupt=function(t, imesg) assertt(t, "number") assert(t >= 0) atlatc.interrupt.add(t, pos, {type="int", int=true, message=imesg, msg=imesg}) --Compatiblity "message" field. end -- add digiline_send function, if digiline is loaded if minetest.global_exists("digiline") then customfct.digiline_send=function(channel, msg) assertt(channel, "string") digiline:receptor_send(pos, digiline.rules.default, channel, msg) end end -- add lines scheduler if enabled if advtrains.lines and advtrains.lines.sched then customfct.schedule = function(rwtime, msg) advtrains.lines.sched.enqueue(rwtime, "atlatc_env", {pos=pos, msg=msg}, advtrains.encode_pos(pos), 1) end customfct.schedule_in = function(rwtime, msg) advtrains.lines.sched.enqueue_in(rwtime, "atlatc_env", {pos=pos, msg=msg}, advtrains.encode_pos(pos), 1) end end local datain=nodetbl.data or {} local succ, dataout = atlatc.envs[nodetbl.env]:execute_code(datain, nodetbl.code, evtdata, customfct) if succ then atlatc.active.nodes[ph].data=atlatc.remove_invalid_data(dataout) else atlatc.active.nodes[ph].err=dataout atwarn("LuaAutomation ATC interface rail at",ph,": LUA Error:",dataout) if meta then meta:set_string("infotext", "LuaAutomation ATC interface rail, ERROR:"..dataout) end end if meta then meta:set_string("formspec", ac.getform(pos, meta)) end end function ac.on_digiline_receive(pos, node, channel, msg) atlatc.interrupt.add(0, pos, {type="digiline", digiline=true, channel = channel, msg = msg}) end if advtrains.lines and advtrains.lines.sched then advtrains.lines.sched.register_callback("atlatc_env", function(data) -- This adds another interrupt to the atlatc queue... there might be a better way atlatc.interrupt.add(0, data.pos, {type="schedule",schedule=true, msg=data.msg}) end) end atlatc.active=ac