mirror of
https://github.com/SquidDev-CC/CC-Tweaked
synced 2026-04-12 01:51:23 +00:00
Ever since 1.17, turtle and pocket upgrades have been loaded from datpacks, rather than being hard-coded in Java. However, upgrades have always been stored in our own registry-like structure, rather than using vanilla's registries. This has become a bit of a problem with the introduction of components. The upgrade components now hold the upgrade object (rather than just its id), which means we need the upgrades to be available much earlier (e.g. when reading recipes). The easiest fix here is to store upgrades in proper registries instead. This means that upgrades can no longer be reloaded (it requires a world restart), but otherwise is much nicer: - UpgradeData now stores a Holder<T> rather than a T. - UpgradeSerialiser has been renamed to UpgradeType. This now just provides a Codec<T>, rather than JSON and network reading/writing functions. - Upgrade classes no longer implement getUpgradeID(), but instead have a getType() function, which returns the associated UpgradeType. - Upgrades are now stored in turtle_upgrade (or pocket_upgrade) rather than turtle_upgrades (or pocket_upgrades). This will break existing datapacks, sorry!
27 lines
906 B
Java
27 lines
906 B
Java
// SPDX-FileCopyrightText: 2023 The CC: Tweaked Developers
|
|
//
|
|
// SPDX-License-Identifier: MPL-2.0
|
|
|
|
package dan200.computercraft.api.client.turtle;
|
|
|
|
import dan200.computercraft.api.turtle.ITurtleUpgrade;
|
|
import dan200.computercraft.api.upgrades.UpgradeType;
|
|
|
|
/**
|
|
* A functional interface to register a {@link TurtleUpgradeModeller} for a class of turtle upgrades.
|
|
* <p>
|
|
* This interface is largely intended to be used from multi-loader code, to allow sharing registration code between
|
|
* multiple loaders.
|
|
*/
|
|
@FunctionalInterface
|
|
public interface RegisterTurtleUpgradeModeller {
|
|
/**
|
|
* Register a {@link TurtleUpgradeModeller}.
|
|
*
|
|
* @param type The turtle upgrade type.
|
|
* @param modeller The upgrade modeller.
|
|
* @param <T> The type of the turtle upgrade.
|
|
*/
|
|
<T extends ITurtleUpgrade> void register(UpgradeType<T> type, TurtleUpgradeModeller<T> modeller);
|
|
}
|