/*******************************************************************************
* Copyright (c) 2008 Pierre-Antoine Grégoire.
* 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:
* Pierre-Antoine Grégoire - initial API and implementation
*******************************************************************************/
package org.org.eclipse.dws.core.internal.jobs;
import java.io.ByteArrayInputStream;
import java.io.IOException;
import java.io.InputStream;
import java.util.LinkedHashSet;
import java.util.Set;
import org.apache.log4j.Logger;
import org.eclipse.core.resources.IFile;
import org.eclipse.core.resources.IProject;
import org.eclipse.core.resources.IWorkspaceRoot;
import org.eclipse.core.resources.ResourcesPlugin;
import org.eclipse.core.runtime.IProgressMonitor;
import org.eclipse.core.runtime.IStatus;
import org.eclipse.core.runtime.jobs.Job;
import org.eclipse.swt.widgets.Display;
import org.eclipse.ui.IWorkbenchPage;
import org.eclipse.ui.PartInitException;
import org.eclipse.ui.PlatformUI;
import org.eclipse.ui.ide.IDE;
import org.org.eclipse.core.utils.platform.jobs.BatchSimilarRule;
import org.org.eclipse.core.utils.platform.wizards.StatusInfo;
import org.org.eclipse.dws.core.internal.PomInteractionHelper;
import org.org.eclipse.dws.core.internal.configuration.AggregatedProperties;
import org.org.eclipse.dws.core.internal.model.Pom;
import org.org.eclipse.dws.core.internal.model.PomDependency;
/**
* The Class UpdatePomFileJob.
*/
public final class UpdatePomFileJob extends Job {
/** The logger. */
private Logger logger = Logger.getLogger(UpdatePomFileJob.class);
/** The project name. */
private final String projectName;
/** The pom dependencies. */
private Set<PomDependency> pomDependencies;
/** The updated pom file. */
private IFile updatedPomFile;
/** The Constant JOB_ID. */
private static final String JOB_ID = "DWS : Updating POM file for project ";
/**
* Instantiates a new update pom file job.
*
* @param updatedPomFile the updated pom file
* @param pomDependencies the pom dependencies
*/
public UpdatePomFileJob(IFile updatedPomFile, Set<PomDependency> pomDependencies) {
super(JOB_ID + updatedPomFile);
this.projectName = updatedPomFile.getProject().getName();
this.updatedPomFile = updatedPomFile;
this.pomDependencies = pomDependencies;
this.setPriority(Job.INTERACTIVE);
this.setUser(true);
this.setRule(new BatchSimilarRule(Maven2Jobs.MAVEN2_OTHER_JOB_FAMILY));
}
/* (non-Javadoc)
* @see org.eclipse.core.runtime.jobs.Job#run(org.eclipse.core.runtime.IProgressMonitor)
*/
/**
* @see org.eclipse.core.runtime.jobs.Job#run(org.eclipse.core.runtime.IProgressMonitor)
*/
@Override
public IStatus run(IProgressMonitor monitor) {
StatusInfo result = new StatusInfo(IStatus.OK, "Updated POM.");
try {
// create a sample file
monitor.beginTask("Creating pom.xml", 2);
IWorkspaceRoot root = ResourcesPlugin.getWorkspace().getRoot();
IProject selectedProject = root.getProject(projectName);
if (!selectedProject.exists()) {
throw new Exception("Project \"" + projectName + "\" does not exist.");
}
try {
InputStream stream = updatedPomFile.getContents();
Pom pom = PomInteractionHelper.parsePom(stream);
Set<PomDependency> dependenciesToRemove = new LinkedHashSet<PomDependency>();
for (PomDependency pomDependency : pom.getChildren()) {
final String comparisonString = pomDependency.getGroupId() + pomDependency.getArtifactId() + pomDependency.getVersion() + pomDependency.getClassifier();
for (PomDependency dependency : pomDependencies) {
if (comparisonString.equals(dependency.getGroupId() + dependency.getArtifactId() + dependency.getVersion() + dependency.getClassifier())) {
dependenciesToRemove.add(dependency);
break;
}
}
}
pomDependencies.removeAll(dependenciesToRemove);
stream.close();
stream = null;
if (updatedPomFile.exists()) {
stream = updatedPomFile.getContents();
String resultingPomContents = PomInteractionHelper.addPomDependenciesToPom(stream, pomDependencies, AggregatedProperties.getPomEncoding(selectedProject));
updatedPomFile.setContents(new ByteArrayInputStream(resultingPomContents.getBytes()), true, true, monitor);
stream.close();
} else {
throw new IOException("Pom file Doesn't exist.");
}
} catch (IOException e) {
}
monitor.worked(1);
monitor.setTaskName("Opening file for editing...");
Display.getDefault().asyncExec(new Runnable() {
public void run() {
IWorkbenchPage page = PlatformUI.getWorkbench().getActiveWorkbenchWindow().getActivePage();
try {
IDE.openEditor(page, updatedPomFile, true);
} catch (PartInitException e) {
}
}
});
monitor.worked(1);
} catch (Exception e) {
logger.error(e.getMessage());
monitor.setCanceled(true);
result = new StatusInfo(IStatus.ERROR, "POM file creation error: " + e.getMessage());
} finally {
monitor.done();
}
return result;
}
/* (non-Javadoc)
* @see org.eclipse.core.runtime.jobs.Job#belongsTo(java.lang.Object)
*/
/**
* @see org.eclipse.core.runtime.jobs.Job#belongsTo(java.lang.Object)
*/
@Override
public boolean belongsTo(Object family) {
return Maven2Jobs.MAVEN2_OTHER_JOB_FAMILY.equals(family);
}
}