/*
* Copyright (c) 2013 Cisco Systems, Inc. and others. All rights reserved.
*
* This program and the accompanying materials are made available under the
* terms of the Eclipse Public License v1.0 which accompanies this distribution,
* and is available at http://www.eclipse.org/legal/epl-v10.html
*/
package org.opendaylight.yangtools.binding.model.api.type.builder;
import com.google.common.annotations.Beta;
import org.opendaylight.yangtools.binding.model.api.MethodSignature;
import org.opendaylight.yangtools.binding.model.api.MethodSignature.ValueMechanics;
import org.opendaylight.yangtools.binding.model.api.Type;
import org.opendaylight.yangtools.binding.model.api.TypeMemberComment;
/**
* Method Signature Builder serves solely for building Method Signature and
* returning the new
instance of Method Signature.
* By definition of {@link MethodSignature} the Method in java MUST contain
* Name, Return Type and Access Modifier. By default the Access Modifier can be
* set to public. The Method Signature builder does not contain method for
* addName due to enforce reason that MethodSignatureBuilder SHOULD be
* instantiated only once with defined method name.
* The methods as {@link #addAnnotation(String, String)} and
* {@link #setComment(TypeMemberComment)} can be used as optional because not all methods
* MUST contain annotation or comment definitions.
*
* @see MethodSignature
*/
public interface MethodSignatureBuilder extends TypeMemberBuilder {
/**
* Sets the flag for declaration of method as abstract or non abstract. If the flag {@code isAbstract == true}
* the instantiated Method Signature MUST have return value for {@link MethodSignature#isAbstract()} also equals to
* true
.
*
* @param isAbstract is abstract flag
*/
MethodSignatureBuilder setAbstract(boolean isAbstract);
/**
* Sets the flag indicating whether this is a {@code default interface} method.
*
* @param isDefault true if this signature is to represent a default method.
* @return this builder
*/
MethodSignatureBuilder setDefault(boolean isDefault);
@Beta
MethodSignatureBuilder setMechanics(ValueMechanics mechanics);
/**
* Adds Parameter into the List of method parameters. Neither the Name or Type of parameter can be {@code null}.
*
*
* In case that any of parameters are defined as null
the
* method SHOULD throw an {@link IllegalArgumentException}
*
* @param type Parameter Type
* @param name Parameter Name
*/
MethodSignatureBuilder addParameter(Type type, String name);
/**
* Returns new
immutable instance of Method Signature.
* The definingType
param cannot be null
. Every method in Java MUST be declared and
* defined inside the scope of class
or interface
definition. In case that defining Type
* will be passed as null
reference the method SHOULD thrown {@link IllegalArgumentException}.
*
* @param definingType Defining Type of Method Signature
* @return new
immutable instance of Method Signature.
*/
MethodSignature toInstance(Type definingType);
}