package tool.builder;
import java.util.ArrayList;
import java.util.List;
import java.util.Map;
import org.eclipse.core.resources.IFile;
import org.eclipse.core.resources.IProject;
import org.eclipse.core.resources.IResource;
import org.eclipse.core.resources.IResourceProxy;
import org.eclipse.core.resources.IResourceProxyVisitor;
import org.eclipse.core.resources.ISynchronizer;
import org.eclipse.core.resources.IWorkspace;
import org.eclipse.core.resources.ResourcesPlugin;
import org.eclipse.core.runtime.CoreException;
import org.eclipse.core.runtime.IProgressMonitor;
import org.eclipse.core.runtime.IStatus;
import org.eclipse.core.runtime.QualifiedName;
import org.eclipse.core.runtime.Status;
import org.eclipse.core.runtime.SubMonitor;
import org.eclipse.core.runtime.jobs.Job;
import tool.ToolBuilderActivator;
import tool.builder.resource.RepositoryComponent;
import tool.builder.resource.RepositoryPropertiesManager;
public class RepositoryStateJob extends Job{
IWorkspace workspace;
public RepositoryStateJob( ) {
super("Synchronize repository state");
setUser(true);
this.workspace = ResourcesPlugin.getWorkspace();
}
@Override
protected IStatus run(IProgressMonitor monitor) {
if (!System.getProperty("os.name").startsWith("Windows")){
//ToolBuilderActivator.log(IStatus.WARNING, "The repository interface can only run on Windows using a valid Forte/UDS installation");
return Status.CANCEL_STATUS;
}
IProject[] projects = this.workspace.getRoot().getProjects();
ISynchronizer syncronizer = this.workspace.getSynchronizer();
IStatus status = Status.OK_STATUS;
monitor.beginTask("Synchronize repository state", projects.length);
String projectName = "";
try {
for (IProject project : projects){
projectName = project.getName();
monitor.subTask("Checking " + projectName);
if (project.hasNature(ToolNature.NATURE_ID)){
// setRule(FScript.getFScript(project).getRule());
final Map<String, RepositoryComponent> list = FScript.getFScript(project).ListWorkspaceChanges();
QualifiedName partner = RepositoryPropertiesManager.getSyncQualifiedName(project);
syncronizer.add(partner);
syncronizer.flushSyncInfo(partner, project, IResource.DEPTH_INFINITE);
final List<IFile> components = new ArrayList<IFile>();
project.accept(new IResourceProxyVisitor() {
public boolean visit(IResourceProxy proxy) throws CoreException {
if (proxy.getType() == IResource.FILE) {
IFile file = (IFile) proxy.requestResource();
if (file.getLocation().getFileExtension() != null && file.getLocation().getFileExtension().matches(ToolNature.COMPONENT_EXTENSIONS)) {
components.add(file);
}
}
return true;
}
}, IResource.DEPTH_INFINITE);
IProgressMonitor subMonitor = SubMonitor.convert(monitor, components.size());
for (IFile file : components){
String key = file.getParent().getName() + "." + file.getName().substring(0, file.getName().lastIndexOf('.'));
subMonitor.subTask(key);
RepositoryComponent comp = list.get(key);
if (comp != null) {
RepositoryPropertiesManager.addRepositoryStateProperty(file, comp.getState());
} else {
RepositoryPropertiesManager.addRepositoryStateProperty(file, RepositoryComponent.NOT_IN_REPOSITORY);
}
subMonitor.worked(1);
}
}
monitor.worked(1);
}
} catch (ToolSystemException e) {
ToolBuilderActivator.log(IStatus.ERROR, "Error synchronizing project "+ projectName, e);
status = Status.CANCEL_STATUS;
} catch (InvalidToolRepositoryException e) {
ToolBuilderActivator.log(IStatus.ERROR, "Error synchronizing project "+ projectName, e);
status = Status.CANCEL_STATUS;
} catch (CoreException e) {
ToolBuilderActivator.log(IStatus.ERROR, "Error synchronizing project "+ projectName, e);
status = Status.CANCEL_STATUS;
} finally {
monitor.done();
}
return status;
}
}