mirror of
https://github.com/D00Med/scifi_nodes.git
synced 2025-06-29 22:50:48 +02:00
Compare commits
31 Commits
github-act
...
animated_l
Author | SHA1 | Date | |
---|---|---|---|
317fdd6df6 | |||
2e035f37e9 | |||
178fd9c48b | |||
d2dd770635 | |||
eed0d601be | |||
16ff4dcdb8 | |||
b54333d56b | |||
6492d311c8 | |||
03d097abf8 | |||
9ad9ba33c8 | |||
40bcb29c6d | |||
37aef1ce17 | |||
8a8e566d27 | |||
a3b8ec1522 | |||
ce0501bef3 | |||
6d6432940f | |||
242dbde0e6 | |||
973f14fbd2 | |||
0c19943f05 | |||
3659705c7d | |||
14a123c7b5 | |||
f341f26905 | |||
1b564e0a43 | |||
d50c645648 | |||
992ec19360 | |||
f452274b9c | |||
6010bad2e9 | |||
d48c185f34 | |||
d1f0a8f1cd | |||
8e226561a1 | |||
44fccd50c6 |
15
.github/workflows/integration-test.yml
vendored
Normal file
15
.github/workflows/integration-test.yml
vendored
Normal file
@ -0,0 +1,15 @@
|
|||||||
|
name: integration-test
|
||||||
|
|
||||||
|
on: [push, pull_request]
|
||||||
|
|
||||||
|
jobs:
|
||||||
|
build:
|
||||||
|
|
||||||
|
runs-on: ubuntu-latest
|
||||||
|
timeout-minutes: 10
|
||||||
|
|
||||||
|
steps:
|
||||||
|
- uses: actions/checkout@v1
|
||||||
|
|
||||||
|
- name: integration-test
|
||||||
|
run: ./test/integration-test.sh
|
2
.github/workflows/luacheck.yml
vendored
2
.github/workflows/luacheck.yml
vendored
@ -1,6 +1,6 @@
|
|||||||
name: luacheck
|
name: luacheck
|
||||||
|
|
||||||
on: [push]
|
on: [push, pull_request]
|
||||||
|
|
||||||
jobs:
|
jobs:
|
||||||
build:
|
build:
|
||||||
|
@ -19,6 +19,7 @@ read_globals = {
|
|||||||
"xpanes",
|
"xpanes",
|
||||||
"screwdriver",
|
"screwdriver",
|
||||||
"minetest",
|
"minetest",
|
||||||
"mesecon"
|
"mesecon",
|
||||||
|
"unifieddyes"
|
||||||
|
|
||||||
}
|
}
|
||||||
|
22
README.md
22
README.md
@ -2,10 +2,15 @@
|
|||||||
|
|
||||||
# scifi_nodes
|
# scifi_nodes
|
||||||
|
|
||||||
|

|
||||||
|

