/* * Copyright (C) 2017 The Android Open Source Project * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ package androidx.room.migration.bundle; import androidx.annotation.RestrictTo; import com.google.gson.annotations.SerializedName; import java.util.List; /** * Data class that holds the schema information about a table Index. * * @hide */ @RestrictTo(RestrictTo.Scope.LIBRARY_GROUP) public class IndexBundle implements SchemaEquality { // should match Index.kt public static final String DEFAULT_PREFIX = "index_"; @SerializedName("name") private String mName; @SerializedName("unique") private boolean mUnique; @SerializedName("columnNames") private List mColumnNames; @SerializedName("createSql") private String mCreateSql; public IndexBundle(String name, boolean unique, List columnNames, String createSql) { mName = name; mUnique = unique; mColumnNames = columnNames; mCreateSql = createSql; } public String getName() { return mName; } public boolean isUnique() { return mUnique; } public List getColumnNames() { return mColumnNames; } /** * @hide */ @RestrictTo(RestrictTo.Scope.LIBRARY_GROUP) public String create(String tableName) { return BundleUtil.replaceTableName(mCreateSql, tableName); } @Override public boolean isSchemaEqual(IndexBundle other) { if (mUnique != other.mUnique) return false; if (mName.startsWith(DEFAULT_PREFIX)) { if (!other.mName.startsWith(DEFAULT_PREFIX)) { return false; } } else if (other.mName.startsWith(DEFAULT_PREFIX)) { return false; } else if (!mName.equals(other.mName)) { return false; } // order matters if (mColumnNames != null ? !mColumnNames.equals(other.mColumnNames) : other.mColumnNames != null) { return false; } return true; } }