forked from public-mirrors/HuskSync
Implement variable-sized user data; only save needed data
parent
b9e474d946
commit
cbf5d9c24e
@ -0,0 +1,140 @@
|
|||||||
|
package net.william278.husksync.data;
|
||||||
|
|
||||||
|
import org.jetbrains.annotations.NotNull;
|
||||||
|
import org.jetbrains.annotations.Nullable;
|
||||||
|
|
||||||
|
import java.util.List;
|
||||||
|
|
||||||
|
/**
|
||||||
|
* A builder utility for creating {@link UserData} instances
|
||||||
|
*
|
||||||
|
* @since 2.1
|
||||||
|
*/
|
||||||
|
@SuppressWarnings("UnusedReturnValue")
|
||||||
|
public class UserDataBuilder {
|
||||||
|
|
||||||
|
@NotNull
|
||||||
|
private final UserData userData;
|
||||||
|
|
||||||
|
protected UserDataBuilder(@NotNull String minecraftVersion) {
|
||||||
|
this.userData = new UserData();
|
||||||
|
this.userData.minecraftVersion = minecraftVersion;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the {@link StatusData} to this {@link UserData}
|
||||||
|
*
|
||||||
|
* @param status the {@link StatusData} to set
|
||||||
|
* @return this {@link UserDataBuilder}
|
||||||
|
* @since 2.1
|
||||||
|
*/
|
||||||
|
@NotNull
|
||||||
|
public UserDataBuilder setStatus(@NotNull StatusData status) {
|
||||||
|
this.userData.statusData = status;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the inventory {@link ItemData} to this {@link UserData}
|
||||||
|
*
|
||||||
|
* @param inventoryData the inventory {@link ItemData} to set
|
||||||
|
* @return this {@link UserDataBuilder}
|
||||||
|
* @since 2.1
|
||||||
|
*/
|
||||||
|
@NotNull
|
||||||
|
public UserDataBuilder setInventory(@Nullable ItemData inventoryData) {
|
||||||
|
this.userData.inventoryData = inventoryData;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the ender chest {@link ItemData} to this {@link UserData}
|
||||||
|
*
|
||||||
|
* @param enderChestData the ender chest {@link ItemData} to set
|
||||||
|
* @return this {@link UserDataBuilder}
|
||||||
|
* @since 2.1
|
||||||
|
*/
|
||||||
|
@NotNull
|
||||||
|
public UserDataBuilder setEnderChest(@Nullable ItemData enderChestData) {
|
||||||
|
this.userData.enderChestData = enderChestData;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the {@link List} of {@link ItemData} to this {@link UserData}
|
||||||
|
*
|
||||||
|
* @param potionEffectData the {@link List} of {@link ItemData} to set
|
||||||
|
* @return this {@link UserDataBuilder}
|
||||||
|
* @since 2.1
|
||||||
|
*/
|
||||||
|
@NotNull
|
||||||
|
public UserDataBuilder setPotionEffects(@Nullable PotionEffectData potionEffectData) {
|
||||||
|
this.userData.potionEffectData = potionEffectData;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the {@link List} of {@link ItemData} to this {@link UserData}
|
||||||
|
*
|
||||||
|
* @param advancementData the {@link List} of {@link ItemData} to set
|
||||||
|
* @return this {@link UserDataBuilder}
|
||||||
|
* @since 2.1
|
||||||
|
*/
|
||||||
|
@NotNull
|
||||||
|
public UserDataBuilder setAdvancements(@Nullable List<AdvancementData> advancementData) {
|
||||||
|
this.userData.advancementData = advancementData;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the {@link StatisticsData} to this {@link UserData}
|
||||||
|
*
|
||||||
|
* @param statisticData the {@link StatisticsData} to set
|
||||||
|
* @return this {@link UserDataBuilder}
|
||||||
|
* @since 2.1
|
||||||
|
*/
|
||||||
|
@NotNull
|
||||||
|
public UserDataBuilder setStatistics(@Nullable StatisticsData statisticData) {
|
||||||
|
this.userData.statisticData = statisticData;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the {@link LocationData} to this {@link UserData}
|
||||||
|
*
|
||||||
|
* @param locationData the {@link LocationData} to set
|
||||||
|
* @return this {@link UserDataBuilder}
|
||||||
|
* @since 2.1
|
||||||
|
*/
|
||||||
|
@NotNull
|
||||||
|
public UserDataBuilder setLocation(@Nullable LocationData locationData) {
|
||||||
|
this.userData.locationData = locationData;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Set the {@link PersistentDataContainerData} to this {@link UserData}
|
||||||
|
*
|
||||||
|
* @param persistentDataContainerData the {@link PersistentDataContainerData} to set
|
||||||
|
* @return this {@link UserDataBuilder}
|
||||||
|
* @since 2.1
|
||||||
|
*/
|
||||||
|
@NotNull
|
||||||
|
public UserDataBuilder setPersistentDataContainer(@Nullable PersistentDataContainerData persistentDataContainerData) {
|
||||||
|
this.userData.persistentDataContainerData = persistentDataContainerData;
|
||||||
|
return this;
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Build and get the {@link UserData} instance
|
||||||
|
*
|
||||||
|
* @return the {@link UserData} instance
|
||||||
|
* @since 2.1
|
||||||
|
*/
|
||||||
|
@NotNull
|
||||||
|
public UserData build() {
|
||||||
|
return this.userData;
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Loading…
Reference in New Issue