/* * CraftBook Copyright (C) 2010-2017 sk89q <http://www.sk89q.com> * CraftBook Copyright (C) 2011-2017 me4502 <http://www.me4502.com> * CraftBook Copyright (C) Contributors * * This program is free software: you can redistribute it and/or modify it under the terms of the GNU General Public * License as published by the Free * Software Foundation, either version 3 of the License, or (at your option) any later version. * * This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied * warranty of MERCHANTABILITY or * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details. * * You should have received a copy of the GNU General Public License along with this program. If not, * see <http://www.gnu.org/licenses/>. */ package com.sk89q.craftbook.sponge.util.data.mutable; import com.sk89q.craftbook.sponge.mechanics.ics.SerializedICData; import com.sk89q.craftbook.sponge.util.data.CraftBookKeys; import com.sk89q.craftbook.sponge.util.data.immutable.ImmutableICData; import org.spongepowered.api.Sponge; import org.spongepowered.api.data.DataContainer; import org.spongepowered.api.data.DataHolder; import org.spongepowered.api.data.DataQuery; import org.spongepowered.api.data.manipulator.mutable.common.AbstractSingleData; import org.spongepowered.api.data.merge.MergeFunction; import org.spongepowered.api.data.value.mutable.Value; import org.spongepowered.api.util.annotation.NonnullByDefault; import java.util.Optional; @NonnullByDefault public class ICData extends AbstractSingleData<SerializedICData, ICData, ImmutableICData> { public ICData() { this(null); } public ICData(SerializedICData value) { super(value, CraftBookKeys.IC_DATA); } public Value<SerializedICData> ic() { return Sponge.getRegistry().getValueFactory() .createValue(CraftBookKeys.IC_DATA, getValue()); } @Override protected Value<SerializedICData> getValueGetter() { return ic(); } @Override public Optional<ICData> fill(DataHolder dataHolder, MergeFunction overlap) { dataHolder.get(ICData.class).ifPresent((data) -> { ICData finalData = overlap.merge(this, data); setValue(finalData.getValue()); }); return Optional.of(this); } @Override public Optional<ICData> from(DataContainer container) { if (container.contains(CraftBookKeys.IC_DATA.getQuery())) { try { Class<SerializedICData> clazz = (Class<SerializedICData>) Class.forName(container.getString(DataQuery.of("ICDataClass")).orElse(SerializedICData.class.getName())); return Optional.of(new ICData(container.getSerializable(CraftBookKeys.IC_DATA.getQuery(), clazz).get())); } catch (ClassNotFoundException e) { e.printStackTrace(); } } return Optional.empty(); } @Override public ICData copy() { return new ICData(getValue()); } @Override public ImmutableICData asImmutable() { return new ImmutableICData(getValue()); } @Override public DataContainer toContainer() { return super.toContainer() .set(DataQuery.of("ICDataClass"), getValue().getClass().getName()) .set(CraftBookKeys.IC_DATA, getValue()); } @Override public int getContentVersion() { return 1; } }