blob: bbbf87ea0b1731d18cca161dc2a8635ccff68ed0 [file] [log] [blame]
/*
* Copyright (c) 2008, Edward Yakop. All Rights Reserved.
*
* 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 org.apache.zest.tools.model.descriptor;
import org.apache.zest.api.composite.MethodDescriptor;
import static org.apache.zest.api.util.NullArgumentException.validateNotNull;
public final class CompositeMethodDetailDescriptor
{
private final MethodDescriptor descriptor;
private CompositeDetailDescriptor composite;
private MethodConstraintsDetailDescriptor constraints;
private MethodConcernsDetailDescriptor concerns;
private MethodSideEffectsDetailDescriptor sideEffects;
CompositeMethodDetailDescriptor( MethodDescriptor aDescriptor )
throws IllegalArgumentException
{
validateNotNull( "aDescriptor", aDescriptor );
descriptor = aDescriptor;
composite = null;
constraints = null;
sideEffects = null;
}
/**
* @return Descriptor of this {@code CompositeMethodDetailDescriptor}. Never return {@code null}.
*
* @since 0.5
*/
public final MethodDescriptor descriptor()
{
return descriptor;
}
/**
* @return Constraints of this {@code CompositeMethodDetailDescriptor}.
* Returns {@code null} if this method does not have any constraints.
*
* @since 0.5
*/
public final MethodConstraintsDetailDescriptor constraints()
{
return constraints;
}
/**
* @return Concerns of this {@code CompositeMethodDetailDescriptor}. Returns {@code null} if this method does not
* have any concerns.
*
* @since 0.5
*/
public final MethodConcernsDetailDescriptor concerns()
{
return concerns;
}
/**
* @return Side-effects of this {@code CompositeMethodDetailDescriptor}. Returns {@code null}
* if this method does not have any side effects.
*
* @since 0.5
*/
public final MethodSideEffectsDetailDescriptor sideEffects()
{
return sideEffects;
}
/**
* @return Composite that owns this {@code CompositeMethodDetailDescriptor}.
*
* @since 0.5
*/
public final CompositeDetailDescriptor composite()
{
return composite;
}
final void setComposite( CompositeDetailDescriptor aDescriptor )
throws IllegalArgumentException
{
validateNotNull( "aDescriptor", aDescriptor );
composite = aDescriptor;
}
final void setConstraints( MethodConstraintsDetailDescriptor aDescriptor )
throws IllegalArgumentException
{
validateNotNull( "aDescriptor", aDescriptor );
aDescriptor.setMethod( this );
constraints = aDescriptor;
}
public void setConcerns( MethodConcernsDetailDescriptor aDescriptor )
{
validateNotNull( "aDescriptor", aDescriptor );
aDescriptor.setMethod( this );
concerns = aDescriptor;
}
final void setSideEffects( MethodSideEffectsDetailDescriptor aDescriptor )
{
validateNotNull( "aDescriptor", aDescriptor );
aDescriptor.setMethod( this );
sideEffects = aDescriptor;
}
@Override
public final String toString()
{
return descriptor.method().getName();
}
}