8 Commits

Author SHA1 Message Date
9ad9ba33c8 #39 fix (chat_send_all to chat_send_player) 2020-06-24 21:32:08 +02:00
40bcb29c6d add white and white2 to colored nodes 2020-06-02 07:23:15 +02:00
37aef1ce17 fix backward compatibility 2020-06-02 07:23:15 +02:00
8a8e566d27 add unifieddyes support 2020-06-02 07:23:15 +02:00
a3b8ec1522 update contributor list
fixes #19
2020-05-13 17:56:14 +02:00
ce0501bef3 fix name typo in github action 2020-05-13 17:55:37 +02:00
6d6432940f add integration-test 2020-05-13 17:55:37 +02:00
242dbde0e6 Merge pull request #36 from D00Med/protected-button
Protected button
2020-05-13 17:55:20 +02:00
9 changed files with 145 additions and 20 deletions

15
.github/workflows/integration-test.yml vendored Normal file
View 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

View File

@ -19,6 +19,7 @@ read_globals = {
"xpanes", "xpanes",
"screwdriver", "screwdriver",
"minetest", "minetest",
"mesecon" "mesecon",
"unifieddyes"
} }

View File

@ -3,11 +3,13 @@
# scifi_nodes # scifi_nodes
![](https://github.com/D00Med/scifi_nodes/workflows/luacheck/badge.svg) ![](https://github.com/D00Med/scifi_nodes/workflows/luacheck/badge.svg)
![](https://github.com/D00Med/scifi_nodes/workflows/integration-test/badge.svg)
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)
@ -42,9 +44,13 @@ CC0
# 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 * Grossam https://github.com/Grossam
* OgelGames https://github.com/OgelGames
* leftshift https://github.com/leftshift
* fluxionary https://github.com/fluxionary

View File

@ -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

View File

@ -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)

View File

@ -500,14 +500,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 +529,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 +586,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 +603,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

25
test/integration-test.sh Executable file
View 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
View 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
View File

@ -0,0 +1,2 @@
name = scifi_nodes_test
depends = scifi_nodes