-
Notifications
You must be signed in to change notification settings - Fork 60
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
fix: dumped buffer must not be empty #240
base: master
Are you sure you want to change the base?
Conversation
src/pc/1.13/ChunkColumn.js
Outdated
@@ -199,6 +199,10 @@ module.exports = (Block, mcData) => { | |||
smartBuffer.writeInt32BE(biome) | |||
}) | |||
|
|||
if (!smartBuffer.length) { | |||
return Buffer.alloc(4096) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
What are these zeros representing? Do you have a link to minecraft code to explain?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It's just a workoaround so the load method (which expects the buffer to be not empty) doesn't crash. I'm not sure why I used the size of 4096. I see the native sever uses the length of 1024.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
There should not be any "workarounds" in stable API methods. The libs should adhere to whatever the vanilla behavior is. In this case "load" deserializes a vanilla chunk from the network and "dump" serializes something to be sent over the network.
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Yes, in this case dump works incorrectly then. Afaik even minecraft-protocol doesn't allow serialization of empty buffers. I understand there should be no workarounds, can you elaborate on the correct way to fix it?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Allocating a buffer of the right size
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Allocating a buffer of the right size
@rom1504 ok, got it fixed. should be good now
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
It's just a workoaround so the load method (which expects the buffer to be not empty) doesn't crash
which load method do you mean? if you mean vanilla one; then ok we should do that and leave a comment to explain this is to address a bug in the vanilla implementation
if it's our implementation of load, then we should fix the bug
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
and checked that native server always sends the buffer filled with 0 in these cases
this seems to suggest the mojang server; is that indeed what you mean? Do you know why they have this bug?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I don't think it's a bug, most probably the vanilla server just tried to normalize the data so the client marks received chunk as empty (otherwise it would print waiting for chunks)
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
And I was about our load method. Not sure what should be fixed in that method instead
@@ -199,6 +199,10 @@ module.exports = (Block, mcData) => { | |||
smartBuffer.writeInt32BE(biome) | |||
}) | |||
|
|||
if (!smartBuffer.length) { | |||
return Buffer.alloc(1024) |
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
why do we want to create empty buffers? if there is a reason, add a comment
PrismarineJS/prismarine-provider-anvil#81 looks like this is working without this change is this prismarine chunk pr truly necessary? |
I never said it is required for basic functionality for new versions, it is not related. Can you look at OP please |
I still don't understand what this PR is trying to fix Is there a bug in the vanilla client or server that makes this necessary? |
Sorry this is old, but as I can see in the description of this PR it fixes loading back the empty chunks. There is an attached region file for testing (let me see if it can be added as a test here). |
Empty chunks are really not a thing in the game. What it seems you're trying to do is instead implicitly encode a chunk with air if the sections array is empty. Which is weird because for 1.18+ the ChunkColumn constructor will automatically fill in all the possible sections to be set to air (via SingleValuePalette) from minY to worldHeight. What you should do is figure out how it's possible to enter the situation rather than trying to error correct there. Sections.length==0 condition should I think throw an error. |
I already made this test in prismarine-anvil-provider:
which runs against this file: https://github.com/zardoy/prismarine-provider-anvil/blob/everything/test/fixtures/1.13.2/r.-1.-1.mca which appears to be the world of type the void
and checked that native server always sends the buffer filled with 0 in these cases