Mods
Resource Packs
Data Packs
Modpacks
Shaders
Plugins
Mods Resource Packs Data Packs Plugins Shaders Modpacks
Get Modrinth App Upgrade to Modrinth+
Sign in
ModsPluginsData PacksShadersResource PacksModpacks
Sign in
Settings
NBT-API

NBT-API

Add custom NBT tags to Items/Tiles/Entities without NMS

200.5k
182
Library

Compatibility

Minecraft: Java Edition

1.21.x
1.20.x
1.19.x
1.18.x
1.17.x
1.16.x
1.15.x
1.14.x
1.13.x
1.12.x
1.11.x
1.10.x
1.9.x
1.8.8–1.8.9
1.7.9–1.7.10

Platforms

Bukkit
Folia
Paper
Purpur
Spigot

Supported environments

Server-side

90% of ad revenue goes to creators

Support creators and Modrinth ad-free with Modrinth+

Links

Report issues View source Visit wiki Join Discord server
Donate on Ko-fi

Creators

tr7zw
tr7zw Owner
SoSeDiK
SoSeDiK Member

Details

Licensed MIT
Created 2 years ago
Updated last month
DescriptionChangelogVersions

Show all versions

2.15.0

by tr7zw on Apr 17, 2025
Download

What's Changed

  • Add 1.21.5 support (Spigot/Paper/forks)
  • Updated Wiki pages a lot
  • Add DataVersion for itemstack conversions by @SoSeDiK in https://github.com/tr7zw/Item-NBT-API/pull/319
  • Fixed list#remove(Object) removing every instance of the Object, not just the first one. #293
  • Add a method to extract difference between two compounds by @SoSeDiK in https://github.com/tr7zw/Item-NBT-API/pull/321
  • Update "Reading world data" wiki example by @SoSeDiK in https://github.com/tr7zw/Item-NBT-API/pull/320
  • Bump org.apache.maven.plugins:maven-javadoc-plugin from 3.11.1 to 3.11.2 by @dependabot in https://github.com/tr7zw/Item-NBT-API/pull/312
  • Add EvenMoreFish to Plugins.md by @FireML in https://github.com/tr7zw/Item-NBT-API/pull/311
  • Bump org.codehaus.mojo:license-maven-plugin from 2.4.0 to 2.5.0 by @dependabot in https://github.com/tr7zw/Item-NBT-API/pull/309
  • Update wiki by @SoSeDiK in https://github.com/tr7zw/Item-NBT-API/pull/313
  • Bump org.apache.maven.plugins:maven-compiler-plugin from 3.13.0 to 3.14.0 by @dependabot in https://github.com/tr7zw/Item-NBT-API/pull/316

New Contributors

  • @FireML made their first contribution in https://github.com/tr7zw/Item-NBT-API/pull/311

Full Changelog: https://github.com/tr7zw/Item-NBT-API/compare/2.14.1...2.15.0

2.14.1

by tr7zw on Dec 16, 2024
Download

What's Changed

  • Add 1.21.4 support
  • Add new experimental NBTJsonUtil#itemStackToJson method to use for 1.20.3+ Chat Hover Components
  • Update wiki by @SoSeDiK in https://github.com/tr7zw/Item-NBT-API/pull/308
  • Bump org.apache.maven.plugins:maven-javadoc-plugin from 3.10.1 to 3.11.1 by @dependabot in https://github.com/tr7zw/Item-NBT-API/pull/306

Full Changelog: https://github.com/tr7zw/Item-NBT-API/compare/2.14.0...2.14.1

2.14.0

by tr7zw on Nov 2, 2024
Download

