-
Notifications
You must be signed in to change notification settings - Fork 85
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Water changes including #618 #619
base: master
Are you sure you want to change the base?
Conversation
WaterFaucet, WaterFall and AirFloodDown are now safe. LavaFaucet and LavaFall are safer, but still burn.
Not fond of having finite water sometimes behave in an infinite manner, will do proper review tomorrow though |
Okay, just to be clear, "Finite_Water" is always finite, this is for the "Active_Water" block. IMO the combinations of the options do make sense for Active_Water and the new one makes for a nice middle way.
|
This is the "eating CPU" commit. With the old version, what you're seeing there is one result of the continuous polling from the finite water blocks. The physics on that gets stuck polling for changes all around the water block and so sees your deletion. However, if you left the level (let it unload) and go back the physics items for those don't get restarted and the physics works as the new version not seeing the block deletions. Basically, it was inconsistent across a level reload. Because of this I don't think the users could really "depend" on either way. As we don't want that polling, the question becomes which way do we want the triggers to run, either inline with the current triggers on block deletion or adding more triggering to emulate the buggy polling? Neither method feels "better" for me and I think I could make "realism" arguments either way (surface tension, sloping/flat surfaces, crumbling vs hard blocks). |
Remove link to edge water flag.
In response to you "not fond" comment, I've added an explicit option for water above the ocean level being finite and infinite below that level. |
So which do you prefer? |
The issues raised here made me think that some things about block physics in general need to be properly looked at and potentially redone, I just haven't found the time to do so |
These three commits
With the last one I note that EdgeWater is a bit lame when combined with FiniteLiquids.
So If both of these flags are set on a map the FiniteLiquids applies always to ActiveLava and to ActiveWater above the edge level. Below the Edge level ActiveWater ignores the FiniteLiquids flag and goes with Flood semantics. This allows flooding of underwater/underground bases but prevents flooding of the overworld.
(Not withstanding my opinion on finite EdgeWater you may want to put this on a distinct Option/property)
The *Faucet fix might make the WaterFaucet suitable for guest access as the block now appears to have no difficult to reverse effects.
Note these commit's can be merged individually if you prefer.