summaryrefslogtreecommitdiff
path: root/concrete
diff options
context:
space:
mode:
Diffstat (limited to 'concrete')
-rw-r--r--concrete/init.lua608
1 files changed, 156 insertions, 452 deletions
diff --git a/concrete/init.lua b/concrete/init.lua
index bf25c32..2e263bc 100644
--- a/concrete/init.lua
+++ b/concrete/init.lua
@@ -1,6 +1,15 @@
--Minetest 0.4.7 mod: concrete
--(c) 2013 by RealBadAngel <mk@realbadangel.pl>
+local technic = technic or {}
+technic.concrete_posts = {}
+
+minetest.register_alias("technic:concrete_post", "technic:concrete_post0")
+minetest.register_alias("technic:concrete_post32", "technic:concrete_post12")
+minetest.register_alias("technic:concrete_post33", "technic:concrete_post3")
+minetest.register_alias("technic:concrete_post34", "technic:concrete_post28")
+minetest.register_alias("technic:concrete_post35", "technic:concrete_post19")
+
minetest.register_craft({
output = 'technic:rebar 6',
recipe = {
@@ -22,12 +31,12 @@ minetest.register_craft({
minetest.register_craft({
output = 'technic:concrete_post_platform 6',
recipe = {
- {'technic:concrete','technic:concrete_post','technic:concrete'},
+ {'technic:concrete','technic:concrete_post0','technic:concrete'},
}
})
minetest.register_craft({
- output = 'technic:concrete_post 12',
+ output = 'technic:concrete_post0 12',
recipe = {
{'default:stone','technic:rebar','default:stone'},
{'default:stone','technic:rebar','default:stone'},
@@ -44,500 +53,195 @@ minetest.register_craft({
}
})
-platform_box = {-0.5 , 0.3 , -0.5 , 0.5 , 0.5 , 0.5 }
-post_str_y={ -0.15 , -0.5 , -0.15 , 0.15 , 0.5 , 0.15 }
-post_str_x1={ 0 , -0.3 , -0.1, 0.5 , 0.3 , 0.1 } -- x+
-post_str_z1={ -0.1 , -0.3 , 0, 0.1 , 0.3 , 0.5 } -- z+
-post_str_x2={ 0 , -0.3 , -0.1, -0.5 , 0.3 , 0.1 } -- x-
-post_str_z2={ -0.1 , -0.3 , 0, 0.1 , 0.3 , -0.5 } -- z-
+local box_platform = {-0.5, 0.3, -0.5, 0.5, 0.5, 0.5}
+local box_center = {-0.15, -0.5, -0.15, 0.15, 0.5, 0.15}
+local box_x1 = {0, -0.3, -0.1, 0.5, 0.3, 0.1}
+local box_z1 = {-0.1, -0.3, 0, 0.1, 0.3, 0.5}
+local box_x2 = {0, -0.3, -0.1, -0.5, 0.3, 0.1}
+local box_z2 = {-0.1, -0.3, 0, 0.1, 0.3, -0.5}
minetest.register_craftitem(":technic:rebar", {
description = "Rebar",
inventory_image = "technic_rebar.png",
- stack_max = 99,
-})
-
-minetest.register_craftitem(":technic:blast_resistant_concrete", {
- description = "Blast-resistant Concrete Block",
- inventory_image = "technic_blast_resistant_concrete_block.png",
- stack_max = 99,
-})
-
-minetest.register_craftitem(":technic:concrete", {
- description = "Concrete Block",
- inventory_image = "technic_concrete_block.png",
- stack_max = 99,
-})
-
-minetest.register_craftitem(":technic:concrete_post", {
- description = "Concrete Post",
- stack_max = 99,
-})
-
-minetest.register_craftitem(":technic:concrete_post_platform", {
- description = "Concrete Post Platform",
- stack_max = 99,
})
minetest.register_node(":technic:concrete", {
description = "Concrete Block",
tile_images = {"technic_concrete_block.png",},
- is_ground_content = true,
- groups={cracky=1,level=2},
+ groups = {cracky=1, level=2, concrete=1},
sounds = default.node_sound_stone_defaults(),
- paramtype = "light",
- light_source = 0,
- sunlight_propagates = true,
- on_construct = function(pos)
- meta=minetest.env:get_meta(pos)
- meta:set_float("postlike",1)
- check_post_connections (pos,1)
+ after_place_node = function(pos, placer, itemstack)
+ technic.update_posts(pos, false)
end,
after_dig_node = function (pos, oldnode, oldmetadata, digger)
- check_post_connections (pos,0)
+ technic.update_posts(pos, false)
end,
})
minetest.register_node(":technic:blast_resistant_concrete", {
description = "Blast-resistant Concrete Block",
tile_images = {"technic_blast_resistant_concrete_block.png",},
- is_ground_content = true,
- groups={cracky=1,level=3},
+ groups={cracky=1, level=3, concrete=1},
sounds = default.node_sound_stone_defaults(),
- paramtype = "light",
- light_source = 0,
- sunlight_propagates = true,
- on_construct = function(pos)
- meta=minetest.env:get_meta(pos)
- meta:set_float("postlike",1)
- check_post_connections (pos,1)
+ after_place_node = function(pos, player, itemstack)
+ technic.update_posts(pos, false)
end,
after_dig_node = function (pos, oldnode, oldmetadata, digger)
- check_post_connections (pos,0)
+ technic.update_posts(pos, false)
end,
})
minetest.register_node(":technic:concrete_post_platform", {
description = "Concrete Post Platform",
tile_images = {"technic_concrete_block.png",},
- is_ground_content = true,
- groups={cracky=1,level=2},
- sounds = default.node_sound_stone_defaults(),
- paramtype = "light",
- light_source = 0,
- sunlight_propagates = true,
- drawtype = "nodebox",
- selection_box = {
- type = "fixed",
- fixed = {platform_box}
- },
- node_box = {
- type = "fixed",
- fixed = {platform_box}
- },
- on_place=function (itemstack, placer, pointed_thing)
- local node=minetest.env:get_node(pointed_thing.under)
- if minetest.get_item_group(node.name, "concrete_post")==0 then
- return minetest.item_place_node(itemstack, placer, pointed_thing)
- end
- local meta=minetest.env:get_meta(pointed_thing.under)
- y1=meta:get_float("y1")
- platform=meta:get_float("platform")
- if y1==1 or platform==1 then
- return minetest.item_place_node(itemstack, placer, pointed_thing)
- end
- y2=meta:get_float("y2")
- x1=meta:get_float("x1")
- x2=meta:get_float("x2")
- z1=meta:get_float("z1")
- z2=meta:get_float("z2")
- rule=make_post_rule_number(x1,x2,y1,y2,z1,z2,1)
- meta:set_float("platform",1)
- hacky_swap_posts(pointed_thing.under,"technic:concrete_post"..rule)
- itemstack:take_item()
- placer:set_wielded_item(itemstack)
- return itemstack
- end,
-})
-
-
-minetest.register_node(":technic:concrete_post", {
- description = "Concrete Post",
- tiles = {"technic_concrete_block.png"},
- groups={cracky=1,level=2,concrete_post=1},
- sounds = default.node_sound_stone_defaults(),
- paramtype = "light",
- light_source = 0,
- sunlight_propagates = true,
- drawtype = "nodebox",
- selection_box = {
- type = "fixed",
- fixed = { -0.15 , -0.5 , -0.15 , 0.15 , 0.5 , 0.15 }},
- node_box = {
- type = "fixed",
- fixed = {-0.15 , -0.5 , -0.15 , 0.15 , 0.5 , 0.15 }},
- on_construct = function(pos)
- meta=minetest.env:get_meta(pos)
- meta:set_int("postlike",1)
- meta:set_int("platform",0)
- meta:set_int("x1",0)
- meta:set_int("x2",0)
- meta:set_int("y1",0)
- meta:set_int("y2",0)
- meta:set_int("z1",0)
- meta:set_int("z2",0)
- check_post_connections (pos,1)
- end,
-
- after_dig_node = function (pos, oldnode, oldmetadata, digger)
- check_post_connections (pos,0)
- end,
-
-})
-
-local x1,x2,y1,z1,z2
-local count=0
-
-for x1 = 0, 1, 1 do --x-
- for x2 = 0, 1, 1 do --x+
- for z1 = 0, 1, 1 do --z-
- for z2 = 0, 1, 1 do --z+
-
- temp_x1={} temp_x2={} temp_z1={} temp_z2={}
-
- if x1==1 then temp_x1=post_str_x1 end
- if x2==1 then temp_x2=post_str_x2 end
- if z1==1 then temp_z1=post_str_z1 end
- if z2==1 then temp_z2=post_str_z2 end
-
-
-minetest.register_node(":technic:concrete_post"..count, {
- description = "Concrete Post",
- tiles = {"technic_concrete_block.png"},
- groups={cracky=1,level=2,not_in_creative_inventory=1,concrete_post=1},
- sounds = default.node_sound_stone_defaults(),
- drop = "technic:concrete_post",
- paramtype = "light",
- light_source = 0,
- sunlight_propagates = true,
- drawtype = "nodebox",
- selection_box = {
- type = "fixed",
- fixed = {
- temp_x1,temp_x2,post_str_y,temp_z1,temp_z2,
- }},
-
- node_box = {
- type = "fixed",
- fixed = {
- temp_x1,temp_x2,post_str_y,temp_z1,temp_z2,
- }},
-
- after_dig_node = function (pos, oldnode, oldmetadata, digger)
- check_post_connections (pos,0)
- end,
-
-})
-
-minetest.register_node(":technic:concrete_post"..count+16, {
- description = "Concrete Post",
- tiles = {"technic_concrete_block.png"},
- groups={cracky=1,level=2,not_in_creative_inventory=1,concrete_post=1},
- sounds = default.node_sound_stone_defaults(),
- drop = "technic:concrete_post_platform",
- paramtype = "light",
- light_source = 0,
- sunlight_propagates = true,
- drawtype = "nodebox",
- selection_box = {
- type = "fixed",
- fixed = {
- platform_box,temp_x1,temp_x2,post_str_y,temp_z1,temp_z2,
- }},
-
- node_box = {
- type = "fixed",
- fixed = {
- platform_box,temp_x1,temp_x2,post_str_y,temp_z1,temp_z2,
- }},
-
- after_dig_node = function (pos, oldnode, oldmetadata, digger)
- dig_post_with_platform (pos,oldnode,oldmetadata)
- end,
-})
-
-count=count+1 end end end end
-
-minetest.register_node(":technic:concrete_post32", {
- description = "Concrete Post",
- tiles = {"technic_concrete_block.png"},
- groups={cracky=1,level=2,not_in_creative_inventory=1,concrete_post=1},
- sounds = default.node_sound_stone_defaults(),
- drop = "technic:concrete_post",
- paramtype = "light",
- light_source = 0,
- sunlight_propagates = true,
- drawtype = "nodebox",
- selection_box = {
- type = "fixed",
- fixed = {-0.5,-0.3,-0.1,0.5,0.3,0.1},
- },
- node_box = {
- type = "fixed",
- fixed = {
- post_str_x1,post_str_x2,
- }},
-
- after_dig_node = function (pos, oldnode, oldmetadata, digger)
- check_post_connections (pos,0)
- end,
-})
-minetest.register_node(":technic:concrete_post33", {
- description = "Concrete Post",
- tiles = {"technic_concrete_block.png"},
- groups={cracky=1,level=2,not_in_creative_inventory=1,concrete_post=1},
- sounds = default.node_sound_stone_defaults(),
- drop = "technic:concrete_post",
- paramtype = "light",
- light_source = 0,
- sunlight_propagates = true,
- drawtype = "nodebox",
- selection_box = {
- type = "fixed",
- fixed = {
- post_str_z1,post_str_z2,
- }},
- node_box = {
- type = "fixed",
- fixed = {
- post_str_z1,post_str_z2,
- }},
-
- after_dig_node = function (pos, oldnode, oldmetadata, digger)
- check_post_connections (pos,0)
- end,
-})
-
-minetest.register_node(":technic:concrete_post34", {
- description = "Concrete Post",
- tiles = {"technic_concrete_block.png"},
- groups={cracky=1,level=2,not_in_creative_inventory=1,concrete_post=1},
- sounds = default.node_sound_stone_defaults(),
- drop = "technic:concrete_post_platform",
- paramtype = "light",
- light_source = 0,
- sunlight_propagates = true,
- drawtype = "nodebox",
- selection_box = {
- type = "fixed",
- fixed = {
- platform_box,post_str_x1,post_str_x2,
- }},
- node_box = {
- type = "fixed",
- fixed = {
- platform_box,post_str_x1,post_str_x2,
- }},
-
- after_dig_node = function (pos, oldnode, oldmetadata, digger)
- dig_post_with_platform (pos,oldnode,oldmetadata)
- end,
-})
-minetest.register_node(":technic:concrete_post35", {
- description = "Concrete Post",
- tiles = {"technic_concrete_block.png"},
- groups={cracky=1,level=2,not_in_creative_inventory=1,concrete_post=1},
+ groups={cracky=1, level=2},
sounds = default.node_sound_stone_defaults(),
- drop = "technic:concrete_post_platform",
paramtype = "light",
- light_source = 0,
- sunlight_propagates = true,
drawtype = "nodebox",
- selection_box = {
- type = "fixed",
- fixed = {
- platform_box,post_str_z1,post_str_z2,
- }},
node_box = {
type = "fixed",
- fixed = {
- platform_box,post_str_z1,post_str_z2,
- }},
- after_dig_node = function (pos, oldnode, oldmetadata, digger)
- dig_post_with_platform (pos,oldnode,oldmetadata)
+ fixed = {box_platform}
+ },
+ on_place = function (itemstack, placer, pointed_thing)
+ local node = minetest.get_node(pointed_thing.under)
+ if not technic.concrete_posts[node.name] then
+ return minetest.item_place_node(itemstack, placer, pointed_thing)
+ end
+ local links = technic.concrete_posts[node.name]
+ if links[5] ~= 0 then -- The post already has a platform
+ return minetest.item_place_node(itemstack, placer, pointed_thing)
+ end
+ local id = technic.get_post_id({links[1], links[2], links[3], links[4], 1})
+ minetest.set_node(pointed_thing.under, {name="technic:concrete_post"..id})
+ itemstack:take_item()
+ placer:set_wielded_item(itemstack)
+ return itemstack
end,
})
-dig_post_with_platform = function (pos,oldnode,oldmetadata)
- x1=tonumber(oldmetadata.fields["x1"])
- x2=tonumber(oldmetadata.fields["x2"])
- y1=tonumber(oldmetadata.fields["y1"])
- y2=tonumber(oldmetadata.fields["y2"])
- z1=tonumber(oldmetadata.fields["z1"])
- z2=tonumber(oldmetadata.fields["z2"])
- print(dump(x1))
- oldmetadata.fields["platform"]="0"
- local rule=make_post_rule_number(x1,x2,y1,y2,z1,z2,0)
- --print(dump(rule))
- oldnode.name="technic:concrete_post"..rule
- minetest.env:set_node(pos,oldnode)
- meta = minetest.env:get_meta(pos)
- meta:from_table(oldmetadata)
-end
+local function gen_post_nodebox(x1, x2, z1, z2, platform)
+ local box = {box_center}
+ if x1 ~= 0 then
+ table.insert(box, box_x1)
+ end
+ if x2 ~= 0 then
+ table.insert(box, box_x2)
+ end
+ if z1 ~= 0 then
+ table.insert(box, box_z1)
+ end
+ if z2 ~= 0 then
+ table.insert(box, box_z2)
+ end
+ if platform ~= 0 then
+ table.insert(box, box_platform)
+ end
+ return box
+end
-check_post_connections = function(pos,mode)
- local pos1={}
- pos1.x=pos.x
- pos1.y=pos.y
- pos1.z=pos.z
- tempx1=0
- tempx2=0
- tempy1=0
- tempy2=0
- tempz1=0
- tempz2=0
-
- pos1.x=pos1.x+1
- if minetest.env:get_meta(pos1):get_int("postlike")==1 then
- x2=mode
- x1=minetest.env:get_meta(pos1):get_int("x1")
- y1=minetest.env:get_meta(pos1):get_int("y1")
- y2=minetest.env:get_meta(pos1):get_int("y2")
- z1=minetest.env:get_meta(pos1):get_int("z1")
- z2=minetest.env:get_meta(pos1):get_int("z2")
- platform=minetest.env:get_meta(pos1):get_int("platform")
- rule=make_post_rule_number(x1,x2,y1,y2,z1,z2,platform)
- hacky_swap_posts(pos1,"technic:concrete_post"..rule)
- meta=minetest.env:get_meta(pos1)
- meta:set_int("x2",x2)
- tempx1=mode
- end
+local function dig_post_with_platform(pos, oldnode, oldmetadata)
+ oldnode.name = "technic:concrete_post0"
+ minetest.set_node(pos, oldnode)
+ technic.update_posts(pos, true)
+end
- pos1.x=pos1.x-2
- if minetest.env:get_meta(pos1):get_int("postlike")==1 then
- x1=mode
- x2=minetest.env:get_meta(pos1):get_int("x2")
- y1=minetest.env:get_meta(pos1):get_int("y1")
- y2=minetest.env:get_meta(pos1):get_int("y2")
- z1=minetest.env:get_meta(pos1):get_int("z1")
- z2=minetest.env:get_meta(pos1):get_int("z2")
- platform=minetest.env:get_meta(pos1):get_int("platform")
- rule=make_post_rule_number(x1,x2,y1,y2,z1,z2,platform)
- hacky_swap_posts(pos1,"technic:concrete_post"..rule)
- meta=minetest.env:get_meta(pos1)
- meta:set_int("x1",x1)
- tempx2=mode
- end
+function technic.posts_should_connect(pos)
+ local node = minetest.get_node(pos)
+ if technic.concrete_posts[node.name] then
+ return "post"
+ elseif minetest.get_item_group(node.name, "concrete") ~= 0 then
+ return "block"
+ end
+end
- pos1.x=pos1.x+1
-
- pos1.y=pos1.y+1
- if minetest.env:get_meta(pos1):get_int("postlike")==1 then
- y2=mode
- x1=minetest.env:get_meta(pos1):get_int("x1")
- x2=minetest.env:get_meta(pos1):get_int("x2")
- y1=minetest.env:get_meta(pos1):get_int("y1")
- z1=minetest.env:get_meta(pos1):get_int("z1")
- z2=minetest.env:get_meta(pos1):get_int("z2")
- platform=minetest.env:get_meta(pos1):get_int("platform")
- rule=make_post_rule_number(x1,x2,y1,y2,z1,z2,platform)
- hacky_swap_posts(pos1,"technic:concrete_post"..rule)
- meta=minetest.env:get_meta(pos1)
- meta:set_int("y2",y2)
- tempy1=mode
- end
+function technic.get_post_id(links)
+ return (links[4] * 1) + (links[3] * 2)
+ + (links[2] * 4) + (links[1] * 8)
+ + (links[5] * 16)
+end
- pos1.y=pos1.y-2
- if minetest.env:get_meta(pos1):get_int("postlike")==1 then
- y1=mode
- x1=minetest.env:get_meta(pos1):get_int("x1")
- x2=minetest.env:get_meta(pos1):get_int("x2")
- y2=minetest.env:get_meta(pos1):get_int("y2")
- z1=minetest.env:get_meta(pos1):get_int("z1")
- z2=minetest.env:get_meta(pos1):get_int("z2")
- platform=minetest.env:get_meta(pos1):get_int("platform")
- rule=make_post_rule_number(x1,x2,y1,y2,z1,z2,platform)
- hacky_swap_posts(pos1,"technic:concrete_post"..rule)
- meta=minetest.env:get_meta(pos1)
- meta:set_int("y1",y1)
- tempy2=mode
- end
- pos1.y=pos1.y+1
+function technic.update_posts(pos, set, secondrun)
+ local node = minetest.get_node(pos)
+ local link_positions = {
+ {x=pos.x+1, y=pos.y, z=pos.z},
+ {x=pos.x-1, y=pos.y, z=pos.z},
+ {x=pos.x, y=pos.y, z=pos.z+1},
+ {x=pos.x, y=pos.y, z=pos.z-1},
+ }
- pos1.z=pos1.z+1
- if minetest.env:get_meta(pos1):get_int("postlike")==1 then
- z2=mode
- x1=minetest.env:get_meta(pos1):get_int("x1")
- x2=minetest.env:get_meta(pos1):get_int("x2")
- y1=minetest.env:get_meta(pos1):get_int("y1")
- y2=minetest.env:get_meta(pos1):get_int("y2")
- z1=minetest.env:get_meta(pos1):get_int("z1")
- platform=minetest.env:get_meta(pos1):get_int("platform")
- rule=make_post_rule_number(x1,x2,y1,y2,z1,z2,platform)
- hacky_swap_posts(pos1,"technic:concrete_post"..rule)
- meta=minetest.env:get_meta(pos1)
- meta:set_int("z2",z2)
- tempz1=mode
- end
- pos1.z=pos1.z-2
-
- if minetest.env:get_meta(pos1):get_int("postlike")==1 then
- z1=mode
- x1=minetest.env:get_meta(pos1):get_int("x1")
- x2=minetest.env:get_meta(pos1):get_int("x2")
- y1=minetest.env:get_meta(pos1):get_int("y1")
- y2=minetest.env:get_meta(pos1):get_int("y2")
- z2=minetest.env:get_meta(pos1):get_int("z2")
- platform=minetest.env:get_meta(pos1):get_int("platform")
- rule=make_post_rule_number(x1,x2,y1,y2,z1,z2,platform)
- hacky_swap_posts(pos1,"technic:concrete_post"..rule)
- meta=minetest.env:get_meta(pos1)
- meta:set_int("z1",z1)
- tempz2=mode
+ local links = {0, 0, 0, 0, 0}
+
+ for i, link_pos in pairs(link_positions) do
+ local connecttype = technic.posts_should_connect(link_pos)
+ if connecttype then
+ links[i] = 1
+ -- Have posts next to us update theirselves,
+ -- but only once. (We don't want to start an
+ -- infinite loop of updates)
+ if not secondrun and connecttype == "post" then
+ technic.update_posts(link_pos, true, true)
+ end
end
- pos1.z=pos1.z+1
-
- if mode==1 then
- meta=minetest.env:get_meta(pos)
- meta:set_int("x1",tempx1)
- meta:set_int("x2",tempx2)
- meta:set_int("y1",tempy1)
- meta:set_int("y2",tempy2)
- meta:set_int("z1",tempz1)
- meta:set_int("z2",tempz2)
- rule=make_post_rule_number(tempx1,tempx2,tempy1,tempy2,tempz1,tempz2,0)
- hacky_swap_posts(pos,"technic:concrete_post"..rule)
+ end
+ -- We don't want to set ourselves if we have been removed or we are
+ -- updating a concrete node
+ if set then
+ -- Preserve platform
+ local oldlinks = technic.concrete_posts[node.name]
+ if oldlinks then
+ links[5] = oldlinks[5]
end
-end
-
-function make_post_rule_number (x1,x2,y1,y2,z1,z2,platform)
- local tempy=y1+y2
- local tempx=x1+x2
- local tempz=z1+z2
- if platform==0 then
- if tempy==0 and tempx==0 and tempz==0 then return 0 end
- if x1==1 and x2==1 and tempz==0 and tempy==0 then return 32 end
- if z1==1 and z2==1 and tempx==0 and tempy==0 then return 33 end
- return z2+z1*2+x2*4+x1*8
- else
- if tempy==0 and tempx==0 and tempz==0 then return 16 end
- if x1==1 and x2==1 and tempz==0 and tempy==0 then return 34 end
- if z1==1 and z2==1 and tempx==0 and tempy==0 then return 35 end
- return z2+z1*2+x2*4+x1*8+16
+ minetest.set_node(pos, {name="technic:concrete_post"
+ ..technic.get_post_id(links)})
end
end
-function hacky_swap_posts(pos,name)
- local node = minetest.env:get_node(pos)
- if node.name == "technic:concrete" or node.name == "technic:blast_resistant_concrete" then
- return nil
+for x1 = 0, 1 do
+for x2 = 0, 1 do
+for z1 = 0, 1 do
+for z2 = 0, 1 do
+for platform = 0, 1 do
+ local links = {x1, x2, z1, z2, platform}
+ local id = technic.get_post_id(links)
+ technic.concrete_posts["technic:concrete_post"..id] = links
+
+ local groups = {cracky=1, level=2, concrete_post=1}
+ if id ~= 0 then
+ groups.not_in_creative_inventory = 1
end
- local meta = minetest.env:get_meta(pos)
- local meta0 = meta:to_table()
- node.name = name
- local meta0 = meta:to_table()
- minetest.env:set_node(pos,node)
- meta = minetest.env:get_meta(pos)
- meta:from_table(meta0)
- return 1
+
+ local drop = "technic:concrete_post0"
+ local after_dig_node = function(pos, oldnode, oldmetadata, digger)
+ technic.update_posts(pos, false)
+ end
+ if platform ~= 0 then
+ drop = "technic:concrete_post_platform"
+ after_dig_node = function(pos, oldnode, oldmetadata, digger)
+ dig_post_with_platform(pos, oldnode, oldmetadata)
+ end
+ end
+
+ minetest.register_node(":technic:concrete_post"..id, {
+ description = "Concrete Post",
+ tiles = {"technic_concrete_block.png"},
+ groups = groups,
+ sounds = default.node_sound_stone_defaults(),
+ drop = drop,
+ paramtype = "light",
+ sunlight_propagates = true,
+ drawtype = "nodebox",
+ node_box = {
+ type = "fixed",
+ fixed = gen_post_nodebox(x1, x2, z1, z2, platform),
+ },
+ after_place_node = function(pos, placer, itemstack)
+ technic.update_posts(pos, true)
+ end,
+ after_dig_node = after_dig_node,
+ })
+end
end
+end
+end
+end
+