|
||||||
|
[](https://content.minetest.net/packages/D00Med/scifi_nodes/)
|
||||||
|
|
||||||
Minetest mod that adds scifi themed blocks, doors, materials, plants and other assets.
|
Minetest mod that adds scifi themed blocks, doors, materials, plants and other assets.
|
||||||
|
|
||||||
# Changes log
|
# Changelog
|
||||||
|
|
||||||
|
* Added support for unifieddyes
|
||||||
* 14/08/2019 : retrocompatibility fixed (aliases in doors.lua)
|
* 14/08/2019 : retrocompatibility fixed (aliases in doors.lua)
|
||||||
* 13/08/2019 :
|
* 13/08/2019 :
|
||||||
* added mod option doors_open_with_mesecon_only (default = false)
|
* added mod option doors_open_with_mesecon_only (default = false)
|
||||||
@ -27,19 +32,26 @@ Minetest mod that adds scifi themed blocks, doors, materials, plants and other a
|
|||||||
|
|
||||||
# Attributions
|
# Attributions
|
||||||
|
|
||||||
CC BY-NC 3.0
|
CC BY 3.0
|
||||||
* scifi_nodes_door_normal.ogg tlwmdbt https://freesound.org/people/tlwmdbt/sounds/165862/
|
* scifi_nodes_door_normal.ogg tlwmdbt https://freesound.org/people/tlwmdbt/sounds/165862/
|
||||||
* scifi_nodes_door_mechanic.ogg primeval_polypod https://freesound.org/people/primeval_polypod/sounds/156507/
|
|
||||||
* scifi_nodes_digicode.ogg https://freesound.org/people/Robinhood76/sounds/94933/
|
|
||||||
* scifi_nodes_switch.ogg http://soundbible.com/1950-Button-Push.html
|
* scifi_nodes_switch.ogg http://soundbible.com/1950-Button-Push.html
|
||||||
* scifi_nodes_palm_scanner.ogg https://freesound.org/people/THE_bizniss/sounds/39313/
|
* scifi_nodes_palm_scanner.ogg https://freesound.org/people/THE_bizniss/sounds/39313/
|
||||||
* scifi_nodes_access_granted https://freesound.org/people/TheBuilder15/sounds/415762/
|
* scifi_nodes_access_granted https://freesound.org/people/TheBuilder15/sounds/415762/
|
||||||
* scifi_nodes_access_refused https://freesound.org/people/RICHERlandTV/sounds/216090/
|
* scifi_nodes_access_refused https://freesound.org/people/RICHERlandTV/sounds/216090/
|
||||||
|
|
||||||
|
CC0
|
||||||
|
* scifi_nodes_digicode.ogg https://freesound.org/people/benjaminharveydesign/sounds/315921/
|
||||||
|
|
||||||
|
|
||||||
# Contributors:
|
# Contributors:
|
||||||
|
|
||||||
|
* D00Med https://github.com/D00Med (creator)
|
||||||
* tanmayameher https://github.com/tanmayameher
|
* tanmayameher https://github.com/tanmayameher
|
||||||
* naturefreshmilk https://github.com/naturefreshmilk
|
* BuckarooBanzay https://github.com/BuckarooBanzay
|
||||||
* acmgit https://github.com/acmgit
|
* acmgit https://github.com/acmgit
|
||||||
* catz85 https://github.com/catz85
|
* catz85 https://github.com/catz85
|
||||||
* coil0 https://github.com/coil0
|
* coil0 https://github.com/coil0
|
||||||
|
* Grossam https://github.com/Grossam
|
||||||
|
* OgelGames https://github.com/OgelGames
|
||||||
|
* leftshift https://github.com/leftshift
|
||||||
|
* fluxionary https://github.com/fluxionary
|
||||||
|
20
crafts.lua
20
crafts.lua
@ -767,6 +767,16 @@ minetest.register_craft({
|
|||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
-- 4 green light bar from 4 green metal, 2 green dye, 1 lightbar
|
||||||
|
minetest.register_craft({
|
||||||
|
output = "scifi_nodes:greenbar_animated 4",
|
||||||
|
recipe = {
|
||||||
|
{"scifi_nodes:greenbar", "", "scifi_nodes:greenbar"},
|
||||||
|
{"", "mesecons:wire_00000000_off", ""},
|
||||||
|
{"scifi_nodes:greenbar", "", "scifi_nodes:greenbar"}
|
||||||
|
}
|
||||||
|
})
|
||||||
|
|
||||||
-- 4 green metal block from 4 green metal
|
-- 4 green metal block from 4 green metal
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
output = "scifi_nodes:green_square 4",
|
output = "scifi_nodes:green_square 4",
|
||||||
@ -1282,10 +1292,13 @@ minetest.register_craft({
|
|||||||
})
|
})
|
||||||
|
|
||||||
-- https://forum.minetest.net/viewtopic.php?f=10&t=13125&p=261481#p261481
|
-- https://forum.minetest.net/viewtopic.php?f=10&t=13125&p=261481#p261481
|
||||||
|
-- with modified recipe
|
||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
output = 'scifi_nodes:windowpanel 4',
|
output = 'scifi_nodes:windowpanel',
|
||||||
recipe = {
|
recipe = {
|
||||||
{"scifi_nodes:glass","",""}
|
{"scifi_nodes:glass_pane","scifi_nodes:glass_pane",""},
|
||||||
|
{"scifi_nodes:glass_pane","scifi_nodes:glass_pane",""},
|
||||||
|
{"","",""}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
@ -1680,7 +1693,7 @@ minetest.register_craft({
|
|||||||
minetest.register_craft({
|
minetest.register_craft({
|
||||||
output = 'scifi_nodes:stripes2top 3',
|
output = 'scifi_nodes:stripes2top 3',
|
||||||
recipe = {
|
recipe = {
|
||||||
{"scifi_nodes:black","scifi_noedes:black","scifi_nodes:black"},
|
{"scifi_nodes:black","scifi_nodes:black","scifi_nodes:black"},
|
||||||
{"default:silver_sand","default:silver_sand","default:silver_sand"}
|
{"default:silver_sand","default:silver_sand","default:silver_sand"}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
@ -1692,4 +1705,3 @@ minetest.register_craft({
|
|||||||
{"scifi_nodes:stripes"}
|
{"scifi_nodes:stripes"}
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
127
doors.lua
127
doors.lua
@ -40,10 +40,10 @@ minetest.register_alias("scifi_nodes:door4d","scifi_nodes:green_door_opened_top"
|
|||||||
|
|
||||||
-- This table now uses named parameters and more convenient variables names
|
-- This table now uses named parameters and more convenient variables names
|
||||||
local doors = {
|
local doors = {
|
||||||
{base_name = "Doom", base_ingredient = "doors:door_obsidian_glass", sound = "scifi_nodes_door_mechanic"},
|
{base_name = "Doom", base_ingredient = "doors:door_obsidian_glass", sound = "scifi_nodes_door_normal"},
|
||||||
{base_name = "black", base_ingredient = "doors:door_steel", sound = "scifi_nodes_door_mechanic"},
|
{base_name = "black", base_ingredient = "doors:door_steel", sound = "scifi_nodes_door_normal"},
|
||||||
{base_name = "white", base_ingredient = "doors:door_glass", sound = "scifi_nodes_door_normal"},
|
{base_name = "white", base_ingredient = "doors:door_glass", sound = "scifi_nodes_door_normal"},
|
||||||
{base_name = "green", base_ingredient = "doors:door_wood", sound = "scifi_nodes_door_mechanic"},
|
{base_name = "green", base_ingredient = "doors:door_wood", sound = "scifi_nodes_door_normal"},
|
||||||
{base_name = "blue", base_ingredient = "default:steelblock", sound = "scifi_nodes_door_normal"}
|
{base_name = "blue", base_ingredient = "default:steelblock", sound = "scifi_nodes_door_normal"}
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -124,6 +124,37 @@ for _, current_door in ipairs(doors) do
|
|||||||
minetest.set_node({x=pos.x,y=pos.y+1,z=pos.z},{name="air"})
|
minetest.set_node({x=pos.x,y=pos.y+1,z=pos.z},{name="air"})
|
||||||
end
|
end
|
||||||
|
|
||||||
|
local function change_adjacent(target, pos, node)
|
||||||
|
local target_opposite, target_top
|
||||||
|
if target == opened then
|
||||||
|
target_top = opened_top
|
||||||
|
target_opposite = closed
|
||||||
|
else
|
||||||
|
target_top = closed_top
|
||||||
|
target_opposite = opened
|
||||||
|
end
|
||||||
|
|
||||||
|
for offset = -1,1,2 do
|
||||||
|
local x = pos.x
|
||||||
|
local y = pos.y
|
||||||
|
local z = pos.z
|
||||||
|
|
||||||
|
-- match param2=0 or param2=2
|
||||||
|
if node.param2 % 2 == 0 then
|
||||||
|
x = x + offset
|
||||||
|
else
|
||||||
|
z = z + offset
|
||||||
|
end
|
||||||
|
|
||||||
|
local adjacent = minetest.get_node({x=x, y=y, z=z})
|
||||||
|
if adjacent.name == target_opposite then
|
||||||
|
minetest.set_node({x=x, y=y, z=z}, {name=target, param2 = adjacent.param2})
|
||||||
|
minetest.set_node({x=x, y=y+1, z=z}, {name=target_top, param2 = adjacent.param2})
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
end
|
||||||
|
|
||||||
local function open_door(pos, node, player, itemstack, pointed_thing)
|
local function open_door(pos, node, player, itemstack, pointed_thing)
|
||||||
-- play sound
|
-- play sound
|
||||||
minetest.sound_play(sound,{
|
minetest.sound_play(sound,{
|
||||||
@ -133,51 +164,12 @@ for _, current_door in ipairs(doors) do
|
|||||||
})
|
})
|
||||||
|
|
||||||
local timer = minetest.get_node_timer(pos)
|
local timer = minetest.get_node_timer(pos)
|
||||||
local a = minetest.get_node({x=pos.x, y=pos.y, z=pos.z-1})
|
|
||||||
local b = minetest.get_node({x=pos.x, y=pos.y, z=pos.z+1})
|
|
||||||
local c = minetest.get_node({x=pos.x+1, y=pos.y, z=pos.z})
|
|
||||||
local d = minetest.get_node({x=pos.x-1, y=pos.y, z=pos.z})
|
|
||||||
local e = minetest.get_node({x=pos.x+1, y=pos.y, z=pos.z-1})
|
|
||||||
local f = minetest.get_node({x=pos.x-1, y=pos.y, z=pos.z-1})
|
|
||||||
local g = minetest.get_node({x=pos.x+1, y=pos.y, z=pos.z+1})
|
|
||||||
local h = minetest.get_node({x=pos.x-1, y=pos.y, z=pos.z+1})
|
|
||||||
|
|
||||||
|
|
||||||
minetest.set_node(pos, {name=opened, param2=node.param2})
|
minetest.set_node(pos, {name=opened, param2=node.param2})
|
||||||
minetest.set_node({x=pos.x,y=pos.y+1,z=pos.z}, {name=opened_top, param2=node.param2})
|
minetest.set_node({x=pos.x,y=pos.y+1,z=pos.z}, {name=opened_top, param2=node.param2})
|
||||||
|
|
||||||
if a.name == closed then
|
change_adjacent(opened, pos, node)
|
||||||
minetest.set_node({x=pos.x, y=pos.y, z=pos.z-1}, {name=opened, param2=a.param2})
|
|
||||||
minetest.set_node({x=pos.x,y=pos.y+1,z=pos.z-1}, {name=opened_top, param2=a.param2})
|
|
||||||
end
|
|
||||||
if b.name == closed then
|
|
||||||
minetest.set_node({x=pos.x, y=pos.y, z=pos.z+1}, {name=opened, param2=b.param2})
|
|
||||||
minetest.set_node({x=pos.x,y=pos.y+1,z=pos.z+1}, {name=opened_top, param2=b.param2})
|
|
||||||
end
|
|
||||||
if c.name == closed then
|
|
||||||
minetest.set_node({x=pos.x+1, y=pos.y, z=pos.z}, {name=opened, param2=c.param2})
|
|
||||||
minetest.set_node({x=pos.x+1,y=pos.y+1,z=pos.z}, {name=opened_top, param2=c.param2})
|
|
||||||
end
|
|
||||||
if d.name == closed then
|
|
||||||
minetest.set_node({x=pos.x-1, y=pos.y, z=pos.z}, {name=opened, param2=d.param2})
|
|
||||||
minetest.set_node({x=pos.x-1,y=pos.y+1,z=pos.z}, {name=opened_top, param2=d.param2})
|
|
||||||
end
|
|
||||||
if e.name == closed then
|
|
||||||
minetest.set_node({x=pos.x+1, y=pos.y, z=pos.z-1}, {name=opened, param2=e.param2})
|
|
||||||
minetest.set_node({x=pos.x+1, y=pos.y+1, z=pos.z-1}, {name=opened_top, param2=e.param2})
|
|
||||||
end
|
|
||||||
if f.name == closed then
|
|
||||||
minetest.set_node({x=pos.x-1, y=pos.y, z=pos.z-1}, {name=opened, param2=f.param2})
|
|
||||||
minetest.set_node({x=pos.x-1, y=pos.y+1, z=pos.z-1}, {name=opened_top, param2=f.param2})
|
|
||||||
end
|
|
||||||
if g.name == closed then
|
|
||||||
minetest.set_node({x=pos.x+1, y=pos.y, z=pos.z+1}, {name=opened, param2=g.param2})
|
|
||||||
minetest.set_node({x=pos.x+1, y=pos.y+1, z=pos.z+1}, {name=opened_top, param2=g.param2})
|
|
||||||
end
|
|
||||||
if h.name == closed then
|
|
||||||
minetest.set_node({x=pos.x-1, y=pos.y, z=pos.z+1}, {name=opened, param2=h.param2})
|
|
||||||
minetest.set_node({x=pos.x-1, y=pos.y+1, z=pos.z+1}, {name=opened_top, param2=h.param2})
|
|
||||||
end
|
|
||||||
timer:start(3)
|
timer:start(3)
|
||||||
end
|
end
|
||||||
|
|
||||||
@ -195,50 +187,11 @@ for _, current_door in ipairs(doors) do
|
|||||||
})
|
})
|
||||||
|
|
||||||
local node = minetest.get_node(pos)
|
local node = minetest.get_node(pos)
|
||||||
local a = minetest.get_node({x=pos.x, y=pos.y, z=pos.z-1})
|
|
||||||
local b = minetest.get_node({x=pos.x, y=pos.y, z=pos.z+1})
|
|
||||||
local c = minetest.get_node({x=pos.x+1, y=pos.y, z=pos.z})
|
|
||||||
local d = minetest.get_node({x=pos.x-1, y=pos.y, z=pos.z})
|
|
||||||
local e = minetest.get_node({x=pos.x+1, y=pos.y, z=pos.z-1})
|
|
||||||
local f = minetest.get_node({x=pos.x-1, y=pos.y, z=pos.z-1})
|
|
||||||
local g = minetest.get_node({x=pos.x+1, y=pos.y, z=pos.z+1})
|
|
||||||
local h = minetest.get_node({x=pos.x-1, y=pos.y, z=pos.z+1})
|
|
||||||
|
|
||||||
minetest.set_node(pos, {name=closed, param2=node.param2})
|
minetest.set_node(pos, {name=closed, param2=node.param2})
|
||||||
minetest.set_node({x=pos.x,y=pos.y+1,z=pos.z}, {name=closed_top, param2=node.param2})
|
minetest.set_node({x=pos.x,y=pos.y+1,z=pos.z}, {name=closed_top, param2=node.param2})
|
||||||
|
|
||||||
if a.name == opened then
|
change_adjacent(closed, pos, node)
|
||||||
minetest.set_node({x=pos.x, y=pos.y, z=pos.z-1}, {name=closed, param2=a.param2})
|
|
||||||
minetest.set_node({x=pos.x,y=pos.y+1,z=pos.z-1}, {name=closed_top, param2=a.param2})
|
|
||||||
end
|
|
||||||
if b.name == opened then
|
|
||||||
minetest.set_node({x=pos.x, y=pos.y, z=pos.z+1}, {name=closed, param2=b.param2})
|
|
||||||
minetest.set_node({x=pos.x,y=pos.y+1,z=pos.z+1}, {name=closed_top, param2=b.param2})
|
|
||||||
end
|
|
||||||
if c.name == opened then
|
|
||||||
minetest.set_node({x=pos.x+1, y=pos.y, z=pos.z}, {name=closed, param2=c.param2})
|
|
||||||
minetest.set_node({x=pos.x+1,y=pos.y+1,z=pos.z}, {name=closed_top, param2=c.param2})
|
|
||||||
end
|
|
||||||
if d.name == opened then
|
|
||||||
minetest.set_node({x=pos.x-1, y=pos.y, z=pos.z}, {name=closed, param2=d.param2})
|
|
||||||
minetest.set_node({x=pos.x-1,y=pos.y+1,z=pos.z}, {name=closed_top, param2=d.param2})
|
|
||||||
end
|
|
||||||
if e.name == opened then
|
|
||||||
minetest.set_node({x=pos.x+1, y=pos.y, z=pos.z-1}, {name=closed, param2=e.param2})
|
|
||||||
minetest.set_node({x=pos.x+1, y=pos.y+1, z=pos.z-1}, {name=closed_top, param2=e.param2})
|
|
||||||
end
|
|
||||||
if f.name == opened then
|
|
||||||
minetest.set_node({x=pos.x-1, y=pos.y, z=pos.z-1}, {name=closed, param2=f.param2})
|
|
||||||
minetest.set_node({x=pos.x-1, y=pos.y+1, z=pos.z-1}, {name=closed_top, param2=f.param2})
|
|
||||||
end
|
|
||||||
if g.name == opened then
|
|
||||||
minetest.set_node({x=pos.x+1, y=pos.y, z=pos.z+1}, {name=closed, param2=g.param2})
|
|
||||||
minetest.set_node({x=pos.x+1, y=pos.y+1, z=pos.z+1}, {name=closed_top, param2=g.param2})
|
|
||||||
end
|
|
||||||
if h.name == opened then
|
|
||||||
minetest.set_node({x=pos.x-1, y=pos.y, z=pos.z+1}, {name=closed, param2=h.param2})
|
|
||||||
minetest.set_node({x=pos.x-1, y=pos.y+1, z=pos.z+1}, {name=closed_top, param2=h.param2})
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|
||||||
local mesecons_doors_rules = {
|
local mesecons_doors_rules = {
|
||||||
@ -265,6 +218,10 @@ for _, current_door in ipairs(doors) do
|
|||||||
},
|
},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
local function nodig(pos, digger)
|
||||||
|
return false
|
||||||
|
end
|
||||||
|
|
||||||
local doors_rightclick = nil -- Crashes serv if empty table !
|
local doors_rightclick = nil -- Crashes serv if empty table !
|
||||||
if not scifi_nodes.doors_open_with_mesecon_only then doors_rightclick = open_door end
|
if not scifi_nodes.doors_open_with_mesecon_only then doors_rightclick = open_door end
|
||||||
|
|
||||||
@ -327,6 +284,7 @@ for _, current_door in ipairs(doors) do
|
|||||||
{0, 0, 0, 0, 0, 0},
|
{0, 0, 0, 0, 0, 0},
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
can_dig = nodig,
|
||||||
})
|
})
|
||||||
|
|
||||||
minetest.register_node(opened, {
|
minetest.register_node(opened, {
|
||||||
@ -385,5 +343,6 @@ for _, current_door in ipairs(doors) do
|
|||||||
{0, 0, 0, 0, 0, 0},
|
{0, 0, 0, 0, 0, 0},
|
||||||
}
|
}
|
||||||
},
|
},
|
||||||
|
can_dig = nodig,
|
||||||
})
|
})
|
||||||
end -- end of doors table browsing
|
end -- end of doors table browsing
|
||||||
|
4
init.lua
4
init.lua
@ -14,9 +14,11 @@ dofile(MP.."/chest.lua")
|
|||||||
dofile(MP.."/plants.lua")
|
dofile(MP.."/plants.lua")
|
||||||
dofile(MP.."/nodes.lua")
|
dofile(MP.."/nodes.lua")
|
||||||
dofile(MP.."/doors.lua")
|
dofile(MP.."/doors.lua")
|
||||||
dofile(MP.."/switches.lua")
|
dofile(MP.."/switch.lua")
|
||||||
|
dofile(MP.."/protected_switch.lua")
|
||||||
dofile(MP.."/nodeboxes.lua")
|
dofile(MP.."/nodeboxes.lua")
|
||||||
dofile(MP.."/palm_scanner.lua")
|
dofile(MP.."/palm_scanner.lua")
|
||||||
dofile(MP.."/digicode.lua")
|
dofile(MP.."/digicode.lua")
|
||||||
dofile(MP.."/models.lua")
|
dofile(MP.."/models.lua")
|
||||||
|
dofile(MP.."/octagon_panes.lua")
|
||||||
dofile(MP.."/crafts.lua")
|
dofile(MP.."/crafts.lua")
|
||||||
|
2
mod.conf
2
mod.conf
@ -1,4 +1,4 @@
|
|||||||
name = scifi_nodes
|
name = scifi_nodes
|
||||||
description = Minetest mod that adds scifi themed blocks, doors, materials, plants and other assets.
|
description = Minetest mod that adds scifi themed blocks, doors, materials, plants and other assets.
|
||||||
depends = default,dye
|
depends = default,dye
|
||||||
optional_depends = xpanes,mesecons,moreblocks,mesecons_microcontroller,mesecons_button,mesecons_torch,mesecons_receiver,basic_materials
|
optional_depends = xpanes,mesecons,moreblocks,mesecons_microcontroller,mesecons_button,mesecons_torch,mesecons_receiver,basic_materials,unifieddyes
|
||||||
|
@ -151,7 +151,8 @@ minetest.register_node("scifi_nodes:pad", {
|
|||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
groups = {cracky=1, oddly_breakable_by_hand=1},
|
groups = {cracky=1, oddly_breakable_by_hand=1},
|
||||||
light_source = 5,
|
light_source = 5,
|
||||||
on_construct = function(pos, node, placer)
|
after_place_node = function(pos, placer, itemstack, pointed_thing)
|
||||||
|
local placer_name = placer:get_player_name()
|
||||||
local meta = minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
if position1 == nil then
|
if position1 == nil then
|
||||||
position1 = pos
|
position1 = pos
|
||||||
@ -160,10 +161,11 @@ minetest.register_node("scifi_nodes:pad", {
|
|||||||
position2 = pos
|
position2 = pos
|
||||||
meta:set_int("type", 2)
|
meta:set_int("type", 2)
|
||||||
else
|
else
|
||||||
minetest.chat_send_all("There can only be two teleportation pads at a time!")
|
minetest.chat_send_player(placer_name, "There can only be two teleportation pads at a time!")
|
||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
on_rightclick = function(pos, node, clicker)
|
on_rightclick = function(pos, node, clicker)
|
||||||
|
local clicker_name = clicker:get_player_name()
|
||||||
local meta = minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
if meta:get_int("type") == 1 and position2 ~= nil and position1 ~= nil then
|
if meta:get_int("type") == 1 and position2 ~= nil and position1 ~= nil then
|
||||||
minetest.add_particlespawner(
|
minetest.add_particlespawner(
|
||||||
@ -236,12 +238,12 @@ minetest.register_node("scifi_nodes:pad", {
|
|||||||
elseif position1 == nil and meta:get_int("type") ~= 2 then
|
elseif position1 == nil and meta:get_int("type") ~= 2 then
|
||||||
position1 = pos
|
position1 = pos
|
||||||
meta:set_int("type", 1)
|
meta:set_int("type", 1)
|
||||||
minetest.chat_send_all("Teleporter 1 connected at "..minetest.pos_to_string(pos))
|
minetest.chat_send_player(clicker_name, "Teleporter 1 connected at "..minetest.pos_to_string(pos))
|
||||||
elseif position2 == nil and meta:get_int("type") ~= 1 then
|
elseif position2 == nil and meta:get_int("type") ~= 1 then
|
||||||
position2 = pos
|
position2 = pos
|
||||||
meta:set_int("type", 2)
|
meta:set_int("type", 2)
|
||||||
minetest.chat_send_all("Teleporter 2 connected at "..minetest.pos_to_string(pos))
|
minetest.chat_send_player(clicker_name, "Teleporter 2 connected at "..minetest.pos_to_string(pos))
|
||||||
else minetest.chat_send_all("Teleporter error!")
|
else minetest.chat_send_player(clicker_name, "Teleporter error!")
|
||||||
end
|
end
|
||||||
end,
|
end,
|
||||||
on_destruct = function(pos, oldnode, placer)
|
on_destruct = function(pos, oldnode, placer)
|
||||||
@ -473,6 +475,12 @@ minetest.register_node("scifi_nodes:light_dynamic", {
|
|||||||
type = "wallmounted",
|
type = "wallmounted",
|
||||||
fixed = {-0.5, -0.5, -0.5, -0.45, 0.5, 0.5}
|
fixed = {-0.5, -0.5, -0.5, -0.45, 0.5, 0.5}
|
||||||
},
|
},
|
||||||
|
node_box = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = {
|
||||||
|
fixed = {-0.5, -0.5, -0.5, -0.45, 0.5, 0.5}
|
||||||
|
}
|
||||||
|
},
|
||||||
paramtype2 = "wallmounted",
|
paramtype2 = "wallmounted",
|
||||||
light_source = default.LIGHT_MAX,
|
light_source = default.LIGHT_MAX,
|
||||||
groups = {cracky=1, oddly_breakable_by_hand=1},
|
groups = {cracky=1, oddly_breakable_by_hand=1},
|
||||||
@ -1078,10 +1086,9 @@ minetest.register_node("scifi_nodes:itemholder", {
|
|||||||
local meta = minetest.get_meta(pos)
|
local meta = minetest.get_meta(pos)
|
||||||
if name == meta:get_string("owner") or
|
if name == meta:get_string("owner") or
|
||||||
minetest.check_player_privs(name, "protection_bypass") then
|
minetest.check_player_privs(name, "protection_bypass") then
|
||||||
local wield_item = clicker:get_wielded_item():get_name()
|
|
||||||
local taken = item:take_item()
|
local taken = item:take_item()
|
||||||
if taken and not taken:is_empty() then
|
if taken and not taken:is_empty() then
|
||||||
minetest.add_item(pos, wield_item)
|
minetest.add_item(pos, taken:to_string())
|
||||||
return item
|
return item
|
||||||
end
|
end
|
||||||
end
|
end
|
||||||
|
63
nodes.lua
63
nodes.lua
@ -182,6 +182,23 @@ minetest.register_node("scifi_nodes:disc", {
|
|||||||
groups = {cracky=1}
|
groups = {cracky=1}
|
||||||
})
|
})
|
||||||
|
|
||||||
|
minetest.register_node("scifi_nodes:greenbar_animated", {
|
||||||
|
description = "animated green light bar",
|
||||||
|
sunlight_propagates = false,
|
||||||
|
tiles = {
|
||||||
|
"scifi_nodes_greenbar.png",
|
||||||
|
"scifi_nodes_greenbar.png", {
|
||||||
|
name="scifi_nodes_greenbar_animated.png",
|
||||||
|
animation={type="vertical_frames", aspect_w=16, aspect_h=16, length=1.00},
|
||||||
|
}
|
||||||
|
},
|
||||||
|
paramtype = "light",
|
||||||
|
paramtype2 = "facedir",
|
||||||
|
groups = {cracky=1},
|
||||||
|
light_source = 10,
|
||||||
|
sounds = default.node_sound_glass_defaults(),
|
||||||
|
on_place = minetest.rotate_node
|
||||||
|
})
|
||||||
|
|
||||||
minetest.register_node("scifi_nodes:blink", {
|
minetest.register_node("scifi_nodes:blink", {
|
||||||
description = "blinking light",
|
description = "blinking light",
|
||||||
@ -500,14 +517,15 @@ minetest.register_node("scifi_nodes:whtlightbnd", {
|
|||||||
-- colors available. When crafting, the last recipes will be checked first.
|
-- colors available. When crafting, the last recipes will be checked first.
|
||||||
--add new block using texture name(without "scifi_nodes_" prefix) then the description, and then the name of the block
|
--add new block using texture name(without "scifi_nodes_" prefix) then the description, and then the name of the block
|
||||||
local nodetypes = {
|
local nodetypes = {
|
||||||
|
-- { name, description, shortname?, light, colorable }
|
||||||
{"blue", "blue lines", "blue"},
|
{"blue", "blue lines", "blue"},
|
||||||
{"holes", "metal with holes","holes"},
|
{"holes", "metal with holes","holes"},
|
||||||
{"white2", "plastic", "white2"},
|
{"white2", "plastic", "white2", 0, true},
|
||||||
{"super_white", "Super Plastic", "super_white", 11},
|
{"super_white", "Super Plastic", "super_white", 11},
|
||||||
{"ultra_white", "Ultra Plastic", "ultra_white", default.LIGHT_MAX},
|
{"ultra_white", "Ultra Plastic", "ultra_white", default.LIGHT_MAX},
|
||||||
{"engine", "engine", "engine"},
|
{"engine", "engine", "engine"},
|
||||||
{"wall", "metal wall", "wall"},
|
{"wall", "metal wall", "wall"},
|
||||||
{"white", "plastic wall", "white"},
|
{"white", "plastic wall", "white", 0, true},
|
||||||
{"stripes2top", "dirty metal block","metal2"},
|
{"stripes2top", "dirty metal block","metal2"},
|
||||||
{"rough", "rough metal", "rough"},
|
{"rough", "rough metal", "rough"},
|
||||||
{"lighttop", "metal block", "metal"},
|
{"lighttop", "metal block", "metal"},
|
||||||
@ -528,12 +546,11 @@ local nodetypes = {
|
|||||||
{"bluetile", "blue tile", "blutl"},
|
{"bluetile", "blue tile", "blutl"},
|
||||||
{"greytile", "grey tile", "grytl"},
|
{"greytile", "grey tile", "grytl"},
|
||||||
{"mesh2", "metal floormesh", "mesh2"},
|
{"mesh2", "metal floormesh", "mesh2"},
|
||||||
{"white", "plastic wall", "white"},
|
|
||||||
{"pipe", "wall pipe", "pipe2"},
|
{"pipe", "wall pipe", "pipe2"},
|
||||||
{"pipeside", "side pipe", "pipe3"},
|
{"pipeside", "side pipe", "pipe3"},
|
||||||
{"tile", "white tile", "tile"},
|
{"tile", "white tile", "tile"},
|
||||||
{"whiteoct", "white octagon", "whiteoct"},
|
{"whiteoct", "white octagon", "whiteoct", 0, true},
|
||||||
{"whitetile", "white tile2", "whttl"},
|
{"whitetile", "white tile2", "whttl", 0, true},
|
||||||
{"black_detail", "black detail", "blckdtl"},
|
{"black_detail", "black detail", "blckdtl"},
|
||||||
{"green_square", "green metal block", "grnblck"},
|
{"green_square", "green metal block", "grnblck"},
|
||||||
{"red_square", "red metal block", "redblck"},
|
{"red_square", "red metal block", "redblck"},
|
||||||
@ -586,12 +603,16 @@ local nodetypes = {
|
|||||||
{"blackplate", "Black plate", "", 0},
|
{"blackplate", "Black plate", "", 0},
|
||||||
}
|
}
|
||||||
|
|
||||||
|
local has_unifieddyes_mod = minetest.get_modpath("unifieddyes")
|
||||||
|
|
||||||
for _, row in ipairs(nodetypes) do
|
for _, row in ipairs(nodetypes) do
|
||||||
local name = row[1]
|
local name = row[1]
|
||||||
local desc = row[2]
|
local desc = row[2]
|
||||||
local light = row[4]
|
local light = row[4]
|
||||||
|
local is_colorable = row[5]
|
||||||
|
|
||||||
-- Node Definition
|
-- Node Definition
|
||||||
minetest.register_node("scifi_nodes:"..name, {
|
local node_def = {
|
||||||
description = desc,
|
description = desc,
|
||||||
tiles = {"scifi_nodes_"..name..".png"},
|
tiles = {"scifi_nodes_"..name..".png"},
|
||||||
groups = {cracky=1},
|
groups = {cracky=1},
|
||||||
@ -599,5 +620,35 @@ for _, row in ipairs(nodetypes) do
|
|||||||
paramtype2 = "facedir",
|
paramtype2 = "facedir",
|
||||||
light_source = light,
|
light_source = light,
|
||||||
sounds = default.node_sound_glass_defaults()
|
sounds = default.node_sound_glass_defaults()
|
||||||
|
}
|
||||||
|
|
||||||
|
if is_colorable and has_unifieddyes_mod then
|
||||||
|
-- overwrite attributes on the "uncolored" node
|
||||||
|
node_def.palette = "unifieddyes_palette_extended.png"
|
||||||
|
node_def.groups.ud_param2_colorable = 1
|
||||||
|
node_def.airbrush_replacement_node = "scifi_nodes:"..name.."_colored"
|
||||||
|
end
|
||||||
|
|
||||||
|
-- register node
|
||||||
|
minetest.register_node("scifi_nodes:"..name, node_def)
|
||||||
|
|
||||||
|
if is_colorable and has_unifieddyes_mod then
|
||||||
|
-- register colored node
|
||||||
|
minetest.register_node("scifi_nodes:"..name.."_colored", {
|
||||||
|
description = desc,
|
||||||
|
tiles = {"scifi_nodes_"..name..".png"},
|
||||||
|
groups = {
|
||||||
|
cracky = 1,
|
||||||
|
ud_param2_colorable = 1,
|
||||||
|
not_in_creative_inventory = 1
|
||||||
|
},
|
||||||
|
palette = "unifieddyes_palette_extended.png",
|
||||||
|
paramtype = "light",
|
||||||
|
paramtype2 = "color",
|
||||||
|
light_source = light,
|
||||||
|
sounds = default.node_sound_glass_defaults(),
|
||||||
|
on_construct = unifieddyes.on_construct,
|
||||||
|
on_dig = unifieddyes.on_dig
|
||||||
})
|
})
|
||||||
end
|
end
|
||||||
|
end
|
||||||
|
111
octagon_panes.lua
Normal file
111
octagon_panes.lua
Normal file
@ -0,0 +1,111 @@
|
|||||||
|
|
||||||
|
local function register(basename, description, texture)
|
||||||
|
local nodename_single = "scifi_nodes:" .. basename .. "_pane"
|
||||||
|
local nodename_double = "scifi_nodes:" .. basename .. "_pane_double"
|
||||||
|
local nodename_offset = "scifi_nodes:" .. basename .. "_pane_offset"
|
||||||
|
local recipe_ingredient = "scifi_nodes:" .. basename
|
||||||
|
|
||||||
|
-- single height
|
||||||
|
minetest.register_node(nodename_single, {
|
||||||
|
description = description,
|
||||||
|
drawtype = "nodebox",
|
||||||
|
tiles = {
|
||||||
|
texture
|
||||||
|
},
|
||||||
|
wield_image = texture,
|
||||||
|
paramtype = "light",
|
||||||
|
paramtype2 = "facedir",
|
||||||
|
sunlight_propagates = true,
|
||||||
|
is_ground_content = false,
|
||||||
|
node_box = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = {{-0.5, -0.5, -0.03125, 0.5, 0.5, 0.03125}},
|
||||||
|
},
|
||||||
|
selection_box = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = {{-0.5, -0.5, -0.25, 0.5, 0.5, 0.25}},
|
||||||
|
},
|
||||||
|
groups = {cracky = 3, oddly_breakable_by_hand = 3},
|
||||||
|
use_texture_alpha = true,
|
||||||
|
sounds = default.node_sound_glass_defaults()
|
||||||
|
})
|
||||||
|
|
||||||
|
-- double height
|
||||||
|
minetest.register_node(nodename_double, {
|
||||||
|
description = description,
|
||||||
|
drawtype = "nodebox",
|
||||||
|
tiles = {
|
||||||
|
texture
|
||||||
|
},
|
||||||
|
wield_image = texture,
|
||||||
|
paramtype = "light",
|
||||||
|
paramtype2 = "facedir",
|
||||||
|
sunlight_propagates = true,
|
||||||
|
is_ground_content = false,
|
||||||
|
node_box = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = {{-0.5, -0.5, -0.03125, 0.5, 1.5, 0.03125}},
|
||||||
|
},
|
||||||
|
selection_box = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = {{-0.5, -0.5, -0.25, 0.5, 1.5, 0.25}},
|
||||||
|
},
|
||||||
|
groups = {cracky = 3, oddly_breakable_by_hand = 3},
|
||||||
|
use_texture_alpha = true,
|
||||||
|
sounds = default.node_sound_glass_defaults()
|
||||||
|
})
|
||||||
|
|
||||||
|
-- single height with offset
|
||||||
|
minetest.register_node(nodename_offset, {
|
||||||
|
description = description,
|
||||||
|
drawtype = "nodebox",
|
||||||
|
tiles = {
|
||||||
|
texture
|
||||||
|
},
|
||||||
|
wield_image = texture,
|
||||||
|
paramtype = "light",
|
||||||
|
paramtype2 = "facedir",
|
||||||
|
sunlight_propagates = true,
|
||||||
|
is_ground_content = false,
|
||||||
|
node_box = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = {{-0.5, -0.5, 0.96875, 0.5, 0.5, 1.03125}},
|
||||||
|
},
|
||||||
|
selection_box = {
|
||||||
|
type = "fixed",
|
||||||
|
fixed = {{-0.5, -0.5, 0.75, 0.5, 0.5, 1.25}},
|
||||||
|
},
|
||||||
|
groups = {cracky = 3, oddly_breakable_by_hand = 3},
|
||||||
|
use_texture_alpha = true,
|
||||||
|
sounds = default.node_sound_glass_defaults()
|
||||||
|
})
|
||||||
|
|
||||||
|
-- register recipes
|
||||||
|
|
||||||
|
minetest.register_craft({
|
||||||
|
output = nodename_single .. " 16",
|
||||||
|
recipe = {
|
||||||
|
{recipe_ingredient}
|
||||||
|
},
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_craft({
|
||||||
|
output = nodename_double .. " 16",
|
||||||
|
recipe = {
|
||||||
|
{recipe_ingredient},
|
||||||
|
{recipe_ingredient}
|
||||||
|
},
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_craft({
|
||||||
|
output = nodename_offset,
|
||||||
|
type = "shapeless",
|
||||||
|
recipe = {nodename_single},
|
||||||
|
})
|
||||||
|
end
|
||||||
|
|
||||||
|
register("octrng", "Orange Octagon Glass pane", "scifi_nodes_octrng.png")
|
||||||
|
register("octgrn", "Green Octagon Glass pane", "scifi_nodes_octgrn.png")
|
||||||
|
register("octbl", "Blue Octagon Glass pane", "scifi_nodes_octbl.png")
|
||||||
|
register("octppl", "Purple Octagon Glass pane", "scifi_nodes_octppl.png")
|
||||||
|
register("glass", "Dark Glass pane", "scifi_nodes_glass.png")
|
@ -29,7 +29,7 @@ for _, row in ipairs(plants) do
|
|||||||
description = desc,
|
description = desc,
|
||||||
tiles = {"scifi_nodes_"..name..".png"},
|
tiles = {"scifi_nodes_"..name..".png"},
|
||||||
drawtype = "plantlike",
|
drawtype = "plantlike",
|
||||||
inventory_image = {"scifi_nodes_"..name..".png"},
|
inventory_image = "scifi_nodes_"..name..".png",
|
||||||
groups = {snappy=1, oddly_breakable_by_hand=1, dig_immediate=3, flora=1},
|
groups = {snappy=1, oddly_breakable_by_hand=1, dig_immediate=3, flora=1},
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
visual_scale = size,
|
visual_scale = size,
|
||||||
|
89
protected_switch.lua
Normal file
89
protected_switch.lua
Normal file
@ -0,0 +1,89 @@
|
|||||||
|
|
||||||
|
--------------
|
||||||
|
-- Switches --
|
||||||
|
--------------
|
||||||
|
|
||||||
|
local has_mesecons = minetest.get_modpath("mesecons")
|
||||||
|
|
||||||
|
local function toggle_switch(pos, _, player)
|
||||||
|
local node = minetest.get_node(pos)
|
||||||
|
local name = node.name
|
||||||
|
if name == "scifi_nodes:protected_switch_on" then
|
||||||
|
-- toggle off
|
||||||
|
minetest.sound_play("scifi_nodes_switch", {max_hear_distance = 8, pos = pos})
|
||||||
|
minetest.set_node(pos, {name = "scifi_nodes:protected_switch_off", param2 = node.param2})
|
||||||
|
mesecon.receptor_off(pos, scifi_nodes.get_switch_rules(node.param2))
|
||||||
|
elseif name == "scifi_nodes:protected_switch_off" then
|
||||||
|
-- toggle on, check protection first
|
||||||
|
if player and minetest.is_protected(pos, player:get_player_name()) then
|
||||||
|
-- position is protected, abort
|
||||||
|
minetest.sound_play("scifi_nodes_scanner_refused", {max_hear_distance = 8, pos = pos})
|
||||||
|
return
|
||||||
|
end
|
||||||
|
minetest.sound_play("scifi_nodes_switch", {max_hear_distance = 8, pos = pos})
|
||||||
|
minetest.set_node(pos, {name = "scifi_nodes:protected_switch_on", param2 = node.param2})
|
||||||
|
mesecon.receptor_on(pos, scifi_nodes.get_switch_rules(node.param2))
|
||||||
|
minetest.get_node_timer(pos):start(2)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
minetest.register_node("scifi_nodes:protected_switch_on", {
|
||||||
|
description = "Protected wall switch",
|
||||||
|
sunlight_propagates = true,
|
||||||
|
buildable_to = false,
|
||||||
|
tiles = {"scifi_nodes_switch_on.png",},
|
||||||
|
inventory_image = "scifi_nodes_switch_on.png",
|
||||||
|
wield_image = "scifi_nodes_switch_on.png",
|
||||||
|
drawtype = "signlike",
|
||||||
|
node_box = {type = "wallmounted",},
|
||||||
|
selection_box = {type = "wallmounted",},
|
||||||
|
paramtype = "light",
|
||||||
|
paramtype2 = "wallmounted",
|
||||||
|
light_source = 5,
|
||||||
|
groups = {
|
||||||
|
cracky=1,
|
||||||
|
oddly_breakable_by_hand = 1,
|
||||||
|
not_in_creative_inventory = 1,
|
||||||
|
mesecon_needs_receiver = 1
|
||||||
|
},
|
||||||
|
mesecons = {
|
||||||
|
receptor = {
|
||||||
|
state = (has_mesecons and mesecon.state.on)
|
||||||
|
}
|
||||||
|
},
|
||||||
|
sounds = default.node_sound_glass_defaults(),
|
||||||
|
on_rightclick = (has_mesecons and toggle_switch),
|
||||||
|
on_timer = (has_mesecons and toggle_switch)
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_node("scifi_nodes:protected_switch_off", {
|
||||||
|
description = "Protected wall switch",
|
||||||
|
tiles = {"scifi_nodes_switch_off.png",},
|
||||||
|
inventory_image = "scifi_nodes_switch_on.png",
|
||||||
|
wield_image = "scifi_nodes_switch_on.png",
|
||||||
|
drawtype = "signlike",
|
||||||
|
sunlight_propagates = true,
|
||||||
|
buildable_to = false,
|
||||||
|
node_box = {type = "wallmounted",},
|
||||||
|
selection_box = {type = "wallmounted",},
|
||||||
|
paramtype = "light",
|
||||||
|
paramtype2 = "wallmounted",
|
||||||
|
groups = {
|
||||||
|
cracky = 1,
|
||||||
|
oddly_breakable_by_hand = 1,
|
||||||
|
mesecon_needs_receiver = 1
|
||||||
|
},
|
||||||
|
mesecons = {
|
||||||
|
receptor = {
|
||||||
|
state = (has_mesecons and mesecon.state.off)
|
||||||
|
}
|
||||||
|
},
|
||||||
|
sounds = default.node_sound_glass_defaults(),
|
||||||
|
on_rightclick = (has_mesecons and toggle_switch)
|
||||||
|
})
|
||||||
|
|
||||||
|
minetest.register_craft({
|
||||||
|
output = "scifi_nodes:protected_switch_off 2",
|
||||||
|
type = "shapeless",
|
||||||
|
recipe = {"scifi_nodes:switch_off", "default:steel_ingot"}
|
||||||
|
})
|
Binary file not shown.
@ -33,7 +33,12 @@ minetest.register_node("scifi_nodes:switch_on", {
|
|||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
paramtype2 = "wallmounted",
|
paramtype2 = "wallmounted",
|
||||||
light_source = 5,
|
light_source = 5,
|
||||||
groups = {cracky=1, oddly_breakable_by_hand=1, not_in_creative_inventory=1, mesecon_needs_receiver = 1},
|
groups = {
|
||||||
|
cracky=1,
|
||||||
|
oddly_breakable_by_hand = 1,
|
||||||
|
not_in_creative_inventory = 1,
|
||||||
|
mesecon_needs_receiver = 1
|
||||||
|
},
|
||||||
mesecons = {
|
mesecons = {
|
||||||
receptor = {
|
receptor = {
|
||||||
state = (has_mesecons and mesecon.state.on)
|
state = (has_mesecons and mesecon.state.on)
|
||||||
@ -56,7 +61,11 @@ minetest.register_node("scifi_nodes:switch_off", {
|
|||||||
selection_box = {type = "wallmounted",},
|
selection_box = {type = "wallmounted",},
|
||||||
paramtype = "light",
|
paramtype = "light",
|
||||||
paramtype2 = "wallmounted",
|
paramtype2 = "wallmounted",
|
||||||
groups = {cracky=1, oddly_breakable_by_hand=1, mesecon_needs_receiver = 1},
|
groups = {
|
||||||
|
cracky = 1,
|
||||||
|
oddly_breakable_by_hand = 1,
|
||||||
|
mesecon_needs_receiver = 1
|
||||||
|
},
|
||||||
mesecons = {
|
mesecons = {
|
||||||
receptor = {
|
receptor = {
|
||||||
state = (has_mesecons and mesecon.state.off)
|
state = (has_mesecons and mesecon.state.off)
|
25
test/integration-test.sh
Executable file
25
test/integration-test.sh
Executable file
@ -0,0 +1,25 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
# Spins up a test world to ensure proper working recipes and registrations
|
||||||
|
|
||||||
|
CWD=$(dirname $0)
|
||||||
|
cd ${CWD}/../
|
||||||
|
|
||||||
|
CFG=/tmp/minetest.conf
|
||||||
|
MTDIR=/tmp/mt
|
||||||
|
WORLDDIR=${MTDIR}/worlds/world
|
||||||
|
|
||||||
|
cat <<EOF > ${CFG}
|
||||||
|
# empty
|
||||||
|
EOF
|
||||||
|
|
||||||
|
mkdir -p ${WORLDDIR}
|
||||||
|
chmod 777 ${MTDIR} -R
|
||||||
|
docker run --rm -i \
|
||||||
|
-v ${CFG}:/etc/minetest/minetest.conf:ro \
|
||||||
|
-v ${MTDIR}:/var/lib/minetest/.minetest \
|
||||||
|
-v $(pwd)/:/var/lib/minetest/.minetest/worlds/world/worldmods/scifi_nodes \
|
||||||
|
-v $(pwd)/test/test_mod/:/var/lib/minetest/.minetest/worlds/world/worldmods/scifi_nodes_test \
|
||||||
|
--network host \
|
||||||
|
registry.gitlab.com/minetest/minetest/server:5.2.0
|
||||||
|
|
||||||
|
test -f ${WORLDDIR}/integration_test.json && exit 0 || exit 1
|
40
test/test_mod/init.lua
Normal file
40
test/test_mod/init.lua
Normal file
@ -0,0 +1,40 @@
|
|||||||
|
|
||||||
|
minetest.log("warning", "[TEST] integration-test enabled!")
|
||||||
|
|
||||||
|
-- those mods have to be present
|
||||||
|
local assert_mods = {
|
||||||
|
"scifi_nodes"
|
||||||
|
}
|
||||||
|
|
||||||
|
-- those nodes have to be present
|
||||||
|
local assert_nodes = {
|
||||||
|
"scifi_nodes:crate",
|
||||||
|
"scifi_nodes:door1a"
|
||||||
|
}
|
||||||
|
|
||||||
|
minetest.register_on_mods_loaded(function()
|
||||||
|
minetest.after(0, function()
|
||||||
|
-- check mods
|
||||||
|
for _, modname in ipairs(assert_mods) do
|
||||||
|
if not minetest.get_modpath(modname) then
|
||||||
|
error("Mod not present: " .. modname)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
-- check nodes
|
||||||
|
for _, nodename in ipairs(assert_nodes) do
|
||||||
|
if not minetest.registered_nodes[nodename] then
|
||||||
|
error("Node not present: " .. nodename)
|
||||||
|
end
|
||||||
|
end
|
||||||
|
|
||||||
|
local data = minetest.write_json({ success = true }, true);
|
||||||
|
local file = io.open(minetest.get_worldpath().."/integration_test.json", "w" );
|
||||||
|
if file then
|
||||||
|
file:write(data)
|
||||||
|
file:close()
|
||||||
|
end
|
||||||
|
minetest.request_shutdown("success")
|
||||||
|
|
||||||
|
end)
|
||||||
|
end)
|
2
test/test_mod/mod.conf
Normal file
2
test/test_mod/mod.conf
Normal file
@ -0,0 +1,2 @@
|
|||||||
|
name = scifi_nodes_test
|
||||||
|
depends = scifi_nodes
|
BIN
textures/scifi_nodes_greenbar_animated.png
Normal file
BIN
textures/scifi_nodes_greenbar_animated.png
Normal file
Binary file not shown.
After Width: | Height: | Size: 278 B |
Reference in New Issue
Block a user