Does the plugin work with any client version?

Hey, so I'm running a server that allows many many client versions to join through via version. It's running on 1.16.5, so is supported by DH. My question is, will newer clients work? Or do the versions have to match?
Solution:
Okay cool. All you have to to is toggle the dhs.read-forge-byte property in the pom.xml file that represents your Minecraft version
Jump to solution
95 Replies
Puhpine
Puhpine3w ago
the versions have to match it may work between small point releases but no more than that
BrainStone
BrainStoneOP3w ago
Unfortunate. Will it at least not cause problems? Like I could imagine the newer clients sending data that will cause problems
Puhpine
Puhpine3w ago
im not sure
BrainStone
BrainStoneOP3w ago
Ok. So I guess I gotta try
Jckf
Jckf3w ago
DH and DHS for 1.16.5 up to and including 1.20.2 should work together. And 1.20.4 up to and including 1.21.4 should work together. The reason is that there is a difference in the network protocol between versions 1.20.2 and 1.20.4
BrainStone
BrainStoneOP3w ago
Ah interesting. I've been putting off updating the server past 1.17 due to the world height issues I guess I have to do that now
Jckf
Jckf3w ago
@пшш Can comment on how solvable the protocol difference issue is.
BrainStone
BrainStoneOP3w ago
I know this is asking much, but would it be feasible to explicitly support that?
Puhpine
Puhpine3w ago
was i thinking of the mod version or was i just spouting nonsense?
Jckf
Jckf3w ago
I'm not sure about that specifically, but I know the plugin does things the same way for every version below 1.20.4 - and the same way for every version from 1.20.4 and up What do you mean? I can make the plugin for 1.16.5 explicitly only work for 1.20.4 and up - is that what you're asking?
пшш
пшш3w ago
Protocol wise, one byte of difference (not counting minecraft shenanigans) But overall, it's gonna get messy very quickly and probably not worth the time supporting it
BrainStone
BrainStoneOP3w ago
No, sorry I meant that the plugin is able to support both protocol versions. Maybe through ViaVersions help Fair Thanks for your time I did not expect to get such authorative answer this quickly While you're here I want to express my extreme gratitude for your amazing mod. This is genuinely the best mod MC has ever seen.
Jckf
Jckf3w ago
If I was able to make it work for both version ranges, then I would already be doing so ;( But if you don't have players that use MC 1.20.2 or older, then we could probably make a custom version just for you
BrainStone
BrainStoneOP3w ago
The one thing I'd ask is that clients with an incompatible don't mess anything up I could actually use that. I don't think anyone even uses 1.20 at all anymore. It's just that updating the server is an extreme hassle
Jckf
Jckf3w ago
Alright. Are you familiar with Java compiling at all, or would you need me to do it?
BrainStone
BrainStoneOP3w ago
I'm a MC dev myself. I'm intimately familar with it
Solution
Jckf
Jckf3w ago
Okay cool. All you have to to is toggle the dhs.read-forge-byte property in the pom.xml file that represents your Minecraft version
Jckf
Jckf3w ago
Then build
BrainStone
BrainStoneOP3w ago
Ah lol. That's easy. Thanks ^^
Jckf
Jckf3w ago
Let me know how it goes. I'm kinda curious =P
BrainStone
BrainStoneOP3w ago
Ok. Will do I'm curious as well ^^ Btw, with this update it would make sense to completely clear the multiplayer DH data, right?
Jckf
Jckf3w ago
No need. It doesn't change the stored LODs. Only the "header" of each message sent between the server and client
BrainStone
BrainStoneOP3w ago
Hm. Interesting, because when joining the server it did have to recreate them all
Jckf
Jckf3w ago
The only reason DHS will ever recreate a LOD is if one or more of the underlying chunks change
BrainStone
BrainStoneOP3w ago
And I do have quite the large data set of them on my disk from manually flying around xD Hm. Weird. Though as mentioned when joining the other server after installing the plugin, none of my previous data was there anymore
Jckf
Jckf3w ago
Right, that's probably because the plugin sends a key that identifies the server/world pair, and the previously autogenerated key is not the same. If you look in the DH folder on your client, I think you'll find you have two folders per world now One will be your old LODs, and the folder name will probably be pretty weird While the other will have a more sane name and contain your new ones from the plugin
BrainStone
BrainStoneOP3w ago
Yeah I genuinely don't feel like manually sorting that, so wiping it is xD
Jckf
Jckf3w ago
Yeah. The server would probably end up sending you replacement LODs for all of your old ones anyway, since their timestamps will be older than the server's
BrainStone
BrainStoneOP3w ago
Alright One more question. Is there an option to reload the config? *command
Jckf
Jckf3w ago
Sorry, no ;( Let me check if I can make that happen real quick though
BrainStone
BrainStoneOP3w ago
^^
Jckf
Jckf3w ago
Okay yeah, I think I can make that happen pretty easily
BrainStone
BrainStoneOP3w ago
Luckily I messed up my previous changes that I was about to revert, so no need for me at this very moment One side note, just because I just spotted that ARe these messages normal
[22:47:31 WARN]: [DHS] Could not delete LOD survival 34x-1.
[22:47:36 WARN]: [DHS] Could not delete LOD survival 35x0.
[22:47:41 WARN]: [DHS] Could not delete LOD survival 34x-3.
[22:47:31 WARN]: [DHS] Could not delete LOD survival 34x-1.
[22:47:36 WARN]: [DHS] Could not delete LOD survival 35x0.
[22:47:41 WARN]: [DHS] Could not delete LOD survival 34x-3.
Jckf
Jckf3w ago
Ah yes, you should compile the develop branch instead of master The message simply means that an update was triggered for an area where no LOD exists already, so it couldn't delete the old LOD
BrainStone
BrainStoneOP3w ago
Makes sense from a programming point of view, but really pointless in practice So develop has that fixed?
Jckf
Jckf3w ago
Yes
BrainStone
BrainStoneOP3w ago
Awesome
Jckf
Jckf3w ago
Instead of blindly trying to delete something it doesn't know if exists, it'll check first So the warning is still there, but won't trigger for this scenario
BrainStone
BrainStoneOP3w ago
👍🏼 Another aside, does the plugin respect the world border?
Jckf
Jckf3w ago
No, but you can specify a border in the plugin too, beyond which it will reject LOD requests. It'll also communicate this border to the clients so that they don't actually request a bunch of stuff that will end up rejected anyway This way you can set the DH border a bit beyond the "real" world border, if you'd like
BrainStone
BrainStoneOP3w ago
Would it be possible to respect the border (including changes to it)? Manually configuring stuff like that is extremely tedious
Jckf
Jckf3w ago
Hm, probably. But are you changing the world border very frequently?
BrainStone
BrainStoneOP3w ago
A setting to specify how many chunks beyond that could work for the previous scenario I do have worlds where they are semi regularily are expanded And people being able to see beyond them defeats the purpose
Jckf
Jckf3w ago
Alright. Can you create a ticket with that request?
BrainStone
BrainStoneOP3w ago
Sure
Jckf
Jckf3w ago
Pushed the command now. Haven't tested it, but it Should Just Work ™️ It's just /dhs reload Required permission is distant_horizons.admin
BrainStone
BrainStoneOP3w ago
Let me see
Jckf
Jckf3w ago
I should probably make it clear out the loaded config before reloading though, in case any vars are removed Hang on
BrainStone
BrainStoneOP3w ago
lol. I just noticed that I already have my server updated... I don't know where I kept reading that old version... You have no idea how stupid I feel right now
Jckf
Jckf3w ago
lol
BrainStone
BrainStoneOP3w ago
Just give me a ping when the fixed reload is done
Jckf
Jckf3w ago
Now I think Again, untested
BrainStone
BrainStoneOP3w ago
I get this error
[23:16:38] [Server thread/ERROR]: Error occurred while enabling DHSupport v0.9.0-SNAPSHOT (Is it up to date?)
java.lang.StackOverflowError: null
at DHS-0.9.0-SNAPSHOT_for_MC-1.21.1.jar/no.jckf.dhsupport.bukkit.DhSupportBukkitPlugin.reloadConfig(DhSupportBukkitPlugin.java:122) ~[DHS-0.9.0-SNAPSHOT_for_MC-1.21.1.jar:?]
at org.bukkit.plugin.java.JavaPlugin.getConfig(JavaPlugin.java:156) ~[paper-mojangapi-1.21.1-R0.1-SNAPSHOT.jar:?]
at DHS-0.9.0-SNAPSHOT_for_MC-1.21.1.jar/no.jckf.dhsupport.bukkit.handler.ConfigLoader.onDisable(ConfigLoader.java:73) ~[DHS-0.9.0-SNAPSHOT_for_MC-1.21.1.jar:?]
at DHS-0.9.0-SNAPSHOT_for_MC-1.21.1.jar/no.jckf.dhsupport.bukkit.DhSupportBukkitPlugin.reloadConfig(DhSupportBukkitPlugin.java:123) ~[DHS-0.9.0-SNAPSHOT_for_MC-1.21.1.jar:?]
at org.bukkit.plugin.java.JavaPlugin.getConfig(JavaPlugin.java:156) ~[paper-mojangapi-1.21.1-R0.1-SNAPSHOT.jar:?]
at DHS-0.9.0-SNAPSHOT_for_MC-1.21.1.jar/no.jckf.dhsupport.bukkit.handler.ConfigLoader.onDisable(ConfigLoader.java:73) ~[DHS-0.9.0-SNAPSHOT_for_MC-1.21.1.jar:?]
...
at org.bukkit.plugin.java.JavaPlugin.getConfig(JavaPlugin.java:156) ~[paper-mojangapi-1.21.1-R0.1-SNAPSHOT.jar:?]
at DHS-0.9.0-SNAPSHOT_for_MC-1.21.1.jar/no.jckf.dhsupport.bukkit.handler.ConfigLoader.onDisable(ConfigLoader.java:73) ~[DHS-0.9.0-SNAPSHOT_for_MC-1.21.1.jar:?]
at DHS-0.9.0-SNAPSHOT_for_MC-1.21.1.jar/no.jckf.dhsupport.bukkit.DhSupportBukkitPlugin.reloadConfig(DhSupportBukkitPlugin.java:123) ~[DHS-0.9.0-SNAPSHOT_for_MC-1.21.1.jar:?]
at org.bukkit.plugin.java.JavaPlugin.getConfig(JavaPlugin.java:156) ~[paper-mojangapi-1.21.1-R0.1-SNAPSHOT.jar:?]
[23:16:38] [Server thread/ERROR]: Error occurred while enabling DHSupport v0.9.0-SNAPSHOT (Is it up to date?)
java.lang.StackOverflowError: null
at DHS-0.9.0-SNAPSHOT_for_MC-1.21.1.jar/no.jckf.dhsupport.bukkit.DhSupportBukkitPlugin.reloadConfig(DhSupportBukkitPlugin.java:122) ~[DHS-0.9.0-SNAPSHOT_for_MC-1.21.1.jar:?]
at org.bukkit.plugin.java.JavaPlugin.getConfig(JavaPlugin.java:156) ~[paper-mojangapi-1.21.1-R0.1-SNAPSHOT.jar:?]
at DHS-0.9.0-SNAPSHOT_for_MC-1.21.1.jar/no.jckf.dhsupport.bukkit.handler.ConfigLoader.onDisable(ConfigLoader.java:73) ~[DHS-0.9.0-SNAPSHOT_for_MC-1.21.1.jar:?]
at DHS-0.9.0-SNAPSHOT_for_MC-1.21.1.jar/no.jckf.dhsupport.bukkit.DhSupportBukkitPlugin.reloadConfig(DhSupportBukkitPlugin.java:123) ~[DHS-0.9.0-SNAPSHOT_for_MC-1.21.1.jar:?]
at org.bukkit.plugin.java.JavaPlugin.getConfig(JavaPlugin.java:156) ~[paper-mojangapi-1.21.1-R0.1-SNAPSHOT.jar:?]
at DHS-0.9.0-SNAPSHOT_for_MC-1.21.1.jar/no.jckf.dhsupport.bukkit.handler.ConfigLoader.onDisable(ConfigLoader.java:73) ~[DHS-0.9.0-SNAPSHOT_for_MC-1.21.1.jar:?]
...
at org.bukkit.plugin.java.JavaPlugin.getConfig(JavaPlugin.java:156) ~[paper-mojangapi-1.21.1-R0.1-SNAPSHOT.jar:?]
at DHS-0.9.0-SNAPSHOT_for_MC-1.21.1.jar/no.jckf.dhsupport.bukkit.handler.ConfigLoader.onDisable(ConfigLoader.java:73) ~[DHS-0.9.0-SNAPSHOT_for_MC-1.21.1.jar:?]
at DHS-0.9.0-SNAPSHOT_for_MC-1.21.1.jar/no.jckf.dhsupport.bukkit.DhSupportBukkitPlugin.reloadConfig(DhSupportBukkitPlugin.java:123) ~[DHS-0.9.0-SNAPSHOT_for_MC-1.21.1.jar:?]
at org.bukkit.plugin.java.JavaPlugin.getConfig(JavaPlugin.java:156) ~[paper-mojangapi-1.21.1-R0.1-SNAPSHOT.jar:?]
During startup that is
Jckf
Jckf3w ago
Stack overflow lol Guess that's what I get for trying to play video games and code at the same time
BrainStone
BrainStoneOP3w ago
I feel you
Jckf
Jckf3w ago
Ah, I accidentally overrode a method, which is called outside of my own code Classic
BrainStone
BrainStoneOP3w ago
yeah
Jckf
Jckf3w ago
No description
Jckf
Jckf3w ago
There we go
BrainStone
BrainStoneOP3w ago
Thanks ^^
Jckf
Jckf3w ago
Sorry about that
BrainStone
BrainStoneOP3w ago
No worries I do have one issue now however That being that with the snapshot no LODs are being loaded. Only the ones I have on my client
Jckf
Jckf3w ago
One of the changes in the snapshot is to check a permission to let people use DH. I might have messed up that logic
BrainStone
BrainStoneOP3w ago
Can I know that permission, so I can quickly debug it?
Jckf
Jckf3w ago
distant_horizons.worlds.<world name>
BrainStone
BrainStoneOP3w ago
Also I hope it's set up properly on servers without permissions plugins All true for me Seems like messed up logic
[23:34:25 INFO]: [LP] VB > the_brainstone - distant_horizons.admin - true
[23:34:25 INFO]: [LP] VB > the_brainstone - distant_horizons.admin - true
[23:34:25 INFO]: [DHS] Received DH config for The_BrainStone in world_bau
[23:34:25 INFO]: [LP] VB > the_brainstone - distant_horizons.worlds.world_bau - true
[23:34:26 INFO]: [LP] VB > the_brainstone - distant_horizons.admin - true
[23:34:26 INFO]: [LP] VB > the_brainstone - distant_horizons.admin - true
[23:34:25 INFO]: [LP] VB > the_brainstone - distant_horizons.admin - true
[23:34:25 INFO]: [LP] VB > the_brainstone - distant_horizons.admin - true
[23:34:25 INFO]: [DHS] Received DH config for The_BrainStone in world_bau
[23:34:25 INFO]: [LP] VB > the_brainstone - distant_horizons.worlds.world_bau - true
[23:34:26 INFO]: [LP] VB > the_brainstone - distant_horizons.admin - true
[23:34:26 INFO]: [LP] VB > the_brainstone - distant_horizons.admin - true
(for reference)
Jckf
Jckf3w ago
Yeah I'm really dealing with a tristate here, since not having the permission should resolve as true, but I cannot rely on the native permission logic for that, since it didn't exist in older version of Minecraft and I did indeed mess it up Pushed a fix now
BrainStone
BrainStoneOP3w ago
Alright Joining the server and hearing my fans spin up is a good sign xD It works now
Jckf
Jckf3w ago
Nice Thanks for the patience
BrainStone
BrainStoneOP3w ago
You're welcome I know how it is I can't stress enough how amazing this mod is
Jckf
Jckf3w ago
Haha I agree. The only reason I made the plugin is because I wanted it for my own server =P
BrainStone
BrainStoneOP3w ago
I know that motivation so well
Jckf
Jckf3w ago
It was originally a stand-alone porject, not officially affiliated with DH
BrainStone
BrainStoneOP3w ago
And then the thought: "Ah well, other people might like it too"
Jckf
Jckf3w ago
May I ask what projects you've worked on btw? Anything I would know?
BrainStone
BrainStoneOP3w ago
The biggest I'd say is BungeeChat
Jckf
Jckf3w ago
Ah, that's pretty OG, no? Pretty sure I've used it like 10 years ago
BrainStone
BrainStoneOP3w ago
Well, I made version 2 Took it over from the original author
Jckf
Jckf3w ago
Ah That's a pretty good thing to do Loads of abandoned projects out there
BrainStone
BrainStoneOP2w ago
Indeed Been doing that for quite some time as well Hey @Jckf . Don't mean to necro this thread, but I don't have access to the dev channel yet, so I thought this was the best way to reach you. If you'd like to discuss my MR in a more direct manner, I'm up for a chat
Jckf
Jckf2w ago
Oops, didn't see this until now
BrainStone
BrainStoneOP2w ago
No worries Did you notice my comment about the scaling? I literally noticed it seconds after you merged
Jckf
Jckf2w ago
Coordinate scaling is only relevant for clients, but is semi-broken in its current state in DH itself. The center coordinate has to be scaled according to the world's scale factor before sending it to the client, other than that we don't need to care about it I'll ask how much of a contribution is required to get the Discord role 👍
BrainStone
BrainStoneOP2w ago
Ah ok. Then let me quickly fix that. And thanks
Jckf
Jckf2w ago
Do you need to change anything though?
BrainStone
BrainStoneOP2w ago
Yes. The scaling would need to happen after getting the values. Else the scaling is lost
Jckf
Jckf2w ago
The values I expect from the WorldInterface methods is the real coordinates as observed by the player in-game. I think that's what you return, also when tracking the vanilla border?
BrainStone
BrainStoneOP2w ago
Then I really don't understand the purpose Let me check the old code and try to understand it to see what it originally did and if anything needs to be done
Jckf
Jckf2w ago
What it does is in practice a workaround for what I consider a bug in DH
BrainStone
BrainStoneOP2w ago
Fair. Though I think if it's a workaround it should be kept
Jckf
Jckf2w ago
Oh, you removed it from the config handler? I didn't catch that
BrainStone
BrainStoneOP2w ago
Ok. So old logic is - read dhs config for border center - scale it - set it to keep value New logic ignores the scaling completely No it's not kept. It just happens before reading the config values and the value is discarded. I think I have a fix, one second Now it keeps the scaling for the client config
Jckf
Jckf2w ago
Yeah, the "keep value" is the one we send back to the client, and the border center we send back must be scaled. But we don't use the value afterwards, even though it sticks around inside the player config It's only for the client to "fix" the weirdness in DH
BrainStone
BrainStoneOP2w ago
Fair New MR should fix that as well Sorry for the oversight
Jckf
Jckf2w ago
No worries. I should have caught it

Did you find this page helpful?