diff options
| author | Vanessa Ezekowitz <vanessaezekowitz@gmail.com> | 2012-08-24 13:39:29 -0400 | 
|---|---|---|
| committer | Vanessa Ezekowitz <vanessaezekowitz@gmail.com> | 2012-08-24 13:39:29 -0400 | 
| commit | 4a834d17b28cd0d39fd116c67d3107a586f017f8 (patch) | |
| tree | 608eb768312fc5f9e166b64e840152ed5a920046 | |
| parent | 83f853d2ae772f55b31307d0573b64820e274262 (diff) | |
Added pneumatic tubes with their own autoplace code (does not connect to
steel pipes).  Fixed a recursion bug that sometimes caused a stack overflow.
| -rw-r--r-- | autoplace.lua | 52 | ||||
| -rw-r--r-- | changelog.txt | 3 | ||||
| -rw-r--r-- | init.lua | 17 | ||||
| -rw-r--r-- | textures/pipeworks_tube_end.png | bin | 0 -> 482 bytes | |||
| -rw-r--r-- | textures/pipeworks_tube_inv.png | bin | 0 -> 508 bytes | |||
| -rw-r--r-- | textures/pipeworks_tube_noctr.png | bin | 0 -> 385 bytes | |||
| -rw-r--r-- | textures/pipeworks_tube_plain.png | bin | 0 -> 399 bytes | |||
| -rw-r--r-- | textures/pipeworks_tube_short.png | bin | 0 -> 269 bytes | |||
| -rw-r--r-- | textures/pipeworks_tube_transparent.png | bin | 0 -> 109 bytes | |||
| -rw-r--r-- | tubes.lua | 198 | 
10 files changed, 258 insertions, 12 deletions
| diff --git a/autoplace.lua b/autoplace.lua index 2f7c7f1..492f558 100644 --- a/autoplace.lua +++ b/autoplace.lua @@ -1,4 +1,6 @@ -pipe_scanforobjects = function(pos) +-- autorouting for pipes + +function pipe_scanforobjects(pos)  	pipe_autoroute({ x=pos.x-1, y=pos.y  , z=pos.z   }, "_loaded")  	pipe_autoroute({ x=pos.x+1, y=pos.y  , z=pos.z   }, "_loaded")  	pipe_autoroute({ x=pos.x  , y=pos.y-1, z=pos.z   }, "_loaded") @@ -17,19 +19,59 @@ pipe_scanforobjects = function(pos)  end  function pipe_autoroute(pos, state) -  	nctr = minetest.env:get_node(pos)  	if (string.find(nctr.name, "pipeworks:pipe_") == nil) then return end  	pipes_scansurroundings(pos)  	nsurround = pxm..pxp..pym..pyp..pzm..pzp -	  	if nsurround == "000000" then nsurround = "110000" end -  	minetest.env:add_node(pos, { name = "pipeworks:pipe_"..nsurround..state })  end +-- autorouting for pneumatic tubes + +function tube_scanforobjects(pos) +	tube_autoroute({ x=pos.x-1, y=pos.y  , z=pos.z   }) +	tube_autoroute({ x=pos.x+1, y=pos.y  , z=pos.z   }) +	tube_autoroute({ x=pos.x  , y=pos.y-1, z=pos.z   }) +	tube_autoroute({ x=pos.x  , y=pos.y+1, z=pos.z   }) +	tube_autoroute({ x=pos.x  , y=pos.y  , z=pos.z-1 }) +	tube_autoroute({ x=pos.x  , y=pos.y  , z=pos.z+1 }) +	tube_autoroute(pos) +end + +function tube_autoroute(pos) +	nctr = minetest.env:get_node(pos) +	if (string.find(nctr.name, "pipeworks:tube_") == nil) then return end + +	pxm=0 +	pxp=0 +	pym=0 +	pyp=0 +	pzm=0 +	pzp=0 + +	nxm = minetest.env:get_node({ x=pos.x-1, y=pos.y  , z=pos.z   }) +	nxp = minetest.env:get_node({ x=pos.x+1, y=pos.y  , z=pos.z   }) +	nym = minetest.env:get_node({ x=pos.x  , y=pos.y-1, z=pos.z   }) +	nyp = minetest.env:get_node({ x=pos.x  , y=pos.y+1, z=pos.z   }) +	nzm = minetest.env:get_node({ x=pos.x  , y=pos.y  , z=pos.z-1 }) +	nzp = minetest.env:get_node({ x=pos.x  , y=pos.y  , z=pos.z+1 }) + +	if (string.find(nxm.name, "pipeworks:tube_") ~= nil) then pxm=1 end +	if (string.find(nxp.name, "pipeworks:tube_") ~= nil) then pxp=1 end +	if (string.find(nym.name, "pipeworks:tube_") ~= nil) then pym=1 end +	if (string.find(nyp.name, "pipeworks:tube_") ~= nil) then pyp=1 end +	if (string.find(nzm.name, "pipeworks:tube_") ~= nil) then pzm=1 end +	if (string.find(nzp.name, "pipeworks:tube_") ~= nil) then pzp=1 end + +	nsurround = pxm..pxp..pym..pyp..pzm..pzp +	minetest.env:add_node(pos, { name = "pipeworks:tube_"..nsurround }) +end + +-- auto-rotation code for various devices the tubes attach to +  function pipe_device_autorotate(pos, state, bname)  	if state == nil then @@ -53,7 +95,7 @@ function pipe_device_autorotate(pos, state, bname)  end -pipes_scansurroundings = function(pos) +function pipes_scansurroundings(pos)  	pxm=0  	pxp=0  	pym=0 diff --git a/changelog.txt b/changelog.txt index 8db2a4a..9e51430 100644 --- a/changelog.txt +++ b/changelog.txt @@ -1,6 +1,9 @@  Changelog  --------- +2012-08-24: Added square-ish pneumatic tubes, with their own autoplace code  +(they do not connect to the steel pipes or their related devices). +  2012-08-22: Added outlet grate, made it participate in autoplace algorithm.    Extended storage tank to show fill level in 10% steps (0% to 100%).  Added   "expansion tank" that appears if the user stacks tanks upwards.  (Downwards is  @@ -1,13 +1,15 @@  -- Pipeworks mod by Vanessa Ezekowitz - 2012-08-05  -- --- Entirely my own code.  This mod merely supplies enough nodes to build  --- a bunch of pipes in all directions and with all types of junctions +-- Entirely my own code.  This mod supplies various shapes of pipes +-- and devices that they can connect to such as pumps, valves, etc. +-- All pipes autoconnect as you lay them out, and devices will auto- +-- connect to them.  --  -- License: WTFPL  -- --- comment-out the following dofile line to disnable the old pipe nodes. -dofile(minetest.get_modpath("pipeworks").."/oldpipes.lua") +-- Un-comment the following dofile line to re-enable the old pipe nodes. +-- dofile(minetest.get_modpath("pipeworks").."/oldpipes.lua")  -- tables @@ -116,7 +118,7 @@ dbg = function(s)  	end  end -function fix_newpipe_names(table, replacement) +function pipes_fix_image_names(table, replacement)  	outtable={}  	for i in ipairs(table) do  		outtable[i]=string.gsub(table[i], "_XXXXX", replacement) @@ -249,7 +251,7 @@ for zp = 0, 1 do  	minetest.register_node("pipeworks:pipe_"..pname.."_empty", {  		description = pipedesc,  		drawtype = "nodebox", -		tiles = fix_newpipe_names(outimgs, "_empty"), +		tiles = pipes_fix_image_names(outimgs, "_empty"),  		paramtype = "light",  		selection_box = {  	             	type = "fixed", @@ -280,7 +282,7 @@ for zp = 0, 1 do  	minetest.register_node("pipeworks:pipe_"..pname.."_loaded", {  		description = "Pipe segment (loaded, "..pname..")... You hacker, you.",  		drawtype = "nodebox", -		tiles = fix_newpipe_names(outimgs, "_loaded"), +		tiles = pipes_fix_image_names(outimgs, "_loaded"),  		paramtype = "light",  		selection_box = {  	             	type = "fixed", @@ -314,6 +316,7 @@ end  end  end +dofile(minetest.get_modpath("pipeworks").."/tubes.lua")  dofile(minetest.get_modpath("pipeworks").."/devices.lua")  dofile(minetest.get_modpath("pipeworks").."/autoplace.lua") diff --git a/textures/pipeworks_tube_end.png b/textures/pipeworks_tube_end.pngBinary files differ new file mode 100644 index 0000000..e35edb3 --- /dev/null +++ b/textures/pipeworks_tube_end.png diff --git a/textures/pipeworks_tube_inv.png b/textures/pipeworks_tube_inv.pngBinary files differ new file mode 100644 index 0000000..93c51b1 --- /dev/null +++ b/textures/pipeworks_tube_inv.png diff --git a/textures/pipeworks_tube_noctr.png b/textures/pipeworks_tube_noctr.pngBinary files differ new file mode 100644 index 0000000..5add4cf --- /dev/null +++ b/textures/pipeworks_tube_noctr.png diff --git a/textures/pipeworks_tube_plain.png b/textures/pipeworks_tube_plain.pngBinary files differ new file mode 100644 index 0000000..2d9c8d8 --- /dev/null +++ b/textures/pipeworks_tube_plain.png diff --git a/textures/pipeworks_tube_short.png b/textures/pipeworks_tube_short.pngBinary files differ new file mode 100644 index 0000000..ba69c08 --- /dev/null +++ b/textures/pipeworks_tube_short.png diff --git a/textures/pipeworks_tube_transparent.png b/textures/pipeworks_tube_transparent.pngBinary files differ new file mode 100644 index 0000000..4b4ee1f --- /dev/null +++ b/textures/pipeworks_tube_transparent.png diff --git a/tubes.lua b/tubes.lua new file mode 100644 index 0000000..fb606a0 --- /dev/null +++ b/tubes.lua @@ -0,0 +1,198 @@ +-- This file supplies pneumatic tubes. + +-- tables + +minetest.register_alias("pipeworks:tube", "pipeworks:tube_000000") + +tube_leftstub = { +	{ -32/64, -9/64, -9/64, 9/64, 9/64, 9/64 },	-- tube segment against -X face +} + +tube_rightstub = { +	{ -9/64, -9/64, -9/64,  32/64, 9/64, 9/64 },	-- tube segment against +X face +} + +tube_bottomstub = { +	{ -9/64, -32/64, -9/64,   9/64, 9/64, 9/64 },	-- tube segment against -Y face +} + + +tube_topstub = { +	{ -9/64, -9/64, -9/64,   9/64, 32/64, 9/64 },	-- tube segment against +Y face +} + +tube_frontstub = { +	{ -9/64, -9/64, -32/64,   9/64, 9/64, 9/64 },	-- tube segment against -Z face +} + +tube_backstub = { +	{ -9/64, -9/64, -9/64,   9/64, 9/64, 32/64 },	-- tube segment against -Z face +}  + +tube_selectboxes = { +	{ -32/64,  -10/64,  -10/64,  10/64,  10/64,  10/64 }, +	{ -10/64 ,  -10/64,  -10/64, 32/64,  10/64,  10/64 }, +	{ -10/64 , -32/64,  -10/64,  10/64,  10/64,  10/64 }, +	{ -10/64 ,  -10/64,  -10/64,  10/64, 32/64,  10/64 }, +	{ -10/64 ,  -10/64, -32/64,  10/64,  10/64,  10/64 }, +	{ -10/64 ,  -10/64,  -10/64,  10/64,  10/64, 32/64 } +} + +--  Functions + +function tube_addbox(t, b) +	for i in ipairs(b) +		do table.insert(t, b[i]) +	end +end + +-- now define the nodes! + +for xm = 0, 1 do +for xp = 0, 1 do +for ym = 0, 1 do +for yp = 0, 1 do +for zm = 0, 1 do +for zp = 0, 1 do +	local outboxes = {} +	local outsel = {} +	local outimgs = {} + +	if yp==1 then +		tube_addbox(outboxes, tube_topstub) +		table.insert(outsel, tube_selectboxes[4]) +		table.insert(outimgs, "pipeworks_tube_noctr.png") +	else +		table.insert(outimgs, "pipeworks_tube_plain.png") +	end +	if ym==1 then +		tube_addbox(outboxes, tube_bottomstub) +		table.insert(outsel, tube_selectboxes[3]) +		table.insert(outimgs, "pipeworks_tube_noctr.png") +	else +		table.insert(outimgs, "pipeworks_tube_plain.png") +	end +	if xp==1 then +		tube_addbox(outboxes, tube_rightstub) +		table.insert(outsel, tube_selectboxes[2]) +		table.insert(outimgs, "pipeworks_tube_noctr.png") +	else +		table.insert(outimgs, "pipeworks_tube_plain.png") +	end +	if xm==1 then +		tube_addbox(outboxes, tube_leftstub) +		table.insert(outsel, tube_selectboxes[1]) +		table.insert(outimgs, "pipeworks_tube_noctr.png") +	else +		table.insert(outimgs, "pipeworks_tube_plain.png") +	end +	if zp==1 then +		tube_addbox(outboxes, tube_backstub) +		table.insert(outsel, tube_selectboxes[6]) +		table.insert(outimgs, "pipeworks_tube_noctr.png") +	else +		table.insert(outimgs, "pipeworks_tube_plain.png") +	end +	if zm==1 then +		tube_addbox(outboxes, tube_frontstub) +		table.insert(outsel, tube_selectboxes[5]) +		table.insert(outimgs, "pipeworks_tube_noctr.png") +	else +		table.insert(outimgs, "pipeworks_tube_plain.png") +	end + +	local jx = xp+xm +	local jy = yp+ym +	local jz = zp+zm + +	if (jx+jy+jz) == 1 then +		if xm == 1 then  +			table.remove(outimgs, 3) +			table.insert(outimgs, 3, "pipeworks_tube_end.png") +		end +		if xp == 1 then  +			table.remove(outimgs, 4) +			table.insert(outimgs, 4, "pipeworks_tube_end.png") +		end +		if ym == 1 then  +			table.remove(outimgs, 1) +			table.insert(outimgs, 1, "pipeworks_tube_end.png") +		end +		if xp == 1 then  +			table.remove(outimgs, 2) +			table.insert(outimgs, 2, "pipeworks_tube_end.png") +		end +		if zm == 1 then  +			table.remove(outimgs, 5) +			table.insert(outimgs, 5, "pipeworks_tube_end.png") +		end +		if zp == 1 then  +			table.remove(outimgs, 6) +			table.insert(outimgs, 6, "pipeworks_tube_end.png") +		end +	end + +	local tname = xm..xp..ym..yp..zm..zp +	local tgroups = "" + +	if tname ~= "000000" then +		tgroups = {snappy=3, tube=1, not_in_creative_inventory=1} +		tubedesc = "Pneumatic tube segment ("..tname..")... You hacker, you." +		iimg=nil +	else +		tgroups = {snappy=3, tube=1} +		tubedesc = "Pneumatic tube segment" +		iimg="pipeworks_tube_inv.png" +		outimgs = { +			"pipeworks_tube_short.png", +			"pipeworks_tube_short.png", +			"pipeworks_tube_end.png", +			"pipeworks_tube_end.png", +			"pipeworks_tube_short.png", +			"pipeworks_tube_short.png" +		} +		outboxes = { -24/64, -9/64, -9/64, 24/64, 9/64, 9/64 } +		outsel = { -24/64, -10/64, -10/64, 24/64, 10/64, 10/64 } +	end +	 +	minetest.register_node("pipeworks:tube_"..tname, { +		description = tubedesc, +		drawtype = "nodebox", +		tiles = outimgs, +		inventory_image=iimg, +		wield_image=iimg, +		paramtype = "light", +		selection_box = { +	             	type = "fixed", +			fixed = outsel +		}, +		node_box = { +			type = "fixed", +			fixed = outboxes +		}, +		groups = tgroups, +		sounds = default.node_sound_wood_defaults(), +		walkable = true, +		stack_max = 99, +		drop = "pipeworks:tube_000000", +		tubelike=1, +		on_construct = function(pos) +		local meta = minetest.env:get_meta(pos) +		meta:set_int("tubelike",1) +		end, +		after_place_node = function(pos) +			tube_scanforobjects(pos) +		end, +		after_dig_node = function(pos) +			tube_scanforobjects(pos) +		end +	}) + +end +end +end +end +end +end + +print("pipeworks loaded!") | 
