/*
* 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
* 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.
*/
/**
* The requested managed object was found but its type could not be
* determined.
*/
/**
* An enumeration defining the reasons why the definition could not
* be resolved.
*/
public static enum Reason {
/**
* The managed object could be found but its type resolved to an
* abstract managed object definition.
*/
/**
* The managed object could be found but did not contain any type
* information (eg missing object classes in LDAP).
*/
/**
* The managed object could be found but did not contain the
* expected type information (eg incorrect object classes in
* LDAP).
*/
}
/**
* Version ID required by serializable classes.
*/
// Create the message.
switch (reason) {
case NO_TYPE_INFORMATION:
case WRONG_TYPE_INFORMATION:
default:
}
}
// The expected type of managed object.
private final AbstractManagedObjectDefinition<?, ?> d;
// The reason why the definition could not be determined.
/**
* Create a new definition decoding exception.
*
* @param d
* The expected type of managed object.
* @param reason
* The reason why the definition could not be determined.
*/
super(createMessage(d, reason));
this.d = d;
}
/**
* Gets the expected managed object definition.
*
* @return Returns the expected managed object definition.
*/
return d;
}
/**
* Gets the reason why the definition could not be determined.
*
* @return Returns the reason why the definition could not be
* determined.
*/
return reason;
}
}