Skip to content
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

Update Geysermetica #2

Open
wants to merge 1,368 commits into
base: master
Choose a base branch
from
Open
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
1368 commits
Select commit Hold shift + click to select a range
9091393
Keep chugging away
Camotoy Apr 20, 2024
6d8021f
Update the non-item parts (#4586)
basaigh Apr 20, 2024
aed7f1b
Update the item parts
Camotoy Apr 20, 2024
94e533e
Fix tags and attributes
basaigh Apr 21, 2024
8bd2df0
Trying to get more compiled but brain is officially fried for the day!
Camotoy Apr 21, 2024
ab8832b
Compiles
AJ-Ferguson Apr 21, 2024
687ddbb
Tiny fixes
Camotoy Apr 21, 2024
61907b1
Little more work
Camotoy Apr 21, 2024
57ce570
Update mappings submodule
basaigh Apr 21, 2024
b73f23d
remove global palette bits, fix nullable block entity tags
onebeastchris Apr 21, 2024
48164e9
Bump mcpl to fix item deserialization
basaigh Apr 21, 2024
c5e02d2
ensure geyser builds
onebeastchris Apr 21, 2024
8381a14
Fix book signing
AJ-Ferguson Apr 21, 2024
dac5f69
Bump mcpl
basaigh Apr 22, 2024
c34f0f2
Update for latest MCProtocolLib
Camotoy Apr 22, 2024
6a5efa3
Start on 1.20.5 mod platform support - NeoForge (temporarily) excluded
onebeastchris Apr 22, 2024
11f79d4
Refactor Java registry storage; implement trim support
Camotoy Apr 22, 2024
d3f902a
Banners
AJ-Ferguson Apr 23, 2024
1bdbcab
Wolf variants
AJ-Ferguson Apr 23, 2024
3f499e3
Start on custom skulls
Kas-tle Apr 23, 2024
9d8edad
Fix horse inventory
AJ-Ferguson Apr 23, 2024
c48428d
init: pick item component change
onebeastchris Apr 23, 2024
b814088
Refactor TagCache to be extensible
Camotoy Apr 23, 2024
d105dad
Update for release. STILL NOT READY YET THOUGH
Camotoy Apr 23, 2024
abea013
Fix llama carpets
Camotoy Apr 23, 2024
c54624f
Fix some cases of empty tags being needed
Camotoy Apr 23, 2024
687d299
target 1.20.5 release, build neoforge again
onebeastchris Apr 23, 2024
bbaffb2
Wolf interactions
AJ-Ferguson Apr 23, 2024
a1534e4
Basic Armadillo structure
Camotoy Apr 24, 2024
9490a09
Calculate horse inventory size
AJ-Ferguson Apr 24, 2024
b29e0d9
Move MCProtocolLib to dev - package ID change
Camotoy Apr 24, 2024
9d540fe
Shulker box NPE fix
Camotoy Apr 24, 2024
652f6af
Fix custom skulls 1.20.5
Kas-tle Apr 25, 2024
99e6a29
Entity properties
Kas-tle Apr 25, 2024
16cb76f
neoforge 1.20.5 boots
onebeastchris Apr 25, 2024
8e3a3ea
implement curse of binding check for wolf armor removal
onebeastchris Apr 25, 2024
3656395
Armadillo states
AJ-Ferguson Apr 26, 2024
91a7460
idea: deal with cookies and transfer
onebeastchris Apr 26, 2024
f67c131
Forcibly disconnect players even if no server target was set in the J…
onebeastchris Apr 26, 2024
68534f3
Merge remote-tracking branch 'upstream/feature/1.20.5' into feature/1…
onebeastchris Apr 26, 2024
5015a2e
bump project version to 2.3.0
onebeastchris Apr 26, 2024
a57e7b5
Update ViaVersion api usage to be compatible with ViaVersion 4.10 (#4…
onebeastchris Apr 26, 2024
42a9ba6
Update ViaProxy platform (#4607)
RaphiMC Apr 26, 2024
2fa7585
Switch to Cloudburst NBT only
Camotoy Apr 27, 2024
9217414
Merge remote-tracking branch 'origin/feature/1.20.5' into feature/1.20.5
Camotoy Apr 27, 2024
f47754b
Goat horns
Camotoy Apr 27, 2024
6d5ac23
Dyeable items work.
Camotoy Apr 28, 2024
e97bbcc
Potion effect colors
AJ-Ferguson Apr 28, 2024
9cb9a14
Don't use tee to write metadata.json to downloads API (#4612)
Kas-tle Apr 28, 2024
420f677
Fix suspicious stew NPEs
basaigh Apr 28, 2024
9b1e450
Fix injectors, should work with Spigot/Paper 1.20.5 now
onebeastchris Apr 28, 2024
8ab0921
Merge remote-tracking branch 'upstream/feature/1.20.5' into feature/1…
onebeastchris Apr 28, 2024
82123ae
Fix: Modded platform injector not being used
onebeastchris Apr 28, 2024
e8c1c22
Fix banners on shields
Camotoy Apr 29, 2024
88ae447
Fix banner block entity base colors with no patterns
Camotoy Apr 29, 2024
a82a156
Firework shapes
Camotoy Apr 29, 2024
4ff746e
Fix translateTag NPE
AJ-Ferguson Apr 29, 2024
8b7b8cd
Properly shutdown LocalSession's, ensure transferring works properly …
onebeastchris Apr 29, 2024
5d3630c
ominous banners - this really isn't ideal
onebeastchris Apr 29, 2024
28d5db6
revert bad change
onebeastchris Apr 29, 2024
c963503
Entity scale attribute is now applied
Camotoy Apr 30, 2024
dacacc6
Anvil renaming
AJ-Ferguson Apr 30, 2024
74d6a37
Fix bug when adding enchantments in anvil
AJ-Ferguson Apr 30, 2024
ff9965f
Translate item repair cost component
AJ-Ferguson Apr 30, 2024
dd745b9
move to paper-adapters
onebeastchris Apr 30, 2024
d99f498
translate ominous banners
onebeastchris Apr 30, 2024
4a0a694
revert bad diff
onebeastchris Apr 30, 2024
51cbbba
Merge remote-tracking branch 'upstream/feature/1.20.5' into feature/1…
onebeastchris Apr 30, 2024
2558354
viaversion 4.10.0 compat, indicate 1.20.6 support on modrinth
onebeastchris Apr 30, 2024
aff7d2c
Fix potential NPE
AJ-Ferguson Apr 30, 2024
59a2c0d
Use item tags for all animal loved food
Camotoy Apr 30, 2024
abb1d7d
Indicate Java 1.20.6 support
Camotoy Apr 30, 2024
1e8d6b2
Different registry implementation; fix banner blocks with ViaVersion
Camotoy May 1, 2024
cc635d4
This would probably end up being an issue...
Camotoy May 1, 2024
1291b89
Ensure proper Geyser starting/disabling when Geyser is used on a clie…
onebeastchris May 1, 2024
fdae333
Add data components hash code to translated NBT
AJ-Ferguson May 1, 2024
d003818
Potion fixes
AJ-Ferguson May 2, 2024
29a613b
Use java default area effect cloud radius
AJ-Ferguson May 2, 2024
60f8532
Fix attribute display text
AJ-Ferguson May 2, 2024
f7c65f3
properly annotate methods in the ServerTransferEvent
onebeastchris May 2, 2024
efda134
Merge branch 'master' into feature/1.20.5
Camotoy May 2, 2024
6a214f2
Remove duplicate method
Camotoy May 2, 2024
cab1a20
Set mappings commit to master
Camotoy May 2, 2024
b39ed5d
Panda eating particles are not necessarily bamboo
Camotoy May 3, 2024
a39cd65
Fix velocity ping passthrough (#4626)
basaigh May 3, 2024
9d299ee
Fix particle reading issues (#4631)
basaigh May 3, 2024
b8fe71a
Bump MCPL to fix ClientboundExplodePacket (#4635)
AJ-Ferguson May 4, 2024
5770c96
Indicate support for 1.20.81
Camotoy May 5, 2024
8addcad
Bump MCPL to increase NBT max depth (#4639)
AJ-Ferguson May 5, 2024
0a261f1
Update MCPL and MCAuthLib (#4645)
AJ-Ferguson May 7, 2024
cda7a19
Fix discarding of custom trim patterns/materials (#4642)
eclipseisoffline May 7, 2024
627c2ba
Fix various mob attack animations (#4627)
AJ-Ferguson May 7, 2024
e697eb3
Feat: Make connection data exposed in api less prone to throw errors …
onebeastchris May 10, 2024
7801e35
Map new Mace enchantments for Bedrock clients (#4653)
Teelair May 10, 2024
86dafbc
Ensure we load mod resources correctly on Geyser-NeoForge (#4651)
onebeastchris May 12, 2024
b11a6d7
Remove unofficial skin sources and add skin event for extensions (#4507)
rtm516 May 14, 2024
4d61766
Fix SessionSkinApplyEvent not keeping altered skin data (#4663)
rtm516 May 14, 2024
6c4b2cb
Don't create a property manager if an entity has no properties
Camotoy May 15, 2024
423d2e3
Emulate vanilla behavior with existing registries
Camotoy May 15, 2024
9bca012
Bump Erosion
Camotoy May 15, 2024
cbaa9cd
Block refactory
Camotoy May 17, 2024
a46332a
Move block breaking to new system
Camotoy May 17, 2024
1cd0aad
Comment out snow collision
Camotoy May 17, 2024
b010c50
Various entity fixes: Ensure TNT doesn't bug into the ground, reset p…
onebeastchris May 17, 2024
5ebb6ef
Fix: using curly brackets in custom Minecraft locale overrides
onebeastchris May 17, 2024
06dc0d1
Collisions without BlockMapping
Camotoy May 17, 2024
beef01f
Pistons now use the new block stuff
Camotoy May 18, 2024
a439f3e
Fix compilation for Spigot
Camotoy May 18, 2024
8b77031
Resolve issue when trying to transfer a Geyser player (#4673)
onebeastchris May 18, 2024
6c904b2
It's almost done.
Camotoy May 18, 2024
1e9dbaf
Here is the Spigot change
Camotoy May 18, 2024
d85549c
BlockMapping is removed
Camotoy May 20, 2024
1b075ba
Actually implement adventure mode predicates, kind of.
Camotoy May 20, 2024
f489fd3
Add TrapDoorBlock
AJ-Ferguson May 20, 2024
a780eea
Open advancement tab regardless of currently open tab (#4665)
gecko10000 May 20, 2024
db166ad
Small optimizations and BlockStateValues reduction
Camotoy May 21, 2024
0094fa1
BlockState values can now be switched at runtime
Camotoy May 21, 2024
96bfda2
Fix #4683
Camotoy May 22, 2024
f7b026d
Remove old sneaking/crawling workarounds
Camotoy May 22, 2024
6f4c29c
Match Advancement Packet Behavior Towards Java (#4684)
gecko10000 May 22, 2024
377eb07
Merge remote-tracking branch 'origin/master' into dev
Kas-tle May 23, 2024
ec3327e
Minor minor changes
Camotoy May 23, 2024
d5fdbeb
Make allow-third-party-capes default to false (#4690)
rtm516 May 25, 2024
0ea01bf
Allow skull pick item NBT
Camotoy May 25, 2024
5f7a31a
Fix #4688
Camotoy May 26, 2024
fa6808a
Bedrock 1.21.0 Support (#4687)
Kas-tle May 27, 2024
cb0488a
Fix NPE in TippedArrow when it has no components (#4694)
valaphee May 27, 2024
3570caa
Fix crafting output not updating sometimes (#4692)
valaphee May 27, 2024
cf27b88
Switch to centralized GitHub actions (#4693)
Kas-tle May 27, 2024
444b5ec
Remove BlockStateUpdater dependency
Camotoy May 27, 2024
675faf6
Remove unused chat class
Camotoy May 27, 2024
6c88cc5
Merge branch 'master' of https://github.com/GeyserMC/Geyser into dev
Camotoy May 27, 2024
fe63665
Composite gradle setup and artifact archival (#4696)
Kas-tle May 28, 2024
0fcf0f9
Update Bungee version check, create logger earlier (#4697)
onebeastchris May 28, 2024
63c84bc
Yeet lectern cache (#4695)
onebeastchris May 29, 2024
97d9207
Merge branch 'dev' of https://github.com/GeyserMC/Geyser into dev
Camotoy May 29, 2024
7ba95f1
Composite gradle setup and artifact archival (#4696)
Kas-tle May 28, 2024
dc15491
Only include downloads on master
Kas-tle May 29, 2024
8be60b4
Remove lectern/item frame dropping handling for pre 1.20.60
onebeastchris May 29, 2024
66f30a2
Ensure we send commands/chat the same way a Java client would (#4703)
onebeastchris May 29, 2024
c8fbffb
Piston head correct pick block behavior
Camotoy May 30, 2024
da5d800
Add native offhand support for *some* items
Camotoy May 31, 2024
214cc5a
Initial changes for Java 1.21
Camotoy Jun 1, 2024
65fd409
Painting re-implemented. Started on enchantments
Camotoy Jun 3, 2024
8ad10f8
Boats are leashable
Camotoy Jun 3, 2024
aaad10b
Merge remote-tracking branch 'upstream/master' into dev
onebeastchris Jun 3, 2024
0ca4230
Feature: Add API to show/hide GUI elements (#4705)
onebeastchris Jun 3, 2024
6c245a6
Adapt for new enchantment changes
Camotoy Jun 4, 2024
3ead9e9
More unneeded classes
Camotoy Jun 4, 2024
087322f
Small set optimization
Camotoy Jun 4, 2024
688b642
Ignore PurchaseReceiptPacket (#4719)
onebeastchris Jun 4, 2024
42ae9eb
Fix air bubbles for Bedrock 1.21
Camotoy Jun 4, 2024
e2a61d4
Merge branch 'dev' into feature/1.21
Camotoy Jun 5, 2024
fcdd1b9
New banner patterns
Camotoy Jun 5, 2024
4ee9dd5
New potions and merge potion enums
Camotoy Jun 5, 2024
3f8739a
New effects
Camotoy Jun 5, 2024
8f5d156
Implement Bogged entity
Camotoy Jun 6, 2024
c3994a6
Override forward-hostname setting if ViaProxy wildcard domain handlin…
RaphiMC Jun 6, 2024
29c9515
Re-implement jukebox songs
Camotoy Jun 7, 2024
79bcc79
Remove Registries.RECORDS
Camotoy Jun 7, 2024
b7931f8
Update protocol to suppress packet warnings
onebeastchris Jun 6, 2024
9b776b5
Fixed remote config being reset everytime when accessed on Geyser-Via…
RaphiMC Jun 7, 2024
8ae1150
Remove unused lectern code in ModWorldManager, fix spelling error in …
onebeastchris Jun 7, 2024
007ecb4
Ensure custom blocks can be represented at any index
Camotoy Jun 9, 2024
c136bcb
Merge remote-tracking branch 'origin/dev' into feature/1.21
Camotoy Jun 9, 2024
e9e3646
New potion effects
Camotoy Jun 9, 2024
ae6059b
Implement wind charges
Camotoy Jun 9, 2024
f954dd9
oooops
Camotoy Jun 9, 2024
edee5e7
Add builtin server transfer support for ViaProxy (#4723)
RaphiMC Jun 9, 2024
02179a7
You shall compile!
Camotoy Jun 10, 2024
18ad652
Merge branch 'master' of https://github.com/GeyserMC/Geyser
Camotoy Jun 10, 2024
538e9f4
Properly remove SnowCollision
Camotoy Jun 10, 2024
9a310f2
1.21-pre4 updated block tags
Camotoy Jun 11, 2024
7fc370c
Merge remote-tracking branch 'origin/master' into feature/1.21
Camotoy Jun 11, 2024
d198071
Properly show dyed wolf armor
Camotoy Jun 11, 2024
956a84a
Enchantment tag can be null
Camotoy Jun 11, 2024
b78c7b2
Fix #4729
Camotoy Jun 11, 2024
29dacd2
Properly remap coral blocks on 1.20.80
Camotoy Jun 11, 2024
a42c979
This variant of tag loading should be slightly more efficient
Camotoy Jun 12, 2024
82d68bf
Bump fabric/neoforge dependencies to 1.21, update README.md, bump Gey…
onebeastchris Jun 12, 2024
ecffb56
Refactor static recipe loading
Camotoy Jun 13, 2024
7314571
Merge branch 'feature/1.21' of https://github.com/GeyserMC/Geyser int…
Camotoy Jun 13, 2024
2ecc4cd
Point to right mappings
Camotoy Jun 13, 2024
82d0a87
Remove debug code
Camotoy Jun 13, 2024
9db1dd1
Fix some water plants not being waterlogged
Camotoy Jun 13, 2024
52a93ec
Implement breeze
Camotoy Jun 13, 2024
3528b1d
Allow recipes to default count as 1
Camotoy Jun 13, 2024
be04ff2
Update to latest MCProtocolLib
Camotoy Jun 13, 2024
026e6fc
Merge remote-tracking branch 'origin/master' into feature/1.21
Camotoy Jun 13, 2024
73d5f24
Fix compilation for modded
Camotoy Jun 13, 2024
d00cab1
Only translate double chest tags if we are dealing with a double ches…
onebeastchris Jun 13, 2024
db5a528
Fix: Improper detection of virtual double chests (#4738)
onebeastchris Jun 13, 2024
842e1b4
Merge branch 'master' of https://github.com/GeyserMC/Geyser into feat…
Camotoy Jun 13, 2024
ce3083b
Fix key regression with pre-built registries
Camotoy Jun 13, 2024
746be56
Sanity check for BlockState being chest
Camotoy Jun 13, 2024
b6653ac
Catch Throwable when trying to load world adapter
onebeastchris Jun 13, 2024
a5ecee7
Update Bungee warning for outdated proxy checks
onebeastchris Jun 13, 2024
4a334a2
Bed block sanity check for villagers
Camotoy Jun 13, 2024
6a71577
Update mod dependencies to their official 1.21 releases
onebeastchris Jun 13, 2024
09c0ada
Catch Throwable when trying to load world adapter
onebeastchris Jun 13, 2024
138c7b4
Catch EOFExceptions while pinging Java servers when it is misconfigur…
onebeastchris Jun 14, 2024
28e4661
Fix incoming player chat
Camotoy Jun 14, 2024
a9ba1ad
Properly translate ominous items
Camotoy Jun 14, 2024
7e87af7
Fix item attribute modifiers
Camotoy Jun 14, 2024
be83fe7
Re-enable crafter inventory
Camotoy Jun 14, 2024
b1d319b
Add Spigot 1.21 world adapter
onebeastchris Jun 15, 2024
851ed36
Translate vault block entity
Camotoy Jun 15, 2024
6025931
Properly translate player entity UUID for vaults
Camotoy Jun 16, 2024
bd30b34
Bump MCPL
AJ-Ferguson Jun 16, 2024
3b46622
Merge branch 'master' of https://github.com/GeyserMC/Geyser into feat…
Camotoy Jun 16, 2024
0484782
Merge branch 'feature/1.21' of https://github.com/GeyserMC/Geyser int…
Camotoy Jun 16, 2024
d9f9fcf
Bump Protocol
Camotoy Jun 16, 2024
6cda7c2
Partially implement handling of "hide_tooltip" and fix attribute modi…
YHDiamond Jun 16, 2024
1efb633
Bump MCPL (#4756)
basaigh Jun 16, 2024
63a3da7
Fix reading custom jukebox songs (#4757)
eclipseisoffline Jun 16, 2024
deb25d7
Bump mappings to fix effects error on startup (#4760)
basaigh Jun 17, 2024
29928c2
Sanity check for shulker boxes (#4762)
onebeastchris Jun 17, 2024
77fa37f
Fix: readme not being synched to modrinth, publish spigot/bungee/velo…
onebeastchris Jun 17, 2024
a9300fb
Vault: show some components in block entity (enchantments, potion types)
Camotoy Jun 18, 2024
6884a0f
Fix: norwegian locale handling (#4716)
onebeastchris Jun 19, 2024
2c47330
Use integrated world managers for decorated pot animation
Camotoy Jun 19, 2024
34158f9
Feat: Add changelog to modrinth releases (#4770)
onebeastchris Jun 19, 2024
126d56d
Fix: Ignore invalid block entity data sent by Java server (#4766)
onebeastchris Jun 19, 2024
57cb854
Update Floodgate download location
Camotoy Jun 19, 2024
2e6cf2f
Update mappings
Camotoy Jun 20, 2024
ded6f6b
Fix NPEs caused by custom head blocks from Polymer (#4764)
eclipseisoffline Jun 20, 2024
fc529a6
Fix build errors reporting to the wrong directory by updating blossom…
AlexProgrammerDE Jun 20, 2024
f49acb2
Indicate support for Bedrock 1.21.1
Camotoy Jun 20, 2024
dd9d5f3
Work around Bedrock players looking like Steve
Camotoy Jun 20, 2024
78642db
Ensure players get disconnected with no Java disconnect packet
Camotoy Jun 20, 2024
c00a02e
Add trial chambers map icon (#4783)
basaigh Jun 21, 2024
1104707
Fix: Bedrock players dying of fall damage, instead of falling in the …
onebeastchris Jun 21, 2024
a12d60d
Show trial chamber map item texture
Camotoy Jun 21, 2024
21ccafc
DataComponentType.ITEM_NAME should remove italics
Camotoy Jun 21, 2024
e6bf3ff
Proper trial spawner block entity data
Camotoy Jun 21, 2024
55e90b6
Show build number in startup log, fix Geyser version command(#4336)
onebeastchris Jun 22, 2024
a8bd93a
Add fix (#4792)
letsgoawaydev Jun 23, 2024
ca2312c
Create .editorconfig (#4615)
AlexProgrammerDE Jun 24, 2024
835ba9e
Remove casting from block mappings
Camotoy Jun 24, 2024
130b272
Limit particle amount in LevelParticlesPacket (#4802)
AJ-Ferguson Jun 29, 2024
c621e93
Merge branch 'master' of https://github.com/GeyserMC/Geyser
Camotoy Jun 29, 2024
d800f73
Update license to 2024
Camotoy Jun 29, 2024
7612686
Don't show git version string twice
Camotoy Jul 1, 2024
48ea81e
Update mappings (#4812)
onebeastchris Jul 1, 2024
ff1e1dd
Fix attribute modifier tooltips (#4816)
eclipseisoffline Jul 2, 2024
b9c2f61
Updating cosmetica to 1.21 + Better README.MD
oliik2013 Jul 5, 2024
c55cbe9
Deleted gradle
oliik2013 Jul 5, 2024
adaaa20
Deleted broken github workflows
oliik2013 Jul 5, 2024
2ebd9ce
deleted: README.md
oliik2013 Jul 7, 2024
077f1a5
new file: README.md
oliik2013 Jul 7, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
init: pick item component change
  • Loading branch information
onebeastchris authored and Camotoy committed Apr 24, 2024
commit c48428daf0fe0216553279b177d70716daf8ad34
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,10 @@

package org.geysermc.geyser.platform.mod.world;

import com.github.steveice10.mc.protocol.data.game.Holder;
import com.github.steveice10.mc.protocol.data.game.entity.player.GameMode;
import com.github.steveice10.mc.protocol.data.game.item.component.BannerPatternLayer;
import com.github.steveice10.mc.protocol.data.game.item.component.DataComponentType;
import com.github.steveice10.mc.protocol.data.game.level.block.BlockEntityInfo;
import net.kyori.adventure.text.serializer.gson.GsonComponentSerializer;
import net.kyori.adventure.text.serializer.legacy.LegacyComponentSerializer;
Expand All @@ -43,6 +46,7 @@
import net.minecraft.world.level.Level;
import net.minecraft.world.level.block.Block;
import net.minecraft.world.level.block.entity.BannerBlockEntity;
import net.minecraft.world.level.block.entity.BannerPatternLayers;
import net.minecraft.world.level.block.entity.BlockEntity;
import net.minecraft.world.level.block.entity.LecternBlockEntity;
import net.minecraft.world.level.chunk.ChunkAccess;
Expand All @@ -62,6 +66,7 @@
import org.geysermc.geyser.util.BlockEntityUtils;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.List;
import java.util.concurrent.CompletableFuture;

Expand Down Expand Up @@ -217,8 +222,8 @@ public GameMode getDefaultGameMode(GeyserSession session) {

@NonNull
@Override
public CompletableFuture<com.github.steveice10.opennbt.tag.builtin.CompoundTag> getPickItemNbt(GeyserSession session, int x, int y, int z, boolean addNbtData) {
CompletableFuture<com.github.steveice10.opennbt.tag.builtin.CompoundTag> future = new CompletableFuture<>();
public CompletableFuture<com.github.steveice10.mc.protocol.data.game.item.component.DataComponents> getPickItemComponents(GeyserSession session, int x, int y, int z, boolean addNbtData) {
CompletableFuture<com.github.steveice10.mc.protocol.data.game.item.component.DataComponents> future = new CompletableFuture<>();
server.execute(() -> {
ServerPlayer player = getPlayer(session);
if (player == null) {
Expand All @@ -235,7 +240,22 @@ public CompletableFuture<com.github.steveice10.opennbt.tag.builtin.CompoundTag>
// the banner might have a custom name, both of which a Java client knows and caches
ItemStack itemStack = banner.getItem();

future.complete(null); // todo 1.20.5
com.github.steveice10.mc.protocol.data.game.item.component.DataComponents components =
new com.github.steveice10.mc.protocol.data.game.item.component.DataComponents(new HashMap<>());

components.put(DataComponentType.DAMAGE, itemStack.getDamageValue());

Component customName = itemStack.getComponents().get(DataComponents.CUSTOM_NAME);
if (customName != null) {
components.put(DataComponentType.CUSTOM_NAME, toKyoriComponent(customName));
}

BannerPatternLayers pattern = itemStack.get(DataComponents.BANNER_PATTERNS);
if (pattern != null) {
components.put(DataComponentType.BANNER_PATTERNS, toPatternList(pattern));
}

future.complete(components);
return;
}
future.complete(null);
Expand All @@ -262,8 +282,7 @@ private static List<String> getPages(ItemStack itemStack) {
if (writtenBookContent != null) {
return writtenBookContent.pages().stream()
.map(Filterable::raw)
.map((component) -> Component.Serializer.toJson(component, RegistryAccess.EMPTY))
.map((json -> LEGACY_SERIALIZER.serialize(GSON_SERIALIZER.deserializeOr(json, net.kyori.adventure.text.Component.empty()))))
.map(GeyserModWorldManager::fromComponent)
.toList();
} else {
WritableBookContent writableBookContent = itemStack.get(DataComponents.WRITABLE_BOOK_CONTENT);
Expand All @@ -275,4 +294,25 @@ private static List<String> getPages(ItemStack itemStack) {
.toList();
}
}

private static String fromComponent(Component component) {
String json = Component.Serializer.toJson(component, RegistryAccess.EMPTY);
return LEGACY_SERIALIZER.serialize(GSON_SERIALIZER.deserializeOr(json, net.kyori.adventure.text.Component.empty()));
}

private static net.kyori.adventure.text.Component toKyoriComponent(Component component) {
String json = Component.Serializer.toJson(component, RegistryAccess.EMPTY);
return GSON_SERIALIZER.deserializeOr(json, net.kyori.adventure.text.Component.empty());
}

private static List<BannerPatternLayer> toPatternList(BannerPatternLayers patternLayers) {
return patternLayers.layers().stream()
.map(layer -> {
BannerPatternLayer.BannerPattern pattern = new BannerPatternLayer.BannerPattern(
layer.pattern().value().assetId().toString(), layer.pattern().value().translationKey()
);
return new BannerPatternLayer(Holder.ofCustom(pattern), layer.color().getId());
})
.toList();
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -26,8 +26,8 @@
package org.geysermc.geyser.platform.spigot.world.manager;

import com.github.steveice10.mc.protocol.data.game.entity.player.GameMode;
import com.github.steveice10.mc.protocol.data.game.item.component.DataComponents;
import com.github.steveice10.mc.protocol.data.game.level.block.BlockEntityInfo;
import com.github.steveice10.opennbt.tag.builtin.CompoundTag;
import org.bukkit.Bukkit;
import org.bukkit.Chunk;
import org.bukkit.World;
Expand All @@ -39,7 +39,6 @@
import org.cloudburstmc.nbt.NbtMap;
import org.geysermc.erosion.bukkit.BukkitLecterns;
import org.geysermc.erosion.bukkit.BukkitUtils;
import org.geysermc.erosion.bukkit.PickBlockUtils;
import org.geysermc.erosion.bukkit.SchedulerUtils;
import org.geysermc.geyser.GeyserImpl;
import org.geysermc.geyser.level.GameRule;
Expand Down Expand Up @@ -205,8 +204,8 @@ public boolean hasPermission(GeyserSession session, String permission) {
}

@Override
public @NonNull CompletableFuture<@Nullable CompoundTag> getPickItemNbt(GeyserSession session, int x, int y, int z, boolean addNbtData) {
CompletableFuture<@Nullable CompoundTag> future = new CompletableFuture<>();
public @NonNull CompletableFuture<@Nullable DataComponents> getPickItemComponents(GeyserSession session, int x, int y, int z, boolean addNbtData) {
CompletableFuture<@Nullable DataComponents> future = new CompletableFuture<>();
Player bukkitPlayer;
if ((bukkitPlayer = Bukkit.getPlayer(session.getPlayerEntity().getUuid())) == null) {
future.complete(null);
Expand All @@ -215,7 +214,7 @@ public boolean hasPermission(GeyserSession session, String permission) {
Block block = bukkitPlayer.getWorld().getBlockAt(x, y, z);
// Paper 1.19.3 complains about async access otherwise.
// java.lang.IllegalStateException: Tile is null, asynchronous access?
SchedulerUtils.runTask(this.plugin, () -> future.complete(PickBlockUtils.pickBlock(block)), block);
SchedulerUtils.runTask(this.plugin, () -> future.complete(/*PickBlockUtils.pickBlock(block)*/ null), block); // TODO fix erosion once clear how to handle this
return future;
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -25,8 +25,8 @@

package org.geysermc.geyser.erosion;

import com.github.steveice10.mc.protocol.data.game.item.component.DataComponents;
import com.github.steveice10.mc.protocol.data.game.level.block.value.PistonValueType;
import com.github.steveice10.opennbt.tag.builtin.CompoundTag;
import io.netty.channel.Channel;
import it.unimi.dsi.fastutil.ints.Int2ObjectMap;
import it.unimi.dsi.fastutil.ints.Int2ObjectMaps;
Expand All @@ -43,7 +43,14 @@
import org.geysermc.erosion.packet.ErosionPacketSender;
import org.geysermc.erosion.packet.backendbound.BackendboundInitializePacket;
import org.geysermc.erosion.packet.backendbound.BackendboundPacket;
import org.geysermc.erosion.packet.geyserbound.*;
import org.geysermc.erosion.packet.geyserbound.GeyserboundBatchBlockIdPacket;
import org.geysermc.erosion.packet.geyserbound.GeyserboundBlockEntityPacket;
import org.geysermc.erosion.packet.geyserbound.GeyserboundBlockIdPacket;
import org.geysermc.erosion.packet.geyserbound.GeyserboundBlockLookupFailPacket;
import org.geysermc.erosion.packet.geyserbound.GeyserboundBlockPlacePacket;
import org.geysermc.erosion.packet.geyserbound.GeyserboundHandshakePacket;
import org.geysermc.erosion.packet.geyserbound.GeyserboundPickBlockPacket;
import org.geysermc.erosion.packet.geyserbound.GeyserboundPistonEventPacket;
import org.geysermc.geyser.level.block.BlockStateValues;
import org.geysermc.geyser.level.physics.Direction;
import org.geysermc.geyser.network.GameProtocol;
Expand All @@ -64,7 +71,7 @@ public final class GeyserboundPacketHandlerImpl extends AbstractGeyserboundPacke
@Setter
private CompletableFuture<int[]> pendingBatchLookup = null;
@Setter
private CompletableFuture<CompoundTag> pickBlockLookup = null;
private CompletableFuture<DataComponents> pickBlockLookup = null;

private final AtomicInteger nextTransactionId = new AtomicInteger(1);

Expand Down Expand Up @@ -140,7 +147,7 @@ public void handleBlockPlace(GeyserboundBlockPlacePacket packet) {
@Override
public void handlePickBlock(GeyserboundPickBlockPacket packet) {
if (this.pickBlockLookup != null) {
this.pickBlockLookup.complete(packet.getTag());
//this.pickBlockLookup.complete(packet.getTag()); // TODO 1.20.5
}
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -26,8 +26,8 @@
package org.geysermc.geyser.level;

import com.github.steveice10.mc.protocol.data.game.entity.player.GameMode;
import com.github.steveice10.mc.protocol.data.game.item.component.DataComponents;
import com.github.steveice10.mc.protocol.data.game.level.block.BlockEntityInfo;
import com.github.steveice10.opennbt.tag.builtin.CompoundTag;
import it.unimi.dsi.fastutil.objects.Object2ObjectMap;
import it.unimi.dsi.fastutil.objects.Object2ObjectOpenHashMap;
import it.unimi.dsi.fastutil.objects.ObjectArrayList;
Expand All @@ -36,7 +36,11 @@
import org.cloudburstmc.math.vector.Vector3i;
import org.cloudburstmc.nbt.NbtMap;
import org.cloudburstmc.nbt.NbtMapBuilder;
import org.geysermc.erosion.packet.backendbound.*;
import org.geysermc.erosion.packet.backendbound.BackendboundBatchBlockEntityPacket;
import org.geysermc.erosion.packet.backendbound.BackendboundBatchBlockRequestPacket;
import org.geysermc.erosion.packet.backendbound.BackendboundBlockEntityPacket;
import org.geysermc.erosion.packet.backendbound.BackendboundBlockRequestPacket;
import org.geysermc.erosion.packet.backendbound.BackendboundPickBlockPacket;
import org.geysermc.erosion.util.BlockPositionIterator;
import org.geysermc.erosion.util.LecternUtils;
import org.geysermc.geyser.session.GeyserSession;
Expand Down Expand Up @@ -174,12 +178,12 @@ public boolean hasPermission(GeyserSession session, String permission) {

@NonNull
@Override
public CompletableFuture<@Nullable CompoundTag> getPickItemNbt(GeyserSession session, int x, int y, int z, boolean addNbtData) {
public CompletableFuture<@Nullable DataComponents> getPickItemComponents(GeyserSession session, int x, int y, int z, boolean addNbtData) {
var erosionHandler = session.getErosionHandler().getAsActive();
if (erosionHandler == null) {
return super.getPickItemNbt(session, x, y, z, addNbtData);
return super.getPickItemComponents(session, x, y, z, addNbtData);
}
CompletableFuture<CompoundTag> future = new CompletableFuture<>();
CompletableFuture<DataComponents> future = new CompletableFuture<>();
erosionHandler.setPickBlockLookup(future);
erosionHandler.sendPacket(new BackendboundPickBlockPacket(Vector3i.from(x, y, z)));
return future;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -26,9 +26,9 @@
package org.geysermc.geyser.level;

import com.github.steveice10.mc.protocol.data.game.entity.player.GameMode;
import com.github.steveice10.mc.protocol.data.game.item.component.DataComponents;
import com.github.steveice10.mc.protocol.data.game.level.block.BlockEntityInfo;
import com.github.steveice10.mc.protocol.data.game.setting.Difficulty;
import com.github.steveice10.opennbt.tag.builtin.CompoundTag;
import org.checkerframework.checker.nullness.qual.NonNull;
import org.checkerframework.checker.nullness.qual.Nullable;
import org.cloudburstmc.math.vector.Vector3i;
Expand Down Expand Up @@ -220,7 +220,7 @@ public void setDifficulty(GeyserSession session, Difficulty difficulty) {
* @return expected NBT for this item.
*/
@NonNull
public CompletableFuture<@Nullable CompoundTag> getPickItemNbt(GeyserSession session, int x, int y, int z, boolean addNbtData) {
public CompletableFuture<@Nullable DataComponents> getPickItemComponents(GeyserSession session, int x, int y, int z, boolean addExtraData) {
return CompletableFuture.completedFuture(null);
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -26,9 +26,6 @@
package org.geysermc.geyser.translator.protocol.bedrock;

import com.github.steveice10.mc.protocol.data.game.item.ItemStack;
import com.github.steveice10.opennbt.tag.builtin.CompoundTag;
import com.github.steveice10.opennbt.tag.builtin.ListTag;
import com.github.steveice10.opennbt.tag.builtin.StringTag;
import org.cloudburstmc.math.vector.Vector3i;
import org.cloudburstmc.protocol.bedrock.packet.BlockPickRequestPacket;
import org.geysermc.geyser.entity.EntityDefinitions;
Expand Down Expand Up @@ -68,33 +65,23 @@ public void translate(GeyserSession session, BlockPickRequestPacket packet) {
}

BlockMapping blockMapping = BlockRegistries.JAVA_BLOCKS.getOrDefault(blockToPick, BlockMapping.DEFAULT);
boolean addNbtData = packet.isAddUserData() && blockMapping.isBlockEntity(); // Holding down CTRL
/*if (BlockStateValues.getBannerColor(blockToPick) != -1 || addNbtData) { //TODO
session.getGeyser().getWorldManager().getPickItemNbt(session, vector.getX(), vector.getY(), vector.getZ(), addNbtData)
.whenComplete((tag, ex) -> session.ensureInEventLoop(() -> {
if (tag == null) {
boolean addExtraData = packet.isAddUserData() && blockMapping.isBlockEntity(); // Holding down CTRL
if (BlockStateValues.getBannerColor(blockToPick) != -1 || addExtraData) { //TODO
session.getGeyser().getWorldManager().getPickItemComponents(session, vector.getX(), vector.getY(), vector.getZ(), addExtraData)
.whenComplete((components, ex) -> session.ensureInEventLoop(() -> {
if (components == null) {
pickItem(session, blockMapping);
return;
}

if (addNbtData) {
ListTag lore = new ListTag("Lore");
lore.add(new StringTag("", "\"(+NBT)\""));
CompoundTag display = tag.get("display");
if (display == null) {
display = new CompoundTag("display");
tag.put(display);
}
display.put(lore);
}
// I don't really like this... I'd rather get an ID from the block mapping I think
ItemMapping mapping = session.getItemMappings().getMapping(blockMapping.getPickItem());

ItemStack itemStack = new ItemStack(mapping.getJavaItem().javaId(), 1, tag);
ItemStack itemStack = new ItemStack(mapping.getJavaItem().javaId(), 1, components);
InventoryUtils.findOrCreateItem(session, itemStack);
}));
return;
}*/
}

pickItem(session, blockMapping);
}
Expand Down
2 changes: 1 addition & 1 deletion gradle/libs.versions.toml
Original file line number Diff line number Diff line change
Expand Up @@ -15,7 +15,7 @@ protocol-connection = "3.0.0.Beta1-20240411.165033-128"
raknet = "1.0.0.CR3-20240416.144209-1"
blockstateupdater="1.20.80-20240411.142413-1"
mcauthlib = "d9d773e"
mcprotocollib = "4ee05b62" # Revert from jitpack after release
mcprotocollib = "7026b600" # Revert from jitpack after release
adventure = "4.14.0"
adventure-platform = "4.3.0"
junit = "5.9.2"
Expand Down