Metadata on Entities

Place to ask discuss and request the modding support of Factorio. Don't request mods here.
y_e_a_r
Burner Inserter
Burner Inserter
Posts: 10
Joined: Wed Jun 07, 2023 10:38 pm
Contact:

Metadata on Entities

Post by y_e_a_r »

Original post in "Modding Help": viewtopic.php?f=25&t=114167&p=615620#p615620 that I'm reposting here.
Similar request for Items: viewtopic.php?f=221&t=5851&p=45281&hili ... ata#p45281 that is in "Won't Implement".

Hi,

I'm developing a mod that stores additional metadata on some new entities. For example, I need to store the list of item requests associated with my custom chest entity.

I'm currently doing the "standard" approach used by many other mods like SE where I have a table in global that maps from unit_number to metadata. I also have some helper code that stores the metadata to and from blueprints.

While this approach works for copy/paste, it:
- Requires a lot of boilerplate code
- Doesn't work when pasting blueprints over existing entities
- Doesn't work with undo

I've been blown away by the high quality of modding docs and the lua APIs so this current workaround feels uncharacteristically difficult to implement.

Is there a better way to store custom metadata on entities?

If not, I can think of a few potential approaches that would make it a ton easier to build mods with custom entities.

One approach would be to add an optional "metadata" field to LuaEntity that is persisted across all copy/paste/undo actions. This field ideally would be able to store any custom Lua object that can be serialized in a blueprint.

Another approach I can think of is tags. While tags currently only seem to be supported on ghosts, it would be interesting to see if they could also be supported for normal entities. I'm not sure if there's any additional overhead associated with tags that need to be serialized to blueprints, but it would be amazing if this were possible.

I'm not familiar with the Factorio source code or appetite to make a change like this with all the work on the expansion, but this one change would both remove buggy boilerplate and fix annoying bugs with current implementations for a significant number of mods.

Thanks for your time!
curiosity
Filter Inserter
Filter Inserter
Posts: 557
Joined: Wed Sep 11, 2019 4:13 pm
Contact:

Re: Metadata on Entities

Post by curiosity »

y_e_a_r
Burner Inserter
Burner Inserter
Posts: 10
Joined: Wed Jun 07, 2023 10:38 pm
Contact:

Re: Metadata on Entities

Post by y_e_a_r »

Nice find on the duplicate. It's a bummer to see that the previous post was closed as "Won't Implement" but it looks like that thread doesn't address the gaps mentioned here around blueprint pasting and undo.

I totally understand the concerns around memory sizes and separating "core" data from "lua" data but I can't help but think there are ways to address those concerns while implementing this functionality, especially since it's such a common feature of mods.

For example there could be mod-local metadata where the Factorio runtime internally keeps track of the (mod_id, entity_id) -> metadata mapping. This solves the issues:
- Each mod gets its own metadata per entity so different mods don't conflict
- The mapping is stored separately from existing entities so it doesn't affect the memory footprint of entities and is only used when mods opt into the feature.
curiosity
Filter Inserter
Filter Inserter
Posts: 557
Joined: Wed Sep 11, 2019 4:13 pm
Contact:

Re: Metadata on Entities

Post by curiosity »

y_e_a_r wrote: Sun Aug 04, 2024 8:46 pm Nice find on the duplicate. It's a bummer to see that the previous post was closed as "Won't Implement" but it looks like that thread doesn't address the gaps mentioned here around blueprint pasting and undo.
viewtopic.php?f=28&t=106026 viewtopic.php?f=28&t=103934
You even +1'd to the second one.
y_e_a_r wrote: Sun Aug 04, 2024 8:46 pm For example there could be mod-local metadata where the Factorio runtime internally keeps track of the (mod_id, entity_id) -> metadata mapping. This solves the issues:
- Each mod gets its own metadata per entity so different mods don't conflict
- The mapping is stored separately from existing entities so it doesn't affect the memory footprint of entities and is only used when mods opt into the feature.
None of this solves any issues. Instead it just shoves the work off onto the game. It has all the drawbacks that boskid mentioned.
Also, it sounds suspiciously like a library. So you can write one and release it for other people to use, if one or more don't already exist.
y_e_a_r
Burner Inserter
Burner Inserter
Posts: 10
Joined: Wed Jun 07, 2023 10:38 pm
Contact:

Re: Metadata on Entities

Post by y_e_a_r »

So you're saying that instead of adding support for managing entity metadata, it would be better to focus on adding events like `on_blueprint_paste` and `on_undo` so mods can manage metadata rather than the core game?
curiosity
Filter Inserter
Filter Inserter
Posts: 557
Joined: Wed Sep 11, 2019 4:13 pm
Contact:

Re: Metadata on Entities

Post by curiosity »

I'm saying that's what you are more likely to get, at least with your proposal as it is. Besides, those events would have other uses.
User avatar
Stringweasel
Filter Inserter
Filter Inserter
Posts: 435
Joined: Thu Apr 27, 2017 8:22 pm
Contact:

Re: Metadata on Entities

Post by Stringweasel »

y_e_a_r wrote: Tue Aug 06, 2024 12:52 am adding events like `on_blueprint_paste`
This is similar to this post viewtopic.php?p=381580#p381580. It seems like the raising of events during the pasting of blueprints safely is quite complicated on the engine's side.
Alt-F4 Author | Factorio Modder
Probably known for: (Configurable) Valves | Better Victory Screen | Space Spidertron | Fluidic Power
Official Contributor to Space Exploration
curiosity
Filter Inserter
Filter Inserter
Posts: 557
Joined: Wed Sep 11, 2019 4:13 pm
Contact:

Re: Metadata on Entities

Post by curiosity »

Stringweasel wrote: Tue Aug 06, 2024 7:19 am This is similar to this post viewtopic.php?p=381580#p381580. It seems like the raising of events during the pasting of blueprints safely is quite complicated on the engine's side.
No, that's specifically for the recipe change due to blueprint. The blueprint itself would be simpler, if you look at the call stack.
Post Reply

Return to “Modding interface requests”