mirror of
				https://github.com/Alfresco/alfresco-community-repo.git
				synced 2025-10-29 15:21:53 +00:00 
			
		
		
		
	125788 rmunteanu: Merged 5.1.N (5.1.2) to 5.2.N (5.2.1)
      125606 rmunteanu: Merged 5.1.1 (5.1.1) to 5.1.N (5.1.2)
         125515 slanglois: MNT-16155 Update source headers - add new Copyrights for Java and JSP source files + automatic check in the build
git-svn-id: https://svn.alfresco.com/repos/alfresco-enterprise/alfresco/HEAD/root@127810 c4b6b30b-aa2e-2d43-bbcb-ca4b014f7261
		
	
		
			
				
	
	
		
			189 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
			
		
		
	
	
			189 lines
		
	
	
		
			5.4 KiB
		
	
	
	
		
			Java
		
	
	
	
	
	
/*
 | 
						|
 * #%L
 | 
						|
 * Alfresco Repository
 | 
						|
 * %%
 | 
						|
 * Copyright (C) 2005 - 2016 Alfresco Software Limited
 | 
						|
 * %%
 | 
						|
 * This file is part of the Alfresco software. 
 | 
						|
 * If the software was purchased under a paid Alfresco license, the terms of 
 | 
						|
 * the paid license agreement will prevail.  Otherwise, the software is 
 | 
						|
 * provided under the following open source license terms:
 | 
						|
 * 
 | 
						|
 * Alfresco is free software: you can redistribute it and/or modify
 | 
						|
 * it under the terms of the GNU Lesser General Public License as published by
 | 
						|
 * the Free Software Foundation, either version 3 of the License, or
 | 
						|
 * (at your option) any later version.
 | 
						|
 * 
 | 
						|
 * Alfresco 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
 | 
						|
 * along with Alfresco. If not, see <http://www.gnu.org/licenses/>.
 | 
						|
 * #L%
 | 
						|
 */
 | 
						|
package org.alfresco.util.schemacomp.model;
 | 
						|
 | 
						|
import java.util.ArrayList;
 | 
						|
import java.util.List;
 | 
						|
 | 
						|
import org.alfresco.util.schemacomp.DbObjectVisitor;
 | 
						|
import org.alfresco.util.schemacomp.DbProperty;
 | 
						|
import org.alfresco.util.schemacomp.DiffContext;
 | 
						|
import org.apache.commons.logging.Log;
 | 
						|
import org.apache.commons.logging.LogFactory;
 | 
						|
 | 
						|
/**
 | 
						|
 * Represents an index on a table.
 | 
						|
 * 
 | 
						|
 * @author Matt Ward
 | 
						|
 */
 | 
						|
