org.andromda.metafacades.emf.uml22.TemplateParameterFacadeLogic Maven / Gradle / Ivy
Go to download
Show more of this group Show more artifacts with this name
Show all versions of andromda-metafacades-emf-uml22 Show documentation
Show all versions of andromda-metafacades-emf-uml22 Show documentation
The Eclipse EMF UML2 v2.X metafacades. This is the set of EMF UML2 2.X metafacades
implementations. These implement the common UML metafacades for .uml model files.
The newest version!
// 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 org.andromda.core.common.Introspector;
import org.andromda.core.metafacade.MetafacadeBase;
import org.andromda.core.metafacade.ModelValidationMessage;
import org.andromda.metafacades.uml.ModelElementFacade;
import org.andromda.metafacades.uml.TemplateParameterFacade;
import org.apache.log4j.Logger;
import org.eclipse.uml2.uml.TemplateParameter;
/**
*
* Represents a UML template parameter. Exposes a parameterable
* element as a formal template parameter of a template.
*
* MetafacadeLogic for TemplateParameterFacade
*
* @see TemplateParameterFacade
*/
public abstract class TemplateParameterFacadeLogic
extends MetafacadeBase
implements TemplateParameterFacade
{
/**
* The underlying UML object
* @see TemplateParameter
*/
protected TemplateParameter metaObject;
/** Create Metafacade implementation instance using the MetafacadeFactory from the context
* @param metaObjectIn
* @param context
*/
protected TemplateParameterFacadeLogic(TemplateParameter metaObjectIn, String context)
{
super(metaObjectIn, getContext(context));
this.metaObject = metaObjectIn;
}
/**
* The logger instance.
*/
private static final Logger logger = Logger.getLogger(TemplateParameterFacadeLogic.class);
/**
* Gets the context for this metafacade logic instance.
* @param context String. Set to TemplateParameterFacade if null
* @return context String
*/
private static String getContext(String context)
{
if (context == null)
{
context = "org.andromda.metafacades.uml.TemplateParameterFacade";
}
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 TemplateParameterFacade
*/
public boolean isTemplateParameterFacadeMetaType()
{
return true;
}
// ------------- associations ------------------
/**
*
* @return (ModelElementFacade)handleGetParameter()
*/
public final ModelElementFacade getParameter()
{
ModelElementFacade getParameter2r = null;
// templateParameterFacade has no pre constraints
Object result = handleGetParameter();
MetafacadeBase shieldedResult = this.shieldedElement(result);
try
{
getParameter2r = (ModelElementFacade)shieldedResult;
}
catch (ClassCastException ex)
{
// Bad things happen if the metafacade type mapping in metafacades.xml is wrong - Warn
TemplateParameterFacadeLogic.logger.warn("incorrect metafacade cast for TemplateParameterFacadeLogic.getParameter ModelElementFacade " + result + ": " + shieldedResult);
}
// templateParameterFacade has no post constraints
return getParameter2r;
}
/**
* UML Specific type is transformed by shieldedElements to AndroMDA Metafacade type
* @return Object
*/
protected abstract Object handleGetParameter();
/**
*
* @return (ModelElementFacade)handleGetDefaultElement()
*/
public final ModelElementFacade getDefaultElement()
{
ModelElementFacade getDefaultElement3r = null;
// templateParameterFacade has no pre constraints
Object result = handleGetDefaultElement();
MetafacadeBase shieldedResult = this.shieldedElement(result);
try
{
getDefaultElement3r = (ModelElementFacade)shieldedResult;
}
catch (ClassCastException ex)
{
// Bad things happen if the metafacade type mapping in metafacades.xml is wrong - Warn
TemplateParameterFacadeLogic.logger.warn("incorrect metafacade cast for TemplateParameterFacadeLogic.getDefaultElement ModelElementFacade " + result + ": " + shieldedResult);
}
// templateParameterFacade has no post constraints
return getDefaultElement3r;
}
/**
* UML Specific type is transformed by shieldedElements to AndroMDA Metafacade type
* @return Object
*/
protected abstract Object handleGetDefaultElement();
/**
* @param validationMessages Collection
* @see MetafacadeBase#validateInvariants(Collection validationMessages)
*/
@Override
public void validateInvariants(Collection validationMessages)
{
}
/**
* The property that stores the name of the metafacade.
*/
private static final String NAME_PROPERTY = "name";
private static final String FQNAME_PROPERTY = "fullyQualifiedName";
/**
* @see Object#toString()
*/
@Override
public String toString()
{
final StringBuilder toString = new StringBuilder(this.getClass().getName());
toString.append("[");
try
{
toString.append(Introspector.instance().getProperty(this, FQNAME_PROPERTY));
}
catch (final Throwable tryAgain)
{
try
{
toString.append(Introspector.instance().getProperty(this, NAME_PROPERTY));
}
catch (final Throwable ignore)
{
// - just ignore when the metafacade doesn't have a name or fullyQualifiedName property
}
}
toString.append("]");
return toString.toString();
}
}
© 2015 - 2024 Weber Informatics LLC | Privacy Policy