OperationFacadeLogic.java
// license-header java merge-point
//
// Attention: generated code (by MetafacadeLogic.vsl) - do not modify!
//
package org.andromda.metafacades.emf.uml22;
import java.util.Collection;
import java.util.List;
import org.andromda.core.metafacade.MetafacadeBase;
import org.andromda.core.metafacade.ModelValidationMessage;
import org.andromda.metafacades.uml.ClassifierFacade;
import org.andromda.metafacades.uml.ConstraintFacade;
import org.andromda.metafacades.uml.ModelElementFacade;
import org.andromda.metafacades.uml.OperationFacade;
import org.andromda.metafacades.uml.ParameterFacade;
import org.andromda.translation.ocl.validation.OCLCollections;
import org.andromda.translation.ocl.validation.OCLExpressions;
import org.andromda.translation.ocl.validation.OCLIntrospector;
import org.andromda.translation.ocl.validation.OCLResultEnsurer;
import org.apache.log4j.Logger;
import org.eclipse.uml2.uml.Operation;
/**
* A behavioral feature of a classifier that specifies the name, type, parameters, and constraints
* for invoking an associated behavior. May invoke both the execution of method behaviors as well as
* other behavioral responses.
* MetafacadeLogic for OperationFacade
*
* @see OperationFacade
*/
public abstract class OperationFacadeLogic
extends ModelElementFacadeLogicImpl
implements OperationFacade
{
/**
* The underlying UML object
* @see Operation
*/
protected Operation metaObject;
/** Create Metafacade implementation instance using the MetafacadeFactory from the context
* @param metaObjectIn
* @param context
*/
protected OperationFacadeLogic(Operation metaObjectIn, String context)
{
super(metaObjectIn, getContext(context));
this.metaObject = metaObjectIn;
}
/**
* The logger instance.
*/
private static final Logger logger = Logger.getLogger(OperationFacadeLogic.class);
/**
* Gets the context for this metafacade logic instance.
* @param context String. Set to OperationFacade if null
* @return context String
*/
private static String getContext(String context)
{
if (context == null)
{
context = "org.andromda.metafacades.uml.OperationFacade";
}
return context;
}
/** Reset context only for non-root metafacades
* @param context
*/
@Override
public void resetMetafacadeContext(String context)
{
if (!this.contextRoot) // reset context only for non-root metafacades
{
context = getContext(context); // to have same value as in original constructor call
setMetafacadeContext (context);
}
}
/**
* @return boolean true always
* @see OperationFacade
*/
public boolean isOperationFacadeMetaType()
{
return true;
}
// --------------- attributes ---------------------
/**
* @see OperationFacade#getSignature()
* @return String
*/
protected abstract String handleGetSignature();
private String __signature1a;
private boolean __signature1aSet = false;
/**
* Return the operation signature, including public/protested abstract returnType name plus
* argument type and name
* @return (String)handleGetSignature()
*/
public final String getSignature()
{
String signature1a = this.__signature1a;
if (!this.__signature1aSet)
{
// signature has no pre constraints
signature1a = handleGetSignature();
// signature has no post constraints
this.__signature1a = signature1a;
if (isMetafacadePropertyCachingEnabled())
{
this.__signature1aSet = true;
}
}
return signature1a;
}
/**
* @see OperationFacade#getCall()
* @return String
*/
protected abstract String handleGetCall();
private String __call2a;
private boolean __call2aSet = false;
/**
* Constructs the operation call with the operation name
* @return (String)handleGetCall()
*/
public final String getCall()
{
String call2a = this.__call2a;
if (!this.__call2aSet)
{
// call has no pre constraints
call2a = handleGetCall();
// call has no post constraints
this.__call2a = call2a;
if (isMetafacadePropertyCachingEnabled())
{
this.__call2aSet = true;
}
}
return call2a;
}
/**
* @see OperationFacade#getTypedArgumentList()
* @return String
*/
protected abstract String handleGetTypedArgumentList();
private String __typedArgumentList3a;
private boolean __typedArgumentList3aSet = false;
/**
* A comma-separated parameter list (type and name of each parameter) of an operation.
* @return (String)handleGetTypedArgumentList()
*/
public final String getTypedArgumentList()
{
String typedArgumentList3a = this.__typedArgumentList3a;
if (!this.__typedArgumentList3aSet)
{
// typedArgumentList has no pre constraints
typedArgumentList3a = handleGetTypedArgumentList();
// typedArgumentList has no post constraints
this.__typedArgumentList3a = typedArgumentList3a;
if (isMetafacadePropertyCachingEnabled())
{
this.__typedArgumentList3aSet = true;
}
}
return typedArgumentList3a;
}
/**
* @see OperationFacade#isStatic()
* @return boolean
*/
protected abstract boolean handleIsStatic();
private boolean __static4a;
private boolean __static4aSet = false;
/**
* True is the operation is static (only a single instance can be instantiated).
* @return (boolean)handleIsStatic()
*/
public final boolean isStatic()
{
boolean static4a = this.__static4a;
if (!this.__static4aSet)
{
// static has no pre constraints
static4a = handleIsStatic();
// static has no post constraints
this.__static4a = static4a;
if (isMetafacadePropertyCachingEnabled())
{
this.__static4aSet = true;
}
}
return static4a;
}
/**
* @see OperationFacade#isAbstract()
* @return boolean
*/
protected abstract boolean handleIsAbstract();
private boolean __abstract5a;
private boolean __abstract5aSet = false;
/**
* True is the operation is abstract.
* @return (boolean)handleIsAbstract()
*/
public final boolean isAbstract()
{
boolean abstract5a = this.__abstract5a;
if (!this.__abstract5aSet)
{
// abstract has no pre constraints
abstract5a = handleIsAbstract();
// abstract has no post constraints
this.__abstract5a = abstract5a;
if (isMetafacadePropertyCachingEnabled())
{
this.__abstract5aSet = true;
}
}
return abstract5a;
}
/**
* @see OperationFacade#getExceptionList()
* @return String
*/
protected abstract String handleGetExceptionList();
private String __exceptionList6a;
private boolean __exceptionList6aSet = false;
/**
* A comma separated list containing all exceptions that this operation throws. Exceptions are
* determined through dependencies that have the target element stereotyped as <<Exception>>.
* @return (String)handleGetExceptionList()
*/
public final String getExceptionList()
{
String exceptionList6a = this.__exceptionList6a;
if (!this.__exceptionList6aSet)
{
// exceptionList has no pre constraints
exceptionList6a = handleGetExceptionList();
// exceptionList has no post constraints
this.__exceptionList6a = exceptionList6a;
if (isMetafacadePropertyCachingEnabled())
{
this.__exceptionList6aSet = true;
}
}
return exceptionList6a;
}
/**
* @see OperationFacade#getExceptions()
* @return Collection<ModelElementFacade>
*/
protected abstract Collection<ModelElementFacade> handleGetExceptions();
private Collection<ModelElementFacade> __exceptions7a;
private boolean __exceptions7aSet = false;
/**
* A collection of all exceptions thrown by this operation.
* @return (Collection<ModelElementFacade>)handleGetExceptions()
*/
public final Collection<ModelElementFacade> getExceptions()
{
Collection<ModelElementFacade> exceptions7a = this.__exceptions7a;
if (!this.__exceptions7aSet)
{
// exceptions has no pre constraints
exceptions7a = handleGetExceptions();
// exceptions has no post constraints
this.__exceptions7a = exceptions7a;
if (isMetafacadePropertyCachingEnabled())
{
this.__exceptions7aSet = true;
}
}
return exceptions7a;
}
/**
* @see OperationFacade#isReturnTypePresent()
* @return boolean
*/
protected abstract boolean handleIsReturnTypePresent();
private boolean __returnTypePresent8a;
private boolean __returnTypePresent8aSet = false;
/**
* True/false depending on whether or not the operation has a return type or not (i.e. a return
* type of something other than void).
* @return (boolean)handleIsReturnTypePresent()
*/
public final boolean isReturnTypePresent()
{
boolean returnTypePresent8a = this.__returnTypePresent8a;
if (!this.__returnTypePresent8aSet)
{
// returnTypePresent has no pre constraints
returnTypePresent8a = handleIsReturnTypePresent();
// returnTypePresent has no post constraints
this.__returnTypePresent8a = returnTypePresent8a;
if (isMetafacadePropertyCachingEnabled())
{
this.__returnTypePresent8aSet = true;
}
}
return returnTypePresent8a;
}
/**
* @see OperationFacade#isExceptionsPresent()
* @return boolean
*/
protected abstract boolean handleIsExceptionsPresent();
private boolean __exceptionsPresent9a;
private boolean __exceptionsPresent9aSet = false;
/**
* True if the operation has (i.e. throws any exceptions) false otherwise.
* @return (boolean)handleIsExceptionsPresent()
*/
public final boolean isExceptionsPresent()
{
boolean exceptionsPresent9a = this.__exceptionsPresent9a;
if (!this.__exceptionsPresent9aSet)
{
// exceptionsPresent has no pre constraints
exceptionsPresent9a = handleIsExceptionsPresent();
// exceptionsPresent has no post constraints
this.__exceptionsPresent9a = exceptionsPresent9a;
if (isMetafacadePropertyCachingEnabled())
{
this.__exceptionsPresent9aSet = true;
}
}
return exceptionsPresent9a;
}
/**
* @see OperationFacade#getArgumentNames()
* @return String
*/
protected abstract String handleGetArgumentNames();
private String __argumentNames10a;
private boolean __argumentNames10aSet = false;
/**
* A comma separated list of all argument names.
* @return (String)handleGetArgumentNames()
*/
public final String getArgumentNames()
{
String argumentNames10a = this.__argumentNames10a;
if (!this.__argumentNames10aSet)
{
// argumentNames has no pre constraints
argumentNames10a = handleGetArgumentNames();
// argumentNames has no post constraints
this.__argumentNames10a = argumentNames10a;
if (isMetafacadePropertyCachingEnabled())
{
this.__argumentNames10aSet = true;
}
}
return argumentNames10a;
}
/**
* @see OperationFacade#getArgumentTypeNames()
* @return String
*/
protected abstract String handleGetArgumentTypeNames();
private String __argumentTypeNames11a;
private boolean __argumentTypeNames11aSet = false;
/**
* A comma separated list of all types of each argument, in order.
* @return (String)handleGetArgumentTypeNames()
*/
public final String getArgumentTypeNames()
{
String argumentTypeNames11a = this.__argumentTypeNames11a;
if (!this.__argumentTypeNames11aSet)
{
// argumentTypeNames has no pre constraints
argumentTypeNames11a = handleGetArgumentTypeNames();
// argumentTypeNames has no post constraints
this.__argumentTypeNames11a = argumentTypeNames11a;
if (isMetafacadePropertyCachingEnabled())
{
this.__argumentTypeNames11aSet = true;
}
}
return argumentTypeNames11a;
}
/**
* @see OperationFacade#isQuery()
* @return boolean
*/
protected abstract boolean handleIsQuery();
private boolean __query12a;
private boolean __query12aSet = false;
/**
* Indicates whether or not this operation is a query operation.
* @return (boolean)handleIsQuery()
*/
public final boolean isQuery()
{
boolean query12a = this.__query12a;
if (!this.__query12aSet)
{
// query has no pre constraints
query12a = handleIsQuery();
// query has no post constraints
this.__query12a = query12a;
if (isMetafacadePropertyCachingEnabled())
{
this.__query12aSet = true;
}
}
return query12a;
}
/**
* @see OperationFacade#getConcurrency()
* @return String
*/
protected abstract String handleGetConcurrency();
private String __concurrency13a;
private boolean __concurrency13aSet = false;
/**
* Returns the concurrency modifier for this operation (i.e. concurrent, guarded or sequential)
* of the model element, will attempt a lookup for these values in the language mappings (if
* any).
* @return (String)handleGetConcurrency()
*/
public final String getConcurrency()
{
String concurrency13a = this.__concurrency13a;
if (!this.__concurrency13aSet)
{
// concurrency has no pre constraints
concurrency13a = handleGetConcurrency();
// concurrency has no post constraints
this.__concurrency13a = concurrency13a;
if (isMetafacadePropertyCachingEnabled())
{
this.__concurrency13aSet = true;
}
}
return concurrency13a;
}
/**
* @see OperationFacade#getPreconditionName()
* @return String
*/
protected abstract String handleGetPreconditionName();
private String __preconditionName14a;
private boolean __preconditionName14aSet = false;
/**
* The name of the operation that handles precondition constraints.
* @return (String)handleGetPreconditionName()
*/
public final String getPreconditionName()
{
String preconditionName14a = this.__preconditionName14a;
if (!this.__preconditionName14aSet)
{
// preconditionName has no pre constraints
preconditionName14a = handleGetPreconditionName();
// preconditionName has no post constraints
this.__preconditionName14a = preconditionName14a;
if (isMetafacadePropertyCachingEnabled())
{
this.__preconditionName14aSet = true;
}
}
return preconditionName14a;
}
/**
* @see OperationFacade#getPostconditionName()
* @return String
*/
protected abstract String handleGetPostconditionName();
private String __postconditionName15a;
private boolean __postconditionName15aSet = false;
/**
* The name of the operation that handles postcondition constraints.
* @return (String)handleGetPostconditionName()
*/
public final String getPostconditionName()
{
String postconditionName15a = this.__postconditionName15a;
if (!this.__postconditionName15aSet)
{
// postconditionName has no pre constraints
postconditionName15a = handleGetPostconditionName();
// postconditionName has no post constraints
this.__postconditionName15a = postconditionName15a;
if (isMetafacadePropertyCachingEnabled())
{
this.__postconditionName15aSet = true;
}
}
return postconditionName15a;
}
/**
* @see OperationFacade#getPreconditionSignature()
* @return String
*/
protected abstract String handleGetPreconditionSignature();
private String __preconditionSignature16a;
private boolean __preconditionSignature16aSet = false;
/**
* The signature of the precondition operation.
* @return (String)handleGetPreconditionSignature()
*/
public final String getPreconditionSignature()
{
String preconditionSignature16a = this.__preconditionSignature16a;
if (!this.__preconditionSignature16aSet)
{
// preconditionSignature has no pre constraints
preconditionSignature16a = handleGetPreconditionSignature();
// preconditionSignature has no post constraints
this.__preconditionSignature16a = preconditionSignature16a;
if (isMetafacadePropertyCachingEnabled())
{
this.__preconditionSignature16aSet = true;
}
}
return preconditionSignature16a;
}
/**
* @see OperationFacade#getPreconditionCall()
* @return String
*/
protected abstract String handleGetPreconditionCall();
private String __preconditionCall17a;
private boolean __preconditionCall17aSet = false;
/**
* The call to the precondition operation.
* @return (String)handleGetPreconditionCall()
*/
public final String getPreconditionCall()
{
String preconditionCall17a = this.__preconditionCall17a;
if (!this.__preconditionCall17aSet)
{
// preconditionCall has no pre constraints
preconditionCall17a = handleGetPreconditionCall();
// preconditionCall has no post constraints
this.__preconditionCall17a = preconditionCall17a;
if (isMetafacadePropertyCachingEnabled())
{
this.__preconditionCall17aSet = true;
}
}
return preconditionCall17a;
}
/**
* @see OperationFacade#isPreconditionsPresent()
* @return boolean
*/
protected abstract boolean handleIsPreconditionsPresent();
private boolean __preconditionsPresent18a;
private boolean __preconditionsPresent18aSet = false;
/**
* Whether any precondition constraints are present on this operation.
* @return (boolean)handleIsPreconditionsPresent()
*/
public final boolean isPreconditionsPresent()
{
boolean preconditionsPresent18a = this.__preconditionsPresent18a;
if (!this.__preconditionsPresent18aSet)
{
// preconditionsPresent has no pre constraints
preconditionsPresent18a = handleIsPreconditionsPresent();
// preconditionsPresent has no post constraints
this.__preconditionsPresent18a = preconditionsPresent18a;
if (isMetafacadePropertyCachingEnabled())
{
this.__preconditionsPresent18aSet = true;
}
}
return preconditionsPresent18a;
}
/**
* @see OperationFacade#isPostconditionsPresent()
* @return boolean
*/
protected abstract boolean handleIsPostconditionsPresent();
private boolean __postconditionsPresent19a;
private boolean __postconditionsPresent19aSet = false;
/**
* Whether any postcondition constraints are present on this operation.
* @return (boolean)handleIsPostconditionsPresent()
*/
public final boolean isPostconditionsPresent()
{
boolean postconditionsPresent19a = this.__postconditionsPresent19a;
if (!this.__postconditionsPresent19aSet)
{
// postconditionsPresent has no pre constraints
postconditionsPresent19a = handleIsPostconditionsPresent();
// postconditionsPresent has no post constraints
this.__postconditionsPresent19a = postconditionsPresent19a;
if (isMetafacadePropertyCachingEnabled())
{
this.__postconditionsPresent19aSet = true;
}
}
return postconditionsPresent19a;
}
/**
* @see OperationFacade#getLower()
* @return int
*/
protected abstract int handleGetLower();
private int __lower20a;
private boolean __lower20aSet = false;
/**
* the lower value for the multiplicity
* -only applicable for UML2
* @return (int)handleGetLower()
*/
public final int getLower()
{
int lower20a = this.__lower20a;
if (!this.__lower20aSet)
{
// lower has no pre constraints
lower20a = handleGetLower();
// lower has no post constraints
this.__lower20a = lower20a;
if (isMetafacadePropertyCachingEnabled())
{
this.__lower20aSet = true;
}
}
return lower20a;
}
/**
* @see OperationFacade#getUpper()
* @return int
*/
protected abstract int handleGetUpper();
private int __upper21a;
private boolean __upper21aSet = false;
/**
* the upper value for the multiplicity (will be -1 for *)
* - only applicable for UML2
* @return (int)handleGetUpper()
*/
public final int getUpper()
{
int upper21a = this.__upper21a;
if (!this.__upper21aSet)
{
// upper has no pre constraints
upper21a = handleGetUpper();
// upper has no post constraints
this.__upper21a = upper21a;
if (isMetafacadePropertyCachingEnabled())
{
this.__upper21aSet = true;
}
}
return upper21a;
}
/**
* @see OperationFacade#getReturnParameter()
* @return ParameterFacade
*/
protected abstract ParameterFacade handleGetReturnParameter();
private ParameterFacade __returnParameter22a;
private boolean __returnParameter22aSet = false;
/**
* (UML2 Only). Get the actual return parameter (which may have stereotypes etc).
* @return (ParameterFacade)handleGetReturnParameter()
*/
public final ParameterFacade getReturnParameter()
{
ParameterFacade returnParameter22a = this.__returnParameter22a;
if (!this.__returnParameter22aSet)
{
// returnParameter has no pre constraints
returnParameter22a = handleGetReturnParameter();
// returnParameter has no post constraints
this.__returnParameter22a = returnParameter22a;
if (isMetafacadePropertyCachingEnabled())
{
this.__returnParameter22aSet = true;
}
}
return returnParameter22a;
}
/**
* @see OperationFacade#isOverriding()
* @return boolean
*/
protected abstract boolean handleIsOverriding();
private boolean __overriding23a;
private boolean __overriding23aSet = false;
/**
* True if this operation overrides an operation defined in an ancestor class. An operation
* overrides when the names of the operations as well as the types of the arguments are equal.
* The return type may be different and is, as well as any exceptions, ignored.
* @return (boolean)handleIsOverriding()
*/
public final boolean isOverriding()
{
boolean overriding23a = this.__overriding23a;
if (!this.__overriding23aSet)
{
// overriding has no pre constraints
overriding23a = handleIsOverriding();
// overriding has no post constraints
this.__overriding23a = overriding23a;
if (isMetafacadePropertyCachingEnabled())
{
this.__overriding23aSet = true;
}
}
return overriding23a;
}
/**
* @see OperationFacade#isOrdered()
* @return boolean
*/
protected abstract boolean handleIsOrdered();
private boolean __ordered24a;
private boolean __ordered24aSet = false;
/**
* UML2 only: If isMany (Collection type returned), is the type unique within the collection.
* Unique+Ordered determines CollectionType implementation of return result. Default=false.
* @return (boolean)handleIsOrdered()
*/
public final boolean isOrdered()
{
boolean ordered24a = this.__ordered24a;
if (!this.__ordered24aSet)
{
// ordered has no pre constraints
ordered24a = handleIsOrdered();
// ordered has no post constraints
this.__ordered24a = ordered24a;
if (isMetafacadePropertyCachingEnabled())
{
this.__ordered24aSet = true;
}
}
return ordered24a;
}
/**
* @see OperationFacade#getGetterSetterReturnTypeName()
* @return String
*/
protected abstract String handleGetGetterSetterReturnTypeName();
private String __getterSetterReturnTypeName25a;
private boolean __getterSetterReturnTypeName25aSet = false;
/**
* Return Type with multiplicity taken into account. UML14 does not allow multiplicity *.
* @return (String)handleGetGetterSetterReturnTypeName()
*/
public final String getGetterSetterReturnTypeName()
{
String getterSetterReturnTypeName25a = this.__getterSetterReturnTypeName25a;
if (!this.__getterSetterReturnTypeName25aSet)
{
// getterSetterReturnTypeName has no pre constraints
getterSetterReturnTypeName25a = handleGetGetterSetterReturnTypeName();
// getterSetterReturnTypeName has no post constraints
this.__getterSetterReturnTypeName25a = getterSetterReturnTypeName25a;
if (isMetafacadePropertyCachingEnabled())
{
this.__getterSetterReturnTypeName25aSet = true;
}
}
return getterSetterReturnTypeName25a;
}
/**
* @see OperationFacade#isMany()
* @return boolean
*/
protected abstract boolean handleIsMany();
private boolean __many26a;
private boolean __many26aSet = false;
/**
* UML2 only. If the return type parameter multiplicity>1 OR the operation multiplicity>1.
* Default=false.
* @return (boolean)handleIsMany()
*/
public final boolean isMany()
{
boolean many26a = this.__many26a;
if (!this.__many26aSet)
{
// many has no pre constraints
many26a = handleIsMany();
// many has no post constraints
this.__many26a = many26a;
if (isMetafacadePropertyCachingEnabled())
{
this.__many26aSet = true;
}
}
return many26a;
}
/**
* @see OperationFacade#isUnique()
* @return boolean
*/
protected abstract boolean handleIsUnique();
private boolean __unique27a;
private boolean __unique27aSet = false;
/**
* UML2 only: for Collection return type, is the type unique within the collection.
* Unique+Ordered determines the returned CollectionType. Default=false.
* @return (boolean)handleIsUnique()
*/
public final boolean isUnique()
{
boolean unique27a = this.__unique27a;
if (!this.__unique27aSet)
{
// unique has no pre constraints
unique27a = handleIsUnique();
// unique has no post constraints
this.__unique27a = unique27a;
if (isMetafacadePropertyCachingEnabled())
{
this.__unique27aSet = true;
}
}
return unique27a;
}
/**
* @see OperationFacade#isLeaf()
* @return boolean
*/
protected abstract boolean handleIsLeaf();
private boolean __leaf28a;
private boolean __leaf28aSet = false;
/**
* IsLeaf property in the operation. If true, operation is final, cannot be extended or
* implemented by a descendant. Default=false.
* @return (boolean)handleIsLeaf()
*/
public final boolean isLeaf()
{
boolean leaf28a = this.__leaf28a;
if (!this.__leaf28aSet)
{
// leaf has no pre constraints
leaf28a = handleIsLeaf();
// leaf has no post constraints
this.__leaf28a = leaf28a;
if (isMetafacadePropertyCachingEnabled())
{
this.__leaf28aSet = true;
}
}
return leaf28a;
}
/**
* @see OperationFacade#getMethodBody()
* @return String
*/
protected abstract String handleGetMethodBody();
private String __methodBody29a;
private boolean __methodBody29aSet = false;
/**
* Returns the operation method body determined from UML sequence diagrams or other UML sources.
* @return (String)handleGetMethodBody()
*/
public final String getMethodBody()
{
String methodBody29a = this.__methodBody29a;
if (!this.__methodBody29aSet)
{
// methodBody has no pre constraints
methodBody29a = handleGetMethodBody();
// methodBody has no post constraints
this.__methodBody29a = methodBody29a;
if (isMetafacadePropertyCachingEnabled())
{
this.__methodBody29aSet = true;
}
}
return methodBody29a;
}
// ---------------- business methods ----------------------
/**
* Method to be implemented in descendants
* Searches the given feature for the specified tag.
* If the follow boolean is set to true then the search will continue from the class operation
* to the class itself and then up the class hierarchy.
* @param name
* @param follow
* @return Object
*/
protected abstract Object handleFindTaggedValue(String name, boolean follow);
/**
* Searches the given feature for the specified tag.
* If the follow boolean is set to true then the search will continue from the class operation
* to the class itself and then up the class hierarchy.
* @param name String
* The name of the tagged value to find.
* @param follow boolean
* TODO: Model Documentation for
* OperationFacade.findTaggedValue(follow)
* @return handleFindTaggedValue(name, follow)
*/
public Object findTaggedValue(String name, boolean follow)
{
// findTaggedValue has no pre constraints
Object returnValue = handleFindTaggedValue(name, follow);
// findTaggedValue has no post constraints
return returnValue;
}
/**
* Method to be implemented in descendants
* Returns a comma separated list of exceptions appended to the comma separated list of fully
* qualified 'initialException' classes passed in to this method.
* @param initialExceptions
* @return String
*/
protected abstract String handleGetExceptionList(String initialExceptions);
/**
* Returns a comma separated list of exceptions appended to the comma separated list of fully
* qualified 'initialException' classes passed in to this method.
* @param initialExceptions String
* A comma separated list of fully qualified 'initialException' classes passed in to this
* method.
* @return handleGetExceptionList(initialExceptions)
*/
public String getExceptionList(String initialExceptions)
{
// getExceptionList has no pre constraints
String returnValue = handleGetExceptionList(initialExceptions);
// getExceptionList has no post constraints
return returnValue;
}
/**
* Method to be implemented in descendants
* Returns the signature of the operation and optionally appends the argument names (if
* withArgumentNames is true), otherwise returns the signature with just the types alone in the
* signature.
* @param withArgumentNames
* @return String
*/
protected abstract String handleGetSignature(boolean withArgumentNames);
/**
* Returns the signature of the operation and optionally appends the argument names (if
* withArgumentNames is true), otherwise returns the signature with just the types alone in the
* signature.
* @param withArgumentNames boolean
* TODO: Model Documentation for
* OperationFacade.getSignature(withArgumentNames)
* @return handleGetSignature(withArgumentNames)
*/
public String getSignature(boolean withArgumentNames)
{
// getSignature has no pre constraints
String returnValue = handleGetSignature(withArgumentNames);
// getSignature has no post constraints
return returnValue;
}
/**
* Method to be implemented in descendants
* A comma-separated parameter list (type and name of each parameter) of an operation with an
* optional modifier (i.e final) before each parameter.
* @param modifier
* @return String
*/
protected abstract String handleGetTypedArgumentList(String modifier);
/**
* A comma-separated parameter list (type and name of each parameter) of an operation with an
* optional modifier (i.e final) before each parameter.
* @param modifier String
* The modifier to prefix the arguments with (i.e. 'final')
* @return handleGetTypedArgumentList(modifier)
*/
public String getTypedArgumentList(String modifier)
{
// getTypedArgumentList has no pre constraints
String returnValue = handleGetTypedArgumentList(modifier);
// getTypedArgumentList has no post constraints
return returnValue;
}
/**
* Method to be implemented in descendants
* Returns the signature of the operation and optionally appends the given 'argumentModifier' to
* each argument.
* @param argumentModifier
* @return String
*/
protected abstract String handleGetSignature(String argumentModifier);
/**
* Returns the signature of the operation and optionally appends the given 'argumentModifier' to
* each argument.
* @param argumentModifier String
* The modifier to give the arguments (i.e. 'final').
* @return handleGetSignature(argumentModifier)
*/
public String getSignature(String argumentModifier)
{
// getSignature has no pre constraints
String returnValue = handleGetSignature(argumentModifier);
// getSignature has no post constraints
return returnValue;
}
/**
* Method to be implemented in descendants
* Finds the parameter on this operation having the given name, if no parameter is found, null
* is returned instead.
* @param name
* @return ParameterFacade
*/
protected abstract ParameterFacade handleFindParameter(String name);
/**
* Finds the parameter on this operation having the given name, if no parameter is found, null
* is returned instead.
* @param name String
* The name of the parameter to find on the owner operation.
* @return handleFindParameter(name)
*/
public ParameterFacade findParameter(String name)
{
// findParameter has no pre constraints
ParameterFacade returnValue = handleFindParameter(name);
// findParameter has no post constraints
return returnValue;
}
// ------------- associations ------------------
/**
* A behavioral feature of a classifier that specifies the name, type, parameters, and
* constraints for
* invoking an associated behavior. May invoke both the execution of method behaviors as well as
* other
* behavioral responses.
* @return (Collection<ConstraintFacade>)handleGetPostconditions()
*/
public final Collection<ConstraintFacade> getPostconditions()
{
Collection<ConstraintFacade> getPostconditions1r = null;
// operationFacade has no pre constraints
Collection result = handleGetPostconditions();
List shieldedResult = this.shieldedElements(result);
try
{
getPostconditions1r = (Collection<ConstraintFacade>)shieldedResult;
}
catch (ClassCastException ex)
{
// Bad things happen if the metafacade type mapping in metafacades.xml is wrong - Warn
OperationFacadeLogic.logger.warn("incorrect metafacade cast for OperationFacadeLogic.getPostconditions Collection<ConstraintFacade> " + result + ": " + shieldedResult);
}
// operationFacade has no post constraints
return getPostconditions1r;
}
/**
* UML Specific type is returned in Collection, transformed by shieldedElements to AndroMDA Metafacade type
* @return Collection
*/
protected abstract Collection handleGetPostconditions();
/**
* A behavioral feature of a classifier that specifies the name, type, parameters, and
* constraints for
* invoking an associated behavior. May invoke both the execution of method behaviors as well as
* other
* behavioral responses.
* @return (Collection<ParameterFacade>)handleGetArguments()
*/
public final Collection<ParameterFacade> getArguments()
{
Collection<ParameterFacade> getArguments2r = null;
// operationFacade has no pre constraints
Collection result = handleGetArguments();
List shieldedResult = this.shieldedElements(result);
try
{
getArguments2r = (Collection<ParameterFacade>)shieldedResult;
}
catch (ClassCastException ex)
{
// Bad things happen if the metafacade type mapping in metafacades.xml is wrong - Warn
OperationFacadeLogic.logger.warn("incorrect metafacade cast for OperationFacadeLogic.getArguments Collection<ParameterFacade> " + result + ": " + shieldedResult);
}
// operationFacade has no post constraints
return getArguments2r;
}
/**
* UML Specific type is returned in Collection, transformed by shieldedElements to AndroMDA Metafacade type
* @return Collection
*/
protected abstract Collection handleGetArguments();
/**
* The operations owned by this classifier.
* @return (ClassifierFacade)handleGetOwner()
*/
public final ClassifierFacade getOwner()
{
ClassifierFacade getOwner3r = null;
// operations has no pre constraints
Object result = handleGetOwner();
MetafacadeBase shieldedResult = this.shieldedElement(result);
try
{
getOwner3r = (ClassifierFacade)shieldedResult;
}
catch (ClassCastException ex)
{
// Bad things happen if the metafacade type mapping in metafacades.xml is wrong - Warn
OperationFacadeLogic.logger.warn("incorrect metafacade cast for OperationFacadeLogic.getOwner ClassifierFacade " + result + ": " + shieldedResult);
}
// operations has no post constraints
return getOwner3r;
}
/**
* UML Specific type is transformed by shieldedElements to AndroMDA Metafacade type
* @return Object
*/
protected abstract Object handleGetOwner();
/**
* If this parameter is located on an operation, this will represent that operation.
* @return (Collection<ParameterFacade>)handleGetParameters()
*/
public final Collection<ParameterFacade> getParameters()
{
Collection<ParameterFacade> getParameters4r = null;
// operation has no pre constraints
Collection result = handleGetParameters();
List shieldedResult = this.shieldedElements(result);
try
{
getParameters4r = (Collection<ParameterFacade>)shieldedResult;
}
catch (ClassCastException ex)
{
// Bad things happen if the metafacade type mapping in metafacades.xml is wrong - Warn
OperationFacadeLogic.logger.warn("incorrect metafacade cast for OperationFacadeLogic.getParameters Collection<ParameterFacade> " + result + ": " + shieldedResult);
}
// operation has no post constraints
return getParameters4r;
}
/**
* UML Specific type is returned in Collection, transformed by shieldedElements to AndroMDA Metafacade type
* @return Collection
*/
protected abstract Collection handleGetParameters();
/**
* A behavioral feature of a classifier that specifies the name, type, parameters, and
* constraints for
* invoking an associated behavior. May invoke both the execution of method behaviors as well as
* other
* behavioral responses.
* @return (ClassifierFacade)handleGetReturnType()
*/
public final ClassifierFacade getReturnType()
{
ClassifierFacade getReturnType5r = null;
// operationFacade has no pre constraints
Object result = handleGetReturnType();
MetafacadeBase shieldedResult = this.shieldedElement(result);
try
{
getReturnType5r = (ClassifierFacade)shieldedResult;
}
catch (ClassCastException ex)
{
// Bad things happen if the metafacade type mapping in metafacades.xml is wrong - Warn
OperationFacadeLogic.logger.warn("incorrect metafacade cast for OperationFacadeLogic.getReturnType ClassifierFacade " + result + ": " + shieldedResult);
}
// operationFacade has no post constraints
return getReturnType5r;
}
/**
* UML Specific type is transformed by shieldedElements to AndroMDA Metafacade type
* @return Object
*/
protected abstract Object handleGetReturnType();
/**
* A behavioral feature of a classifier that specifies the name, type, parameters, and
* constraints for
* invoking an associated behavior. May invoke both the execution of method behaviors as well as
* other
* behavioral responses.
* @return (Collection<ConstraintFacade>)handleGetPreconditions()
*/
public final Collection<ConstraintFacade> getPreconditions()
{
Collection<ConstraintFacade> getPreconditions6r = null;
// operationFacade has no pre constraints
Collection result = handleGetPreconditions();
List shieldedResult = this.shieldedElements(result);
try
{
getPreconditions6r = (Collection<ConstraintFacade>)shieldedResult;
}
catch (ClassCastException ex)
{
// Bad things happen if the metafacade type mapping in metafacades.xml is wrong - Warn
OperationFacadeLogic.logger.warn("incorrect metafacade cast for OperationFacadeLogic.getPreconditions Collection<ConstraintFacade> " + result + ": " + shieldedResult);
}
// operationFacade has no post constraints
return getPreconditions6r;
}
/**
* UML Specific type is returned in Collection, transformed by shieldedElements to AndroMDA Metafacade type
* @return Collection
*/
protected abstract Collection handleGetPreconditions();
private OperationFacade __getOverriddenOperation7r;
private boolean __getOverriddenOperation7rSet = false;
/**
* A behavioral feature of a classifier that specifies the name, type, parameters, and
* constraints for
* invoking an associated behavior. May invoke both the execution of method behaviors as well as
* other
* behavioral responses.
* @return (OperationFacade)handleGetOverriddenOperation()
*/
public final OperationFacade getOverriddenOperation()
{
OperationFacade getOverriddenOperation7r = this.__getOverriddenOperation7r;
if (!this.__getOverriddenOperation7rSet)
{
// operationFacade has no pre constraints
Object result = handleGetOverriddenOperation();
MetafacadeBase shieldedResult = this.shieldedElement(result);
try
{
getOverriddenOperation7r = (OperationFacade)shieldedResult;
}
catch (ClassCastException ex)
{
// Bad things happen if the metafacade type mapping in metafacades.xml is wrong - Warn
OperationFacadeLogic.logger.warn("incorrect metafacade cast for OperationFacadeLogic.getOverriddenOperation OperationFacade " + result + ": " + shieldedResult);
}
// operationFacade has no post constraints
this.__getOverriddenOperation7r = getOverriddenOperation7r;
if (isMetafacadePropertyCachingEnabled())
{
this.__getOverriddenOperation7rSet = true;
}
}
return getOverriddenOperation7r;
}
/**
* UML Specific type is transformed by shieldedElements to AndroMDA Metafacade type
* @return Object
*/
protected abstract Object handleGetOverriddenOperation();
/**
* <p><b>Constraint:</b> org::andromda::metafacades::uml::OperationFacade::operation needs a return type</p>
* <p><b>Error:</b> Each operation needs a return type, you cannot leave the type unspecified, even if you want void you'll need to explicitly specify it.</p>
* <p><b>OCL:</b> context OperationFacade
inv: returnType.name->notEmpty()</p>
* <p><b>Constraint:</b> org::andromda::metafacades::uml::OperationFacade::operation must have a name</p>
* <p><b>Error:</b> Each operation must have a non-empty name.</p>
* <p><b>OCL:</b> context OperationFacade
inv: name -> notEmpty()</p>
* <p><b>Constraint:</b> org::andromda::metafacades::uml::OperationFacade::primitive operation return cannot be used in a Collection</p>
* <p><b>Error:</b> Primitive return parameters cannot be used in Collections (multiplicity > 1). Use the wrapped type or Array type instead.</p>
* <p><b>OCL:</b> context OperationFacade inv: returnParameter.type.primitive implies (many = false)</p>
* <p><b>Constraint:</b> org::andromda::metafacades::uml::OperationFacade::wrapped primitive operation return should not be required</p>
* <p><b>Error:</b> Wrapped primitive operation return must have a multiplicity lower bound = 0 (must be optional). Use the unwrapped type, or change the multiplicity.</p>
* <p><b>OCL:</b> context OperationFacade inv: returnParameter.type.wrappedPrimitive and many = false implies (lower = 0)</p>
* <p><b>Constraint:</b> org::andromda::metafacades::uml::OperationFacade::primitive operation return must be required</p>
* <p><b>Error:</b> Primitive operation return types must have a multiplicity lower bound > 0 (must be required). Use a wrapped type, or change the multiplicity.</p>
* <p><b>OCL:</b> context OperationFacade inv: returnParameter.type.primitive implies (lower > 0)</p>
* <p><b>Constraint:</b> org::andromda::metafacades::uml::OperationFacade::operation multiplicity must match return parameter multiplicity</p>
* <p><b>Error:</b> Operation return parameter with multiplicity greater than 1 must match the operation multiplicity greater than 1.</p>
* <p><b>OCL:</b> context OperationFacade
inv: many implies (returnParameter.many)</p>
* @param validationMessages Collection<ModelValidationMessage>
* @see ModelElementFacadeLogicImpl#validateInvariants(Collection validationMessages)
*/
@Override
public void validateInvariants(Collection<ModelValidationMessage> validationMessages)
{
super.validateInvariants(validationMessages);
try
{
final Object contextElement = this.THIS();
boolean constraintValid = OCLResultEnsurer.ensure(OCLCollections.notEmpty(OCLIntrospector.invoke(contextElement,"returnType.name")));
if (!constraintValid)
{
validationMessages.add(
new ModelValidationMessage(
(MetafacadeBase)contextElement ,
"org::andromda::metafacades::uml::OperationFacade::operation needs a return type",
"Each operation needs a return type, you cannot leave the type unspecified, even if you want void you'll need to explicitly specify it."));
}
}
catch (Throwable th)
{
Throwable cause = th.getCause();
int depth = 0; // Some throwables have infinite recursion
while (cause != null && depth < 7)
{
th = cause;
depth++;
}
logger.error("Error validating constraint 'org::andromda::metafacades::uml::OperationFacade::operation needs a return type' ON "
+ this.THIS().toString() + ": " + th.getMessage(), th);
}
try
{
final Object contextElement = this.THIS();
boolean constraintValid = OCLResultEnsurer.ensure(OCLCollections.notEmpty(OCLIntrospector.invoke(contextElement,"name")));
if (!constraintValid)
{
validationMessages.add(
new ModelValidationMessage(
(MetafacadeBase)contextElement ,
"org::andromda::metafacades::uml::OperationFacade::operation must have a name",
"Each operation must have a non-empty name."));
}
}
catch (Throwable th)
{
Throwable cause = th.getCause();
int depth = 0; // Some throwables have infinite recursion
while (cause != null && depth < 7)
{
th = cause;
depth++;
}
logger.error("Error validating constraint 'org::andromda::metafacades::uml::OperationFacade::operation must have a name' ON "
+ this.THIS().toString() + ": " + th.getMessage(), th);
}
try
{
final Object contextElement = this.THIS();
boolean constraintValid = OCLResultEnsurer.ensure((Boolean.valueOf(String.valueOf(OCLIntrospector.invoke(contextElement,"returnParameter.type.primitive"))).booleanValue()?(OCLExpressions.equal(OCLIntrospector.invoke(contextElement,"many"),false)):true));
if (!constraintValid)
{
validationMessages.add(
new ModelValidationMessage(
(MetafacadeBase)contextElement ,
"org::andromda::metafacades::uml::OperationFacade::primitive operation return cannot be used in a Collection",
"Primitive return parameters cannot be used in Collections (multiplicity > 1). Use the wrapped type or Array type instead."));
}
}
catch (Throwable th)
{
Throwable cause = th.getCause();
int depth = 0; // Some throwables have infinite recursion
while (cause != null && depth < 7)
{
th = cause;
depth++;
}
logger.error("Error validating constraint 'org::andromda::metafacades::uml::OperationFacade::primitive operation return cannot be used in a Collection' ON "
+ this.THIS().toString() + ": " + th.getMessage(), th);
}
try
{
final Object contextElement = this.THIS();
boolean constraintValid = OCLResultEnsurer.ensure((Boolean.valueOf(String.valueOf(Boolean.valueOf(String.valueOf(OCLIntrospector.invoke(contextElement,"returnParameter.type.wrappedPrimitive"))).booleanValue()&&OCLExpressions.equal(OCLIntrospector.invoke(contextElement,"many"),false))).booleanValue()?(OCLExpressions.equal(OCLIntrospector.invoke(contextElement,"lower"),0)):true));
if (!constraintValid)
{
validationMessages.add(
new ModelValidationMessage(
(MetafacadeBase)contextElement ,
"org::andromda::metafacades::uml::OperationFacade::wrapped primitive operation return should not be required",
"Wrapped primitive operation return must have a multiplicity lower bound = 0 (must be optional). Use the unwrapped type, or change the multiplicity."));
}
}
catch (Throwable th)
{
Throwable cause = th.getCause();
int depth = 0; // Some throwables have infinite recursion
while (cause != null && depth < 7)
{
th = cause;
depth++;
}
logger.error("Error validating constraint 'org::andromda::metafacades::uml::OperationFacade::wrapped primitive operation return should not be required' ON "
+ this.THIS().toString() + ": " + th.getMessage(), th);
}
try
{
final Object contextElement = this.THIS();
boolean constraintValid = OCLResultEnsurer.ensure((Boolean.valueOf(String.valueOf(OCLIntrospector.invoke(contextElement,"returnParameter.type.primitive"))).booleanValue()?(OCLExpressions.greater(OCLIntrospector.invoke(contextElement,"lower"),0)):true));
if (!constraintValid)
{
validationMessages.add(
new ModelValidationMessage(
(MetafacadeBase)contextElement ,
"org::andromda::metafacades::uml::OperationFacade::primitive operation return must be required",
"Primitive operation return types must have a multiplicity lower bound > 0 (must be required). Use a wrapped type, or change the multiplicity."));
}
}
catch (Throwable th)
{
Throwable cause = th.getCause();
int depth = 0; // Some throwables have infinite recursion
while (cause != null && depth < 7)
{
th = cause;
depth++;
}
logger.error("Error validating constraint 'org::andromda::metafacades::uml::OperationFacade::primitive operation return must be required' ON "
+ this.THIS().toString() + ": " + th.getMessage(), th);
}
try
{
final Object contextElement = this.THIS();
boolean constraintValid = OCLResultEnsurer.ensure((Boolean.valueOf(String.valueOf(OCLIntrospector.invoke(contextElement,"many"))).booleanValue()?(OCLIntrospector.invoke(contextElement,"returnParameter.many")):true));
if (!constraintValid)
{
validationMessages.add(
new ModelValidationMessage(
(MetafacadeBase)contextElement ,
"org::andromda::metafacades::uml::OperationFacade::operation multiplicity must match return parameter multiplicity",
"Operation return parameter with multiplicity greater than 1 must match the operation multiplicity greater than 1."));
}
}
catch (Throwable th)
{
Throwable cause = th.getCause();
int depth = 0; // Some throwables have infinite recursion
while (cause != null && depth < 7)
{
th = cause;
depth++;
}
logger.error("Error validating constraint 'org::andromda::metafacades::uml::OperationFacade::operation multiplicity must match return parameter multiplicity' ON "
+ this.THIS().toString() + ": " + th.getMessage(), th);
}
}
}