aboutsummaryrefslogtreecommitdiff
path: root/advtrains
diff options
context:
space:
mode:
authorMaverick2797 <git.maverick2797@gmail.com>2021-08-18 18:10:41 +0800
committerorwell96 <orwell@bleipb.de>2021-12-29 21:17:34 +0100
commit7db61e9890c6c5174d82c0f4c8c70d3a11994974 (patch)
treee39c7f9b171655a43395e6f4ce02716622b294b2 /advtrains
parent23d524df71e66c443345a043c9767b7c947d5a5c (diff)
downloadadvtrains-7db61e9890c6c5174d82c0f4c8c70d3a11994974.tar.gz
advtrains-7db61e9890c6c5174d82c0f4c8c70d3a11994974.tar.bz2
advtrains-7db61e9890c6c5174d82c0f4c8c70d3a11994974.zip
Automatically group wagons and locomotives based on definition values
Based on the advtrains wiki groups: Type Group Classifier - Locomotives: group:at_loco is_locomotive = true - Controllable: group:at_control seat_groups.dstand - Passengers: group:at_pax seat_groups.pass - Freight: group:at_freight has_inventory = true
Diffstat (limited to 'advtrains')
-rw-r--r--advtrains/wagons.lua13
1 files changed, 11 insertions, 2 deletions
diff --git a/advtrains/wagons.lua b/advtrains/wagons.lua
index 4093f06..94eda30 100644
--- a/advtrains/wagons.lua
+++ b/advtrains/wagons.lua
@@ -1316,14 +1316,23 @@ function advtrains.register_wagon(sysname_p, prototype, desc, inv_img, nincreati
minetest.register_entity(":"..sysname,prototype)
advtrains.wagon_prototypes[sysname] = prototype
+ --group classification to make recipe searching easier
+ local wagon_groups = { not_in_creative_inventory = nincreative and 1 or 0}
+ if prototype.is_locomotive then wagon_groups['at_loco'] = 1 end
+ if prototype.seat_groups then
+ if prototype.seat_groups.dstand then wagon_groups['at_control'] = 1 end
+ if prototype.seat_groups.pass then wagon_groups['at_pax'] = 1 end
+ end
+ if prototype.has_inventory then wagon_groups['at_freight'] = 1 end
+
minetest.register_craftitem(":"..sysname, {
description = desc,
inventory_image = inv_img,
wield_image = inv_img,
stack_max = 1,
- groups = { not_in_creative_inventory = nincreative and 1 or 0},
-
+ groups = wagon_groups,
+
on_place = function(itemstack, placer, pointed_thing)
if not pointed_thing.type == "node" then
return