Skip to main content
summaryrefslogtreecommitdiffstats
path: root/jpa
diff options
context:
space:
mode:
authorpfullbright2010-06-28 17:24:07 +0000
committerpfullbright2010-06-28 17:24:07 +0000
commitd47564d8c4e13e0ede939fd53a9319d271fa5db4 (patch)
treea1a943e8415439482a1b5114782f622da685396a /jpa
parent8c5094b86c3a6e79f9017c56f1afd188e6bfe509 (diff)
downloadwebtools.dali-d47564d8c4e13e0ede939fd53a9319d271fa5db4.tar.gz
webtools.dali-d47564d8c4e13e0ede939fd53a9319d271fa5db4.tar.xz
webtools.dali-d47564d8c4e13e0ede939fd53a9319d271fa5db4.zip
bug 317495 - handle library provider when runtime changes
Diffstat (limited to 'jpa')
-rw-r--r--jpa/plugins/org.eclipse.jpt.core/plugin.xml11
-rw-r--r--jpa/plugins/org.eclipse.jpt.core/src/org/eclipse/jpt/core/internal/facet/RuntimeChangedListener.java45
2 files changed, 55 insertions, 1 deletions
diff --git a/jpa/plugins/org.eclipse.jpt.core/plugin.xml b/jpa/plugins/org.eclipse.jpt.core/plugin.xml
index a0f658f8ab..26ccdd0e83 100644
--- a/jpa/plugins/org.eclipse.jpt.core/plugin.xml
+++ b/jpa/plugins/org.eclipse.jpt.core/plugin.xml
@@ -443,6 +443,16 @@
<extension
+ point="org.eclipse.wst.common.project.facet.core.listeners">
+
+ <listener
+ class="org.eclipse.jpt.core.internal.facet.RuntimeChangedListener"
+ eventTypes="TARGETED_RUNTIMES_CHANGED"/>
+
+ </extension>
+
+
+ <extension
point="org.eclipse.wst.common.project.facet.core.presets">
<static-preset id="jpt.jpa.1_0.preset">
@@ -471,7 +481,6 @@
</supported>
</extension>
-
<extension
point="org.eclipse.wst.validation.validatorV2"
diff --git a/jpa/plugins/org.eclipse.jpt.core/src/org/eclipse/jpt/core/internal/facet/RuntimeChangedListener.java b/jpa/plugins/org.eclipse.jpt.core/src/org/eclipse/jpt/core/internal/facet/RuntimeChangedListener.java
new file mode 100644
index 0000000000..4aed10fdeb
--- /dev/null
+++ b/jpa/plugins/org.eclipse.jpt.core/src/org/eclipse/jpt/core/internal/facet/RuntimeChangedListener.java
@@ -0,0 +1,45 @@
+package org.eclipse.jpt.core.internal.facet;
+
+import java.util.HashMap;
+import java.util.Map;
+import org.eclipse.core.resources.IProject;
+import org.eclipse.core.runtime.CoreException;
+import org.eclipse.core.runtime.NullProgressMonitor;
+import org.eclipse.jpt.core.JpaProject;
+import org.eclipse.jpt.core.JptCorePlugin;
+import org.eclipse.jst.common.project.facet.core.libprov.LibraryInstallDelegate;
+import org.eclipse.wst.common.project.facet.core.IFacetedProjectBase;
+import org.eclipse.wst.common.project.facet.core.IProjectFacetVersion;
+import org.eclipse.wst.common.project.facet.core.ProjectFacetsManager;
+import org.eclipse.wst.common.project.facet.core.events.IFacetedProjectEvent;
+import org.eclipse.wst.common.project.facet.core.events.IFacetedProjectListener;
+
+public class RuntimeChangedListener
+ implements IFacetedProjectListener {
+
+ public void handleEvent(IFacetedProjectEvent facetedProjectEvent) {
+
+ IFacetedProjectBase fpb = facetedProjectEvent.getWorkingCopy();
+ if (fpb == null) {
+ fpb = facetedProjectEvent.getProject();
+ }
+ IProjectFacetVersion pfv =
+ fpb.getProjectFacetVersion(ProjectFacetsManager.getProjectFacet(JptCorePlugin.FACET_ID));
+ if (pfv != null) {
+ Map<String, Object> enablementVariables = new HashMap<String, Object>();
+ enablementVariables.put(JpaLibraryProviderConstants.EXPR_VAR_JPA_PLATFORM, getJpaPlatformId(fpb.getProject()));
+ LibraryInstallDelegate lp = new LibraryInstallDelegate(fpb, pfv, enablementVariables);
+ try {
+ lp.execute(new NullProgressMonitor());
+ }
+ catch (CoreException ce) {
+ JptCorePlugin.log(ce);
+ }
+ }
+ }
+
+ protected String getJpaPlatformId(IProject project) {
+ JpaProject jpaProject = JptCorePlugin.getJpaProject(project);
+ return (jpaProject == null) ? null : jpaProject.getJpaPlatform().getId();
+ }
+}

Back to the top