summaryrefslogtreecommitdiff
path: root/stargate
diff options
context:
space:
mode:
authorRealBadAngel <mk@realbadangel.pl>2013-03-10 18:36:40 +0100
committerRealBadAngel <mk@realbadangel.pl>2013-03-10 18:37:29 +0100
commit773382cf2c58939dcbdc0c948be2ba6c1371994c (patch)
tree0b435439158657df52f0ee61091f051be2d44581 /stargate
parent9b54837f9974b80ddb4e6706e90f9243a916b712 (diff)
initial stargate code
Diffstat (limited to 'stargate')
-rw-r--r--stargate/depends.txt1
-rw-r--r--stargate/gate_defs.lua470
-rw-r--r--stargate/init.lua9
-rw-r--r--stargate/io.lua1
-rw-r--r--stargate/sounds/click.oggbin0 -> 4869 bytes
-rw-r--r--stargate/sounds/gate_activate.oggbin0 -> 59105 bytes
-rw-r--r--stargate/sounds/stargatetheme.oggbin0 -> 1929516 bytes
-rw-r--r--stargate/stargate_gui.lua198
-rw-r--r--stargate/textures/dot_icon.pngbin0 -> 731 bytes
-rw-r--r--stargate/textures/down1.pngbin0 -> 17451 bytes
-rw-r--r--stargate/textures/down1_off.pngbin0 -> 3949 bytes
-rw-r--r--stargate/textures/down2.pngbin0 -> 50990 bytes
-rw-r--r--stargate/textures/down2_off.pngbin0 -> 3922 bytes
-rw-r--r--stargate/textures/down3.pngbin0 -> 18134 bytes
-rw-r--r--stargate/textures/down3_off.pngbin0 -> 4078 bytes
-rw-r--r--stargate/textures/mid1.pngbin0 -> 53664 bytes
-rw-r--r--stargate/textures/mid1_off.pngbin0 -> 4096 bytes
-rw-r--r--stargate/textures/mid2.pngbin0 -> 128108 bytes
-rw-r--r--stargate/textures/mid2_off.pngbin0 -> 164 bytes
-rw-r--r--stargate/textures/mid3.pngbin0 -> 53759 bytes
-rw-r--r--stargate/textures/mid3_off.pngbin0 -> 4084 bytes
-rw-r--r--stargate/textures/ok_icon.pngbin0 -> 2427 bytes
-rw-r--r--stargate/textures/ok_ikon.pngbin0 -> 3393 bytes
-rw-r--r--stargate/textures/pencil_icon.pngbin0 -> 1258 bytes
-rw-r--r--stargate/textures/st1.pngbin0 -> 223485 bytes
-rw-r--r--stargate/textures/st2.pngbin0 -> 328368 bytes
-rw-r--r--stargate/textures/st3.pngbin0 -> 217304 bytes
-rw-r--r--stargate/textures/st_all.xcfbin0 -> 1477136 bytes
-rw-r--r--stargate/textures/stargate.pngbin0 -> 23614 bytes
-rw-r--r--stargate/textures/static.xcfbin0 -> 56109 bytes
-rw-r--r--stargate/textures/tick_ok_sign_4190.jpgbin0 -> 8554 bytes
-rw-r--r--stargate/textures/toggle_icon.pngbin0 -> 963 bytes
-rw-r--r--stargate/textures/up1.pngbin0 -> 17323 bytes
-rw-r--r--stargate/textures/up1_off.pngbin0 -> 3894 bytes
-rw-r--r--stargate/textures/up1r.pngbin0 -> 18187 bytes
-rw-r--r--stargate/textures/up2.pngbin0 -> 51448 bytes
-rw-r--r--stargate/textures/up2_off.pngbin0 -> 3721 bytes
-rw-r--r--stargate/textures/up3.pngbin0 -> 19636 bytes
-rw-r--r--stargate/textures/up3_off.pngbin0 -> 4012 bytes
39 files changed, 679 insertions, 0 deletions
diff --git a/stargate/depends.txt b/stargate/depends.txt
new file mode 100644
index 0000000..8b13789
--- /dev/null
+++ b/stargate/depends.txt
@@ -0,0 +1 @@
+
diff --git a/stargate/gate_defs.lua b/stargate/gate_defs.lua
new file mode 100644
index 0000000..57189d5
--- /dev/null
+++ b/stargate/gate_defs.lua
@@ -0,0 +1,470 @@
+function swap_gate_node(pos,name,dir)
+ local node = minetest.env:get_node(pos)
+ local meta = minetest.env:get_meta(pos)
+ local meta0 = meta:to_table()
+ node.name = name
+ node.param1=0
+ node.param2=dir
+ minetest.env:set_node(pos,node)
+ meta=minetest.env:get_meta(pos)
+ meta:from_table(meta0)
+end
+
+function getDir (player)
+ local dir=player:get_look_dir()
+ if math.abs(dir.x)>math.abs(dir.z) then
+ if dir.x>0 then return 0 end
+ return 1
+ end
+ if dir.z>0 then return 2 end
+ return 3
+end
+
+function checkNode (pos)
+ local node=minetest.env:get_node(pos)
+ if node.name == "air" then return 0 end
+ return 1
+end
+
+function addGateNode (gateNodes,i,pos)
+gateNodes[i].pos.x=pos.x
+gateNodes[i].pos.y=pos.y
+gateNodes[i].pos.z=pos.z
+end
+
+function placeGate (player,pos)
+ local player_name=player:get_player_name()
+ local dir=minetest.dir_to_facedir(player:get_look_dir())
+ local pos1=pos
+ local gateNodes={}
+ for i=1,9,1 do
+ gateNodes[i]={}
+ gateNodes[i].pos={}
+ end
+ if dir==1 then
+ addGateNode(gateNodes,1,pos1)
+ pos1.z=pos1.z+1
+ addGateNode(gateNodes,2,pos1)
+ pos1.z=pos1.z-2
+ addGateNode(gateNodes,3,pos1)
+ pos1.z=pos1.z+1
+ pos1.y=pos1.y+1
+ addGateNode(gateNodes,4,pos1)
+ pos1.z=pos1.z+1
+ addGateNode(gateNodes,5,pos1)
+ pos1.z=pos1.z-2
+ addGateNode(gateNodes,6,pos1)
+ pos1.z=pos1.z+1
+ pos1.y=pos1.y+1
+ addGateNode(gateNodes,7,pos1)
+ pos1.z=pos1.z+1
+ addGateNode(gateNodes,8,pos1)
+ pos1.z=pos1.z-2
+ addGateNode(gateNodes,9,pos1)
+ end
+ if dir==3 then
+ addGateNode(gateNodes,1,pos1)
+ pos1.z=pos1.z+1
+ addGateNode(gateNodes,3,pos1)
+ pos1.z=pos1.z-2
+ addGateNode(gateNodes,2,pos1)
+ pos1.z=pos1.z+1
+ pos1.y=pos1.y+1
+ addGateNode(gateNodes,4,pos1)
+ pos1.z=pos1.z+1
+ addGateNode(gateNodes,6,pos1)
+ pos1.z=pos1.z-2
+ addGateNode(gateNodes,5,pos1)
+ pos1.z=pos1.z+1
+ pos1.y=pos1.y+1
+ addGateNode(gateNodes,7,pos1)
+ pos1.z=pos1.z+1
+ addGateNode(gateNodes,9,pos1)
+ pos1.z=pos1.z-2
+ addGateNode(gateNodes,8,pos1)
+ end
+ if dir==2 then
+ addGateNode(gateNodes,1,pos1)
+ pos1.x=pos1.x+1
+ addGateNode(gateNodes,2,pos1)
+ pos1.x=pos1.x-2
+ addGateNode(gateNodes,3,pos1)
+ pos1.x=pos1.x+1
+ pos1.y=pos1.y+1
+ addGateNode(gateNodes,4,pos1)
+ pos1.x=pos1.x+1
+ addGateNode(gateNodes,5,pos1)
+ pos1.x=pos1.x-2
+ addGateNode(gateNodes,6,pos1)
+ pos1.x=pos1.x+1
+ pos1.y=pos1.y+1
+ addGateNode(gateNodes,7,pos1)
+ pos1.x=pos1.x+1
+ addGateNode(gateNodes,8,pos1)
+ pos1.x=pos1.x-2
+ addGateNode(gateNodes,9,pos1)
+ end
+ if dir==0 then
+ addGateNode(gateNodes,1,pos1)
+ pos1.x=pos1.x+1
+ addGateNode(gateNodes,3,pos1)
+ pos1.x=pos1.x-2
+ addGateNode(gateNodes,2,pos1)
+ pos1.x=pos1.x+1
+ pos1.y=pos1.y+1
+ addGateNode(gateNodes,4,pos1)
+ pos1.x=pos1.x+1
+ addGateNode(gateNodes,6,pos1)
+ pos1.x=pos1.x-2
+ addGateNode(gateNodes,5,pos1)
+ pos1.x=pos1.x+1
+ pos1.y=pos1.y+1
+ addGateNode(gateNodes,7,pos1)
+ pos1.x=pos1.x+1
+ addGateNode(gateNodes,9,pos1)
+ pos1.x=pos1.x-2
+ addGateNode(gateNodes,8,pos1)
+ end
+ for i=1,9,1 do
+ local node=minetest.env:get_node(gateNodes[i].pos)
+ if node.name ~= "air" then return false end
+ end
+ minetest.env:set_node(gateNodes[1].pos,{name="stargate:gatenode8_off", param1=0, param2=dir})
+ minetest.env:set_node(gateNodes[2].pos,{name="stargate:gatenode7_off", param1=0, param2=dir})
+ minetest.env:set_node(gateNodes[3].pos,{name="stargate:gatenode9_off", param1=0, param2=dir})
+ minetest.env:set_node(gateNodes[4].pos,{name="stargate:gatenode5_off", param1=0, param2=dir})
+ minetest.env:set_node(gateNodes[5].pos,{name="stargate:gatenode4_off", param1=0, param2=dir})
+ minetest.env:set_node(gateNodes[6].pos,{name="stargate:gatenode6_off", param1=0, param2=dir})
+ minetest.env:set_node(gateNodes[7].pos,{name="stargate:gatenode2_off", param1=0, param2=dir})
+ minetest.env:set_node(gateNodes[8].pos,{name="stargate:gatenode1_off", param1=0, param2=dir})
+ minetest.env:set_node(gateNodes[9].pos,{name="stargate:gatenode3_off", param1=0, param2=dir})
+ local meta = minetest.env:get_meta(gateNodes[1].pos)
+ meta:set_string("infotext", "Stargate inactive\nOwned by: "..player_name)
+ meta:set_string("gateNodes",minetest.serialize(gateNodes))
+ meta:set_int("gateActive",0)
+ meta:set_string("owner",player_name)
+ stargate.registerGate(player_name,gateNodes[1].pos)
+ return true
+end
+
+function removeGate (pos)
+ local meta = minetest.env:get_meta(pos)
+ local player_name=meta:get_string("owner")
+ local gateNodes=minetest.deserialize(meta:get_string("gateNodes"))
+ for i=2,9,1 do
+ minetest.env:remove_node(gateNodes[i].pos)
+ end
+ stargate.unregisterGate(player_name,gateNodes[1].pos)
+end
+
+function activateGate (player,pos)
+ local node = minetest.env:get_node(pos)
+ local dir=node.param2
+ local meta = minetest.env:get_meta(pos)
+ local gateNodes=minetest.deserialize(meta:get_string("gateNodes"))
+ meta:set_int("gateActive",1)
+ meta:set_string("infotext", "Stargate active")
+ minetest.sound_play("gate_activate", {pos = pos, gain = 1.0,loop = false, max_hear_distance = 72,})
+ swap_gate_node(gateNodes[1].pos,"stargate:gatenode8",dir)
+ swap_gate_node(gateNodes[2].pos,"stargate:gatenode7",dir)
+ swap_gate_node(gateNodes[3].pos,"stargate:gatenode9",dir)
+ swap_gate_node(gateNodes[4].pos,"stargate:gatenode5",dir)
+ swap_gate_node(gateNodes[5].pos,"stargate:gatenode4",dir)
+ swap_gate_node(gateNodes[6].pos,"stargate:gatenode6",dir)
+ swap_gate_node(gateNodes[7].pos,"stargate:gatenode2",dir)
+ swap_gate_node(gateNodes[8].pos,"stargate:gatenode1",dir)
+ swap_gate_node(gateNodes[9].pos,"stargate:gatenode3",dir)
+end
+
+function deactivateGate (player,pos)
+ local node = minetest.env:get_node(pos)
+ local dir=node.param2
+ local meta = minetest.env:get_meta(pos)
+ local gateNodes=minetest.deserialize(meta:get_string("gateNodes"))
+ meta:set_int("gateActive",0)
+ meta:set_string("infotext", "Stargate inactive")
+ swap_gate_node(gateNodes[1].pos,"stargate:gatenode8_off",dir)
+ swap_gate_node(gateNodes[2].pos,"stargate:gatenode7_off",dir)
+ swap_gate_node(gateNodes[3].pos,"stargate:gatenode9_off",dir)
+ swap_gate_node(gateNodes[4].pos,"stargate:gatenode5_off",dir)
+ swap_gate_node(gateNodes[5].pos,"stargate:gatenode4_off",dir)
+ swap_gate_node(gateNodes[6].pos,"stargate:gatenode6_off",dir)
+ swap_gate_node(gateNodes[7].pos,"stargate:gatenode2_off",dir)
+ swap_gate_node(gateNodes[8].pos,"stargate:gatenode1_off",dir)
+ swap_gate_node(gateNodes[9].pos,"stargate:gatenode3_off",dir)
+end
+
+gateCanDig = function(pos,player)
+ local player_name = player:get_player_name()
+ local meta = minetest.env:get_meta(pos)
+ local owner=meta:get_string("owner")
+ if player_name==owner then return true
+ else return false end
+end
+
+sg_selection_box = {
+ type = "fixed",
+ fixed={{-1.5,-0.5,-1/20,1.5,2.5,1/20},},
+ }
+sg_selection_box_empty = {
+ type = "fixed",
+ fixed={},
+ }
+sg_node_box = {
+ type = "fixed",
+ fixed={{-.5,-.5,0,.5,.5,0},},
+ }
+sg_groups = {snappy=2,choppy=2,oddly_breakable_by_hand=2,not_in_creative_inventory=1}
+sg_groups1 = {snappy=2,choppy=2,oddly_breakable_by_hand=2}
+
+minetest.register_node("stargate:gatenode1",{
+ description = "up1",
+ tiles = {"default_cobble.png","default_cobble.png","default_cobble.png","default_cobble.png",
+ {name="up3.png",animation={type="vertical_frames", aspect_w=16, aspect_h=16, length=1},},
+ {name="up1.png",animation={type="vertical_frames", aspect_w=16, aspect_h=16, length=1},}},
+ groups = sg_groups,
+ paramtype2 = "facedir",
+ paramtype = "light",
+ light_source = 10,
+ drawtype = "nodebox",
+ selection_box = sg_selection_box_empty,
+ node_box=sg_node_box,
+})
+minetest.register_node("stargate:gatenode2",{
+ description = "up2",
+ tiles = {"default_cobble.png","default_cobble.png","default_cobble.png","default_cobble.png",
+ {name="up2.png",animation={type="vertical_frames", aspect_w=16, aspect_h=16, length=1},},
+ {name="up2.png",animation={type="vertical_frames", aspect_w=16, aspect_h=16, length=1},}},
+ groups = sg_groups,
+ paramtype2 = "facedir",
+ paramtype = "light",
+ light_source = 10,
+ drawtype = "nodebox",
+ selection_box = sg_selection_box_empty,
+ node_box=sg_node_box,
+})
+
+minetest.register_node("stargate:gatenode3",{
+ description = "up3",
+ tiles = {"default_cobble.png","default_cobble.png","default_cobble.png","default_cobble.png",
+ {name="up1.png",animation={type="vertical_frames", aspect_w=16, aspect_h=16, length=1},},
+ {name="up3.png",animation={type="vertical_frames", aspect_w=16, aspect_h=16, length=1},}},
+ groups = sg_groups,
+ paramtype2 = "facedir",
+ paramtype = "light",
+ light_source = 10,
+ drawtype = "nodebox",
+ selection_box = sg_selection_box_empty,
+ node_box=sg_node_box,
+})
+
+minetest.register_node("stargate:gatenode4",{
+ description = "mid1",
+ tiles = {"default_cobble.png","default_cobble.png","default_cobble.png","default_cobble.png",
+ {name="mid3.png",animation={type="vertical_frames", aspect_w=16, aspect_h=16, length=1},},
+ {name="mid1.png",animation={type="vertical_frames", aspect_w=16, aspect_h=16, length=1},}},
+ groups = sg_groups,
+ paramtype2 = "facedir",
+ paramtype = "light",
+ light_source = 10,
+ drawtype = "nodebox",
+ selection_box = sg_selection_box_empty,
+ node_box=sg_node_box,
+})
+minetest.register_node("stargate:gatenode5",{
+ description = "mid2",
+ tiles = {"default_cobble.png","default_cobble.png","default_cobble.png","default_cobble.png",
+ {name="mid2.png",animation={type="vertical_frames", aspect_w=16, aspect_h=16, length=1},},
+ {name="mid2.png",animation={type="vertical_frames", aspect_w=16, aspect_h=16, length=1},}},
+ groups = sg_groups,
+ paramtype2 = "facedir",
+ paramtype = "light",
+ light_source = 10,
+ drawtype = "nodebox",
+ selection_box = sg_selection_box_empty,
+ node_box=sg_node_box,
+})
+
+minetest.register_node("stargate:gatenode6",{
+ description = "mid3",
+ tiles = {"default_cobble.png","default_cobble.png","default_cobble.png","default_cobble.png",
+ {name="mid1.png",animation={type="vertical_frames", aspect_w=16, aspect_h=16, length=1},},
+ {name="mid3.png",animation={type="vertical_frames", aspect_w=16, aspect_h=16, length=1},}},
+ groups = sg_groups,
+ paramtype2 = "facedir",
+ paramtype = "light",
+ light_source = 10,
+ drawtype = "nodebox",
+ selection_box = sg_selection_box_empty,
+ node_box=sg_node_box,
+})
+
+minetest.register_node("stargate:gatenode7",{
+ description = "down1",
+ tiles = {"default_cobble.png","default_cobble.png","default_cobble.png","default_cobble.png",
+ {name="down3.png",animation={type="vertical_frames", aspect_w=16, aspect_h=16, length=1},},
+ {name="down1.png",animation={type="vertical_frames", aspect_w=16, aspect_h=16, length=1},}},
+ groups = sg_groups,
+ paramtype2 = "facedir",
+ paramtype = "light",
+ light_source = 10,
+ drawtype = "nodebox",
+ selection_box = sg_selection_box_empty,
+ node_box=sg_node_box,
+})
+
+minetest.register_node("stargate:gatenode8",{
+ description = "down2",
+ tiles = {"default_cobble.png","default_cobble.png","default_cobble.png","default_cobble.png",
+ {name="down2.png",animation={type="vertical_frames", aspect_w=16, aspect_h=16, length=1},},
+ {name="down2.png",animation={type="vertical_frames", aspect_w=16, aspect_h=16, length=1},}},
+ groups = sg_groups,
+ drop="stargate:gatenode8_off",
+ paramtype2 = "facedir",
+ paramtype = "light",
+ light_source = 10,
+ drawtype = "nodebox",
+ selection_box = sg_selection_box,
+ node_box=sg_node_box,
+ can_dig = gateCanDig,
+ on_destruct = function (pos)
+ removeGate(pos)
+ end,
+})
+
+minetest.register_node("stargate:gatenode9",{
+ description = "down3",
+ tiles = {"default_cobble.png","default_cobble.png","default_cobble.png","default_cobble.png",
+ {name="down1.png",animation={type="vertical_frames", aspect_w=16, aspect_h=16, length=1},},
+ {name="down3.png",animation={type="vertical_frames", aspect_w=16, aspect_h=16, length=1},}},
+ groups = sg_groups,
+ paramtype2 = "facedir",
+ paramtype = "light",
+ light_source = 10,
+ drawtype = "nodebox",
+ selection_box = sg_selection_box_empty,
+ node_box=sg_node_box,
+})
+
+minetest.register_node("stargate:gatenode1_off",{
+ description = "up1_off",
+ tiles = {"default_cobble.png","default_cobble.png","default_cobble.png","default_cobble.png",
+ "up3_off.png","up1_off.png"},
+ groups = sg_groups,
+ paramtype2 = "facedir",
+ paramtype = "light",
+ drawtype = "nodebox",
+ selection_box = sg_selection_box_empty,
+ node_box=sg_node_box,
+})
+minetest.register_node("stargate:gatenode2_off",{
+ description = "up2_off",
+ tiles = {"default_cobble.png","default_cobble.png","default_cobble.png","default_cobble.png",
+ "up2_off.png","up2_off.png"},
+ groups = sg_groups,
+ paramtype2 = "facedir",
+ paramtype = "light",
+ drawtype = "nodebox",
+ selection_box = sg_selection_box_empty,
+ node_box=sg_node_box,
+})
+
+minetest.register_node("stargate:gatenode3_off",{
+ description = "up3_off",
+ tiles = {"default_cobble.png","default_cobble.png","default_cobble.png","default_cobble.png",
+ "up1_off.png","up3_off.png"},
+ groups = sg_groups,
+ paramtype2 = "facedir",
+ paramtype = "light",
+ drawtype = "nodebox",
+ selection_box = sg_selection_box_empty,
+ node_box=sg_node_box,
+})
+
+minetest.register_node("stargate:gatenode4_off",{
+ description = "mid1_off",
+ tiles = {"default_cobble.png","default_cobble.png","default_cobble.png","default_cobble.png",
+ "mid3_off.png","mid1_off.png"},
+ groups = sg_groups,
+ paramtype2 = "facedir",
+ paramtype = "light",
+ drawtype = "nodebox",
+ selection_box = sg_selection_box_empty,
+ node_box=sg_node_box,
+})
+minetest.register_node("stargate:gatenode5_off",{
+ description = "mid2_off",
+ tiles = {"default_cobble.png","default_cobble.png","default_cobble.png","default_cobble.png",
+ "mid2_off.png","mid2_off.png"},
+ groups = sg_groups,
+ paramtype2 = "facedir",
+ paramtype = "light",
+ drawtype = "nodebox",
+ selection_box = sg_selection_box_empty,
+ node_box=sg_node_box,
+})
+
+minetest.register_node("stargate:gatenode6_off",{
+ description = "mid3_off",
+ tiles = {"default_cobble.png","default_cobble.png","default_cobble.png","default_cobble.png",
+ "mid1_off.png","mid3_off.png"},
+ groups = sg_groups,
+ paramtype2 = "facedir",
+ paramtype = "light",
+ drawtype = "nodebox",
+ selection_box = sg_selection_box_empty,
+ node_box=sg_node_box,
+})
+
+minetest.register_node("stargate:gatenode7_off",{
+ description = "down1_off",
+ tiles = {"default_cobble.png","default_cobble.png","default_cobble.png","default_cobble.png",
+ "down3_off.png","down1_off.png"},
+ groups = sg_groups,
+ paramtype2 = "facedir",
+ paramtype = "light",
+ drawtype = "nodebox",
+ selection_box = sg_selection_box_empty,
+ node_box=sg_node_box,
+})
+
+--main gate node
+minetest.register_node("stargate:gatenode8_off",{
+ description = "Stargate",
+ inventory_image = "stargate.png",
+ wield_image = "stargate.png",
+ tiles = {"default_cobble.png","default_cobble.png","default_cobble.png","default_cobble.png",
+ "down2_off.png","down2_off.png"},
+ groups = sg_groups1,
+ paramtype2 = "facedir",
+ paramtype = "light",
+ drawtype = "nodebox",
+ selection_box = sg_selection_box,
+ node_box=sg_node_box,
+ can_dig = gateCanDig,
+ on_destruct = function (pos)
+ removeGate(pos)
+ end,
+ on_place = function(itemstack, placer, pointed_thing)
+ local pos = pointed_thing.above
+ if placeGate(placer,pos)==true then
+ itemstack:take_item(1)
+ return itemstack
+ else
+ return
+ end
+ end,
+ on_rightclick=stargate.gateFormspecHandler,
+})
+
+minetest.register_node("stargate:gatenode9_off",{
+ description = "down3_off",
+ tiles = {"default_cobble.png","default_cobble.png","default_cobble.png","default_cobble.png",
+ "down1_off.png","down3_off.png"},
+ groups = sg_groups,
+ paramtype2 = "facedir",
+ paramtype = "light",
+ drawtype = "nodebox",
+ selection_box = sg_selection_box_empty,
+ node_box=sg_node_box,
+})
diff --git a/stargate/init.lua b/stargate/init.lua
new file mode 100644
index 0000000..3f09cc2
--- /dev/null
+++ b/stargate/init.lua
@@ -0,0 +1,9 @@
+-- Minetest 0.4.5 : stargate
+
+--data tables definitions
+stargate={}
+stargate_network = {}
+
+modpath=minetest.get_modpath("stargate")
+dofile(modpath.."/stargate_gui.lua")
+dofile(modpath.."/gate_defs.lua")
diff --git a/stargate/io.lua b/stargate/io.lua
new file mode 100644
index 0000000..8b13789
--- /dev/null
+++ b/stargate/io.lua
@@ -0,0 +1 @@
+
diff --git a/stargate/sounds/click.ogg b/stargate/sounds/click.ogg
new file mode 100644
index 0000000..3db63a0
--- /dev/null
+++ b/stargate/sounds/click.ogg
Binary files differ
diff --git a/stargate/sounds/gate_activate.ogg b/stargate/sounds/gate_activate.ogg
new file mode 100644
index 0000000..4725f23
--- /dev/null
+++ b/stargate/sounds/gate_activate.ogg
Binary files differ
diff --git a/stargate/sounds/stargatetheme.ogg b/stargate/sounds/stargatetheme.ogg
new file mode 100644
index 0000000..52dd016
--- /dev/null
+++ b/stargate/sounds/stargatetheme.ogg
Binary files differ
diff --git a/stargate/stargate_gui.lua b/stargate/stargate_gui.lua
new file mode 100644
index 0000000..93357d1
--- /dev/null
+++ b/stargate/stargate_gui.lua
@@ -0,0 +1,198 @@
+-- default GUI page
+stargate.default_page = "main"
+stargate.players={}
+stargate.current_page={}
+
+stargate.save_data = function()
+ local data = minetest.serialize( stargate_network )
+ local path = minetest.get_worldpath().."/mod_stargate.data"
+ local file = io.open( path, "w" )
+ if( file ) then
+ file:write( data )
+ file:close()
+ return true
+ else return nil
+ end
+end
+
+stargate.restore_data = function()
+ local path = minetest.get_worldpath().."/mod_stargate.data"
+ local file = io.open( path, "r" )
+ if( file ) then
+ local data = file:read("*all")
+ stargate_network = minetest.deserialize( data )
+ file:close()
+ return true
+ else return nil
+ end
+end
+
+-- load Stargates network data
+if stargate.restore_data()==nil then
+ print ("[stargate] network data not found. Creating new file.")
+ if stargate.save_data()==nil then
+ print ("[stargate] Cannot load nor create new file!")
+ --crash or something here?
+ else
+ print ("[stargate] New data file created.")
+ end
+end
+
+-- register_on_joinplayer
+minetest.register_on_joinplayer(function(player)
+ local player_name = player:get_player_name()
+ stargate.players[player_name]={}
+ stargate.players[player_name]["formspec"]=""
+ stargate.players[player_name]["current_page"]=stargate.default_page
+ stargate.players[player_name]["own_gates"]={}
+ stargate.players[player_name]["own_gates_count"]=0
+ stargate.players[player_name]["public_gates"]={}
+ stargate.players[player_name]["public_gates_count"]=0
+end)
+
+stargate.registerGate = function(player_name,pos)
+ if stargate_network[player_name]==nil then
+ stargate_network[player_name]={}
+ end
+ local new_gate ={}
+ new_gate["pos"]=pos
+ new_gate["type"]="private"
+ new_gate["description"]=""
+ table.insert(stargate_network[player_name],new_gate)
+ if stargate.save_data()==nil then
+ print ("[stargate] Couldnt update network file!")
+ end
+end
+
+stargate.unregisterGate = function(player_name,pos)
+ for __,gates in ipairs(stargate_network[player_name]) do
+ if gates["pos"].x==pos.x and gates["pos"].y==pos.y and gates["pos"].z==pos.z then
+ table.remove(stargate_network[player_name], __)
+ break
+ end
+ end
+ if stargate.save_data()==nil then
+ print ("[stargate] Couldnt update network file!")
+ end
+end
+
+--show formspec to player
+stargate.gateFormspecHandler = function(pos, node, clicker, itemstack)
+ local player_name = clicker:get_player_name()
+ local meta = minetest.env:get_meta(pos)
+ local owner=meta:get_string("owner")
+ if player_name~=owner then return end
+ local current_gate=nil
+ stargate.players[player_name]["own_gates"]={}
+ stargate.players[player_name]["public_gates"]={}
+ local own_gates_count=0
+ for __,gates in ipairs(stargate_network[player_name]) do
+ if gates["pos"].x==pos.x and gates["pos"].y==pos.y and gates["pos"].z==pos.z then
+ current_gate=gates
+ else
+ own_gates_count=own_gates_count+1
+ table.insert(stargate.players[player_name]["own_gates"],gates)
+ end
+ end
+ stargate.players[player_name]["own_gates_count"]=own_gates_count
+ if current_gate==nil then
+ print ("Gate not registered in network! Please remove it and place once again.")
+ return nil
+ end
+ stargate.players[player_name]["current_index"]=0
+ stargate.players[player_name]["current_gate"]=current_gate
+ stargate.players[player_name]["dest_type"]="own"
+ local formspec=stargate.get_formspec(player_name,"main")
+ stargate.players[player_name]["formspec"]=formspec
+ minetest.show_formspec(player_name, "stargate:main", formspec)
+end
+
+-- get_formspec
+stargate.get_formspec = function(player_name,page)
+ if player_name==nil then return "" end
+ stargate.players[player_name]["current_page"]=page
+ local current_gate=stargate.players[player_name]["current_gate"]
+ local formspec = "size[14,10]"
+ --background
+ formspec = formspec .."background[-0.19,-0.2,;14.38,10.55;ui_form_bg.png]"
+ formspec = formspec.."label[0,0.0;Stargate]"
+ formspec = formspec.."label[0,.5;Position: ("..current_gate["pos"].x..","..current_gate["pos"].y..","..current_gate["pos"].z..")]"
+ formspec = formspec.."image_button[3.5,.6;.6,.6;toggle_icon.png;toggle_type;]"
+ formspec = formspec.."label[4,.5;Type: "..current_gate["type"].."]"
+ formspec = formspec.."image_button[6.5,.6;.6,.6;pencil_icon.png;edit_desc;]"
+ formspec = formspec.."label[0,1.1;Destination: ]"
+ formspec = formspec.."label[0,1.7;Aviable destinations:]"
+ formspec = formspec.."image_button[3.5,1.8;.6,.6;toggle_icon.png;toggle_dest_type;]"
+ formspec = formspec.."label[4,1.7;Type: "..stargate.players[player_name]["dest_type"].."]"
+
+ if page=="main" then
+ formspec = formspec.."image_button[6.5,.6;.6,.6;pencil_icon.png;edit_desc;]"
+ formspec = formspec.."label[7,.5;Description: "..current_gate["description"].."]"
+ end
+ if page=="edit_desc" then
+ formspec = formspec.."image_button[6.5,.6;.6,.6;ok_icon.png;save_desc;]"
+ formspec = formspec.."field[7.3,.7;5,1;desc_box;Edit gate description:;"..current_gate["description"].."]"
+ end
+
+ local list_index=stargate.players[player_name]["current_index"]
+ print(dump(stargate.players[player_name]["own_gates_count"]))
+ local page=math.floor(list_index / (30) + 1)
+ local pagemax = math.floor((stargate.players[player_name]["own_gates_count"]+1) / (30) + 1)
+ for y=0,9,1 do
+ for x=0,2,1 do
+ print(dump(list_index))
+ print(dump(stargate.players[player_name]["own_gates"][list_index+1]))
+ local gate_temp=stargate.players[player_name]["own_gates"][list_index+1]
+ if gate_temp then
+ formspec = formspec.."image_button["..(x*5)..","..(4+y*.8)..";.6,.6;dot_icon.png;list_button"..list_index..";]"
+ formspec = formspec.."label["..(x*5+.8)..","..(4+y*.8)..";("..gate_temp["pos"].x..","..gate_temp["pos"].y..","..gate_temp["pos"].z..")]"
+ end
+ list_index=list_index+1
+ end
+ end
+ return formspec
+end
+
+-- register_on_player_receive_fields
+minetest.register_on_player_receive_fields(function(player, formname, fields)
+ local player_name = player:get_player_name()
+ local current_gate=stargate.players[player_name]["current_gate"]
+ local formspec
+
+ if fields.toggle_type then
+ if current_gate["type"] == "private" then
+ current_gate["type"]="public"
+ else current_gate["type"]="private" end
+ formspec= stargate.get_formspec(player_name,"main")
+ stargate.players[player_name]["formspec"]=formspec
+ minetest.show_formspec(player_name, "stargate:main", formspec)
+ minetest.sound_play("click", {to_player=player_name, gain = 0.5})
+ return
+ end
+ if fields.toggle_dest_type then
+ if stargate.players[player_name]["dest_type"] == "all own" then
+ stargate.players[player_name]["dest_type"]="all public"
+ else stargate.players[player_name]["dest_type"]="all own" end
+ formspec= stargate.get_formspec(player_name,"main")
+ stargate.players[player_name]["formspec"]=formspec
+ minetest.show_formspec(player_name, "stargate:main", formspec)
+ minetest.sound_play("click", {to_player=player_name, gain = 0.5})
+ return
+ end
+ if fields.edit_desc then
+ formspec= stargate.get_formspec(player_name,"edit_desc")
+ stargate.players[player_name]["formspec"]=formspec
+ minetest.show_formspec(player_name, "stargate:main", formspec)
+ minetest.sound_play("click", {to_player=player_name, gain = 0.5})
+ return
+ end
+
+ if fields.save_desc then
+ current_gate["description"]=fields.desc_box
+ formspec= stargate.get_formspec(player_name,"main")
+ stargate.players[player_name]["formspec"]=formspec
+ minetest.show_formspec(player_name, "stargate:main", formspec)
+ minetest.sound_play("click", {to_player=player_name, gain = 0.5})
+ return
+ end
+end)
diff --git a/stargate/textures/dot_icon.png b/stargate/textures/dot_icon.png
new file mode 100644
index 0000000..e73af1a
--- /dev/null
+++ b/stargate/textures/dot_icon.png
Binary files differ
diff --git a/stargate/textures/down1.png b/stargate/textures/down1.png
new file mode 100644
index 0000000..a87134d
--- /dev/null
+++ b/stargate/textures/down1.png
Binary files differ
diff --git a/stargate/textures/down1_off.png b/stargate/textures/down1_off.png
new file mode 100644
index 0000000..9783f22
--- /dev/null
+++ b/stargate/textures/down1_off.png
Binary files differ
diff --git a/stargate/textures/down2.png b/stargate/textures/down2.png
new file mode 100644
index 0000000..e2b8f83
--- /dev/null
+++ b/stargate/textures/down2.png
Binary files differ
diff --git a/stargate/textures/down2_off.png b/stargate/textures/down2_off.png
new file mode 100644
index 0000000..7910ff6
--- /dev/null
+++ b/stargate/textures/down2_off.png
Binary files differ
diff --git a/stargate/textures/down3.png b/stargate/textures/down3.png
new file mode 100644
index 0000000..b6adc8c
--- /dev/null
+++ b/stargate/textures/down3.png
Binary files differ
diff --git a/stargate/textures/down3_off.png b/stargate/textures/down3_off.png
new file mode 100644
index 0000000..5fd8feb
--- /dev/null
+++ b/stargate/textures/down3_off.png
Binary files differ
diff --git a/stargate/textures/mid1.png b/stargate/textures/mid1.png
new file mode 100644
index 0000000..6cdb9ff
--- /dev/null
+++ b/stargate/textures/mid1.png
Binary files differ
diff --git a/stargate/textures/mid1_off.png b/stargate/textures/mid1_off.png
new file mode 100644
index 0000000..ceae50f
--- /dev/null
+++ b/stargate/textures/mid1_off.png
Binary files differ
diff --git a/stargate/textures/mid2.png b/stargate/textures/mid2.png
new file mode 100644
index 0000000..9167989
--- /dev/null
+++ b/stargate/textures/mid2.png
Binary files differ
diff --git a/stargate/textures/mid2_off.png b/stargate/textures/mid2_off.png
new file mode 100644
index 0000000..b29c3d6
--- /dev/null
+++ b/stargate/textures/mid2_off.png
Binary files differ
diff --git a/stargate/textures/mid3.png b/stargate/textures/mid3.png
new file mode 100644
index 0000000..1420e27
--- /dev/null
+++ b/stargate/textures/mid3.png
Binary files differ
diff --git a/stargate/textures/mid3_off.png b/stargate/textures/mid3_off.png
new file mode 100644
index 0000000..ae4f932
--- /dev/null
+++ b/stargate/textures/mid3_off.png
Binary files differ
diff --git a/stargate/textures/ok_icon.png b/stargate/textures/ok_icon.png
new file mode 100644
index 0000000..779fc3b
--- /dev/null
+++ b/stargate/textures/ok_icon.png
Binary files differ
diff --git a/stargate/textures/ok_ikon.png b/stargate/textures/ok_ikon.png
new file mode 100644
index 0000000..5bdff96
--- /dev/null
+++ b/stargate/textures/ok_ikon.png
Binary files differ
diff --git a/stargate/textures/pencil_icon.png b/stargate/textures/pencil_icon.png
new file mode 100644
index 0000000..af77c2f
--- /dev/null
+++ b/stargate/textures/pencil_icon.png
Binary files differ
diff --git a/stargate/textures/st1.png b/stargate/textures/st1.png
new file mode 100644
index 0000000..c7c4248
--- /dev/null
+++ b/stargate/textures/st1.png
Binary files differ
diff --git a/stargate/textures/st2.png b/stargate/textures/st2.png
new file mode 100644
index 0000000..c30f9ae
--- /dev/null
+++ b/stargate/textures/st2.png
Binary files differ
diff --git a/stargate/textures/st3.png b/stargate/textures/st3.png
new file mode 100644
index 0000000..e5464d9
--- /dev/null
+++ b/stargate/textures/st3.png
Binary files differ
diff --git a/stargate/textures/st_all.xcf b/stargate/textures/st_all.xcf
new file mode 100644
index 0000000..a2e4441
--- /dev/null
+++ b/stargate/textures/st_all.xcf
Binary files differ
diff --git a/stargate/textures/stargate.png b/stargate/textures/stargate.png
new file mode 100644
index 0000000..339c389
--- /dev/null
+++ b/stargate/textures/stargate.png
Binary files differ
diff --git a/stargate/textures/static.xcf b/stargate/textures/static.xcf
new file mode 100644
index 0000000..c106ab1
--- /dev/null
+++ b/stargate/textures/static.xcf
Binary files differ
diff --git a/stargate/textures/tick_ok_sign_4190.jpg b/stargate/textures/tick_ok_sign_4190.jpg
new file mode 100644
index 0000000..5f6c6aa
--- /dev/null
+++ b/stargate/textures/tick_ok_sign_4190.jpg
Binary files differ
diff --git a/stargate/textures/toggle_icon.png b/stargate/textures/toggle_icon.png
new file mode 100644
index 0000000..4792158
--- /dev/null
+++ b/stargate/textures/toggle_icon.png
Binary files differ
diff --git a/stargate/textures/up1.png b/stargate/textures/up1.png
new file mode 100644
index 0000000..89f47d2
--- /dev/null
+++ b/stargate/textures/up1.png
Binary files differ
diff --git a/stargate/textures/up1_off.png b/stargate/textures/up1_off.png
new file mode 100644
index 0000000..c4e6361
--- /dev/null
+++ b/stargate/textures/up1_off.png
Binary files differ
diff --git a/stargate/textures/up1r.png b/stargate/textures/up1r.png
new file mode 100644
index 0000000..6dc6a1d
--- /dev/null
+++ b/stargate/textures/up1r.png
Binary files differ
diff --git a/stargate/textures/up2.png b/stargate/textures/up2.png
new file mode 100644
index 0000000..9527d79
--- /dev/null
+++ b/stargate/textures/up2.png
Binary files differ
diff --git a/stargate/textures/up2_off.png b/stargate/textures/up2_off.png
new file mode 100644
index 0000000..88de6f8
--- /dev/null
+++ b/stargate/textures/up2_off.png
Binary files differ
diff --git a/stargate/textures/up3.png b/stargate/textures/up3.png
new file mode 100644
index 0000000..6767c2d
--- /dev/null
+++ b/stargate/textures/up3.png
Binary files differ
diff --git a/stargate/textures/up3_off.png b/stargate/textures/up3_off.png
new file mode 100644
index 0000000..efa5cc9
--- /dev/null
+++ b/stargate/textures/up3_off.png
Binary files differ