/* * This file is part of OneConfig. * OneConfig - Next Generation Config Library for Minecraft: Java Edition * Copyright (C) 2021, 2022 Polyfrost. * <https://polyfrost.cc> <https://github.com/Polyfrost/> * * DO NOT ALTER OR REMOVE COPYRIGHT NOTICES OR THIS FILE HEADER. * * OneConfig is licensed under the terms of version 3 of the GNU Lesser * General Public License as published by the Free Software Foundation, AND * under the Additional Terms Applicable to OneConfig, as published by Polyfrost, * either version 1.0 of the Additional Terms, 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 * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License. If not, see <https://www.gnu.org/licenses/>. You should * have also received a copy of the Additional Terms Applicable * to OneConfig, as published by Polyfrost. If not, see * <https://polyfrost.cc/legal/oneconfig/additional-terms> */ package cc.polyfrost.oneconfig.config.migration; import java.lang.annotation.ElementType; import java.lang.annotation.Retention; import java.lang.annotation.RetentionPolicy; import java.lang.annotation.Target; /** * <pre style="font-size: 12px">{@code public @interface JsonName}</pre> * This interface is used to specify a previous name for an element.<br> * For example, if you changed the name of a variable when you migrated/updated your mod to use OneConfig, * you can use this annotation to specify the previous name so that the Migrator can grab it. <br> * <b>This annotation uses dot notation to specify the full, case sensitive path to the old config field. See {@link JsonMigrator} for more information.</b> */ @Retention(RetentionPolicy.RUNTIME) @Target(ElementType.FIELD) public @interface JsonName { String value(); }