/* * 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 legal-notices/CDDLv1_0.txt * or http://forgerock.org/license/CDDLv1.0.html. * 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 legal-notices/CDDLv1_0.txt. * 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. * Portions Copyright 2015 ForgeRock AS. */ package org.opends.guitools.controlpanel.datamodel; import java.util.Objects; 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<>(); 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) { if (this == o) { return true; } if (o instanceof ObjectClassValue) { ObjectClassValue oc = (ObjectClassValue)o; return Objects.equals(structural, oc.getStructural()) && auxiliary.equals(oc.getAuxiliary()); } return false; } }