Skip to main content
aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
Diffstat (limited to 'extraplugins/qompass/designer/org.eclipse.papyrus.qompass.designer.core/src/org/eclipse/papyrus/qompass/designer/core/extensions/InstanceConfigurator.java')
-rw-r--r--extraplugins/qompass/designer/org.eclipse.papyrus.qompass.designer.core/src/org/eclipse/papyrus/qompass/designer/core/extensions/InstanceConfigurator.java121
1 files changed, 121 insertions, 0 deletions
diff --git a/extraplugins/qompass/designer/org.eclipse.papyrus.qompass.designer.core/src/org/eclipse/papyrus/qompass/designer/core/extensions/InstanceConfigurator.java b/extraplugins/qompass/designer/org.eclipse.papyrus.qompass.designer.core/src/org/eclipse/papyrus/qompass/designer/core/extensions/InstanceConfigurator.java
new file mode 100644
index 00000000000..709c8236cd2
--- /dev/null
+++ b/extraplugins/qompass/designer/org.eclipse.papyrus.qompass.designer.core/src/org/eclipse/papyrus/qompass/designer/core/extensions/InstanceConfigurator.java
@@ -0,0 +1,121 @@
+/*******************************************************************************
+ * Copyright (c) 2011 CEA LIST.
+ * 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
+ *
+ * Contributors:
+ * CEA LIST - initial API and implementation
+ *******************************************************************************/
+
+package org.eclipse.papyrus.qompass.designer.core.extensions;
+
+import org.eclipse.core.runtime.CoreException;
+import org.eclipse.core.runtime.IConfigurationElement;
+import org.eclipse.core.runtime.IExtensionRegistry;
+import org.eclipse.core.runtime.Platform;
+import org.eclipse.papyrus.FCM.ContainerRule;
+import org.eclipse.papyrus.FCM.UseInstanceConfigurator;
+import org.eclipse.papyrus.qompass.designer.core.Activator;
+import org.eclipse.papyrus.qompass.designer.core.Messages;
+import org.eclipse.papyrus.qompass.designer.core.deployment.DepUtils;
+import org.eclipse.uml2.uml.Classifier;
+import org.eclipse.uml2.uml.InstanceSpecification;
+import org.eclipse.uml2.uml.Property;
+import org.eclipse.uml2.uml.util.UMLUtil;
+
+
+/**
+ * Support for the configuration of instances via the Eclipse extension mechanism
+ */
+public class InstanceConfigurator {
+
+ public static final String IINSTANCE_CONFIG_ID = Activator.PLUGIN_ID + ".instanceConfig"; //$NON-NLS-1$
+
+ public static boolean onNodeModel = false;
+
+ /**
+ * Configure an instance. The configurator is selected by means of a stereotype on the classifier of
+ * the passed instance.
+ *
+ * @see org.eclipse.papyrus.qompass.designer.core.extensions.IInstanceConfigurator
+ * @param instance
+ * the specification of instance that should be configured
+ * @param componentPart
+ * the part representing the instance (before container expansion)
+ * @param port
+ * a port within the context of container
+ */
+ public static void configureInstance(InstanceSpecification instance, Property componentPart, InstanceSpecification parentInstance) {
+ Classifier component = DepUtils.getClassifier(instance);
+ UseInstanceConfigurator useInstanceConfigurator = UMLUtil.getStereotypeApplication(component, UseInstanceConfigurator.class);
+ configureInstance(useInstanceConfigurator, instance, componentPart, parentInstance);
+ }
+
+ /**
+ * Configure an instance. The configurator is selected by means of a stereotype on the passed container rule.
+ *
+ * @see org.eclipse.papyrus.qompass.designer.core.extensions.IInstanceConfigurator
+ * @param rule
+ * the applied container rule
+ * @param instance
+ * the specification of instance that should be configured
+ * @param componentPart
+ * the part representing the instance (before container expansion)
+ * @param port
+ * a port within the context of container
+ */
+ public static void configureInstance(ContainerRule rule, InstanceSpecification instance, Property componentPart, InstanceSpecification parentInstance) {
+ UseInstanceConfigurator useInstanceConfigurator = UMLUtil.getStereotypeApplication(rule.getBase_Class(), UseInstanceConfigurator.class);
+ configureInstance(useInstanceConfigurator, instance, componentPart, parentInstance);
+ }
+
+ /**
+ * Configure an instance with a given configurator
+ *
+ * @param useInstanceConfigurator
+ * @param instance
+ * @param componentPart
+ * @param containerContext
+ */
+ public static void configureInstance(UseInstanceConfigurator useInstanceConfigurator, InstanceSpecification instance, Property componentPart, InstanceSpecification parentInstance) {
+ if (useInstanceConfigurator != null) {
+ org.eclipse.papyrus.FCM.InstanceConfigurator instanceConfigurator = useInstanceConfigurator.getConfigurator();
+ if (instanceConfigurator.isOnNodeModel() == onNodeModel) {
+ if (instanceConfigurator != null) {
+ String id = instanceConfigurator.getBase_Class().getName();
+ IInstanceConfigurator iConfigurator = getInstanceConfigurator(id);
+ if (iConfigurator != null) {
+ iConfigurator.configureInstance(instance, componentPart, parentInstance);
+
+ }
+ }
+ }
+ }
+ }
+
+ protected static IInstanceConfigurator getInstanceConfigurator(String iConfiguratorID) {
+ IExtensionRegistry reg = Platform.getExtensionRegistry();
+ IConfigurationElement[] configElements = reg.getConfigurationElementsFor(IINSTANCE_CONFIG_ID);
+ for (IConfigurationElement configElement : configElements) {
+ try {
+ final String iConfiguratorIDext = configElement.getAttribute("configuratorID"); //$NON-NLS-1$
+ if (iConfiguratorIDext == null) {
+ throw new RuntimeException(String.format(
+ Messages.InstanceConfigurator_InvalidPluginExtension, iConfiguratorID));
+ }
+ if (iConfiguratorIDext.equals(iConfiguratorID)) {
+ // TODO: cache returned instance (avoid creating a new instance each time => more efficient, no need for static attributes)
+ final Object obj = configElement.createExecutableExtension("class"); //$NON-NLS-1$
+ if (obj instanceof IInstanceConfigurator) {
+ return (IInstanceConfigurator) obj;
+ }
+ }
+ } catch (CoreException exception) {
+ exception.printStackTrace();
+ }
+ }
+ return null;
+ }
+}

Back to the top