From 9ba4e3d3084d0e8ef93c5ef65529756ed57f599e Mon Sep 17 00:00:00 2001 From: Luke aka SwissalpS Date: Thu, 29 Feb 2024 21:38:45 +0100 Subject: [PATCH 1/6] is_ground_content fixup (#82) digiline nodes aren't ground content --- inventory.lua | 1 + lcd.lua | 1 + lightsensor.lua | 1 + rtc.lua | 1 + wire_std.lua | 1 + 5 files changed, 5 insertions(+) diff --git a/inventory.lua b/inventory.lua index 741d995..0004954 100644 --- a/inventory.lua +++ b/inventory.lua @@ -168,6 +168,7 @@ minetest.register_node("digilines:chest", { paramtype2 = "facedir", legacy_facedir_simple = true, groups = {choppy=2, oddly_breakable_by_hand=2, tubedevice=1, tubedevice_receiver=1, axey=1, handy=1}, + is_ground_content = false, sounds = digilines.sounds.node_sound_wood_defaults(), _mcl_blast_resistance = 1, _mcl_hardness = 0.8, diff --git a/lcd.lua b/lcd.lua index 0faac6c..7d0b1c4 100644 --- a/lcd.lua +++ b/lcd.lua @@ -286,6 +286,7 @@ minetest.register_node("digilines:lcd", { node_box = lcd_box, selection_box = lcd_box, groups = {choppy = 3, dig_immediate = 2}, + is_ground_content = false, _mcl_blast_resistance = 1, _mcl_hardness = 0.8, after_place_node = function(pos) diff --git a/lightsensor.lua b/lightsensor.lua index f97abb4..b39871c 100644 --- a/lightsensor.lua +++ b/lightsensor.lua @@ -39,6 +39,7 @@ minetest.register_node("digilines:lightsensor", { paramtype = "light", groups = {dig_immediate=2}, + is_ground_content = false, _mcl_blast_resistance = 1, _mcl_hardness = 0.8, selection_box = lsensor_selbox, diff --git a/rtc.lua b/rtc.lua index a7a422a..6c4ce05 100644 --- a/rtc.lua +++ b/rtc.lua @@ -35,6 +35,7 @@ minetest.register_node("digilines:rtc", { paramtype = "light", paramtype2 = "facedir", groups = {dig_immediate=2}, + is_ground_content = false, _mcl_blast_resistance = 1, _mcl_hardness = 0.8, selection_box = rtc_selbox, diff --git a/wire_std.lua b/wire_std.lua index 7b371c0..5ba8b27 100644 --- a/wire_std.lua +++ b/wire_std.lua @@ -109,6 +109,7 @@ for zmy=0, 1 do fixed = nodebox }, groups = groups, + is_ground_content = false, walkable = false, stack_max = 99, drop = "digilines:wire_std_00000000" From 9dc03641f4b1bd88b7968d9dc6d7d4b0494f3658 Mon Sep 17 00:00:00 2001 From: Bebibio <95770149+Bebibio@users.noreply.github.com> Date: Sun, 7 Apr 2024 17:36:11 +0200 Subject: [PATCH 2/6] Create diglines.fr.tr (#83) MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit * Create diglines.fr.tr French translation added. Normally I got it right (I'm French 😄 ), but you can change it if something is weird. * Update diglines.fr.tr: - Changing the lowercase 'd' to the uppercase 'D' of digilines - Changing the name of the RTC --- locale/diglines.fr.tr | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) create mode 100644 locale/diglines.fr.tr diff --git a/locale/diglines.fr.tr b/locale/diglines.fr.tr new file mode 100644 index 0000000..701a993 --- /dev/null +++ b/locale/diglines.fr.tr @@ -0,0 +1,23 @@ +# textdomain: digilines + + +### inventory.lua ### + +Channel=Canal +Digiline Chest=Coffre de digiline + +### lcd.lua ### + +Digiline LCD=Ecran à cristaux liquides Digiline + +### lightsensor.lua ### + +Digiline Lightsensor=Capteur de lumière Digiline + +### rtc.lua ### + +Digiline Real Time Clock (RTC)=Horloge du temps réel Digiline (Rtc) + +### wire_std.lua ### + +Digiline=Digiline From 982cfa1fda8b5e6710f9574e5c37da84701f46c7 Mon Sep 17 00:00:00 2001 From: Niklp Date: Sun, 7 Jul 2024 18:51:15 +0200 Subject: [PATCH 3/6] Use `initial_properties` table for text entity (#85) --- lcd.lua | 8 +++++--- 1 file changed, 5 insertions(+), 3 deletions(-) diff --git a/lcd.lua b/lcd.lua index 7d0b1c4..105a66e 100644 --- a/lcd.lua +++ b/lcd.lua @@ -336,9 +336,11 @@ minetest.register_lbm({ }) minetest.register_entity(":digilines_lcd:text", { - collisionbox = { 0, 0, 0, 0, 0, 0 }, - visual = "upright_sprite", - textures = {}, + initial_properties = { + collisionbox = { 0, 0, 0, 0, 0, 0 }, + visual = "upright_sprite", + textures = {}, + }, on_activate = set_texture, }) From d40edf79df0376979693787458e1538061de1f50 Mon Sep 17 00:00:00 2001 From: 1F616EMO~nya Date: Wed, 31 Jul 2024 03:27:36 +0800 Subject: [PATCH 4/6] Fix bottom texture of RTC (#86) --- rtc.lua | 5 ++++- textures/digilines_rtc_bottom.png | Bin 0 -> 98 bytes 2 files changed, 4 insertions(+), 1 deletion(-) create mode 100644 textures/digilines_rtc_bottom.png diff --git a/rtc.lua b/rtc.lua index 6c4ce05..07add3e 100644 --- a/rtc.lua +++ b/rtc.lua @@ -30,7 +30,10 @@ minetest.register_alias("digilines_rtc:rtc", "digilines:rtc") minetest.register_node("digilines:rtc", { description = S("Digiline Real Time Clock (RTC)"), drawtype = "nodebox", - tiles = {"digilines_rtc.png"}, + tiles = { + "digilines_rtc.png", "digilines_rtc_bottom.png", "digilines_rtc.png", + "digilines_rtc.png", "digilines_rtc.png", "digilines_rtc.png" + }, paramtype = "light", paramtype2 = "facedir", diff --git a/textures/digilines_rtc_bottom.png b/textures/digilines_rtc_bottom.png new file mode 100644 index 0000000000000000000000000000000000000000..2c453ea01e4bca6f9c06d21a735aa432f3c65e7d GIT binary patch literal 98 zcmeAS@N?(olHy`uVBq!ia0vp^0wB!61SBU+%rFB|nw~C>Ar*|tKlqtXPuD+wyn&HT vKuv1GQpOC~i?1BJ+~>A1_gHm4dBV#O#lGll-)g^qKurvuu6{1-oD!M Date: Thu, 29 Aug 2024 15:35:53 +0300 Subject: [PATCH 5/6] Update documentation about Digiline Chests (#88) --- README.inventory | 65 ------------------------- docs/chest.md | 123 +++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 123 insertions(+), 65 deletions(-) delete mode 100644 README.inventory create mode 100644 docs/chest.md diff --git a/README.inventory b/README.inventory deleted file mode 100644 index 96458e4..0000000 --- a/README.inventory +++ /dev/null @@ -1,65 +0,0 @@ -Basic idea: place this chest down at the end of a pipeline. Feed stuff into it. Attach a luacontroller to it with a digiline in between. Program the luacontroller to turn on a wire to stop the pipeline when the chest is full. Don't put more than one kind of item down the pipeline into the chest, unless you want weird tricksy behavior. - -...[F]===[C]--{L} - |__________| - [B] -F: filter -B: blinky plant -C: digiline chest -L: luacontroller -==: pipe -__: mesecons ---: digiline - -Make sure you use mem in the luacontroller to keep the mesecon wire on indefinitely after the chest signals full. When it signals "take" someone took an item out and you can start the pipeline up again. -This may be a bad idea if they only take half a stack or something. Oh well. - -When you put something in, you get a "put" to indicate it's OK (sort of (still buggy)) and can fit inside the chest. When you get a "lost", that means it won't fit inside the chest, and will bounce, possibly popping out. When you get a "overflow" that means you tried to add something to a chest that just filled up, and the stack will bounce. When you get a "full" that means the chest just filled up. - -"Filled up" for all intents and purposes, means taking the type of whatever just went into the chest, and seeing if at least 1 of that type can be added to the chest. If it cannot, then it's filled up. That means a chest full of stacks of 30 copper and one spot of 98 gold, and you add one gold to that, it will say it's full. Add 30 copper to it, and it won't. - -Generally you'll be working with full stacks in pipeworks. Even the non-mese filters will accumulate items in a chest, and not spread them out into multiple stacks. And generally your destination chests will each have one of any kind of item. So all you have to worry about is when you've got 99 everywhere, and one space possibly free. A mese filter can fail on that in fact, for instance if you have room for 45 gold, and it tries to push a stack of 50 gold. All 50 will bounce! The code for chests isn't smart enough to add the 45 and bounce the leftover 5. So only use mese filters when you're sure a full stack has accumulated for the filter to push, and there are no partial stacks at the destination. - -For some reason when an "overflow" happens, when it checks if the stack can fit inside the chest, the answer is yes it can fit! Then it doesn't. Sort of buggy. - -itemstack - the qualified name, a space, then the amount. If the space and amount are ommitted, that represents just 1. - -examples: "default:chest 33" "default:coal" "default:axe_diamond" - -bounce - - when an item cannot enter the destination container it will travel back up the tube it came from, going along alternate routes if they exist, but otherwise popping out of the tube. - -popping out - - the little thingy travelling through the tube disappears, and an entity of the item appears, as if it was just dropped. This entity can expire, losing your items permanently! - - -The messages are: - - -put - - this means that the inventory claimed it could fit that stack of items inside it. Inventories lie. But with the above caveats this is quite usable. -lost - - the stack couldn't fit in the chest and bounces. -full - - the chest has been filled. The itemstack is what filled it. count is what's leftover. - until chests can suck up part of a stack and not bounce the whole stack, that count will - always be 0 -overflow - - generally this is the same as lost, except that the "put" event happened, meaning that the - itemstack was allowed in the chest. - - this will happen with two stacks in rapid succession, the first filling the chest, and the - second bouncing. the in this case will be the amount of the second. - - overflow can't happen with two different kinds of items, you'll get a put, maybe full, then lost for the second kind - -Tricky situation: -if you have a blank spot and put say 82 torches down your pipeline, followed by 99 coal, the 82 torches will go in the chest, and the chest will see that 1 more torch can fit since that would only go to 83. Since 1 more torch can fit, no "full" message will fire off. Then when the coal hits the chest, the "fail" message will fire and the coal will bounce out. The chest couldn't predict that coal would be coming next, so it couldn't know that the chest is full, for coal, while not full for torches. - -The inventory is also compatible with [`tubelib`](https://github.com/joe7575/techpack/tree/master/tubelib), which generally works in the same way as [`pipeworks`](https://gitlab.com/VanessaE/pipeworks) but transfers happen immediately and do not "bounce". This means that the messages should be identical to the messages sent by [`pipeworks`](https://gitlab.com/VanessaE/pipeworks), except that items will not send the "lost" message when they cannot fit. -One oddity is that "take" messages will be asynchronous because, if an item does not fit in the chest, the event will need to be canceled. This means that it is possible (though highly unlikely) to recieve a "put" message into a slot which you have not yet recieved a "take" message for, there will not actually be two stacks in the same slot, though it may briefly appear that way until the "take" message is recieved. - -TODO: - - make chest.lua a mixin that gets both default and locked chests - - digiline aware furnaces - - digiline aware technic machines, grinders, alloy furnaces, etc - - the pipes going into the chests don't snap to the pipe holes in the digiline chests. They still act fine as pipeworks destinations though. - - digiline chests seem to be immune to filters. But it's late and I'm shipping this. Someone else can figure out why the chests aren't acting like pipeworks chests, despite cloning the pipeworks chest's object. Oh who am I kidding. I'll do it myself I guess, once I've lost hope of aid again. diff --git a/docs/chest.md b/docs/chest.md new file mode 100644 index 0000000..7632c19 --- /dev/null +++ b/docs/chest.md @@ -0,0 +1,123 @@ +Digiline Chest is a chest which allows to notify about different inventory actions via Digiline messages. + +## Available messages + +``` +{ + action = "empty" +} +``` +The message is sent when the chest has just become empty. + +---------------------------- + +``` +{ + action = "full", + stack = +} +``` +The message is sent when the chest has become full for a particular item specified in ``. + +---------------------------- + +``` +{ + action = "toverflow", + stack = , + side = +} +``` +The message is sent when the chest cannot accept a `` delivered by tube connected to the `` because the chest is full. + +---------------------------- + +``` +{ + action = "tput", + stack = , + to_slot = , + side = +} +``` +The message is sent when the chest accepts a ``, delivered by tube which is connected to ``, to slot ``. + +---------------------------- + +``` +{ + action = "ttake", + stack = , + from_slot = , + side = +} +``` +The message is sent when a tube connected to the chest to `` extracts a `` from slot ``. + +---------------------------- + +``` +{ + action = "umove", + stack = , + from_slot = , + to_slot = +} +``` +The message is sent when user moves `` from `` to `` within the chest. + +---------------------------- + +``` +{ + action = "uswap", + x_stack = , + x_slot = , + y_stack = , + y_slot = +} +``` +The message is sent when user swaps `` in `` with `` in `` within the chest. + +---------------------------- + +``` +{ + action = "utake", + stack = , + from_slot = +} +``` +The message is sent when user takes `` from `` in the chest. + +---------------------------- + +``` +{ + action = "uput", + stack = , + to_slot = +} +``` +The message is sent when user puts `` to the chest to `` + +### Fields used within the messages + +| Field | Description | +| ----- | ----------- | +| `` | A table which contains data about the stack, and corresponds to the format returned by the :to_table() method of ItemStack (check the Minetest API documentation). | +| ``, ``, ``, `` | The index of the corresponding slot starting from 1. | +| `` | A vector represented as a table of format `{ x = , y = , z = }` which represent the direction from which the tube is connected to the chest. | + +## Additional information + +The inventory is also compatible with [`tubelib`](https://github.com/joe7575/techpack/tree/master/tubelib), which generally works in the same way as [`pipeworks`](https://gitlab.com/VanessaE/pipeworks) but transfers happen immediately and do not "bounce". This means that the messages should be identical to the messages sent by [`pipeworks`](https://gitlab.com/VanessaE/pipeworks), except that items will not send the "toverflow" message when they cannot fit. +One oddity is that "ttake" messages will be asynchronous because, if an item does not fit in the chest, the event will need to be canceled. This means that it is possible (though highly unlikely) to recieve a "tput" message into a slot which you have not yet recieved a "ttake" message for, there will not actually be two stacks in the same slot, though it may briefly appear that way until the "ttake" message is recieved. + +## To do + +- make chest.lua a mixin that gets both default and locked chests +- digiline aware furnaces +- digiline aware technic machines, grinders, alloy furnaces, etc +- the pipes going into the chests don't snap to the pipe holes in the digiline chests. They still act fine as pipeworks destinations though. +- digiline chests seem to be immune to filters. But it's late and I'm shipping this. Someone else can figure out why the chests aren't acting like pipeworks chests, despite cloning the pipeworks chest's object. Oh who am I kidding. I'll do it myself I guess, once I've lost hope of aid again. From 7d4895d5d4a093041e3e6c8a8676f3b99bb477b7 Mon Sep 17 00:00:00 2001 From: cheapie Date: Mon, 9 Sep 2024 14:08:39 -0500 Subject: [PATCH 6/6] Disallow LCD messages that aren't strings or numbers (#89) --- lcd.lua | 2 ++ 1 file changed, 2 insertions(+) diff --git a/lcd.lua b/lcd.lua index 105a66e..1f5f33f 100644 --- a/lcd.lua +++ b/lcd.lua @@ -259,6 +259,8 @@ local on_digiline_receive = function(pos, _, channel, msg) local setchan = meta:get_string("channel") if setchan ~= channel then return end + if type(msg) ~= "string" and type(msg) ~= "number" then return end + meta:set_string("text", msg) meta:set_string("infotext", msg)