/*
* CDDL HEADER START
*
* The contents of this file are subject to the terms of the
* Common Development and Distribution License, Version 1.0 only
* (the "License"). You may not use this file except in compliance
* with the License.
*
* You can obtain a copy of the license at
* trunk/opends/resource/legal-notices/OpenDS.LICENSE
* or https://OpenDS.dev.java.net/OpenDS.LICENSE.
* See the License for the specific language governing permissions
* and limitations under the License.
*
* When distributing Covered Code, include this CDDL HEADER in each
* file and include the License file at
* trunk/opends/resource/legal-notices/OpenDS.LICENSE. If applicable,
* add the following below this CDDL HEADER, with the fields enclosed
* by brackets "[]" replaced with your own identifying information:
* Portions Copyright [yyyy] [name of copyright owner]
*
* CDDL HEADER END
*
*
* Copyright 2008 Sun Microsystems, Inc.
*/
package org.opends.guitools.controlpanel.datamodel;
import java.util.Set;
import java.util.SortedSet;
import java.util.TreeSet;
/**
* This class represent all the objectclass values for a given entry. It is
* used by the entry editors (SimplifiedEntryView and TableEntryView) to edit
* and display the objectclass.
*
*/
public class ObjectClassValue
{
private String structural;
private SortedSet<String> auxiliary = new TreeSet<String>();
private int hashCode;
/**
* Constructor of the object class value.
* @param structural the name of the structural objectclass.
* @param auxiliary the auxiliary objectclasses.
*/
public ObjectClassValue(String structural, Set<String> auxiliary)
{
this.structural = structural;
this.auxiliary.addAll(auxiliary);
if (structural != null)
{
// This can happen when the schema checking is not enabled.
hashCode = structural.hashCode();
}
for (String oc : auxiliary)
{
hashCode += oc.hashCode();
}
}
/**
* Returns the names of the auxiliary objectclasses.
* @return the names of the auxiliary objectclasses.
*/
public SortedSet<String> getAuxiliary()
{
return auxiliary;
}
/**
* Returns the name of the structural objectclass.
* @return the name of the structural objectclass.
*/
public String getStructural()
{
return structural;
}
/**
* {@inheritDoc}
*/
public int hashCode()
{
return hashCode;
}
/**
* {@inheritDoc}
*/
public boolean equals(Object o)
{
boolean equals;
if (o != this)
{
if (o != null)
{
if (o instanceof ObjectClassValue)
{
ObjectClassValue oc = (ObjectClassValue)o;
if (structural != null)
{
equals = structural.equals(oc.getStructural());
}
else
{
equals = oc.getStructural() == null;
}
if (equals)
{
equals = auxiliary.equals(oc.getAuxiliary());
}
}
else
{
equals = false;
}
}
else
{
equals = false;
}
}
else
{
equals = true;
}
return equals;
}
}