Jump to content
View in the app

A better way to browse. Learn more.

Forge Forums

A full-screen app on your home screen with push notifications, badges and more.

To install this app on iOS and iPadOS
  1. Tap the Share icon in Safari
  2. Scroll the menu and tap Add to Home Screen.
  3. Tap Add in the top-right corner.
To install this app on Android
  1. Tap the 3-dot menu (⋮) in the top-right corner of the browser.
  2. Tap Add to Home screen or Install app.
  3. Confirm by tapping Install.

Featured Replies

Posted

Hey there, I'll keep this short and sweet. I'm trying to fix this and wondered if anyone can help. I'm running code using findNearestMapStructure to find the nearest Jungle Temple and send the coordinates to the executing player. However, said method is returning null every single time. Any ideas why?

if (entity instanceof Player player && !player.getLevel().isClientSide()) {]

ServerLevel level = (ServerLevel) player.getLevel();
				HolderSet<Structure> holderset = HolderSet.direct(Structures.JUNGLE_TEMPLE);
				BlockPos pos = new BlockPos(x, y, z);
				Pair<BlockPos, Holder<Structure>> pair = level.getChunkSource().getGenerator().findNearestMapStructure(level, holderset, pos, 100, false); // This always returns null
				BlockPos structurepos = pair.getFirst();
				
				int strx = structurepos.getX();
				int stry = structurepos.getY();
				int strz = structurepos.getZ();
				
				player.displayClientMessage(Component.literal("The compass twinkles, and you sense a jungle temple at " + Integer.toString(strx) + ", " + Integer.toString(stry) + ", " + Integer.toString(strz) + "!"), (false));
                  

}

 

Your holder is for the wrong registry.

You need to get one from the active server registry.

 

This works for me based on your code:

@Mod.EventBusSubscriber(modid = MODID)
public class Events {

    @SubscribeEvent
    public static void commands(RegisterCommandsEvent event) {
        event.getDispatcher().register(Commands.literal("blah").executes(Events::blah));
    }

    public static int blah(CommandContext<CommandSourceStack> context) throws CommandSyntaxException {
        var entity = context.getSource().getEntityOrException();
        if (entity instanceof Player player && !player.getLevel().isClientSide()) {

            ServerLevel level = (ServerLevel) player.getLevel();

            // Your code using the builtin regisry which is not used at runtime
            // HolderSet<Structure> holderset = HolderSet.direct(Structures.JUNGLE_TEMPLE);

            // Code using the server registry
            Registry<Structure> registry = level.registryAccess().registryOrThrow(Registry.STRUCTURE_REGISTRY);
            HolderSet<Structure> holderSet = registry.getHolder(BuiltinStructures.JUNGLE_TEMPLE).map(HolderSet::direct).orElseThrow();

            BlockPos pos = player.blockPosition();
            Pair<BlockPos, Holder<Structure>> pair = level.getChunkSource().getGenerator().findNearestMapStructure(level, holderSet, pos, 100, false); // This always returns null
            BlockPos structurepos = pair.getFirst();
            int strx = structurepos.getX();
            int stry = structurepos.getY();
            int strz = structurepos.getZ();
            
            player.displayClientMessage(Component.literal("Location " + Integer.toString(strx) + ", " + Integer.toString(stry) + ", " + Integer.toString(strz) + "!"), (false));
        }
        return 1;
    }
}

 

Boilerplate:

If you don't post your logs/debug.log we can't help you. For curseforge you need to enable the forge debug.log in its minecraft settings. You should also post your crash report if you have one.

If there is no error in the log file and you don't have a crash report then post the launcher_log.txt from the minecraft folder. Again for curseforge this will be in your curseforge/minecraft/Install

Large files should be posted to a file sharing site like https://gist.github.com  You should also read the support forum sticky post.

  • Author

Thanks so much warjort! I was just investigating and figuring this out and your comment confirmed my suspicions. I needed to get the holder directly from the registry for this to work. For anyone who finds this thread in the future, my solution was to change this line:
 

HolderSet<Structure> holderset = HolderSet.direct(Structures.JUNGLE_TEMPLE);

With this:

Registry<Structure> reg = level.registryAccess().registryOrThrow(Registry.STRUCTURE_REGISTRY);
Holder<Structure> holder = reg.getHolder((Structures.JUNGLE_TEMPLE.unwrapKey().get())).get();
HolderSet<Structure> holderset = HolderSet.direct(holder);

And voila:

image.png

Thanks for the help!

Join the conversation

You can post now and register later. If you have an account, sign in now to post with your account.
Note: Your post will require moderator approval before it will be visible.

Guest
Unfortunately, your content contains terms that we do not allow. Please edit your content to remove the highlighted words below.
Reply to this topic...

Important Information

By using this site, you agree to our Terms of Use.

Configure browser push notifications

Chrome (Android)
  1. Tap the lock icon next to the address bar.
  2. Tap Permissions → Notifications.
  3. Adjust your preference.
Chrome (Desktop)
  1. Click the padlock icon in the address bar.
  2. Select Site settings.
  3. Find Notifications and adjust your preference.