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

EnchantmentBook Registration always with same NamespaceID -> Override #9

Open
Verox001 opened this issue Aug 26, 2023 · 3 comments
Open

Comments

@Verox001
Copy link
Contributor

By using the Enchantment#register method and setting the second argument (registerItem) to true, doesn't register ALL enchantment books correctly. Even though having an enchantment with MaxLevel 5, it only registers the book for level one.

Why does this happen?

The reason may be that all custom registered books use the same NamespaceId of the Enchantment, which results in all other enchantment books after level one not being registered, since there already is one with the same NamespaceId registered.
https://github.com/PowerNukkitX/PowerNukkitX/blob/1dfc7db755ecd638366d65caf4c1c179817841da/src/main/java/cn/nukkit/item/enchantment/Enchantment.java#L367

I created my own EnchantmentBook classes with unique NamespaceIds and it worked like a charm.

📋 Debug information

  • PowerNukkit version: 1.20.10-r1
@AzaleeX
Copy link
Member

AzaleeX commented Aug 31, 2023

Hello @Verox001

we need more information to be able to solve the problem like for example your custom NamespaceId or even an in-game image and your code it can be useful

@Verox001
Copy link
Contributor Author

Verox001 commented Sep 2, 2023

public class Stabilization extends Enchantment {

    public Stabilization() {
        super(new Identifier("cc:stabilization"), "Stabilization", Rarity.UNCOMMON, EnchantmentType.SWORD);
    }

    @Override
    public int getMaxLevel() {
        return 5;
    }

    @Override
    public boolean canEnchant(@NotNull Item item) {
        Plugin.getInstance().getLogger().info(item.getNamespaceId());
        Plugin.getInstance().getLogger().info(item.getNamespaceId().equals("cc:boomerang") ? "true" : "false");
        return item.getNamespaceId().equals("cc:boomerang");
    }

    @Override
    public int getMaxEnchantAbility(int level) {
        return this.getMinEnchantAbility(level) + 20;
    }

    @Override
    public int getMinEnchantAbility(int level) {
        return 8 * level - 7;
    }
}

This is my code for the enchantment class and this is how I register it in the onLoad method:

Enchantment.register(new Stabilization(), true);

And here is an image that only one enchantment level book has been registered:
image

And here is an image of trying to enchant a unechanted boomerang with Stabilization 1 (It doesn't work either. canEnchant doesn't even get called):
image

@Verox001
Copy link
Contributor Author

Verox001 commented Oct 7, 2023

@AzaleeX Could you have a look at this please?

@CoolLoong CoolLoong transferred this issue from PowerNukkitX/PowerNukkitX Jan 15, 2024
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests

2 participants