public class Index extends AbstractDbObject
 | 
						|
{
 | 
						|
    private final List<String> columnNames = new ArrayList<String>();
 | 
						|
    private boolean unique;
 | 
						|
    private static Log logger = LogFactory.getLog(Index.class);
 | 
						|
    
 | 
						|
    public Index(String name)
 | 
						|
    {
 | 
						|
        super(null, name);
 | 
						|
    }
 | 
						|
    
 | 
						|
    /**
 | 
						|
     * @param table the parent table
 | 
						|
     * @param columnNames List<String>
 | 
						|
     */
 | 
						|
    public Index(Table table, String name, List<String> columnNames)
 | 
						|
    {
 | 
						|
        super(table, name);
 | 
						|
        this.columnNames.addAll(columnNames);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * @return the columnNames
 | 
						|
     */
 | 
						|
    public List<String> getColumnNames()
 | 
						|
    {
 | 
						|
        return this.columnNames;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * @param columnNames the columnNames to set
 | 
						|
     */
 | 
						|
    public void setColumnNames(List<String> columnNames)
 | 
						|
    {
 | 
						|
        this.columnNames.clear();
 | 
						|
        this.columnNames.addAll(columnNames);
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * Does this index have the unique attribute?
 | 
						|
     * 
 | 
						|
     * @return unique
 | 
						|
     */
 | 
						|
    public boolean isUnique()
 | 
						|
    {
 | 
						|
        return this.unique;
 | 
						|
    }
 | 
						|
 | 
						|
    /**
 | 
						|
     * @see #isUnique()
 | 
						|
     * @param unique boolean
 | 
						|
     */
 | 
						|
    public void setUnique(boolean unique)
 | 
						|
    {
 | 
						|
        this.unique = unique;
 | 
						|
    }
 | 
						|
 | 
						|
 | 
						|
    @Override
 | 
						|
    public int hashCode()
 | 
						|
    {
 | 
						|
        final int prime = 31;
 | 
						|
        int result = super.hashCode();
 | 
						|
        result = prime * result + ((this.columnNames == null) ? 0 : this.columnNames.hashCode());
 | 
						|
        result = prime * result + (this.unique ? 1231 : 1237);
 | 
						|
        return result;
 | 
						|
    }
 | 
						|
 | 
						|
    @Override
 | 
						|
    public boolean equals(Object obj)
 | 
						|
    {
 | 
						|
        if (this == obj) return true;
 | 
						|
        if (!super.equals(obj)) return false;
 | 
						|
        if (getClass() != obj.getClass()) return false;
 | 
						|
        Index other = (Index) obj;
 | 
						|
        if (this.unique != other.unique) 
 | 
						|
        {
 | 
						|
            return false;
 | 
						|
        }
 | 
						|
        if (this.columnNames == null)
 | 
						|
        {
 | 
						|
            if (other.columnNames != null) return false;
 | 
						|
        }
 | 
						|
        else if (!this.columnNames.equals(other.columnNames)) return false;
 | 
						|
        
 | 
						|
        return true;
 | 
						|
    }
 | 
						|
 | 
						|
    @Override
 | 
						|
    public boolean sameAs(DbObject o)
 | 
						|
    {
 | 
						|
        if (o != null && o instanceof Index)
 | 
						|
        {
 | 
						|
            Index other = (Index) o;
 | 
						|
            
 | 
						|
            // An index can only be 'the same' if it belongs to the correct table.
 | 
						|
            if (!getParent().sameAs(other.getParent()))
 | 
						|
            {
 | 
						|
                return false;
 | 
						|
            }
 | 
						|
            
 | 
						|
            // If it has the same name, then it is intended to be the same index
 | 
						|
            if (getName() != null && getName().equals(other.getName()))
 | 
						|
            {
 | 
						|
                return true;
 | 
						|
            }
 | 
						|
            else
 | 
						|
            {
 | 
						|
                // If one index is unique and the other is not then it is not a match
 | 
						|
                if (this.unique != other.unique) 
 | 
						|
                {
 | 
						|
                    return false;
 | 
						|
                }
 | 
						|
                
 | 
						|
                // The name may be different, but if it has the same parent table (see above)
 | 
						|
                // and indexes the same columns, then it is the same index.
 | 
						|
                return columnNames.equals(other.getColumnNames());
 | 
						|
            }
 | 
						|
        }
 | 
						|
        
 | 
						|
        return false;
 | 
						|
    }
 | 
						|
 | 
						|
    
 | 
						|
    @Override
 | 
						|
    protected void doDiff(DbObject right, DiffContext ctx)
 | 
						|
    {
 | 
						|
        Index rightIndex = (Index) right;
 | 
						|
        // DatabaseMetaData provides the columns in the correct order for the index.
 | 
						|
        // So compare as ordered collections...
 | 
						|
        comparisonUtils.compareSimpleOrderedLists(
 | 
						|
                    new DbProperty(this, "columnNames"),
 | 
						|
                    new DbProperty(rightIndex, "columnNames"),
 | 
						|
                    ctx);
 | 
						|
        comparisonUtils.compareSimple(
 | 
						|
                    new DbProperty(this, "unique"),
 | 
						|
                    new DbProperty(rightIndex, "unique"),
 | 
						|
                    ctx);
 | 
						|
    }
 | 
						|
    
 | 
						|
    
 | 
						|
    @Override
 | 
						|
    public void accept(DbObjectVisitor visitor)
 | 
						|
    {
 | 
						|
        visitor.visit(this);
 | 
						|
    }
 | 
						|
}
 |