diff options
author | Maverick2797 <git.maverick2797@gmail.com> | 2021-08-18 18:10:41 +0800 |
---|---|---|
committer | orwell96 <orwell@bleipb.de> | 2021-12-29 21:17:34 +0100 |
commit | 7db61e9890c6c5174d82c0f4c8c70d3a11994974 (patch) | |
tree | e39c7f9b171655a43395e6f4ce02716622b294b2 /advtrains | |
parent | 23d524df71e66c443345a043c9767b7c947d5a5c (diff) | |
download | advtrains-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.lua | 13 |
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 |