The project is a fresh URP project with NetCode and Unity Physics installed. In the scene, there is a Networking (Convert To Client Server Entity), and a Cube and GhostCollection as children. The cube has a Ghost Authoring Component and the GhostCollection has it in its list.
I assume cube (2) should not be processed by the BuildPhysicsWorld system, and only the one that is actually “in the world” (not in the GhostPrefabBuffer) should be processed, e.g. falling down etc. By the looks of it, however, both are processed by the BuildPhysicsWorld system.
One thing I am wondering about: Should the GhostPrefabBuffer etc. be in another world and only when prefabs are spawned into the Server World should it be used to spawn new entities into the Server World?
The GhostCollection should be in the same world. One of the Cubes created - usually the first one - should have a prefab tag added to it which prevents it from being processed by any systems. Not sure why that is not happening in your case and I was not able to reproduce it.
Did you make the Cube a prefab or just add it to the scene? All ghosts should be prefabs.
What does the Cube with the prefab tag on it look like, is it processed by many systems or just BuildPhysicsWorld?
Thanks for the answer – just a quick question (so I can try anwering your questions hopefully tonight): Did you try it with the case-attached project to reproduce or did you try to recreate it manually? From my first picture, it looks like it may not be a Prefab…?
Ok, I have checked my project attached to case 1211673 – indeed, the cube is not a prefab.
I’ve now made it a prefab, and only one is now picked up (the one with the GhostSystemStateComponent). So your hunch was right, thanks!
To get it working after changing the cube to a prefab, updating the ghost list was necessary (pretty obvious, but not that obvious – the original cube instance was still in there).
I think it would be helpful if adding non-Prefabs/non-Ghost-Authoring-Components to the Ghost Collection Authoring Component was not allowed, if that is possible.
Yes, we still have work to do on making sure invalid setups gives errors instead of mysterious bugs in the netcode. I have filed an internal bug for this one so we don’t forget it.