What's Changed

  • Add 1.21.3 support (and 1.21.2, but you shouldn't be using this version)
  • Hide NBTFile/NBTContainer fully behind NBT (methods are now deprecated, pointing to the equivalent NBT replacement)
  • Add missing addCompound(ReadableNBT comp) to ReadWriteNBTCompoundList
  • Fix edge-case in writing out Bukkit items without data
  • Try to auto-detect pre 1.20.3 item nbt also via the "Count" tag for updating
  • Bump org.apache.maven.plugins:maven-javadoc-plugin from 3.8.0 to 3.10.0 by @dependabot in https://github.com/tr7zw/Item-NBT-API/pull/297
  • Bump org.apache.maven.plugins:maven-javadoc-plugin from 3.10.0 to 3.10.1 by @dependabot in https://github.com/tr7zw/Item-NBT-API/pull/300

Full Changelog: https://github.com/tr7zw/Item-NBT-API/compare/2.13.2...2.14.0

2.13.2

by tr7zw on Aug 10, 2024
Download

What's Changed

  • Add 1.21.1 support
  • Small wiki changes by @SoSeDiK in https://github.com/tr7zw/Item-NBT-API/pull/287
  • Bump org.apache.maven.plugins:maven-javadoc-plugin from 3.7.0 to 3.8.0 by @dependabot in https://github.com/tr7zw/Item-NBT-API/pull/290
  • Prevent chunk loading during tile entity tests by @SoSeDiK in https://github.com/tr7zw/Item-NBT-API/pull/288

Full Changelog: https://github.com/tr7zw/Item-NBT-API/compare/2.13.1...2.13.2

2.13.1

by tr7zw on Jun 20, 2024
Download

What's Changed

  • Fix Paper 1.21
  • Fix resolveCompound in ReadWriteNBT not returning ReadWriteNBT
  • Add a missing @Nullable flag to resolveCompound
  • Removed old incorrect mappings on newer versions
  • General code cleanup
  • Fix datafixer now knowing the 1.21 version id
  • Update wiki by @SoSeDiK in https://github.com/tr7zw/Item-NBT-API/pull/282

If you have questions about how to migrate your code away from NBTItem or how to support 1.20.5+ with the new ItemStack logic, check out the updated wiki! SoSeDiK did an amazing job updating the wiki, including many updated examples. Also, feel free to PR your plugin to the Plugin list on the wiki.

Full Changelog: https://github.com/tr7zw/Item-NBT-API/compare/2.13.0...2.13.1

2.13.0

by tr7zw on Jun 13, 2024
Download

What's Changed

  • Update to 1.21
  • Deprecated lots of old methods/constructors. Please migrate to the NBT class for faster and abstracted alternatives
  • Added new NBT.modifyComponents API for 1.20.5+ to modify vanilla components
  • Removed nbt-injector(you really shouldn't be using this) and nbt-data-api(never finished). This removed a lot of bloat from the jar
  • Bump org.apache.maven.plugins:maven-javadoc-plugin from 3.6.3 to 3.7.0 by @dependabot in https://github.com/tr7zw/Item-NBT-API/pull/279
  • Bump org.apache.maven.plugins:maven-shade-plugin from 3.5.3 to 3.6.0 by @dependabot in https://github.com/tr7zw/Item-NBT-API/pull/278

Full Changelog: https://github.com/tr7zw/Item-NBT-API/compare/2.12.4...2.13.0

2.12.4

by tr7zw on Apr 30, 2024
Download

What's Changed

  • Add 1.20.5 & 1.20.6 support
  • Add Datafixer support to upgrade item NBT to newer versions
  • Auto upgrade old ItemStacks when using NBT.itemStackFromNBT and the related methods (it will assume the NBT is 1.20.4 data, otherwise upgrade the NBT before yourself with the Datafixer)
  • Fix BlockEntity bug on Mojang mapped servers
  • Bump org.apache.maven.plugins:maven-source-plugin from 3.3.0 to 3.3.1 by @dependabot in https://github.com/tr7zw/Item-NBT-API/pull/273
  • Bump org.apache.maven.plugins:maven-shade-plugin from 3.5.2 to 3.5.3 by @dependabot in https://github.com/tr7zw/Item-NBT-API/pull/277

Note

Due to Mojang changes to how ItemStacks work at runtime, vanilla NBT won't be visible on loaded ItemStacks in 1.20.5+ anymore. So modifying vanilla data will not work anymore in the same way as for 1.8-1.20.4, and all plugins need to be updated to be aware of that. If in doubt, feel free to ask on Discord.

Full Changelog: https://github.com/tr7zw/Item-NBT-API/compare/2.12.3...2.12.4

2.12.3

by tr7zw on Mar 24, 2024
Download

What's Changed

  • Add support for un-remapped Paper 1.20+

Other changes

  • Bump org.apache.maven.plugins:maven-compiler-plugin from 3.11.0 to 3.12.0 by @dependabot in https://github.com/tr7zw/Item-NBT-API/pull/261
  • Bump org.apache.maven.plugins:maven-compiler-plugin from 3.12.0 to 3.12.1 by @dependabot in https://github.com/tr7zw/Item-NBT-API/pull/263
  • Update LICENSE copyright to 2024 by @SmartGecko44 in https://github.com/tr7zw/Item-NBT-API/pull/264
  • Bump org.codehaus.mojo:license-maven-plugin from 2.3.0 to 2.4.0 by @dependabot in https://github.com/tr7zw/Item-NBT-API/pull/265
  • Bump org.apache.maven.plugins:maven-shade-plugin from 3.5.1 to 3.5.2 by @dependabot in https://github.com/tr7zw/Item-NBT-API/pull/267
  • Bump org.apache.maven.plugins:maven-compiler-plugin from 3.12.1 to 3.13.0 by @dependabot in https://github.com/tr7zw/Item-NBT-API/pull/270

New Contributors

  • @SmartGecko44 made their first contribution in https://github.com/tr7zw/Item-NBT-API/pull/264

Full Changelog: https://github.com/tr7zw/Item-NBT-API/compare/2.12.2...2.12.3

2.12.2

by tr7zw on Dec 10, 2023
Download

What's Changed

  • Add 1.20.4 support
  • Bump org.apache.maven.plugins:maven-javadoc-plugin from 3.6.0 to 3.6.2 by @dependabot in https://github.com/tr7zw/Item-NBT-API/pull/256
  • Bump org.apache.maven.plugins:maven-javadoc-plugin from 3.6.2 to 3.6.3 by @dependabot in https://github.com/tr7zw/Item-NBT-API/pull/258

Full Changelog: https://github.com/tr7zw/Item-NBT-API/compare/2.12.1...2.12.2

2.12.1

by tr7zw on Nov 4, 2023
Download

What's Changed

  • Fix 1.19R3 using the wrong mapping, causing a test to fail
  • Fix internal version ID of 1.20R2
  • Bump org.apache.maven.plugins:maven-shade-plugin from 3.5.0 to 3.5.1 by @dependabot in https://github.com/tr7zw/Item-NBT-API/pull/250
  • Bump org.codehaus.mojo:license-maven-plugin from 2.2.0 to 2.3.0 by @dependabot in https://github.com/tr7zw/Item-NBT-API/pull/253

Full Changelog: https://github.com/tr7zw/Item-NBT-API/compare/2.12.0...2.12.1

2.12.0

by tr7zw on Sep 21, 2023
Download

2.12.0

Hello everyone, this is the by far biggest NBTAPI update so far. This release contains 100 commits of the total 580 total commits(17% of all commits of the past 7 years?!?), so strap in for the changes.

(Also small reminder that supporting the dev behind this project would be really nice, especially when you use this API to make paid Plugins 😅)

Late changes between 2.12.0-RC1 and 2.12.0:

  • Add 1.20.2 support
  • Fix getKeys on empty ItemStacks
  • Fix modifyMeta on empty ItemStacks
  • Add support for ProxiedLists
  • Add support for using indices like [123] or [-1] in resolve methods
  • Hard prevent Jitpack. If you are using Jitpack for whatever reason, check the wiki to use the correct repo!

Major Changes

  • Add support for Mojang-Mapped servers(Paper-Mojmap/Paper dev mode)
  • Add support for Folia
  • HEAVY performance improvements for NBT.get and NBT.modify (see below)
  • Preview: Interface proxies to access NBT without writing code(see below)
  • Entity/BlockEntity modifications are now atomic and faster to prevent pitfalls
  • Entity/BlockEntity read-only is now a lot faster by only getting the tag once
  • Added resolveOrNull/resolveOrDefault/resolveCompound/resolveOrCreateCompound. They take . separated strings to keys like tag.othertag.key (see below for examples)

Noteworthy Changes

  • Updated bStats from version 1? to 3.0.2
  • Reduced logging for Gson
  • Added long[] support with setLongArray/getLongArray (1.16+)
  • Include NBTAPI version in errors
  • Removed the "functional-annotations" dependency shading users might have noticed
  • Fixed NBTFile.saveTo always saving the root instead of the passed tag
  • Added @Nullable in some key places
  • When the tag is empty at the end of NBT.modify, the tag gets removed from the item instead of saving an empty {} tag
  • Prevented some misuse of the NBT.get/NBT.modify methods
  • New set(String key, T value, NBTHandler<T> handler) method to set your custom data with the provided handler
  • New get(String key, NBTHandler<T> handler) method to get your custom data with the provided handler

Other Changes/Documentation

  • Bump license-maven-plugin from 2.0.1 to 2.1.0 by @dependabot in https://github.com/tr7zw/Item-NBT-API/pull/229
  • Bump maven-shade-plugin from 3.4.1 to 3.5.0 by @dependabot in https://github.com/tr7zw/Item-NBT-API/pull/232
  • Bump license-maven-plugin from 2.1.0 to 2.2.0 by @dependabot in https://github.com/tr7zw/Item-NBT-API/pull/235
  • Read-only optimization by @tr7zw in https://github.com/tr7zw/Item-NBT-API/pull/236
  • Update "set skull skin" documentation by @BlackBaroness in https://github.com/tr7zw/Item-NBT-API/pull/237
  • Fix minor English mistakes in documentation by @BlackBaroness in https://github.com/tr7zw/Item-NBT-API/pull/238
  • add honorable plugin list mentions by @U5B in https://github.com/tr7zw/Item-NBT-API/pull/242
  • Fix Folia detection and NBT#modify for tile entities by @SoSeDiK in https://github.com/tr7zw/Item-NBT-API/pull/243

Performance

This release has a lot of performance optimizations under the hood, mainly for the NBT.get and NBT.modify methods for ItemStacks/Entities/BlockEntities. I highly encourage everyone to start updating their NBTItem/NBTEntity/NBTTileEntity code to use these new methods. All benchmarks are done on Paper-171 on my local PC with 2.11.3 vs 2.12.0-RC1. The numbers are how often the test case was able to run in one second(the JVM did have some warmup time before on these methods). But since it's just one run there is probably a +-5% margin of error on these values, they are just there to get a rough idea.

Itemstacks

Link to the code that runs. The legacy tests use new NBTItem, while the others use the NBT class. Both tests get/set the same data, just changing between the old and new syntax!

NMS-Backed Itemstacks:

  • LegacyGet: 880.620 -> 909.369 = ~3% faster
  • NBT.get: 884.326 -> 4.214.210 = ~376% faster
  • LegacySet: 762.453 -> 804.732 = ~5% faster
  • NBT.modify: 298.238 -> 1.781.667 = ~497% faster

Bukkit-only Itemstacks:

  • LegacyGet: 215.992 -> 202.413 = ~6% slower
  • NBT.get: 223.998 -> 649.626 = ~190% faster
  • LegacySet: 229.485 -> 239.910 = ~4% faster
  • NBT.modify: 166.048 -> 567.107 = 241% faster

Basically, switch to the new NBT.get/NBT.modify method and get at least 200% more performance compared to before.

Persistent Data Container

To get a better idea on the performance of using the NBTAPI to store data on items vs Spigots Persistent Data Container API I checked and compared these too. Again, Paper-171 on 2.12.0-RC1. On NMS-Backed Itemstacks normal PDC is about the same speed as NBT.get. Only when caching the NamespacedKey in a final class field PDC pulls ahead. Writing data, especially on Bukkit-only items is a lot slower, but still easily 500.000+ times per second, so doubt that it's much of an issue(especially for gaining a way more flexible API and pre-1.14 support).

Resolve methods

To simplify working with deeply nested NBT, resolve methods now allow directly getting or working with these tags. Compounds are separated by .. In case you need a . inside a key, it can be escaped with a \. Examples:

// sets foo/bar/baz/test to 42
nbt.resolveOrCreateCompound("foo.bar.baz").setInteger("test", 42);
// gets the value we just set or 0
nbt.resolveOrDefault("foo.bar.baz.test", 0);
// gets the value we just set or null
nbt.resolveOrNull("foo.bar.baz.test", int.class);
// example of a key with a . in it. Sets the key foo/some.key/baz/other
nbt.resolveOrCreateCompound("foo.some\\.key.baz").setInteger("other", 123)
// get a tag or null when it's not there
nbt.resolveCompound("some.nested.key");

Interface Proxies

This is a preview feature contained in this release, and the API might change depending on feedback/development. It allows defining an Interface with normal methods/default methods, and the NBTAPI wraps the NBT with an automatically generated implementation of this Interface.

Methods starting with has/get/set will be interpreted as their respective calls: public boolean hasKills(); runs return nbt.hasTag("kills"); public void setKills(int amount); runs nbt.setInteger("kills", amount); public int getKills(); runs return nbt.getInteger("kills"); Default methods like

        public default void addKill() {
            setKills(getKills() + 1);
        }

inside the interface are supported. Also having a getter return another Interface that also extends NBTProxy is supported. To support other datatypes like ItemStacks, the init method can be overwritten with a default method, using the registerHandler method to add handlers. For example:

        @Override
        default void init() {
            registerHandler(ItemStack.class, NBTHandlers.ITEM_STACK);
        }

To now use your interface, just call NBT.modify or NBT.readNbt like this:

NBT.modify(item, TestInterface.class, ti -> {
ti.addKill();
//or any other method from your interface
});
// This instance can only run read-only methods. Calling any setter will cause an exception
TestInterface yourInterface = NBT.readNbt(item, TestInterface.class);
yourInterface .getKills();

For the complete example check the built-in startup test or the WIP NBT-ItemMeta proxy. Also feel free to ask on Discord.

New Contributors

  • @BlackBaroness made their first contribution in https://github.com/tr7zw/Item-NBT-API/pull/237
  • @U5B made their first contribution in https://github.com/tr7zw/Item-NBT-API/pull/242

Full Changelog: https://github.com/tr7zw/Item-NBT-API/compare/2.11.3...2.12.0-RC1

2.12.0 - Release Candidate 1

by tr7zw on Sep 10, 2023
Download

2.12.0 - Release Candidate 1

Hello everyone, this is the by far biggest NBTAPI update so far, that's why I decided to have a Minecraft-style Release Candidate before the full 2.12.0 release(best-case without any changes). This release contains 84 commits of the total 563 total commits(nearly 15% of all commits of the past 6-7 years?!?), so strap in for the changes.

(Also small reminder that supporting the dev behind this project would be really nice, especially when you use this API to make paid Plugins 😅)

Major Changes

  • Add support for Mojang-Mapped servers(Paper-Mojmap/Paper dev mode)
  • Add support for Folia
  • HEAVY performance improvements for NBT.get and NBT.modify (see below)
  • Preview: Interface proxies to access NBT without writing code(see below)
  • Entity/BlockEntity modifications are now atomic and faster to prevent pitfalls
  • Entity/BlockEntity read-only is now a lot faster by only getting the tag once
  • Added resolveOrNull/resolveOrDefault/resolveCompound/resolveOrCreateCompound. They take . separated strings to keys like tag.othertag.key (see below for examples)

Noteworthy Changes

  • Updated bStats from version 1? to 3.0.2
  • Reduced logging for Gson
  • Added long[] support with setLongArray/getLongArray (1.16+)
  • Include NBTAPI version in errors
  • Removed the "functional-annotations" dependency shading users might have noticed
  • Fixed NBTFile.saveTo always saving the root instead of the passed tag
  • Added @Nullable in some key places
  • When the tag is empty at the end of NBT.modify, the tag gets removed from the item instead of saving an empty {} tag
  • Prevented some misuse of the NBT.get/NBT.modify methods
  • New set(String key, T value, NBTHandler<T> handler) method to set your custom data with the provided handler
  • New get(String key, NBTHandler<T> handler) method to get your custom data with the provided handler

Other Changes/Documentation

  • Bump license-maven-plugin from 2.0.1 to 2.1.0 by @dependabot in https://github.com/tr7zw/Item-NBT-API/pull/229
  • Bump maven-shade-plugin from 3.4.1 to 3.5.0 by @dependabot in https://github.com/tr7zw/Item-NBT-API/pull/232
  • Bump license-maven-plugin from 2.1.0 to 2.2.0 by @dependabot in https://github.com/tr7zw/Item-NBT-API/pull/235
  • Read-only optimization by @tr7zw in https://github.com/tr7zw/Item-NBT-API/pull/236
  • Update "set skull skin" documentation by @BlackBaroness in https://github.com/tr7zw/Item-NBT-API/pull/237
  • Fix minor English mistakes in documentation by @BlackBaroness in https://github.com/tr7zw/Item-NBT-API/pull/238
  • add honorable plugin list mentions by @U5B in https://github.com/tr7zw/Item-NBT-API/pull/242
  • Fix Folia detection and NBT#modify for tile entities by @SoSeDiK in https://github.com/tr7zw/Item-NBT-API/pull/243

Performance

This release has a lot of performance optimizations under the hood, mainly for the NBT.get and NBT.modify methods for ItemStacks/Entities/BlockEntities. I highly encourage everyone to start updating their NBTItem/NBTEntity/NBTTileEntity code to use these new methods. All benchmarks are done on Paper-171 on my local PC with 2.11.3 vs 2.12.0-RC1. The numbers are how often the test case was able to run in one second(the JVM did have some warmup time before on these methods). But since it's just one run there is probably a +-5% margin of error on these values, they are just there to get a rough idea.

Itemstacks

Link to the code that runs. The legacy tests use new NBTItem, while the others use the NBT class. Both tests get/set the same data, just changing between the old and new syntax!

NMS-Backed Itemstacks:

  • LegacyGet: 880.620 -> 909.369 = ~3% faster
  • NBT.get: 884.326 -> 4.214.210 = ~376% faster
  • LegacySet: 762.453 -> 804.732 = ~5% faster
  • NBT.modify: 298.238 -> 1.781.667 = ~497% faster

Bukkit-only Itemstacks:

  • LegacyGet: 215.992 -> 202.413 = ~6% slower
  • NBT.get: 223.998 -> 649.626 = ~190% faster
  • LegacySet: 229.485 -> 239.910 = ~4% faster
  • NBT.modify: 166.048 -> 567.107 = 241% faster

Basically, switch to the new NBT.get/NBT.modify method and get at least 200% more performance compared to before.

Persistent Data Container

To get a better idea on the performance of using the NBTAPI to store data on items vs Spigots Persistent Data Container API I checked and compared these too. Again, Paper-171 on 2.12.0-RC1. On NMS-Backed Itemstacks normal PDC is about the same speed as NBT.get. Only when caching the NamespacedKey in a final class field PDC pulls ahead. Writing data, especially on Bukkit-only items is a lot slower, but still easily 500.000+ times per second, so doubt that it's much of an issue(especially for gaining a way more flexible API and pre-1.14 support).

Resolve methods

To simplify working with deeply nested NBT, resolve methods now allow directly getting or working with these tags. Compounds are separated by .. In case you need a . inside a key, it can be escaped with a \. Examples:

// sets foo/bar/baz/test to 42
nbt.resolveOrCreateCompound("foo.bar.baz").setInteger("test", 42);
// gets the value we just set or 0
nbt.resolveOrDefault("foo.bar.baz.test", 0);
// gets the value we just set or null
nbt.resolveOrNull("foo.bar.baz.test", int.class);
// example of a key with a . in it. Sets the key foo/some.key/baz/other
nbt.resolveOrCreateCompound("foo.some\\.key.baz").setInteger("other", 123)
// get a tag or null when it's not there
nbt.resolveCompound("some.nested.key");

Interface Proxies

This is a preview feature contained in this release, and the API might change depending on feedback/development. It allows defining an Interface with normal methods/default methods, and the NBTAPI wraps the NBT with an automatically generated implementation of this Interface.

Methods starting with has/get/set will be interpreted as their respective calls: public boolean hasKills(); runs return nbt.hasTag("kills"); public void setKills(int amount); runs nbt.setInteger("kills", amount); public int getKills(); runs return nbt.getInteger("kills"); Default methods like

        public default void addKill() {
            setKills(getKills() + 1);
        }

inside the interface are supported. Also having a getter return another Interface that also extends NBTProxy is supported. To support other datatypes like ItemStacks, the init method can be overwritten with a default method, using the registerHandler method to add handlers. For example:

        @Override
        default void init() {
            registerHandler(ItemStack.class, NBTHandlers.ITEM_STACK);
        }

To now use your interface, just call NBT.modify or NBT.readNbt like this:

NBT.modify(item, TestInterface.class, ti -> {
ti.addKill();
//or any other method from your interface
});
// This instance can only run read-only methods. Calling any setter will cause an exception
TestInterface yourInterface = NBT.readNbt(item, TestInterface.class);
yourInterface .getKills();

For the complete example check the built-in startup test or the WIP NBT-ItemMeta proxy. Also feel free to ask on Discord.

New Contributors

  • @BlackBaroness made their first contribution in https://github.com/tr7zw/Item-NBT-API/pull/237
  • @U5B made their first contribution in https://github.com/tr7zw/Item-NBT-API/pull/242

Full Changelog: https://github.com/tr7zw/Item-NBT-API/compare/2.11.3...2.12.0-RC1

2.11.3

by tr7zw on Jun 7, 2023
Download

What's Changed

  • Add 1.20 support
  • Try printing the shaders plugin name in incompatibility messages
  • Print warning when shading the plugin instead of the api/setting the shaded target to "de.tr7zw.nbtapi" (this is reserved for the official plugin)
  • Disable version check for shaded versions by default(turn back on using MinecraftVersion.enableUpdateCheck())
  • Add support for boolean in getOrDefault/getOrNull by @SoSeDiK in https://github.com/tr7zw/Item-NBT-API/pull/222
  • Allow checking nbt type alongside the key by @SoSeDiK in https://github.com/tr7zw/Item-NBT-API/pull/223
  • Bump license-maven-plugin from 2.0.0 to 2.0.1 by @dependabot in https://github.com/tr7zw/Item-NBT-API/pull/221
  • Fix a small typo in nbt-injector by @tom-devv in https://github.com/tr7zw/Item-NBT-API/pull/224
  • Bump maven-source-plugin from 3.2.1 to 3.3.0 by @dependabot in https://github.com/tr7zw/Item-NBT-API/pull/227

A heads-up

More features like Mojang mapped jars/Folia support and a cleaner way to access data using interfaces are on the way. You should consider joining the discord to join the discussion.

New Contributors

  • @tom-devv made their first contribution in https://github.com/tr7zw/Item-NBT-API/pull/224

Full Changelog: https://github.com/tr7zw/Item-NBT-API/compare/2.11.2...2.11.3

2.11.2

by tr7zw on Mar 16, 2023
Download
  • Add 1.19.4 as officially supported(2.11.1 will work fine on 1.19.4, but show a warning that it doesn't know about this version)
  • Fixed the return type of getOrCreateCompound/getCompound in ReadWriteNBT to be ReadWriteNBT too

2.11.1

by tr7zw on Dec 14, 2022
Download

What's Changed

  • Fix StackOverflowError when merging ReadableNBT by @Kevin-OVI in https://github.com/tr7zw/Item-NBT-API/pull/204

New Contributors

  • @Kevin-OVI made their first contribution in https://github.com/tr7zw/Item-NBT-API/pull/204

Full Changelog: https://github.com/tr7zw/Item-NBT-API/compare/2.11.0...2.11.1

2.11.0

by tr7zw on Dec 11, 2022
Download

New major NBTAPI release, adding 1.19.3 support and a new way to interact with the API.

Changes:

  • 1.19.3 support
  • Added interfaces to most nbt logic, including read-only versions
  • Added a new utility class NBT, which provides clean lambda access to read and write NBT. https://github.com/tr7zw/Item-NBT-API/wiki/Using-the-NBT-API has updated examples on how to use this class.
  • Utility readFrom/saveTo methods to NBTFile
  • hasTag as alternative for hasKey, returning boolean instead of Boolean
  • Added getOrDefault method
  • Added getOrNull method
  • Deprecated setObject/getObject, please do the serialization yourself using your preferred lib/settings
  • getUUID/setUUID now will handle pre-1.16 and post-1.16 formats correctly on their own
  • getItemStack will now return null if the tag is not found
  • getKeys is now a copy of the Set, and no longer linked to NMS internal objects
  • Added setItemStackArray/getItemStackArray methods
  • Added modifyMeta methods to ItemStacks. Do not modify the NBT while inside the modifyMeta scope
  • The wiki is now inside the Github repository, so anyone can make pull requests to add examples, clarifications etc.
  • NBTItem now will correctly reject ItemStacks of size 0
  • Updated a lot of Javadoc
  • The full API Javadoc is now available under https://tr7zw.github.io/Item-NBT-API/v2-api/
  • Pulling the NBTAPI plugin via Maven/Gradle will now also correctly contain the API Javadoc(only had the plugin Javadoc before)
  • Fixed small NPE error during error reporting(ironic)
  • NBTCompoundList now extend NBTList<ReadWriteNBT> instead of NBTList<NBTListCompound>. This is a compile-time breaking change, and code needs to be updated accordingly. Already published plugins should not be affected by this.

2.10.0

by tr7zw on Aug 21, 2022
Download

Added:

  • 1.19 support

  • 1.7.10 Crucible support(use the latest build). Thanks, EverNife

Modrinth is open source.

app-ads@1633f40

© Rinth, Inc.

Company

TermsPrivacyRulesCareers

Resources

SupportBlogDocsStatus

Interact

Discord X (Twitter) Mastodon Crowdin
Get Modrinth App Settings
NOT AN OFFICIAL MINECRAFT SERVICE. NOT APPROVED BY OR ASSOCIATED WITH MOJANG OR MICROSOFT.