From 987cc5a6a425b1f9bcd9000608dc389a45c675a1 Mon Sep 17 00:00:00 2001
From: you <ovvv@web.de>
Date: Mon, 05 Jun 2017 16:51:59 +0200
Subject: [PATCH] Add api documentation (#361)

---
 technic/machines/register/generator.lua |  119 +++++++++++++++++++++++++++++++++--------------------------
 1 files changed, 67 insertions(+), 52 deletions(-)

diff --git a/technic/machines/register/generator.lua b/technic/machines/register/generator.lua
index 7de08f3..7805bf0 100644
--- a/technic/machines/register/generator.lua
+++ b/technic/machines/register/generator.lua
@@ -1,6 +1,7 @@
 local S = technic.getter
 
 local fs_helpers = pipeworks.fs_helpers
+local tube_entry = "^pipeworks_tube_connection_metallic.png"
 
 local tube = {
 	insert_object = function(pos, node, stack, direction)
@@ -19,7 +20,8 @@
 	connect_sides = {left=1, right=1, back=1, top=1, bottom=1},
 }
 
-function technic.register_generator(data) 
+function technic.register_generator(data)
+
 	local tier = data.tier
 	local ltier = string.lower(tier)
 
@@ -82,17 +84,17 @@
 		local percent = math.floor((burn_time / burn_totaltime) * 100)
 		meta:set_string("infotext", desc.." ("..percent.."%)")
 
-		local form = ""
+		local form_buttons = ""
 		if ltier ~= "lv" then
-			form = fs_helpers.cycling_button(
+			form_buttons = fs_helpers.cycling_button(
 				meta,
-				"image_button[0,4.3;1,0.6",
+				pipeworks.button_base,
 				"splitstacks",
 				{
-					{text="", texture="pipeworks_button_off.png", addopts="false;false;pipeworks_button_interm.png"},
-					{text="", texture="pipeworks_button_on.png",  addopts="false;false;pipeworks_button_interm.png"}
+					pipeworks.button_off,
+					pipeworks.button_on
 				}
-			).."label[0.9,4.31;Allow splitting incoming stacks from tubes]"
+			)..pipeworks.button_label
 		end
 		meta:set_string("formspec", 
 			"size[8, 9]"..
@@ -102,15 +104,23 @@
 			(percent)..":default_furnace_fire_fg.png]"..
 			"list[current_player;main;0, 5;8, 4;]"..
 			"listring[]"..
-			form
+			form_buttons
 		)
 	end
-	
+
+	local tentry = tube_entry
+	if ltier == "lv" then tentry = "" end
+
 	minetest.register_node("technic:"..ltier.."_generator", {
 		description = desc,
-		tiles = {"technic_"..ltier.."_generator_top.png", "technic_machine_bottom.png",
-		         "technic_"..ltier.."_generator_side.png", "technic_"..ltier.."_generator_side.png",
-		         "technic_"..ltier.."_generator_side.png", "technic_"..ltier.."_generator_front.png"}, 
+		tiles = {
+				"technic_"..ltier.."_generator_top.png"..tentry,
+				"technic_machine_bottom.png"..tentry,
+				"technic_"..ltier.."_generator_side.png"..tentry,
+				"technic_"..ltier.."_generator_side.png"..tentry,
+				"technic_"..ltier.."_generator_side.png"..tentry,
+				"technic_"..ltier.."_generator_front.png"
+		}, 
 		paramtype2 = "facedir",
 		groups = groups,
 		connect_sides = {"bottom", "back", "left", "right"},
@@ -119,24 +129,24 @@
 		tube = data.tube and tube or nil,
 		on_construct = function(pos)
 			local meta = minetest.get_meta(pos)
+			local node = minetest.get_node(pos)
 			meta:set_string("infotext", desc)
 			meta:set_int(data.tier.."_EU_supply", 0)
 			meta:set_int("burn_time", 0)
 			meta:set_int("tube_time",  0)
-			local form = generator_formspec
-			if ltier ~= "lv" then
-				form = generator_formspec ..
-					fs_helpers.cycling_button(
+			local form_buttons = ""
+			if not string.find(node.name, ":lv_") then
+				form_buttons = fs_helpers.cycling_button(
 						meta,
-						"image_button[0,4.3;1,0.6",
+						pipeworks.button_base,
 						"splitstacks",
 						{
-							{text="", texture="pipeworks_button_off.png", addopts="false;false;pipeworks_button_interm.png"},
-							{text="", texture="pipeworks_button_on.png",  addopts="false;false;pipeworks_button_interm.png"}
+							pipeworks.button_off,
+							pipeworks.button_on
 						}
-					).."label[0.9,4.31;Allow splitting incoming stacks from tubes]"
+					)..pipeworks.button_label
 			end
-			meta:set_string("formspec", form)
+			meta:set_string("formspec", generator_formspec..form_buttons)
 			local inv = meta:get_inventory()
 			inv:set_size("src", 1)
 		end,
@@ -151,29 +161,34 @@
 			if not pipeworks.may_configure(pos, sender) then return end
 			fs_helpers.on_receive_fields(pos, fields)
 			local meta = minetest.get_meta(pos)
+			local node = minetest.get_node(pos)
 			local form = generator_formspec
-			if ltier ~= "lv" then
-				form = generator_formspec ..
-					fs_helpers.cycling_button(
+			local form_buttons = ""
+			if not string.find(node.name, ":lv_") then
+				form_buttons = fs_helpers.cycling_button(
 						meta,
-						"image_button[0,4.3;1,0.6",
+						pipeworks.button_base,
 						"splitstacks",
 						{
-							{text="", texture="pipeworks_button_off.png", addopts="false;false;pipeworks_button_interm.png"},
-							{text="", texture="pipeworks_button_on.png",  addopts="false;false;pipeworks_button_interm.png"}
+							pipeworks.button_off,
+							pipeworks.button_on
 						}
-					).."label[0.9,4.31;Allow splitting incoming stacks from tubes]"
+					)..pipeworks.button_label
 			end
-			meta:set_string("formspec", form)
+			meta:set_string("formspec", generator_formspec..form_buttons)
 		end,
-
 	})
 
 	minetest.register_node("technic:"..ltier.."_generator_active", {
 		description = desc,
-		tiles = {"technic_"..ltier.."_generator_top.png", "technic_machine_bottom.png",
-		         "technic_"..ltier.."_generator_side.png", "technic_"..ltier.."_generator_side.png",
-		         "technic_"..ltier.."_generator_side.png", "technic_"..ltier.."_generator_front_active.png"},
+		tiles = {
+			"technic_"..ltier.."_generator_top.png"..tube_entry,
+			"technic_machine_bottom.png"..tube_entry,
+			"technic_"..ltier.."_generator_side.png"..tube_entry,
+			"technic_"..ltier.."_generator_side.png"..tube_entry,
+			"technic_"..ltier.."_generator_side.png"..tube_entry,
+			"technic_"..ltier.."_generator_front_active.png"
+		},
 		paramtype2 = "facedir",
 		groups = active_groups,
 		connect_sides = {"bottom"},
@@ -193,7 +208,8 @@
         	end,
 		on_timer = function(pos, node)
 			local meta = minetest.get_meta(pos)
-			
+			local node = minetest.get_node(pos)
+
 			-- Connected back?
 			if meta:get_int(tier.."_EU_timeout") > 0 then return false end
 			
@@ -212,17 +228,17 @@
 			meta:set_int("burn_time", burn_time)
 			local percent = math.floor(burn_time / burn_totaltime * 100)
 
-			local formbuttons = ""
-			if ltier ~= "lv" then
-				form = fs_helpers.cycling_button(
+			local form_buttons = ""
+			if not string.find(node.name, ":lv_") then
+				form_buttons = fs_helpers.cycling_button(
 					meta,
-					"image_button[0,4.3;1,0.6",
+					pipeworks.button_base,
 					"splitstacks",
 					{
-						{text="", texture="pipeworks_button_off.png", addopts="false;false;pipeworks_button_interm.png"},
-						{text="", texture="pipeworks_button_on.png",  addopts="false;false;pipeworks_button_interm.png"}
+						pipeworks.button_off,
+						pipeworks.button_on
 					}
-				).."label[0.9,4.31;Allow splitting incoming stacks from tubes]"
+				)..pipeworks.button_label
 			end
 			meta:set_string("formspec", 
 				"size[8, 9]"..
@@ -232,7 +248,7 @@
 				(percent)..":default_furnace_fire_fg.png]"..
 				"list[current_player;main;0, 5;8, 4;]"..
 				"listring[]"..
-				form
+				form_buttons
 			)
 			return true
 		end,
@@ -240,18 +256,18 @@
 			if not pipeworks.may_configure(pos, sender) then return end
 			fs_helpers.on_receive_fields(pos, fields)
 			local meta = minetest.get_meta(pos)
-			local form = generator_formspec
-			if ltier ~= "lv" then
-				form = generator_formspec ..
-					fs_helpers.cycling_button(
+			local node = minetest.get_node(pos)
+			local form_buttons = ""
+			if not string.find(node.name, ":lv_") then
+				form_buttons = fs_helpers.cycling_button(
 						meta,
-						"image_button[0,4.3;1,0.6",
+						pipeworks.button_base,
 						"splitstacks",
 						{
-							{text="", texture="pipeworks_button_off.png", addopts="false;false;pipeworks_button_interm.png"},
-							{text="", texture="pipeworks_button_on.png",  addopts="false;false;pipeworks_button_interm.png"}
+							pipeworks.button_off,
+							pipeworks.button_on
 						}
-					).."label[0.9,4.31;Allow splitting incoming stacks from tubes]"
+					)..pipeworks.button_label
 			end
 
 			local burn_totaltime = meta:get_int("burn_totaltime") or 0
@@ -266,10 +282,9 @@
 				(percent)..":default_furnace_fire_fg.png]"..
 				"list[current_player;main;0, 5;8, 4;]"..
 				"listring[]"..
-				form
+				form_buttons
 			)
 		end,
-
 	})
 
 	technic.register_machine(tier, "technic:"..ltier.."_generator",        technic.producer)

--
Gitblit v1.8.0